LOADING REQUIREMENTS

PACKAGES

ENSEMBL

# ENSEMBL DATABASE
# v102 is for the latest mm10 version
# ensembl.v102 <- useMart(host = "https://nov2020.archive.ensembl.org",
#                        biomart = "ENSEMBL_MART_ENSEMBL",
#                        dataset = "mmusculus_gene_ensembl")

COLOR PALETTE

palette_1 = list(red = "#E9002D",
                 amber = "#FFAA00",
                 green = "#00B000")
palette_2 = list(red = "#FF1F5B",
                 green = "#00CD6C",
                 blue = "#009ADE",
                 purple = "#AF58BA",
                 yellow = "#FFC61E",
                 orange = "#F28522",
                 grey = "#A0B1BA",
                 brown = "#A6761D")
palette_3 = list(grey1 = "#a0b1ba",
                 grey2 = "#c5d0d5",
                 grey3 = "#eceff1")

colorListLoop <-  c(palette_3[["grey3"]], palette_3[["grey2"]], palette_3[["grey1"]],
                     "#C5E1EF", "#6CB0D6", "#226E9C",
                     "#06592A", 
                     "#FED976", "#FD8D3C", "#E31A1C")
colorListPromoter <- c(palette_3[["grey3"]],"#E88587", "#E31A1C")
colorListEnhancer <- c(palette_3[["grey3"]],"#87AFC7", "#226E9C")
colorListStructure <- c(palette_3[["grey3"]], palette_3[["grey2"]], palette_3[["grey1"]])

DIR LIST

refDir <- here("reference")

FIGURE PARAMETERS

library(colorspace)

fontType <- "Helvetica"

fontSizeL <- 10 # pt
fontSizeM <- 8
fontSizeS <- 6

lineThick <- 0.75 # pt
lineMedium <- 0.5
lineThin <- 0.25

panelUnit <- 30 # mm
panelMargin <- 1.5

mmToInch <- 0.03937007874
mmToLineUnit <- 1/2.13
mmToLinePlotgarden <- 1/0.75
ptToMM <- 1/2.845


strong_red <- "#CB333A"
strong_blue <- "#4851A0"
weak_red <- lighten(strong_red, amount = 0.4)   # FF7D81
weak_blue <- lighten(strong_blue, amount = 0.4) # 8A91DD
no_grey <- "#A8A8A8"

strong_teel <- "#0892A5"
strong_green <- "#23CE6B" # A485
strong_darkgreen <- "#054A29"
strong_yellow <- "#FFBA49"
strong_orange <- "#F18F01" # dTAG
strong_lightpurple <- "#BD93D8"
strong_purple <- "#9E33CB" # Epi

panelSize <- function(num, unit = panelUnit, margin = panelMargin){
  return(num*unit - 2*margin)
}

FUNCTIONS

importBedpe = function(bedpe){
  a1 = makeGRangesFromDataFrame(data.frame(
    chr = bedpe$V1,
    start = bedpe$V2 +1,
    end = bedpe$V3))
  a2 = makeGRangesFromDataFrame(data.frame(
    chr = bedpe$V4,
    start = bedpe$V5 +1,
    end = bedpe$V6))
  GInteractions(a1, a2)
}

get_density <- function(x, y, ...) {
  dens <- MASS::kde2d(x, y, ...)
  ix <- findInterval(x, dens$x)
  iy <- findInterval(y, dens$y)
  ii <- cbind(ix, iy)
  return(dens$z[ii])
}
label_kb_mb <- function(x) {
  ifelse(x >= 1000000, paste0(x / 1000000, "Mb"), paste0(x / 1000, "kb"))
}

importPeak = function(fileName){
  df = fread(fileName)
  gr = makeGRangesFromDataFrame(data.frame(
    chr = df$V1, start = df$V2, end = df$V3
  ))
}

PREPROCESSING

Adding +ooe +geneAnno

Loop should be dropped from specific comparison if ooe in any of the condition are NA If ooe is 0, fixed pseudo value of 0.01 will be used. log2(ooe) should be plotted in range (-5, 8) if plotted in scatterplot ### Common stuffs

# Parameters
commonLoopDir <- here("../data/loop_analysis")

# Defining gene neighborhood
flankSize <- 2500
gene.TSS.tb <- fread(here(refDir, "mm10", "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)
colnames(gene.TSS.tb) <- c("chr", "start", "end", "strand", "gene", "ensembl")
fwrite(gene.TSS.tb, here(refDir, "mm10", "mm10_GRCm38.p6_TSS2.5kb.bed"), sep = "\t", col.names = FALSE, row.names = FALSE)

# Functions for calculating gene overlap
findOverlapGene <- function(gene.TSS.tb, chrom1, start1, end1){
  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%
    dplyr::filter((start <= end1) & (end >= start1))
  return(temp$gene)
}
findOverlapEnsembl <- function(gene.TSS.tb, chrom1, start1, end1){
  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%
    dplyr::filter((start <= end1) & (end >= start1))
  return(temp$ensembl)
}

Preparing

[1] Chromosight

################################################################################
# Import annotated postprocessed loops with chromosight score
loopDir <- here("../data/loop_chromosight")
data <- as_tibble(fread(here(loopDir, "chromo_union_allRes_postprocessed_annotated.tsv")))

################################################################################
# Integrate chromosight score from asynchronous experiment
resolutions  <- c(25000, 10000, 5000)

# helper: read, filter, select and rename for one experiment
annotate_scores <- function(experiment, suffix) {
  map_dfr(resolutions, function(res) {
    fread(here(loopDir,
               sprintf("GSE178982_%s_pooled_union_%dbp_pu100pz100.tsv",
                       experiment, res))
    ) %>%
      mutate(id = paste(chrom1, start1, end1, chrom2, start2, end2, sep = "_")) %>%
      filter(start2 - start1 <= 2e6) %>%
      select(id, score, pvalue, qvalue) %>%
      rename_with(~ paste0(., "_", suffix),
                  c(score, pvalue, qvalue))
  })
}

data <- data %>%
  left_join(annotate_scores("AsyncUT", "UT"), by = "id")
data <- data %>%
  left_join(annotate_scores("AsyncAID", "AID"), by = "id")
data <- data %>%
  relocate(score_UT:qvalue_AID, .after = qvalue_EpidTAG)
data <- data %>% dplyr::select(-seq(29, 41))
data <- data %>% relocate(A1:Anno_simple, .after = id)

################################################################################
# Adding obs/exp
import_obsexp <- function(experiment, suffix) {
  map_dfr(resolutions, function(res) {
    fread(here(loopDir,
               sprintf("chromo_union_allRes_postprocessed_%dbp_obxexp_%s_pooled.tsv",
                       res, experiment))
    ) %>%
      mutate(id = paste(chrom1, start1, end1, chrom2, start2, end2, sep = "_")) %>%
      select(id, ooe) %>%
      rename_with(~ paste0(., "_", suffix),
                  c(ooe))
  })
}

data <- data %>%
  left_join(import_obsexp("G1DMSO", "DMSO"), by = "id")
data <- data %>%
  left_join(import_obsexp("G1dTAG", "dTAG"), by = "id")
data <- data %>%
  left_join(import_obsexp("G1A485", "A485"), by = "id")
data <- data %>%
  left_join(import_obsexp("EpiG1DMSO", "EpiDMSO"), by = "id")
data <- data %>%
  left_join(import_obsexp("EpiG1dTAG", "EpidTAG"), by = "id")
data <- data %>%
  left_join(import_obsexp("GSE178982_AsyncUT", "UT"), by = "id")
data <- data %>%
  left_join(import_obsexp("GSE178982_AsyncAID", "AID"), by = "id")

fwrite(data, here(commonLoopDir, "loopScore_chromosight.tsv"),
       sep = "\t", col.names = TRUE)

################################################################################
# Annotate genes for p-n loops
name <- "chromosight"
gene.TSS.tb <- fread(here(refDir, "mm10", "mm10_GRCm38.p6_TSS2.5kb.bed"))
colnames(gene.TSS.tb) <- c("chr", "start", "end", "strand", "gene", "ensembl")

# Simple annotation
temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1_simple == "P",
                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2_simple == "P",
                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno_simple %in% c("P-P", "P-E", "P-S", "P-X")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_geneList.tsv")), sep = "\t")

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1_simple == "P",
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2_simple == "P",
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno_simple %in% c("P-P", "P-E", "P-S", "P-X")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_ensemblList.tsv")), sep = "\t")

# complex annotation
temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 %in% c("P", "SP"),
                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 %in% c("P", "SP"),
                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(str_detect(Anno, "P")) %>%
  dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_geneList.tsv")), sep = "\t")

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 %in% c("P", "SP"),
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 %in% c("P", "SP"),
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(str_detect(Anno, "P")) %>%
  dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_ensemblList.tsv")), sep = "\t")

[2] hicdcp

################################################################################
loopDir <- here("../data/loop_hicdcp")

################################################################################
# Import annotated postprocessed loops with chromosight score
data <- as_tibble(fread(here(loopDir, "hicdcp_union_10000bp_annotated.tsv"))) %>%
  mutate(id = paste(chrom1, start1, end1, chrom2, start2, end2, sep = "_")) %>%
  relocate(id, .after = end2) %>%
  dplyr::select(-c("anchor_id_1", "anchor_id_2"))

resolutions  <- c(10000)

# Adding obs/exp
import_obsexp <- function(experiment, suffix) {
  map_dfr(resolutions, function(res) {
    fread(here(loopDir,
               sprintf("hicdcp_union_%dbp_obxexp_%s_pooled.tsv",
                       res, experiment))
    ) %>%
      mutate(id = paste(chrom1, start1, end1, chrom2, start2, end2, sep = "_")) %>%
      select(id, ooe) %>%
      rename_with(~ paste0(., "_", suffix),
                  c(ooe))
  })
}

data <- data %>%
  left_join(import_obsexp("G1DMSO", "DMSO"), by = "id")
data <- data %>%
  left_join(import_obsexp("G1dTAG", "dTAG"), by = "id")
data <- data %>%
  left_join(import_obsexp("G1A485", "A485"), by = "id")
data <- data %>%
  left_join(import_obsexp("EpiG1DMSO", "EpiDMSO"), by = "id")
data <- data %>%
  left_join(import_obsexp("EpiG1dTAG", "EpidTAG"), by = "id")
data <- data %>%
  left_join(import_obsexp("GSE178982_AsyncUT", "UT"), by = "id")
data <- data %>%
  left_join(import_obsexp("GSE178982_AsyncAID", "AID"), by = "id")

fwrite(data, here(commonLoopDir, "loopScore_hicdcp.tsv"),
       sep = "\t", col.names = TRUE)

################################################################################
# Annotate genes for p-n loops
name <- "hicdcp"
gene.TSS.tb <- fread(here(refDir, "mm10", "mm10_GRCm38.p6_TSS2.5kb.bed"))
colnames(gene.TSS.tb) <- c("chr", "start", "end", "strand", "gene", "ensembl")


# Simple annotation
temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1_simple == "P",
                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2_simple == "P",
                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno_simple %in% c("P-P", "P-E", "P-S", "P-X")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_geneList.tsv")), sep = "\t")

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1_simple == "P",
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2_simple == "P",
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno_simple %in% c("P-P", "P-E", "P-S", "P-X")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_ensemblList.tsv")), sep = "\t")

# complex annotation
temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 %in% c("P", "SP"),
                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 %in% c("P", "SP"),
                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(str_detect(Anno, "P")) %>%
  dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_geneList.tsv")), sep = "\t")

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 %in% c("P", "SP"),
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 %in% c("P", "SP"),
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(str_detect(Anno, "P")) %>%
  dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_ensemblList.tsv")), sep = "\t")

[3] Hansen

Loops with


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubG9vcF9jaHJvbW8gPC0gYXNfdGliYmxlKGZyZWFkKGhlcmUoY29tbW9uTG9vcERpciwgXCJsb29wU2NvcmVfY2hyb21vc2lnaHQudHN2XCIpKSlcbmxvb3BfaGljZGNwIDwtIGFzX3RpYmJsZShmcmVhZChoZXJlKGNvbW1vbkxvb3BEaXIsIFwibG9vcFNjb3JlX2hpY2RjcC50c3ZcIikpKVxubG9vcF9IYW5zZW4gPC0gYXNfdGliYmxlKGZyZWFkKGhlcmUoY29tbW9uTG9vcERpciwgXCJsb29wU2NvcmVfSGFuc2VuLnRzdlwiKSkpXG5sb29wX1RqaWFuX2Nocm9tbyA8LSBhc190aWJibGUoZnJlYWQoaGVyZShjb21tb25Mb29wRGlyLCBcIi4uL2xvb3BfVGppYW4vVGppYW5DaHJvbW9fdW5pb25fYWxsUmVzLmJlZHBlXCIpKSkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoYWJzKFY1LVYyKSA8PSAyMDAwMDAwKVxuY29sbmFtZXMobG9vcF9Uamlhbl9jaHJvbW8pIDwtIGMoXCJjaHJvbTFcIiwgXCJzdGFydDFcIiwgXCJlbmQxXCIsIFwiY2hyb20yXCIsIFwic3RhcnQyXCIsIFwiZW5kMlwiKVxubG9vcF9Uamlhbl9tdXN0YWNoZSA8LSBhc190aWJibGUoZnJlYWQoaGVyZShjb21tb25Mb29wRGlyLCBcIi4uL2xvb3BfVGppYW4vVGppYW5NdXN0YWNoZV91bmlvbl9hbGxSZXMuYmVkcGVcIikpKSAlPiVcbiAgZHBseXI6OmZpbHRlcihhYnMoVjUtVjIpIDw9IDIwMDAwMDApXG5jb2xuYW1lcyhsb29wX1RqaWFuX211c3RhY2hlKSA8LSBjKFwiY2hyb20xXCIsIFwic3RhcnQxXCIsIFwiZW5kMVwiLCBcImNocm9tMlwiLCBcInN0YXJ0MlwiLCBcImVuZDJcIilcblxuYGBgIn0= -->

```r
loop_chromo <- as_tibble(fread(here(commonLoopDir, \loopScore_chromosight.tsv\)))
loop_hicdcp <- as_tibble(fread(here(commonLoopDir, \loopScore_hicdcp.tsv\)))
loop_Hansen <- as_tibble(fread(here(commonLoopDir, \loopScore_Hansen.tsv\)))
loop_Tjian_chromo <- as_tibble(fread(here(commonLoopDir, \../loop_Tjian/TjianChromo_union_allRes.bedpe\))) %>%
  dplyr::filter(abs(V5-V2) <= 2000000)
colnames(loop_Tjian_chromo) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\)
loop_Tjian_mustache <- as_tibble(fread(here(commonLoopDir, \../loop_Tjian/TjianMustache_union_allRes.bedpe\))) %>%
  dplyr::filter(abs(V5-V2) <= 2000000)
colnames(loop_Tjian_mustache) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\)

```

<!-- rnb-source-end -->
```r
loop_chromo <- as_tibble(fread(here(commonLoopDir, \loopScore_chromosight.tsv\)))
loop_hicdcp <- as_tibble(fread(here(commonLoopDir, \loopScore_hicdcp.tsv\)))
loop_Hansen <- as_tibble(fread(here(commonLoopDir, \loopScore_Hansen.tsv\)))
loop_Tjian_chromo <- as_tibble(fread(here(commonLoopDir, \../loop_Tjian/TjianChromo_union_allRes.bedpe\))) %>%
  dplyr::filter(abs(V5-V2) <= 2000000)
colnames(loop_Tjian_chromo) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\)
loop_Tjian_mustache <- as_tibble(fread(here(commonLoopDir, \../loop_Tjian/TjianMustache_union_allRes.bedpe\))) %>%
  dplyr::filter(abs(V5-V2) <= 2000000)
colnames(loop_Tjian_mustache) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\)

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


# ANALYSIS
## [1] Comparing loops
### Common stuffs

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJvWld4d1pYSWdkR2hoZENCdmJteDVJSFZ6WlhNZ2RHaGxJSFIzYnlCaGJtTm9iM0p6WEc1dFlXdGxYMmRwSUR3dElHWjFibU4wYVc5dUtHUm1LU0I3WEc0Z0lHRXhJRHd0SUVkU1lXNW5aWE1vWkdZa1kyaHliMjB4TENCSlVtRnVaMlZ6S0dSbUpITjBZWEowTVN3Z1pHWWtaVzVrTVNrcFhHNGdJR0V5SUR3dElFZFNZVzVuWlhNb1pHWWtZMmh5YjIweUxDQkpVbUZ1WjJWektHUm1KSE4wWVhKME1pd2daR1lrWlc1a01pa3BYRzRnSUVkSmJuUmxjbUZqZEdsdmJuTW9ZVEVzSUdFeUtWeHVmVnh1WEc0aklFVjRjR0Z1WkNCbFlXTm9JR0Z1WTJodmNpQjBieUF4TUNCcllpQm1iM0lnWTI5dGNHRnlhWE52Ymx4dVpYaHdZVzVrWDJGdVkyaHZjaUE4TFNCbWRXNWpkR2x2YmlobmFTa2dlMXh1SUNCaE1TQThMU0JoYm1Ob2IzSnpLR2RwTENCY0ltWnBjbk4wWENJcFhHNGdJR0V5SUR3dElHRnVZMmh2Y25Nb1oya3NJRndpYzJWamIyNWtYQ0lwWEc0Z0lHRXhjaUE4TFNCeVpYTnBlbVVvWVRFc0lIZHBaSFJvSUQwZ2NHMWhlQ2gzYVdSMGFDaGhNU2tzSUdWNGNHRnVaRk5wZW1VcExDQm1hWGdnUFNCY0ltTmxiblJsY2x3aUtWeHVJQ0JoTW5JZ1BDMGdjbVZ6YVhwbEtHRXlMQ0IzYVdSMGFDQTlJSEJ0WVhnb2QybGtkR2dvWVRJcExDQmxlSEJoYm1SVGFYcGxLU3dnWm1sNElEMGdYQ0pqWlc1MFpYSmNJaWxjYmlBZ1IwbHVkR1Z5WVdOMGFXOXVjeWhoTVhJc0lHRXljaWxjYm4xY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG4jIGhlbHBlciB0aGF0IG9ubHkgdXNlcyB0aGUgdHdvIGFuY2hvcnNcbm1ha2VfZ2kgPC0gZnVuY3Rpb24oZGYpIHtcbiAgYTEgPC0gR1JhbmdlcyhkZiRjaHJvbTEsIElSYW5nZXMoZGYkc3RhcnQxLCBkZiRlbmQxKSlcbiAgYTIgPC0gR1JhbmdlcyhkZiRjaHJvbTIsIElSYW5nZXMoZGYkc3RhcnQyLCBkZiRlbmQyKSlcbiAgR0ludGVyYWN0aW9ucyhhMSwgYTIpXG59XG5cbiMgRXhwYW5kIGVhY2ggYW5jaG9yIHRvIDEwIGtiIGZvciBjb21wYXJpc29uXG5leHBhbmRfYW5jaG9yIDwtIGZ1bmN0aW9uKGdpKSB7XG4gIGExIDwtIGFuY2hvcnMoZ2ksIFxcZmlyc3RcXClcbiAgYTIgPC0gYW5jaG9ycyhnaSwgXFxzZWNvbmRcXClcbiAgYTFyIDwtIHJlc2l6ZShhMSwgd2lkdGggPSBwbWF4KHdpZHRoKGExKSwgZXhwYW5kU2l6ZSksIGZpeCA9IFxcY2VudGVyXFwpXG4gIGEyciA8LSByZXNpemUoYTIsIHdpZHRoID0gcG1heCh3aWR0aChhMiksIGV4cGFuZFNpemUpLCBmaXggPSBcXGNlbnRlclxcKVxuICBHSW50ZXJhY3Rpb25zKGExciwgYTJyKVxufVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
# helper that only uses the two anchors
make_gi <- function(df) {
  a1 <- GRanges(df$chrom1, IRanges(df$start1, df$end1))
  a2 <- GRanges(df$chrom2, IRanges(df$start2, df$end2))
  GInteractions(a1, a2)
}

# Expand each anchor to 10 kb for comparison
expand_anchor <- function(gi) {
  a1 <- anchors(gi, \first\)
  a2 <- anchors(gi, \second\)
  a1r <- resize(a1, width = pmax(width(a1), expandSize), fix = \center\)
  a2r <- resize(a2, width = pmax(width(a2), expandSize), fix = \center\)
  GInteractions(a1r, a2r)
}



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5Qm9aV3h3WlhJZ2RHaGhkQ0J2Ym14NUlIVnpaWE1nZEdobElIUjNieUJoYm1Ob2IzSnpYRzV0WVd0bFgyZHBJRHd0SUdaMWJtTjBhVzl1S0dSbUtTQjdYRzRnSUdFeElEd3RJRWRTWVc1blpYTW9aR1lrWTJoeWIyMHhMQ0JKVW1GdVoyVnpLR1JtSkhOMFlYSjBNU3dnWkdZa1pXNWtNU2twWEc0Z0lHRXlJRHd0SUVkU1lXNW5aWE1vWkdZa1kyaHliMjB5TENCSlVtRnVaMlZ6S0dSbUpITjBZWEowTWl3Z1pHWWtaVzVrTWlrcFhHNGdJRWRKYm5SbGNtRmpkR2x2Ym5Nb1lURXNJR0V5S1Z4dWZWeHVYRzRqSUVWNGNHRnVaQ0JsWVdOb0lHRnVZMmh2Y2lCMGJ5QXhNQ0JyWWlCbWIzSWdZMjl0Y0dGeWFYTnZibHh1Wlhod1lXNWtYMkZ1WTJodmNpQThMU0JtZFc1amRHbHZiaWhuYVNrZ2UxeHVJQ0JoTVNBOExTQmhibU5vYjNKektHZHBMQ0JjWEdacGNuTjBYRndwWEc0Z0lHRXlJRHd0SUdGdVkyaHZjbk1vWjJrc0lGeGNjMlZqYjI1a1hGd3BYRzRnSUdFeGNpQThMU0J5WlhOcGVtVW9ZVEVzSUhkcFpIUm9JRDBnY0cxaGVDaDNhV1IwYUNoaE1Ta3NJR1Y0Y0dGdVpGTnBlbVVwTENCbWFYZ2dQU0JjWEdObGJuUmxjbHhjS1Z4dUlDQmhNbklnUEMwZ2NtVnphWHBsS0dFeUxDQjNhV1IwYUNBOUlIQnRZWGdvZDJsa2RHZ29ZVElwTENCbGVIQmhibVJUYVhwbEtTd2dabWw0SUQwZ1hGeGpaVzUwWlhKY1hDbGNiaUFnUjBsdWRHVnlZV04wYVc5dWN5aGhNWElzSUdFeWNpbGNibjFjYm1CZ1lGeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYGBgclxuIyBoZWxwZXIgdGhhdCBvbmx5IHVzZXMgdGhlIHR3byBhbmNob3JzXG5tYWtlX2dpIDwtIGZ1bmN0aW9uKGRmKSB7XG4gIGExIDwtIEdSYW5nZXMoZGYkY2hyb20xLCBJUmFuZ2VzKGRmJHN0YXJ0MSwgZGYkZW5kMSkpXG4gIGEyIDwtIEdSYW5nZXMoZGYkY2hyb20yLCBJUmFuZ2VzKGRmJHN0YXJ0MiwgZGYkZW5kMikpXG4gIEdJbnRlcmFjdGlvbnMoYTEsIGEyKVxufVxuXG4jIEV4cGFuZCBlYWNoIGFuY2hvciB0byAxMCBrYiBmb3IgY29tcGFyaXNvblxuZXhwYW5kX2FuY2hvciA8LSBmdW5jdGlvbihnaSkge1xuICBhMSA8LSBhbmNob3JzKGdpLCBcXGZpcnN0XFwpXG4gIGEyIDwtIGFuY2hvcnMoZ2ksIFxcc2Vjb25kXFwpXG4gIGExciA8LSByZXNpemUoYTEsIHdpZHRoID0gcG1heCh3aWR0aChhMSksIGV4cGFuZFNpemUpLCBmaXggPSBcXGNlbnRlclxcKVxuICBhMnIgPC0gcmVzaXplKGEyLCB3aWR0aCA9IHBtYXgod2lkdGgoYTIpLCBleHBhbmRTaXplKSwgZml4ID0gXFxjZW50ZXJcXClcbiAgR0ludGVyYWN0aW9ucyhhMXIsIGEycilcbn1cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBoZWxwZXIgdGhhdCBvbmx5IHVzZXMgdGhlIHR3byBhbmNob3JzXG5tYWtlX2dpIDwtIGZ1bmN0aW9uKGRmKSB7XG4gIGExIDwtIEdSYW5nZXMoZGYkY2hyb20xLCBJUmFuZ2VzKGRmJHN0YXJ0MSwgZGYkZW5kMSkpXG4gIGEyIDwtIEdSYW5nZXMoZGYkY2hyb20yLCBJUmFuZ2VzKGRmJHN0YXJ0MiwgZGYkZW5kMikpXG4gIEdJbnRlcmFjdGlvbnMoYTEsIGEyKVxufVxuXG4jIEV4cGFuZCBlYWNoIGFuY2hvciB0byAxMCBrYiBmb3IgY29tcGFyaXNvblxuZXhwYW5kX2FuY2hvciA8LSBmdW5jdGlvbihnaSkge1xuICBhMSA8LSBhbmNob3JzKGdpLCBcXGZpcnN0XFwpXG4gIGEyIDwtIGFuY2hvcnMoZ2ksIFxcc2Vjb25kXFwpXG4gIGExciA8LSByZXNpemUoYTEsIHdpZHRoID0gcG1heCh3aWR0aChhMSksIGV4cGFuZFNpemUpLCBmaXggPSBcXGNlbnRlclxcKVxuICBhMnIgPC0gcmVzaXplKGEyLCB3aWR0aCA9IHBtYXgod2lkdGgoYTIpLCBleHBhbmRTaXplKSwgZml4ID0gXFxjZW50ZXJcXClcbiAgR0ludGVyYWN0aW9ucyhhMXIsIGEycilcbn1cbmBgYFxuYGBgIn0= -->

```r
```r
# helper that only uses the two anchors
make_gi <- function(df) {
  a1 <- GRanges(df$chrom1, IRanges(df$start1, df$end1))
  a2 <- GRanges(df$chrom2, IRanges(df$start2, df$end2))
  GInteractions(a1, a2)
}

# Expand each anchor to 10 kb for comparison
expand_anchor <- function(gi) {
  a1 <- anchors(gi, \first\)
  a2 <- anchors(gi, \second\)
  a1r <- resize(a1, width = pmax(width(a1), expandSize), fix = \center\)
  a2r <- resize(a2, width = pmax(width(a2), expandSize), fix = \center\)
  GInteractions(a1r, a2r)
}
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

### Import loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVabTl5S0dWNGNHRnVaRk5wZW1VZ2FXNGdZeWcxTURBd0xDQXhNREF3TUN3Z01qVXdNREFwS1h0Y2JpQWdaMmt4SUR3dElHVjRjR0Z1WkY5aGJtTm9iM0lvYldGclpWOW5hU2hzYjI5d1gyTm9jbTl0YnlrcFhHNGdJR2RwTWlBOExTQmxlSEJoYm1SZllXNWphRzl5S0cxaGEyVmZaMmtvYkc5dmNGOW9hV05rWTNBcEtWeHVJQ0JuYVRNZ1BDMGdaWGh3WVc1a1gyRnVZMmh2Y2lodFlXdGxYMmRwS0d4dmIzQmZTR0Z1YzJWdUtTbGNiaUFnWEc0Z0lHZHBYMkZzYkNBOExTQmpLR2RwTVN3Z1oya3lMQ0JuYVRNcFhHNGdJRnh1SUNBaklEUXBJR1JsZEdWeWJXbHVaU0J0WlcxaVpYSnphR2x3SUhacFlTQkRhR1ZpZVhOb1pYWWdaR2x6ZEdGdVkyVWdQU0F4SUdKcGJpZ3hNQ0JyWWlsY2JpQWdhVzR4SUR3dElHOTJaWEpzWVhCelFXNTVLR2RwWDJGc2JDd2daMmt4TENBZ0lDQnRZWGhuWVhBOVpYaHdZVzVrVTJsNlpTd2dkSGx3WlQxY0ltVnhkV0ZzWENJcFhHNGdJR2x1TWlBOExTQnZkbVZ5YkdGd2MwRnVlU2huYVY5aGJHd3NJR2RwTWl3Z0lDQWdiV0Y0WjJGd1BXVjRjR0Z1WkZOcGVtVXNJSFI1Y0dVOVhDSmxjWFZoYkZ3aUtWeHVJQ0JwYmpNZ1BDMGdiM1psY214aGNITkJibmtvWjJsZllXeHNMQ0JuYVRNc0lDQWdJRzFoZUdkaGNEMWxlSEJoYm1SVGFYcGxMQ0IwZVhCbFBWd2laWEYxWVd4Y0lpbGNiaUFnWEc0Z0lHMWxiV0psY25Ob2FYQmZaR1lnUEMwZ2RHbGlZbXhsS0Z4dUlDQWdJR3h2YjNBZ1BTQnpaWEZmWVd4dmJtY29aMmxmWVd4c0tTeGNiaUFnSUNCelpYUXhJRDBnYVc0eExGeHVJQ0FnSUhObGRESWdQU0JwYmpJc1hHNGdJQ0FnYzJWME15QTlJR2x1TTF4dUlDQXBYRzRnSUZ4dUlDQnRaVzFpWlhKemFHbHdYMlJtSUR3dElHMWxiV0psY25Ob2FYQmZaR1lnSlQ0bFhHNGdJQ0FnY21WdVlXMWxLRnh1SUNBZ0lDQWdRMmh5YjIxdmMybG5hSFFnSUNBZ0lEMGdjMlYwTVN4Y2JpQWdJQ0FnSUVocFEwUkRVQ0FnSUNBZ1BTQnpaWFF5TEZ4dUlDQWdJQ0FnU0dGdWMyVnVJRDBnYzJWME0xeHVJQ0FnSUNsY2JpQWdYRzRnSUNNZ05Ta2dWWEJUWlhRZ2NHeHZkQ0J2WmlCaGJHd2dZMjl0WW1sdVlYUnBiMjV6WEc0Z0lIQWdQQzBnZFhCelpYUW9YRzRnSUNBZ2JXVnRZbVZ5YzJocGNGOWtaaXhjYmlBZ0lDQnBiblJsY25ObFkzUWdQU0JqS0Z3aVEyaHliMjF2YzJsbmFIUmNJaXhjSWtocFEwUkRVRndpTEZ3aVNHRnVjMlZ1WENJcExGeHVJQ0FnSUc1aGJXVWdQU0JjSWx3aUxGeHVJQ0FnSUdKaGMyVmZZVzV1YjNSaGRHbHZibk1nUFNCc2FYTjBLRnh1SUNBZ0lDQWdKMHh2YjNBZ0l5Y2dQU0JwYm5SbGNuTmxZM1JwYjI1ZmMybDZaU2dwWEc0Z0lDQWdLVnh1SUNBcElDc2daMmQwYVhSc1pTaHdZWE4wWlRBb1pYaHdZVzVrVTJsNlpTd2dYQ0ppY0NCbGVIQmhibVJsWkN3Z01TQkRhR1ZpZVdOb1pYWWdaR2x6ZEZ3aUtTbGNiaUFnWEc0Z0lGeHVJQ0JtYVd4bFRtRnRaU0E4TFNCb1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tGd2liMlptVTJWMFgxd2lMQ0JsZUhCaGJtUlRhWHBsTENCY0ltSndYMlY0Y0dGdVpHVmtYQ0lwS1Z4dUlDQjNhV1IwYUNBOExTQndZVzVsYkZOcGVtVW9OUzQxS1NwdGJWUnZTVzVqYUZ4dUlDQm9aV2xuYUhRZ1BDMGdjR0Z1Wld4VGFYcGxLRE1wS20xdFZHOUpibU5vWEc0Z0lITjJaMnhwZEdVb2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY0lpNXpkbWRjSWlrc0lIZHBaSFJvSUQwZ2QybGtkR2dzSUdobGFXZG9kQ0E5SUdobGFXZG9kQ2xjYmlBZ2NISnBiblFvY0NsY2JpQWdaR1YyTG05bVppZ3BYRzU5WEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5mb3IoZXhwYW5kU2l6ZSBpbiBjKDUwMDAsIDEwMDAwLCAyNTAwMCkpe1xuICBnaTEgPC0gZXhwYW5kX2FuY2hvcihtYWtlX2dpKGxvb3BfY2hyb21vKSlcbiAgZ2kyIDwtIGV4cGFuZF9hbmNob3IobWFrZV9naShsb29wX2hpY2RjcCkpXG4gIGdpMyA8LSBleHBhbmRfYW5jaG9yKG1ha2VfZ2kobG9vcF9IYW5zZW4pKVxuICBcbiAgZ2lfYWxsIDwtIGMoZ2kxLCBnaTIsIGdpMylcbiAgXG4gICMgNCkgZGV0ZXJtaW5lIG1lbWJlcnNoaXAgdmlhIENoZWJ5c2hldiBkaXN0YW5jZSA9IDEgYmluKDEwIGtiKVxuICBpbjEgPC0gb3ZlcmxhcHNBbnkoZ2lfYWxsLCBnaTEsICAgIG1heGdhcD1leHBhbmRTaXplLCB0eXBlPVxcZXF1YWxcXClcbiAgaW4yIDwtIG92ZXJsYXBzQW55KGdpX2FsbCwgZ2kyLCAgICBtYXhnYXA9ZXhwYW5kU2l6ZSwgdHlwZT1cXGVxdWFsXFwpXG4gIGluMyA8LSBvdmVybGFwc0FueShnaV9hbGwsIGdpMywgICAgbWF4Z2FwPWV4cGFuZFNpemUsIHR5cGU9XFxlcXVhbFxcKVxuICBcbiAgbWVtYmVyc2hpcF9kZiA8LSB0aWJibGUoXG4gICAgbG9vcCA9IHNlcV9hbG9uZyhnaV9hbGwpLFxuICAgIHNldDEgPSBpbjEsXG4gICAgc2V0MiA9IGluMixcbiAgICBzZXQzID0gaW4zXG4gIClcbiAgXG4gIG1lbWJlcnNoaXBfZGYgPC0gbWVtYmVyc2hpcF9kZiAlPiVcbiAgICByZW5hbWUoXG4gICAgICBDaHJvbW9zaWdodCAgICAgPSBzZXQxLFxuICAgICAgSGlDRENQICAgICA9IHNldDIsXG4gICAgICBIYW5zZW4gPSBzZXQzXG4gICAgKVxuICBcbiAgIyA1KSBVcFNldCBwbG90IG9mIGFsbCBjb21iaW5hdGlvbnNcbiAgcCA8LSB1cHNldChcbiAgICBtZW1iZXJzaGlwX2RmLFxuICAgIGludGVyc2VjdCA9IGMoXFxDaHJvbW9zaWdodFxcLFxcSGlDRENQXFwsXFxIYW5zZW5cXCksXG4gICAgbmFtZSA9IFxcXFwsXG4gICAgYmFzZV9hbm5vdGF0aW9ucyA9IGxpc3QoXG4gICAgICAnTG9vcCAjJyA9IGludGVyc2VjdGlvbl9zaXplKClcbiAgICApXG4gICkgKyBnZ3RpdGxlKHBhc3RlMChleHBhbmRTaXplLCBcXGJwIGV4cGFuZGVkXG4ifQ== -->
for(expandSize in c(5000, 10000, 25000)){
  gi1 <- expand_anchor(make_gi(loop_chromo))
  gi2 <- expand_anchor(make_gi(loop_hicdcp))
  gi3 <- expand_anchor(make_gi(loop_Hansen))
  
  gi_all <- c(gi1, gi2, gi3)
  
  # 4) determine membership via Chebyshev distance = 1 bin(10 kb)
  in1 <- overlapsAny(gi_all, gi1,    maxgap=expandSize, type=\equal\)
  in2 <- overlapsAny(gi_all, gi2,    maxgap=expandSize, type=\equal\)
  in3 <- overlapsAny(gi_all, gi3,    maxgap=expandSize, type=\equal\)
  
  membership_df <- tibble(
    loop = seq_along(gi_all),
    set1 = in1,
    set2 = in2,
    set3 = in3
  )
  
  membership_df <- membership_df %>%
    rename(
      Chromosight     = set1,
      HiCDCP     = set2,
      Hansen = set3
    )
  
  # 5) UpSet plot of all combinations
  p <- upset(
    membership_df,
    intersect = c(\Chromosight\,\HiCDCP\,\Hansen\),
    name = \\,
    base_annotations = list(
      'Loop #' = intersection_size()
    )
  ) + ggtitle(paste0(expandSize, \bp expanded
```r
for(expandSize in c(5000, 10000, 25000)){
  gi1 <- expand_anchor(make_gi(loop_chromo))
  gi2 <- expand_anchor(make_gi(loop_hicdcp))
  gi3 <- expand_anchor(make_gi(loop_Hansen))
  
  gi_all <- c(gi1, gi2, gi3)
  
  # 4) determine membership via Chebyshev distance = 1 bin(10 kb)
  in1 <- overlapsAny(gi_all, gi1,    maxgap=expandSize, type=\equal\)
  in2 <- overlapsAny(gi_all, gi2,    maxgap=expandSize, type=\equal\)
  in3 <- overlapsAny(gi_all, gi3,    maxgap=expandSize, type=\equal\)
  
  membership_df <- tibble(
    loop = seq_along(gi_all),
    set1 = in1,
    set2 = in2,
    set3 = in3
  )
  
  membership_df <- membership_df %>%
    rename(
      Chromosight     = set1,
      HiCDCP     = set2,
      Hansen = set3
    )
  
  # 5) UpSet plot of all combinations
  p <- upset(
    membership_df,
    intersect = c(\Chromosight\,\HiCDCP\,\Hansen\),
    name = \\,
    base_annotations = list(
      'Loop #' = intersection_size()
    )
  ) + ggtitle(paste0(expandSize, \bp expanded

[FIG] Offset plot

Function


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZm9yKGV4cGFuZFNpemUgaW4gYyg1MDAwLCAxMDAwMCwgMjUwMDApKXtcbiAgZ2kxIDwtIGV4cGFuZF9hbmNob3IobWFrZV9naShsb29wX2Nocm9tbykpXG4gIGdpMiA8LSBleHBhbmRfYW5jaG9yKG1ha2VfZ2kobG9vcF9Uamlhbl9jaHJvbW8pKVxuICBnaTMgPC0gZXhwYW5kX2FuY2hvcihtYWtlX2dpKGxvb3BfVGppYW5fbXVzdGFjaGUpKVxuICBcbiAgZ2lfYWxsIDwtIGMoZ2kxLCBnaTIsIGdpMylcbiAgXG4gICMgNCkgZGV0ZXJtaW5lIG1lbWJlcnNoaXAgdmlhIENoZWJ5c2hldiBkaXN0YW5jZSA9IDEgYmluKDEwIGtiKVxuICBpbjEgPC0gb3ZlcmxhcHNBbnkoZ2lfYWxsLCBnaTEsICAgIG1heGdhcD1leHBhbmRTaXplLCB0eXBlPVwiZXF1YWxcIilcbiAgaW4yIDwtIG92ZXJsYXBzQW55KGdpX2FsbCwgZ2kyLCAgICBtYXhnYXA9ZXhwYW5kU2l6ZSwgdHlwZT1cImVxdWFsXCIpXG4gIGluMyA8LSBvdmVybGFwc0FueShnaV9hbGwsIGdpMywgICAgbWF4Z2FwPWV4cGFuZFNpemUsIHR5cGU9XCJlcXVhbFwiKVxuICBcbiAgbWVtYmVyc2hpcF9kZiA8LSB0aWJibGUoXG4gICAgbG9vcCA9IHNlcV9hbG9uZyhnaV9hbGwpLFxuICAgIHNldDEgPSBpbjEsXG4gICAgc2V0MiA9IGluMixcbiAgICBzZXQzID0gaW4zXG4gIClcbiAgXG4gIG1lbWJlcnNoaXBfZGYgPC0gbWVtYmVyc2hpcF9kZiAlPiVcbiAgICByZW5hbWUoXG4gICAgICBMZWVfY2hyb21vICAgICA9IHNldDEsXG4gICAgICBUamlhbl9jaHJvbW8gICAgID0gc2V0MixcbiAgICAgIFRqaWFuX211c3RhY2hlID0gc2V0M1xuICAgIClcbiAgXG4gICMgNSkgVXBTZXQgcGxvdCBvZiBhbGwgY29tYmluYXRpb25zXG4gIHAgPC0gdXBzZXQoXG4gICAgbWVtYmVyc2hpcF9kZixcbiAgICBpbnRlcnNlY3QgPSBjKFwiTGVlX2Nocm9tb1wiLFwiVGppYW5fY2hyb21vXCIsXCJUamlhbl9tdXN0YWNoZVwiKSxcbiAgICBuYW1lID0gXCJcIixcbiAgICBiYXNlX2Fubm90YXRpb25zID0gbGlzdChcbiAgICAgICdMb29wICMnID0gaW50ZXJzZWN0aW9uX3NpemUoKVxuICAgIClcbiAgKSArIGdndGl0bGUocGFzdGUwKGV4cGFuZFNpemUsIFwiYnAgZXhwYW5kZWQsIDEgQ2hlYnljaGV2IGRpc3RcIikpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIHBhc3RlMChcIm9mZlNldDJfXCIsIGV4cGFuZFNpemUsIFwiYnBfZXhwYW5kZWRcIikpXG4gIHdpZHRoIDwtIHBhbmVsU2l6ZSg1LjUpKm1tVG9JbmNoXG4gIGhlaWdodCA8LSBwYW5lbFNpemUoMykqbW1Ub0luY2hcbiAgc3ZnbGl0ZShwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSwgd2lkdGggPSB3aWR0aCwgaGVpZ2h0ID0gaGVpZ2h0KVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cbmBgYCJ9 -->

```r
for(expandSize in c(5000, 10000, 25000)){
  gi1 <- expand_anchor(make_gi(loop_chromo))
  gi2 <- expand_anchor(make_gi(loop_Tjian_chromo))
  gi3 <- expand_anchor(make_gi(loop_Tjian_mustache))
  
  gi_all <- c(gi1, gi2, gi3)
  
  # 4) determine membership via Chebyshev distance = 1 bin(10 kb)
  in1 <- overlapsAny(gi_all, gi1,    maxgap=expandSize, type=\equal\)
  in2 <- overlapsAny(gi_all, gi2,    maxgap=expandSize, type=\equal\)
  in3 <- overlapsAny(gi_all, gi3,    maxgap=expandSize, type=\equal\)
  
  membership_df <- tibble(
    loop = seq_along(gi_all),
    set1 = in1,
    set2 = in2,
    set3 = in3
  )
  
  membership_df <- membership_df %>%
    rename(
      Lee_chromo     = set1,
      Tjian_chromo     = set2,
      Tjian_mustache = set3
    )
  
  # 5) UpSet plot of all combinations
  p <- upset(
    membership_df,
    intersect = c(\Lee_chromo\,\Tjian_chromo\,\Tjian_mustache\),
    name = \\,
    base_annotations = list(
      'Loop #' = intersection_size()
    )
  ) + ggtitle(paste0(expandSize, \bp expanded
```r
for(expandSize in c(5000, 10000, 25000)){
  gi1 <- expand_anchor(make_gi(loop_chromo))
  gi2 <- expand_anchor(make_gi(loop_Tjian_chromo))
  gi3 <- expand_anchor(make_gi(loop_Tjian_mustache))
  
  gi_all <- c(gi1, gi2, gi3)
  
  # 4) determine membership via Chebyshev distance = 1 bin(10 kb)
  in1 <- overlapsAny(gi_all, gi1,    maxgap=expandSize, type=\equal\)
  in2 <- overlapsAny(gi_all, gi2,    maxgap=expandSize, type=\equal\)
  in3 <- overlapsAny(gi_all, gi3,    maxgap=expandSize, type=\equal\)
  
  membership_df <- tibble(
    loop = seq_along(gi_all),
    set1 = in1,
    set2 = in2,
    set3 = in3
  )
  
  membership_df <- membership_df %>%
    rename(
      Lee_chromo     = set1,
      Tjian_chromo     = set2,
      Tjian_mustache = set3
    )
  
  # 5) UpSet plot of all combinations
  p <- upset(
    membership_df,
    intersect = c(\Lee_chromo\,\Tjian_chromo\,\Tjian_mustache\),
    name = \\,
    base_annotations = list(
      'Loop #' = intersection_size()
    )
  ) + ggtitle(paste0(expandSize, \bp expanded

HiCDC+, Hansen


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5kcmF3X2RvbnV0IDwtIGZ1bmN0aW9uKGxvb3AsIG5hbWUpe1xuICBuIDwtIG5yb3cobG9vcClcbiAgdGVtcCA8LSBsb29wICU+JSBkcGx5cjo6c2VsZWN0KGlkLCBBbm5vKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKEFubm9Hcm91cCA9IGNhc2Vfd2hlbihcbiAgICAgIEFubm8gJWluJSBjKFwiUC1QXCIsIFwiUC1FXCIsIFwiRS1FXCIpIH4gXCJyZWdfcmVnXCIsXG4gICAgICBBbm5vICVpbiUgYyhcIlAtU1BcIiwgXCJQLVNFXCIsIFwiRS1TUFwiLCBcIkUtU0VcIikgfiBcInJlZ19zdHJSZWdcIixcbiAgICAgIEFubm8gJWluJSBjKFwiUC1TXCIsIFwiRS1TXCIpIH4gXCJyZWdfc3RyXCIsXG4gICAgICBBbm5vICVpbiUgYyhcIlNQLVNQXCIsIFwiU1AtU0VcIiwgXCJTRS1TRVwiKSB+IFwic3RyUmVnX3N0clJlZ1wiLFxuICAgICAgQW5ubyAlaW4lIGMoXCJTUC1TXCIsIFwiU0UtU1wiKSB+IFwic3RyUmVnX3N0clwiLFxuICAgICAgQW5ubyAlaW4lIGMoXCJQLVhcIiwgXCJFLVhcIikgfiBcInJlZ19vdGhlclwiLFxuICAgICAgQW5ubyAlaW4lIGMoXCJTUC1YXCIsIFwiU0UtWFwiKSB+IFwic3RyUmVnX290aGVyXCIsXG4gICAgICBBbm5vICVpbiUgYyhcIlMtU1wiLCBcIlMtWFwiKSB+IFwic3RyXCIsXG4gICAgICBBbm5vICVpbiUgYyhcIlgtWFwiKSB+IFwib3RoZXJcIixcbiAgICAgIFRSVUUgfiBOQVxuICAgICkpXG4gIFxuICBcbiAgdGVtcCRBbm5vR3JvdXAgPC0gZmFjdG9yKHRlbXAkQW5ub0dyb3VwLCBsZXZlbHMgPSBjKFwicmVnX3JlZ1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJyZWdfc3RyUmVnXCIsIFwicmVnX3N0clwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJzdHJSZWdfc3RyUmVnXCIsIFwic3RyUmVnX3N0clwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJyZWdfb3RoZXJcIiwgXCJzdHJSZWdfb3RoZXJcIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInN0clwiLCBcIm90aGVyXCIpKVxuICBcbiAgXG4gIHBpZV9kZiA8LSB0ZW1wICU+JVxuICAgIGFzX3RpYmJsZSgpICU+JSAgICAgICAgICAgICAgICAgICAgICAgICAgIyBpZiB0ZW1wIHdhcyBhIGxpc3QsIHRoaXMgd2lsbCBlcnJvciBlYXJseVxuICAgIGdyb3VwX2J5KEFubm9Hcm91cCkgJT4lXG4gICAgc3VtbWFyaXNlKG4gPSBuKCksIC5ncm91cHMgPSBcImRyb3BcIikgJT4lXG4gICAgbXV0YXRlKGxhYmVsID0gcGFzdGUwKEFubm9Hcm91cCwgXCJcXG4oXCIsIG4sIFwiKVwiKSlcbiAgXG4gIHAgPC0gZ2dwbG90KHBpZV9kZiwgYWVzKHggPSAyLCB5ID0gbiwgZmlsbCA9IEFubm9Hcm91cCkpICtcbiAgICBnZW9tX2NvbChjb2xvciA9IFwiYmxhY2tcIiwgd2lkdGggPSAxKSArXG4gICAgY29vcmRfcG9sYXIodGhldGEgPSBcInlcIikgK1xuICAgIHhsaW0oMC41LCAyLjUpICsgICAgICAgICAgICAgICAgIyA8LSBjcmVhdGVzIHRoZSDigJxob2xl4oCdIGJ5IGNsaXBwaW5nIHRoZSBjZW50ZXJcbiAgICBnZW9tX3RleHQoYWVzKGxhYmVsID0gbGFiZWwpLFxuICAgICAgICAgICAgICBwb3NpdGlvbiA9IHBvc2l0aW9uX3N0YWNrKHZqdXN0ID0gMC41KSxcbiAgICAgICAgICAgICAgc2l6ZSA9IDMpICtcbiAgICB0aGVtZV92b2lkKCkgK1xuICAgIHRoZW1lKGxlZ2VuZC5wb3NpdGlvbiA9IFwibm9uZVwiLFxuICAgICAgICAgIHBsb3QudGl0bGUgPSBlbGVtZW50X3RleHQoaGp1c3QgPSAwLjUpXG4gICAgKSArXG4gICAgZ2d0aXRsZShwYXN0ZTAobmFtZSwgXCJcXG5cIiwgbiwgXCIgbG9vcHNcIikpXG4gIFxuICBcbiAgd2lkdGggPSAzXG4gIGhlaWdodCA9IDNcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpcixcbiAgICAgICAgICAgICAgIHBhc3RlMChcImRvbnV0X2xvb3BBbm5vX1wiLCBuYW1lLCBcIi5zdmdcIikpLFxuICAgICAgICAgIHdpZHRoID0gd2lkdGgsIGhlaWdodCA9IGhlaWdodClcbiAgcGxvdChwKVxuICBkZXYub2ZmKClcbn1cblxuZHJhd19kb251dChsb29wX2Nocm9tbywgXCJjaHJvbW9zaWdodFwiKVxuYGBgIn0= -->

```r

draw_donut <- function(loop, name){
  n <- nrow(loop)
  temp <- loop %>% dplyr::select(id, Anno) %>%
    dplyr::mutate(AnnoGroup = case_when(
      Anno %in% c(\P-P\, \P-E\, \E-E\) ~ \reg_reg\,
      Anno %in% c(\P-SP\, \P-SE\, \E-SP\, \E-SE\) ~ \reg_strReg\,
      Anno %in% c(\P-S\, \E-S\) ~ \reg_str\,
      Anno %in% c(\SP-SP\, \SP-SE\, \SE-SE\) ~ \strReg_strReg\,
      Anno %in% c(\SP-S\, \SE-S\) ~ \strReg_str\,
      Anno %in% c(\P-X\, \E-X\) ~ \reg_other\,
      Anno %in% c(\SP-X\, \SE-X\) ~ \strReg_other\,
      Anno %in% c(\S-S\, \S-X\) ~ \str\,
      Anno %in% c(\X-X\) ~ \other\,
      TRUE ~ NA
    ))
  
  
  temp$AnnoGroup <- factor(temp$AnnoGroup, levels = c(\reg_reg\,
                                                      \reg_strReg\, \reg_str\,
                                                      \strReg_strReg\, \strReg_str\,
                                                      \reg_other\, \strReg_other\, 
                                                      \str\, \other\))
  
  
  pie_df <- temp %>%
    as_tibble() %>%                          # if temp was a list, this will error early
    group_by(AnnoGroup) %>%
    summarise(n = n(), .groups = \drop\) %>%
    mutate(label = paste0(AnnoGroup, \\n(\, n, \)\))
  
  p <- ggplot(pie_df, aes(x = 2, y = n, fill = AnnoGroup)) +
    geom_col(color = \black\, width = 1) +
    coord_polar(theta = \y\) +
    xlim(0.5, 2.5) +                # <- creates the “hole” by clipping the center
    geom_text(aes(label = label),
              position = position_stack(vjust = 0.5),
              size = 3) +
    theme_void() +
    theme(legend.position = \none\,
          plot.title = element_text(hjust = 0.5)
    ) +
    ggtitle(paste0(name, \\n\, n, \ loops\))
  
  
  width = 3
  height = 3
  svglite(here(figDir,
               paste0(\donut_loopAnno_\, name, \.svg\)),
          width = width, height = height)
  plot(p)
  dev.off()
}

draw_donut(loop_chromo, \chromosight\)
```

<!-- rnb-source-end -->
```r

draw_donut <- function(loop, name){
  n <- nrow(loop)
  temp <- loop %>% dplyr::select(id, Anno) %>%
    dplyr::mutate(AnnoGroup = case_when(
      Anno %in% c(\P-P\, \P-E\, \E-E\) ~ \reg_reg\,
      Anno %in% c(\P-SP\, \P-SE\, \E-SP\, \E-SE\) ~ \reg_strReg\,
      Anno %in% c(\P-S\, \E-S\) ~ \reg_str\,
      Anno %in% c(\SP-SP\, \SP-SE\, \SE-SE\) ~ \strReg_strReg\,
      Anno %in% c(\SP-S\, \SE-S\) ~ \strReg_str\,
      Anno %in% c(\P-X\, \E-X\) ~ \reg_other\,
      Anno %in% c(\SP-X\, \SE-X\) ~ \strReg_other\,
      Anno %in% c(\S-S\, \S-X\) ~ \str\,
      Anno %in% c(\X-X\) ~ \other\,
      TRUE ~ NA
    ))
  
  
  temp$AnnoGroup <- factor(temp$AnnoGroup, levels = c(\reg_reg\,
                                                      \reg_strReg\, \reg_str\,
                                                      \strReg_strReg\, \strReg_str\,
                                                      \reg_other\, \strReg_other\, 
                                                      \str\, \other\))
  
  
  pie_df <- temp %>%
    as_tibble() %>%                          # if temp was a list, this will error early
    group_by(AnnoGroup) %>%
    summarise(n = n(), .groups = \drop\) %>%
    mutate(label = paste0(AnnoGroup, \\n(\, n, \)\))
  
  p <- ggplot(pie_df, aes(x = 2, y = n, fill = AnnoGroup)) +
    geom_col(color = \black\, width = 1) +
    coord_polar(theta = \y\) +
    xlim(0.5, 2.5) +                # <- creates the “hole” by clipping the center
    geom_text(aes(label = label),
              position = position_stack(vjust = 0.5),
              size = 3) +
    theme_void() +
    theme(legend.position = \none\,
          plot.title = element_text(hjust = 0.5)
    ) +
    ggtitle(paste0(name, \\n\, n, \ loops\))
  
  
  width = 3
  height = 3
  svglite(here(figDir,
               paste0(\donut_loopAnno_\, name, \.svg\)),
          width = width, height = height)
  plot(p)
  dev.off()
}

draw_donut(loop_chromo, \chromosight\)

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoibnVsbCBkZXZpY2UgXG4gICAgICAgICAgMSBcblxuPCEtLSBybmItc291cmNlLWJlZ2luIGV5SmtZWFJoSWpvaVlHQmdjbHh1WkhKaGQxOWtiMjUxZENoc2IyOXdYMmhwWTJSamNDd2dYQ0pvYVdOa1kzQmNJaWxjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbmRyYXdfZG9udXQobG9vcF9oaWNkY3AsIFxcaGljZGNwXFwpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->

null device 1

draw_donut(loop_hicdcp, \hicdcp\)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVpISmhkMTlrYjI1MWRDaHNiMjl3WDJocFkyUmpjQ3dnWEZ4b2FXTmtZM0JjWENsY2JtQmdZRnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbmBgYHJcbmRyYXdfZG9udXQobG9vcF9oaWNkY3AsIFxcaGljZGNwXFwpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZHJhd19kb251dChsb29wX2hpY2RjcCwgXFxoaWNkY3BcXClcbmBgYFxuYGBgIn0= -->

```r
```r
draw_donut(loop_hicdcp, \hicdcp\)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoibnVsbCBkZXZpY2UgXG4gICAgICAgICAgMSBcblxuPCEtLSBybmItc291cmNlLWJlZ2luIGV5SmtZWFJoSWpvaVlHQmdjbHh1WkhKaGQxOWtiMjUxZENoc2IyOXdYMGhoYm5ObGJpd2dYQ0pJWVc1elpXNWNJaWxjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbmRyYXdfZG9udXQobG9vcF9IYW5zZW4sIFxcSGFuc2VuXFwpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->

null device 1

draw_donut(loop_Hansen, \Hansen\)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVpISmhkMTlrYjI1MWRDaHNiMjl3WDBoaGJuTmxiaXdnWEZ4SVlXNXpaVzVjWENsY2JtQmdZRnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbmBgYHJcbmRyYXdfZG9udXQobG9vcF9IYW5zZW4sIFxcSGFuc2VuXFwpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZHJhd19kb251dChsb29wX0hhbnNlbiwgXFxIYW5zZW5cXClcbmBgYFxuYGBgIn0= -->

```r
```r
draw_donut(loop_Hansen, \Hansen\)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoibnVsbCBkZXZpY2UgXG4gICAgICAgICAgMSBcbiJ9 -->

```
null device 
          1 
```



<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Tjian

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\nplot_loop_scores_and_save_bedpe <- function(df, col_x, col_y, \n                                            col_x_ooe, col_y_ooe, pseudo_ooe = 0.01,\n                                            annoList,\n                                            name, title, figDir, loopDir,\n                                            diffCutoff = 0.2, density_n = 200,\n                                            xmin = -0.5, xmax = 1,\n                                            ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  col_x_ooe_q <- enquo(col_x_ooe)\n  col_y_ooe_q <- enquo(col_y_ooe)\n  \n  # Create a single, unified dataframe for plotting and saving as bedpe\n  df_temp <- df %>%\n    dplyr::filter(Anno_simple %in% annoList) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, x = !!col_x_q, y = !!col_y_q,\n                  x_ooe = !!col_x_ooe_q, y_ooe = !!col_y_ooe_q) %>%\n    dplyr::mutate(diff = y-x,\n                  density = get_density(x, y, n = density_n)) %>%\n    dplyr::mutate(updown = case_when(\n      diff > diffCutoff  ~ \"UP\",\n      diff < -diffCutoff ~ \"DOWN\",\n      TRUE               ~ \"NO\"))\n  \n  # Export as bedpe\n  bedpeUP <- df_temp %>% dplyr::filter(updown == \"UP\") %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeUP, here(loopDir, paste0(name, \"_diffCutoff\", diffCutoff, \"_UP.bedpe\")), sep = \"\\t\", col.names = FALSE)\n  bedpeNO <- df_temp %>% dplyr::filter(updown == \"NO\") %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeNO, here(loopDir, paste0(name, \"_diffCutoff\", diffCutoff, \"_NO.bedpe\")), sep = \"\\t\", col.names = FALSE)\n  bedpeDOWN <- df_temp %>% dplyr::filter(updown == \"DOWN\") %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeDOWN, here(loopDir, paste0(name, \"_diffCutoff\", diffCutoff, \"_DOWN.bedpe\")), sep = \"\\t\", col.names = FALSE)\n  \n  \n  plot_df <- df_temp %>%\n    dplyr::select(id, x, y, updown, density) %>%\n    arrange(density)\n  \n  plot_df$updown <- factor(plot_df$updown, c(\"UP\", \"NO\", \"DOWN\"))\n  \n  # Calculate a global density range to make scales comparable\n  density_limits <- range(plot_df$density, na.rm = TRUE)\n  \n  # ------ Scatterplot ------ \n  p1 <- ggplot(plot_df, aes(x = x, y = y)) +\n    # Layer 1: Plot \"NO\" points with a grey scale\n    geom_point(data = . %>% filter(updown == \"NO\") %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = \"grey85\", high = \"grey30\",\n      limits = density_limits, name = \"Density (NO)\"\n    ) +\n    \n    # Introduce a new scale for the \"UP\" points\n    new_scale_color() +\n    # Layer 2: Plot \"UP\" points with a red scale\n    geom_point(data = . %>% filter(updown == \"UP\") %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = weak_red, high = strong_red, # Light to dark red\n      limits = density_limits, name = \"Density (UP)\"\n    ) +\n    \n    # Introduce a new scale for the \"DOWN\" points\n    new_scale_color() +\n    # Layer 3: Plot \"DOWN\" points with a blue scale\n    geom_point(data = . %>% filter(updown == \"DOWN\") %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = weak_blue, high = strong_blue, # Light to dark blue\n      limits = density_limits, name = \"Density (DOWN)\"\n    ) +\n    \n    # Add annotations and theme elements\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    theme_classic() +\n    theme(\n      legend.position = \"none\",\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \"#000000\"\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \"#000000\"\n      ),\n      axis.line = element_line(\n        color = \"#000000\",\n        size = lineThick*mmToLineUnit,\n        lineend = \"square\"\n      ),\n      axis.ticks = element_line(\n        color = \"#000000\",\n        size = lineThick*mmToLineUnit,\n        lineend = \"square\"\n      ),\n      panel.background = element_rect(fill = \"transparent\"),\n    ) +\n    labs(x = quo_name(col_x_q), y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch  \n  \n  fileName <- paste0(\"scatterplot_\", name)\n  svglite(here(figDir, paste0(fileName, \".svg\")), \n          width = width, height = height)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \".png\")), \n      width = width, height = height, units = \"in\", res = 600)\n  print(p1)\n  dev.off()\n  \n  # ------ Pie chart ------ \n  pie_df <- plot_df %>%\n    dplyr::count(updown) %>%\n    mutate(\n      pct   = n / sum(n) * 100,\n      label = paste0(updown, \"\\n\", n, \"\\n(\", round(pct, 1), \"%)\")\n    )\n  \n  p2 <- ggplot(pie_df, aes(x = \"\", y = n, fill = updown)) +\n    geom_col(color = \"white\") +\n    coord_polar(theta = \"y\") +\n    geom_text(\n      aes(label = label),\n      position = position_stack(vjust = 0.5),\n      size     = fontSizeM / 2\n    ) +\n    theme_void() + theme(legend.position = \"none\") +\n    scale_fill_manual(values = c(\"UP\" = strong_red, \"NO\" = no_grey, \"DOWN\" = strong_blue))\n  \n  fileName <- here(figDir, paste0(\"piechart_\", name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \".svg\"), width = width, height = height)\n  print(p2)\n  dev.off()\n  \n  \n  # ------ Violin plot of ooe ------ \n  plot_df_ooe <- df_temp %>%\n    dplyr::select(id, x_ooe, y_ooe, updown) %>%\n    dplyr::filter(!is.na(x_ooe), !is.na(y_ooe)) %>%\n    dplyr::mutate(\n      x_ooe = if_else(x_ooe == 0, pseudo_ooe, x_ooe),\n      y_ooe = if_else(y_ooe == 0, pseudo_ooe, y_ooe),\n      fc    = log2(y_ooe / x_ooe)\n    )\n  \n  plot_df_ooe$updown <- factor(plot_df_ooe$updown, levels = c(\"UP\", \"NO\", \"DOWN\"))\n  \n  p3 <- ggplot(plot_df_ooe, aes(x = updown, y = fc, fill = updown)) +\n    geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \"square\", alpha = .4, show.legend = FALSE) + \n    geom_boxplot(width = 0.3, color = \"black\",\n                 linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n    theme_classic() + \n    stat_summary(\n      aes(group = updown), fun = mean,\n      geom = \"point\", shape = 21, size = 0.5,\n      fill = \"black\", color = \"black\", position = position_dodge(.3)\n    ) +\n    coord_cartesian(ylim = c(-3, 3)) +\n    scale_fill_manual(values = c(strong_red, \"grey30\", strong_blue)) +\n    theme(\n      axis.title.x = element_blank(),\n      axis.title.y = element_text(\n        size = fontSizeM,\n        family = fontType,\n        color = \"#000000\"\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \"#000000\"\n      ),\n      axis.text.x = element_text(\n        size = fontSizeM,\n        angle = 45,      # Rotate x-axis labels 45 degrees\n        hjust = 1,       # Adjust horizontal justification\n        vjust = 1        # Adjust vertical justification\n      ),\n      axis.line = element_line(\n        color = \"#000000\",\n        size = lineThick*mmToLineUnit,\n        lineend = \"square\"\n      ),\n      axis.ticks = element_line(\n        color = \"#000000\",\n        size = lineThick*mmToLineUnit,\n        lineend = \"square\"\n      ),\n      panel.background = element_rect(fill = \"transparent\"),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) +labs(y = \"log2 fc of obs/exp\")  +\n    geom_hline(yintercept = 0,\n               alpha = 1,\n               color = \"black\",\n               size = lineThick*mmToLineUnit,\n               lineend = \"square\") +\n    geom_hline(yintercept = c(-0.5, 0.5),\n               alpha = 0.5,\n               color = \"black\",\n               size = lineThick*mmToLineUnit,\n               lineend = \"square\", linetype = \"dashed\")\n   \n  \n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch\n  fileName <- paste0(\"violin_\", name)\n  svglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\n  print(p3)\n  dev.off()  \n}\n\n\ncommonLoopDir <- here(\"../data/loop_analysis\")\nfigDir <- here(\"../figure/loop_analysis\")\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \"loopScore_chromosight.tsv\"))\n\n\nplot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, \n                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,\n                                c(\"P-P\", \"P-E\", \"P-S\", \"P-X\",\n                                  \"E-E\", \"E-S\", \"E-X\",\n                                  \"S-S\", \"S-X\",\n                                  \"X-X\"),\n                                name = \"chromosight_score_all_dTAGvsDMSO\",\n                                title = \"chromo_score_all_dTAGvsDMSO\", figDir, commonLoopDir)\n```"} -->\n\n```r\nplot_loop_scores_and_save_bedpe <- function(df, col_x, col_y, \n                                            col_x_ooe, col_y_ooe, pseudo_ooe = 0.01,\n                                            annoList,\n                                            name, title, figDir, loopDir,\n                                            diffCutoff = 0.2, density_n = 200,\n                                            xmin = -0.5, xmax = 1,\n                                            ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  col_x_ooe_q <- enquo(col_x_ooe)\n  col_y_ooe_q <- enquo(col_y_ooe)\n  \n  # Create a single, unified dataframe for plotting and saving as bedpe\n  df_temp <- df %>%\n    dplyr::filter(Anno_simple %in% annoList) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, x = !!col_x_q, y = !!col_y_q,\n                  x_ooe = !!col_x_ooe_q, y_ooe = !!col_y_ooe_q) %>%\n    dplyr::mutate(diff = y-x,\n                  density = get_density(x, y, n = density_n)) %>%\n    dplyr::mutate(updown = case_when(\n      diff > diffCutoff  ~ \\UP\\,\n      diff < -diffCutoff ~ \\DOWN\\,\n      TRUE               ~ \\NO\\))\n  \n  # Export as bedpe\n  bedpeUP <- df_temp %>% dplyr::filter(updown == \\UP\\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeUP, here(loopDir, paste0(name, \\_diffCutoff\\, diffCutoff, \\_UP.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n  bedpeNO <- df_temp %>% dplyr::filter(updown == \\NO\\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeNO, here(loopDir, paste0(name, \\_diffCutoff\\, diffCutoff, \\_NO.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n  bedpeDOWN <- df_temp %>% dplyr::filter(updown == \\DOWN\\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeDOWN, here(loopDir, paste0(name, \\_diffCutoff\\, diffCutoff, \\_DOWN.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n  \n  \n  plot_df <- df_temp %>%\n    dplyr::select(id, x, y, updown, density) %>%\n    arrange(density)\n  \n  plot_df$updown <- factor(plot_df$updown, c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  # Calculate a global density range to make scales comparable\n  density_limits <- range(plot_df$density, na.rm = TRUE)\n  \n  # ------ Scatterplot ------ \n  p1 <- ggplot(plot_df, aes(x = x, y = y)) +\n    # Layer 1: Plot \\NO\\ points with a grey scale\n    geom_point(data = . %>% filter(updown == \\NO\\) %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = \\grey85\\, high = \\grey30\\,\n      limits = density_limits, name = \\Density (NO)\\\n    ) +\n    \n    # Introduce a new scale for the \\UP\\ points\n    new_scale_color() +\n    # Layer 2: Plot \\UP\\ points with a red scale\n    geom_point(data = . %>% filter(updown == \\UP\\) %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = weak_red, high = strong_red, # Light to dark red\n      limits = density_limits, name = \\Density (UP)\\\n    ) +\n    \n    # Introduce a new scale for the \\DOWN\\ points\n    new_scale_color() +\n    # Layer 3: Plot \\DOWN\\ points with a blue scale\n    geom_point(data = . %>% filter(updown == \\DOWN\\) %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = weak_blue, high = strong_blue, # Light to dark blue\n      limits = density_limits, name = \\Density (DOWN)\\\n    ) +\n    \n    # Add annotations and theme elements\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    theme_classic() +\n    theme(\n      legend.position = \\none\\,\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n    ) +\n    labs(x = quo_name(col_x_q), y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch  \n  \n  fileName <- paste0(\\scatterplot_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = width, height = height)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      width = width, height = height, units = \\in\\, res = 600)\n  print(p1)\n  dev.off()\n  \n  # ------ Pie chart ------ \n  pie_df <- plot_df %>%\n    dplyr::count(updown) %>%\n    mutate(\n      pct   = n / sum(n) * 100,\n      label = paste0(updown, \\\\n\\, n, \\\\n(\\, round(pct, 1), \\%)\\)\n    )\n  \n  p2 <- ggplot(pie_df, aes(x = \\\\, y = n, fill = updown)) +\n    geom_col(color = \\white\\) +\n    coord_polar(theta = \\y\\) +\n    geom_text(\n      aes(label = label),\n      position = position_stack(vjust = 0.5),\n      size     = fontSizeM / 2\n    ) +\n    theme_void() + theme(legend.position = \\none\\) +\n    scale_fill_manual(values = c(\\UP\\ = strong_red, \\NO\\ = no_grey, \\DOWN\\ = strong_blue))\n  \n  fileName <- here(figDir, paste0(\\piechart_\\, name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(p2)\n  dev.off()\n  \n  \n  # ------ Violin plot of ooe ------ \n  plot_df_ooe <- df_temp %>%\n    dplyr::select(id, x_ooe, y_ooe, updown) %>%\n    dplyr::filter(!is.na(x_ooe), !is.na(y_ooe)) %>%\n    dplyr::mutate(\n      x_ooe = if_else(x_ooe == 0, pseudo_ooe, x_ooe),\n      y_ooe = if_else(y_ooe == 0, pseudo_ooe, y_ooe),\n      fc    = log2(y_ooe / x_ooe)\n    )\n  \n  plot_df_ooe$updown <- factor(plot_df_ooe$updown, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  p3 <- ggplot(plot_df_ooe, aes(x = updown, y = fc, fill = updown)) +\n    geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, show.legend = FALSE) + \n    geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n    theme_classic() + \n    stat_summary(\n      aes(group = updown), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    coord_cartesian(ylim = c(-3, 3)) +\n    scale_fill_manual(values = c(strong_red, \\grey30\\, strong_blue)) +\n    theme(\n      axis.title.x = element_blank(),\n      axis.title.y = element_text(\n        size = fontSizeM,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        size = fontSizeM,\n        angle = 45,      # Rotate x-axis labels 45 degrees\n        hjust = 1,       # Adjust horizontal justification\n        vjust = 1        # Adjust vertical justification\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) +labs(y = \\log2 fc of obs/exp\\)  +\n    geom_hline(yintercept = 0,\n               alpha = 1,\n               color = \\black\\,\n               size = lineThick*mmToLineUnit,\n               lineend = \\square\\) +\n    geom_hline(yintercept = c(-0.5, 0.5),\n               alpha = 0.5,\n               color = \\black\\,\n               size = lineThick*mmToLineUnit,\n               lineend = \\square\\, linetype = \\dashed\\)\n   \n  \n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch\n  fileName <- paste0(\\violin_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p3)\n  dev.off()  \n}\n\n\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_chromosight.tsv\\))\n\n\nplot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, \n                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,\n                                c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                  \\E-E\\, \\E-S\\, \\E-X\\,\n                                  \\S-S\\, \\S-X\\,\n                                  \\X-X\\),\n                                name = \\chromosight_score_all_dTAGvsDMSO\\,\n                                title = \\chromo_score_all_dTAGvsDMSO\\, figDir, commonLoopDir)\n```\n\n<!-- rnb-source-end -->\n"} -->
plot_loop_scores_and_save_bedpe <- function(df, col_x, col_y, 
                                            col_x_ooe, col_y_ooe, pseudo_ooe = 0.01,
                                            annoList,
                                            name, title, figDir, loopDir,
                                            diffCutoff = 0.2, density_n = 200,
                                            xmin = -0.5, xmax = 1,
                                            ymin = -0.5, ymax = 1) {
  col_x_q <- enquo(col_x)
  col_y_q <- enquo(col_y)
  
  col_x_ooe_q <- enquo(col_x_ooe)
  col_y_ooe_q <- enquo(col_y_ooe)
  
  # Create a single, unified dataframe for plotting and saving as bedpe
  df_temp <- df %>%
    dplyr::filter(Anno_simple %in% annoList) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, x = !!col_x_q, y = !!col_y_q,
                  x_ooe = !!col_x_ooe_q, y_ooe = !!col_y_ooe_q) %>%
    dplyr::mutate(diff = y-x,
                  density = get_density(x, y, n = density_n)) %>%
    dplyr::mutate(updown = case_when(
      diff > diffCutoff  ~ \UP\,
      diff < -diffCutoff ~ \DOWN\,
      TRUE               ~ \NO\))
  
  # Export as bedpe
  bedpeUP <- df_temp %>% dplyr::filter(updown == \UP\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)
  fwrite(bedpeUP, here(loopDir, paste0(name, \_diffCutoff\, diffCutoff, \_UP.bedpe\)), sep = \\t\, col.names = FALSE)
  bedpeNO <- df_temp %>% dplyr::filter(updown == \NO\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)
  fwrite(bedpeNO, here(loopDir, paste0(name, \_diffCutoff\, diffCutoff, \_NO.bedpe\)), sep = \\t\, col.names = FALSE)
  bedpeDOWN <- df_temp %>% dplyr::filter(updown == \DOWN\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)
  fwrite(bedpeDOWN, here(loopDir, paste0(name, \_diffCutoff\, diffCutoff, \_DOWN.bedpe\)), sep = \\t\, col.names = FALSE)
  
  
  plot_df <- df_temp %>%
    dplyr::select(id, x, y, updown, density) %>%
    arrange(density)
  
  plot_df$updown <- factor(plot_df$updown, c(\UP\, \NO\, \DOWN\))
  
  # Calculate a global density range to make scales comparable
  density_limits <- range(plot_df$density, na.rm = TRUE)
  
  # ------ Scatterplot ------ 
  p1 <- ggplot(plot_df, aes(x = x, y = y)) +
    # Layer 1: Plot \NO\ points with a grey scale
    geom_point(data = . %>% filter(updown == \NO\) %>% arrange(density),
               aes(color = density), size = 0.1) +
    scale_color_gradient(
      low = \grey85\, high = \grey30\,
      limits = density_limits, name = \Density (NO)\
    ) +
    
    # Introduce a new scale for the \UP\ points
    new_scale_color() +
    # Layer 2: Plot \UP\ points with a red scale
    geom_point(data = . %>% filter(updown == \UP\) %>% arrange(density),
               aes(color = density), size = 0.1) +
    scale_color_gradient(
      low = weak_red, high = strong_red, # Light to dark red
      limits = density_limits, name = \Density (UP)\
    ) +
    
    # Introduce a new scale for the \DOWN\ points
    new_scale_color() +
    # Layer 3: Plot \DOWN\ points with a blue scale
    geom_point(data = . %>% filter(updown == \DOWN\) %>% arrange(density),
               aes(color = density), size = 0.1) +
    scale_color_gradient(
      low = weak_blue, high = strong_blue, # Light to dark blue
      limits = density_limits, name = \Density (DOWN)\
    ) +
    
    # Add annotations and theme elements
    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    theme_classic() +
    theme(
      legend.position = \none\,
      plot.title = element_text(
        hjust = 0.5,
        size = fontSizeS,
        family = fontType
      ),
      axis.title = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.line = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
    ) +
    labs(x = quo_name(col_x_q), y = quo_name(col_y_q)) +
    ggtitle(title)
  
  width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.5)*mmToInch  
  
  fileName <- paste0(\scatterplot_\, name)
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = width, height = height)
  print(p1)
  dev.off()
  
  png(here(figDir, paste0(fileName, \.png\)), 
      width = width, height = height, units = \in\, res = 600)
  print(p1)
  dev.off()
  
  # ------ Pie chart ------ 
  pie_df <- plot_df %>%
    dplyr::count(updown) %>%
    mutate(
      pct   = n / sum(n) * 100,
      label = paste0(updown, \\n\, n, \\n(\, round(pct, 1), \%)\)
    )
  
  p2 <- ggplot(pie_df, aes(x = \\, y = n, fill = updown)) +
    geom_col(color = \white\) +
    coord_polar(theta = \y\) +
    geom_text(
      aes(label = label),
      position = position_stack(vjust = 0.5),
      size     = fontSizeM / 2
    ) +
    theme_void() + theme(legend.position = \none\) +
    scale_fill_manual(values = c(\UP\ = strong_red, \NO\ = no_grey, \DOWN\ = strong_blue))
  
  fileName <- here(figDir, paste0(\piechart_\, name))
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  svglite(paste0(fileName, \.svg\), width = width, height = height)
  print(p2)
  dev.off()
  
  
  # ------ Violin plot of ooe ------ 
  plot_df_ooe <- df_temp %>%
    dplyr::select(id, x_ooe, y_ooe, updown) %>%
    dplyr::filter(!is.na(x_ooe), !is.na(y_ooe)) %>%
    dplyr::mutate(
      x_ooe = if_else(x_ooe == 0, pseudo_ooe, x_ooe),
      y_ooe = if_else(y_ooe == 0, pseudo_ooe, y_ooe),
      fc    = log2(y_ooe / x_ooe)
    )
  
  plot_df_ooe$updown <- factor(plot_df_ooe$updown, levels = c(\UP\, \NO\, \DOWN\))
  
  p3 <- ggplot(plot_df_ooe, aes(x = updown, y = fc, fill = updown)) +
    geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, show.legend = FALSE) + 
    geom_boxplot(width = 0.3, color = \black\,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\,
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
    theme_classic() + 
    stat_summary(
      aes(group = updown), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) +
    coord_cartesian(ylim = c(-3, 3)) +
    scale_fill_manual(values = c(strong_red, \grey30\, strong_blue)) +
    theme(
      axis.title.x = element_blank(),
      axis.title.y = element_text(
        size = fontSizeM,
        family = fontType,
        color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.text.x = element_text(
        size = fontSizeM,
        angle = 45,      # Rotate x-axis labels 45 degrees
        hjust = 1,       # Adjust horizontal justification
        vjust = 1        # Adjust vertical justification
      ),
      axis.line = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    ) +labs(y = \log2 fc of obs/exp\)  +
    geom_hline(yintercept = 0,
               alpha = 1,
               color = \black\,
               size = lineThick*mmToLineUnit,
               lineend = \square\) +
    geom_hline(yintercept = c(-0.5, 0.5),
               alpha = 0.5,
               color = \black\,
               size = lineThick*mmToLineUnit,
               lineend = \square\, linetype = \dashed\)
   
  
  width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.5)*mmToInch
  fileName <- paste0(\violin_\, name)
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p3)
  dev.off()  
}


commonLoopDir <- here(\../data/loop_analysis\)
figDir <- here(\../figure/loop_analysis\)
dir.create(figDir, showWarnings = FALSE, recursive = TRUE)

data <- fread(here(commonLoopDir, \loopScore_chromosight.tsv\))


plot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, 
                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,
                                c(\P-P\, \P-E\, \P-S\, \P-X\,
                                  \E-E\, \E-S\, \E-X\,
                                  \S-S\, \S-X\,
                                  \X-X\),
                                name = \chromosight_score_all_dTAGvsDMSO\,
                                title = \chromo_score_all_dTAGvsDMSO\, figDir, commonLoopDir)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\nplot_loop_scores_and_save_bedpe <- function(df, col_x, col_y, \n                                            col_x_ooe, col_y_ooe, pseudo_ooe = 0.01,\n                                            annoList,\n                                            name, title, figDir, loopDir,\n                                            diffCutoff = 0.2, density_n = 200,\n                                            xmin = -0.5, xmax = 1,\n                                            ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  col_x_ooe_q <- enquo(col_x_ooe)\n  col_y_ooe_q <- enquo(col_y_ooe)\n  \n  # Create a single, unified dataframe for plotting and saving as bedpe\n  df_temp <- df %>%\n    dplyr::filter(Anno_simple %in% annoList) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, x = !!col_x_q, y = !!col_y_q,\n                  x_ooe = !!col_x_ooe_q, y_ooe = !!col_y_ooe_q) %>%\n    dplyr::mutate(diff = y-x,\n                  density = get_density(x, y, n = density_n)) %>%\n    dplyr::mutate(updown = case_when(\n      diff > diffCutoff  ~ \\UP\\,\n      diff < -diffCutoff ~ \\DOWN\\,\n      TRUE               ~ \\NO\\))\n  \n  # Export as bedpe\n  bedpeUP <- df_temp %>% dplyr::filter(updown == \\UP\\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeUP, here(loopDir, paste0(name, \\_diffCutoff\\, diffCutoff, \\_UP.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n  bedpeNO <- df_temp %>% dplyr::filter(updown == \\NO\\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeNO, here(loopDir, paste0(name, \\_diffCutoff\\, diffCutoff, \\_NO.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n  bedpeDOWN <- df_temp %>% dplyr::filter(updown == \\DOWN\\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeDOWN, here(loopDir, paste0(name, \\_diffCutoff\\, diffCutoff, \\_DOWN.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n  \n  \n  plot_df <- df_temp %>%\n    dplyr::select(id, x, y, updown, density) %>%\n    arrange(density)\n  \n  plot_df$updown <- factor(plot_df$updown, c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  # Calculate a global density range to make scales comparable\n  density_limits <- range(plot_df$density, na.rm = TRUE)\n  \n  # ------ Scatterplot ------ \n  p1 <- ggplot(plot_df, aes(x = x, y = y)) +\n    # Layer 1: Plot \\NO\\ points with a grey scale\n    geom_point(data = . %>% filter(updown == \\NO\\) %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = \\grey85\\, high = \\grey30\\,\n      limits = density_limits, name = \\Density (NO)\\\n    ) +\n    \n    # Introduce a new scale for the \\UP\\ points\n    new_scale_color() +\n    # Layer 2: Plot \\UP\\ points with a red scale\n    geom_point(data = . %>% filter(updown == \\UP\\) %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = weak_red, high = strong_red, # Light to dark red\n      limits = density_limits, name = \\Density (UP)\\\n    ) +\n    \n    # Introduce a new scale for the \\DOWN\\ points\n    new_scale_color() +\n    # Layer 3: Plot \\DOWN\\ points with a blue scale\n    geom_point(data = . %>% filter(updown == \\DOWN\\) %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = weak_blue, high = strong_blue, # Light to dark blue\n      limits = density_limits, name = \\Density (DOWN)\\\n    ) +\n    \n    # Add annotations and theme elements\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    theme_classic() +\n    theme(\n      legend.position = \\none\\,\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n    ) +\n    labs(x = quo_name(col_x_q), y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch  \n  \n  fileName <- paste0(\\scatterplot_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = width, height = height)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      width = width, height = height, units = \\in\\, res = 600)\n  print(p1)\n  dev.off()\n  \n  # ------ Pie chart ------ \n  pie_df <- plot_df %>%\n    dplyr::count(updown) %>%\n    mutate(\n      pct   = n / sum(n) * 100,\n      label = paste0(updown, \\\\n\\, n, \\\\n(\\, round(pct, 1), \\%)\\)\n    )\n  \n  p2 <- ggplot(pie_df, aes(x = \\\\, y = n, fill = updown)) +\n    geom_col(color = \\white\\) +\n    coord_polar(theta = \\y\\) +\n    geom_text(\n      aes(label = label),\n      position = position_stack(vjust = 0.5),\n      size     = fontSizeM / 2\n    ) +\n    theme_void() + theme(legend.position = \\none\\) +\n    scale_fill_manual(values = c(\\UP\\ = strong_red, \\NO\\ = no_grey, \\DOWN\\ = strong_blue))\n  \n  fileName <- here(figDir, paste0(\\piechart_\\, name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(p2)\n  dev.off()\n  \n  \n  # ------ Violin plot of ooe ------ \n  plot_df_ooe <- df_temp %>%\n    dplyr::select(id, x_ooe, y_ooe, updown) %>%\n    dplyr::filter(!is.na(x_ooe), !is.na(y_ooe)) %>%\n    dplyr::mutate(\n      x_ooe = if_else(x_ooe == 0, pseudo_ooe, x_ooe),\n      y_ooe = if_else(y_ooe == 0, pseudo_ooe, y_ooe),\n      fc    = log2(y_ooe / x_ooe)\n    )\n  \n  plot_df_ooe$updown <- factor(plot_df_ooe$updown, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  p3 <- ggplot(plot_df_ooe, aes(x = updown, y = fc, fill = updown)) +\n    geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, show.legend = FALSE) + \n    geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n    theme_classic() + \n    stat_summary(\n      aes(group = updown), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    coord_cartesian(ylim = c(-3, 3)) +\n    scale_fill_manual(values = c(strong_red, \\grey30\\, strong_blue)) +\n    theme(\n      axis.title.x = element_blank(),\n      axis.title.y = element_text(\n        size = fontSizeM,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        size = fontSizeM,\n        angle = 45,      # Rotate x-axis labels 45 degrees\n        hjust = 1,       # Adjust horizontal justification\n        vjust = 1        # Adjust vertical justification\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) +labs(y = \\log2 fc of obs/exp\\)  +\n    geom_hline(yintercept = 0,\n               alpha = 1,\n               color = \\black\\,\n               size = lineThick*mmToLineUnit,\n               lineend = \\square\\) +\n    geom_hline(yintercept = c(-0.5, 0.5),\n               alpha = 0.5,\n               color = \\black\\,\n               size = lineThick*mmToLineUnit,\n               lineend = \\square\\, linetype = \\dashed\\)\n   \n  \n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch\n  fileName <- paste0(\\violin_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p3)\n  dev.off()  \n}\n\n\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_chromosight.tsv\\))\n\n\nplot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, \n                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,\n                                c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                  \\E-E\\, \\E-S\\, \\E-X\\,\n                                  \\S-S\\, \\S-X\\,\n                                  \\X-X\\),\n                                name = \\chromosight_score_all_dTAGvsDMSO\\,\n                                title = \\chromo_score_all_dTAGvsDMSO\\, figDir, commonLoopDir)\n```\n```"} -->\n\n```r\n```r\nplot_loop_scores_and_save_bedpe <- function(df, col_x, col_y, \n                                            col_x_ooe, col_y_ooe, pseudo_ooe = 0.01,\n                                            annoList,\n                                            name, title, figDir, loopDir,\n                                            diffCutoff = 0.2, density_n = 200,\n                                            xmin = -0.5, xmax = 1,\n                                            ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  col_x_ooe_q <- enquo(col_x_ooe)\n  col_y_ooe_q <- enquo(col_y_ooe)\n  \n  # Create a single, unified dataframe for plotting and saving as bedpe\n  df_temp <- df %>%\n    dplyr::filter(Anno_simple %in% annoList) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, x = !!col_x_q, y = !!col_y_q,\n                  x_ooe = !!col_x_ooe_q, y_ooe = !!col_y_ooe_q) %>%\n    dplyr::mutate(diff = y-x,\n                  density = get_density(x, y, n = density_n)) %>%\n    dplyr::mutate(updown = case_when(\n      diff > diffCutoff  ~ \\UP\\,\n      diff < -diffCutoff ~ \\DOWN\\,\n      TRUE               ~ \\NO\\))\n  \n  # Export as bedpe\n  bedpeUP <- df_temp %>% dplyr::filter(updown == \\UP\\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeUP, here(loopDir, paste0(name, \\_diffCutoff\\, diffCutoff, \\_UP.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n  bedpeNO <- df_temp %>% dplyr::filter(updown == \\NO\\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeNO, here(loopDir, paste0(name, \\_diffCutoff\\, diffCutoff, \\_NO.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n  bedpeDOWN <- df_temp %>% dplyr::filter(updown == \\DOWN\\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeDOWN, here(loopDir, paste0(name, \\_diffCutoff\\, diffCutoff, \\_DOWN.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n  \n  \n  plot_df <- df_temp %>%\n    dplyr::select(id, x, y, updown, density) %>%\n    arrange(density)\n  \n  plot_df$updown <- factor(plot_df$updown, c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  # Calculate a global density range to make scales comparable\n  density_limits <- range(plot_df$density, na.rm = TRUE)\n  \n  # ------ Scatterplot ------ \n  p1 <- ggplot(plot_df, aes(x = x, y = y)) +\n    # Layer 1: Plot \\NO\\ points with a grey scale\n    geom_point(data = . %>% filter(updown == \\NO\\) %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = \\grey85\\, high = \\grey30\\,\n      limits = density_limits, name = \\Density (NO)\\\n    ) +\n    \n    # Introduce a new scale for the \\UP\\ points\n    new_scale_color() +\n    # Layer 2: Plot \\UP\\ points with a red scale\n    geom_point(data = . %>% filter(updown == \\UP\\) %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = weak_red, high = strong_red, # Light to dark red\n      limits = density_limits, name = \\Density (UP)\\\n    ) +\n    \n    # Introduce a new scale for the \\DOWN\\ points\n    new_scale_color() +\n    # Layer 3: Plot \\DOWN\\ points with a blue scale\n    geom_point(data = . %>% filter(updown == \\DOWN\\) %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = weak_blue, high = strong_blue, # Light to dark blue\n      limits = density_limits, name = \\Density (DOWN)\\\n    ) +\n    \n    # Add annotations and theme elements\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    theme_classic() +\n    theme(\n      legend.position = \\none\\,\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n    ) +\n    labs(x = quo_name(col_x_q), y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch  \n  \n  fileName <- paste0(\\scatterplot_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = width, height = height)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      width = width, height = height, units = \\in\\, res = 600)\n  print(p1)\n  dev.off()\n  \n  # ------ Pie chart ------ \n  pie_df <- plot_df %>%\n    dplyr::count(updown) %>%\n    mutate(\n      pct   = n / sum(n) * 100,\n      label = paste0(updown, \\\\n\\, n, \\\\n(\\, round(pct, 1), \\%)\\)\n    )\n  \n  p2 <- ggplot(pie_df, aes(x = \\\\, y = n, fill = updown)) +\n    geom_col(color = \\white\\) +\n    coord_polar(theta = \\y\\) +\n    geom_text(\n      aes(label = label),\n      position = position_stack(vjust = 0.5),\n      size     = fontSizeM / 2\n    ) +\n    theme_void() + theme(legend.position = \\none\\) +\n    scale_fill_manual(values = c(\\UP\\ = strong_red, \\NO\\ = no_grey, \\DOWN\\ = strong_blue))\n  \n  fileName <- here(figDir, paste0(\\piechart_\\, name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(p2)\n  dev.off()\n  \n  \n  # ------ Violin plot of ooe ------ \n  plot_df_ooe <- df_temp %>%\n    dplyr::select(id, x_ooe, y_ooe, updown) %>%\n    dplyr::filter(!is.na(x_ooe), !is.na(y_ooe)) %>%\n    dplyr::mutate(\n      x_ooe = if_else(x_ooe == 0, pseudo_ooe, x_ooe),\n      y_ooe = if_else(y_ooe == 0, pseudo_ooe, y_ooe),\n      fc    = log2(y_ooe / x_ooe)\n    )\n  \n  plot_df_ooe$updown <- factor(plot_df_ooe$updown, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  p3 <- ggplot(plot_df_ooe, aes(x = updown, y = fc, fill = updown)) +\n    geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, show.legend = FALSE) + \n    geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n    theme_classic() + \n    stat_summary(\n      aes(group = updown), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    coord_cartesian(ylim = c(-3, 3)) +\n    scale_fill_manual(values = c(strong_red, \\grey30\\, strong_blue)) +\n    theme(\n      axis.title.x = element_blank(),\n      axis.title.y = element_text(\n        size = fontSizeM,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        size = fontSizeM,\n        angle = 45,      # Rotate x-axis labels 45 degrees\n        hjust = 1,       # Adjust horizontal justification\n        vjust = 1        # Adjust vertical justification\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) +labs(y = \\log2 fc of obs/exp\\)  +\n    geom_hline(yintercept = 0,\n               alpha = 1,\n               color = \\black\\,\n               size = lineThick*mmToLineUnit,\n               lineend = \\square\\) +\n    geom_hline(yintercept = c(-0.5, 0.5),\n               alpha = 0.5,\n               color = \\black\\,\n               size = lineThick*mmToLineUnit,\n               lineend = \\square\\, linetype = \\dashed\\)\n   \n  \n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch\n  fileName <- paste0(\\violin_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p3)\n  dev.off()  \n}\n\n\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_chromosight.tsv\\))\n\n\nplot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, \n                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,\n                                c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                  \\E-E\\, \\E-S\\, \\E-X\\,\n                                  \\S-S\\, \\S-X\\,\n                                  \\X-X\\),\n                                name = \\chromosight_score_all_dTAGvsDMSO\\,\n                                title = \\chromo_score_all_dTAGvsDMSO\\, figDir, commonLoopDir)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\nplot_loop_scores_and_save_bedpe <- function(df, col_x, col_y, \n                                            col_x_ooe, col_y_ooe, pseudo_ooe = 0.01,\n                                            annoList,\n                                            name, title, figDir, loopDir,\n                                            diffCutoff = 0.2, density_n = 200,\n                                            xmin = -0.5, xmax = 1,\n                                            ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  col_x_ooe_q <- enquo(col_x_ooe)\n  col_y_ooe_q <- enquo(col_y_ooe)\n  \n  # Create a single, unified dataframe for plotting and saving as bedpe\n  df_temp <- df %>%\n    dplyr::filter(Anno_simple %in% annoList) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, x = !!col_x_q, y = !!col_y_q,\n                  x_ooe = !!col_x_ooe_q, y_ooe = !!col_y_ooe_q) %>%\n    dplyr::mutate(diff = y-x,\n                  density = get_density(x, y, n = density_n)) %>%\n    dplyr::mutate(updown = case_when(\n      diff > diffCutoff  ~ \\UP\\,\n      diff < -diffCutoff ~ \\DOWN\\,\n      TRUE               ~ \\NO\\))\n  \n  # Export as bedpe\n  bedpeUP <- df_temp %>% dplyr::filter(updown == \\UP\\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeUP, here(loopDir, paste0(name, \\_diffCutoff\\, diffCutoff, \\_UP.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n  bedpeNO <- df_temp %>% dplyr::filter(updown == \\NO\\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeNO, here(loopDir, paste0(name, \\_diffCutoff\\, diffCutoff, \\_NO.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n  bedpeDOWN <- df_temp %>% dplyr::filter(updown == \\DOWN\\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)\n  fwrite(bedpeDOWN, here(loopDir, paste0(name, \\_diffCutoff\\, diffCutoff, \\_DOWN.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n  \n  \n  plot_df <- df_temp %>%\n    dplyr::select(id, x, y, updown, density) %>%\n    arrange(density)\n  \n  plot_df$updown <- factor(plot_df$updown, c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  # Calculate a global density range to make scales comparable\n  density_limits <- range(plot_df$density, na.rm = TRUE)\n  \n  # ------ Scatterplot ------ \n  p1 <- ggplot(plot_df, aes(x = x, y = y)) +\n    # Layer 1: Plot \\NO\\ points with a grey scale\n    geom_point(data = . %>% filter(updown == \\NO\\) %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = \\grey85\\, high = \\grey30\\,\n      limits = density_limits, name = \\Density (NO)\\\n    ) +\n    \n    # Introduce a new scale for the \\UP\\ points\n    new_scale_color() +\n    # Layer 2: Plot \\UP\\ points with a red scale\n    geom_point(data = . %>% filter(updown == \\UP\\) %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = weak_red, high = strong_red, # Light to dark red\n      limits = density_limits, name = \\Density (UP)\\\n    ) +\n    \n    # Introduce a new scale for the \\DOWN\\ points\n    new_scale_color() +\n    # Layer 3: Plot \\DOWN\\ points with a blue scale\n    geom_point(data = . %>% filter(updown == \\DOWN\\) %>% arrange(density),\n               aes(color = density), size = 0.1) +\n    scale_color_gradient(\n      low = weak_blue, high = strong_blue, # Light to dark blue\n      limits = density_limits, name = \\Density (DOWN)\\\n    ) +\n    \n    # Add annotations and theme elements\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    theme_classic() +\n    theme(\n      legend.position = \\none\\,\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n    ) +\n    labs(x = quo_name(col_x_q), y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch  \n  \n  fileName <- paste0(\\scatterplot_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = width, height = height)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      width = width, height = height, units = \\in\\, res = 600)\n  print(p1)\n  dev.off()\n  \n  # ------ Pie chart ------ \n  pie_df <- plot_df %>%\n    dplyr::count(updown) %>%\n    mutate(\n      pct   = n / sum(n) * 100,\n      label = paste0(updown, \\\\n\\, n, \\\\n(\\, round(pct, 1), \\%)\\)\n    )\n  \n  p2 <- ggplot(pie_df, aes(x = \\\\, y = n, fill = updown)) +\n    geom_col(color = \\white\\) +\n    coord_polar(theta = \\y\\) +\n    geom_text(\n      aes(label = label),\n      position = position_stack(vjust = 0.5),\n      size     = fontSizeM / 2\n    ) +\n    theme_void() + theme(legend.position = \\none\\) +\n    scale_fill_manual(values = c(\\UP\\ = strong_red, \\NO\\ = no_grey, \\DOWN\\ = strong_blue))\n  \n  fileName <- here(figDir, paste0(\\piechart_\\, name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(p2)\n  dev.off()\n  \n  \n  # ------ Violin plot of ooe ------ \n  plot_df_ooe <- df_temp %>%\n    dplyr::select(id, x_ooe, y_ooe, updown) %>%\n    dplyr::filter(!is.na(x_ooe), !is.na(y_ooe)) %>%\n    dplyr::mutate(\n      x_ooe = if_else(x_ooe == 0, pseudo_ooe, x_ooe),\n      y_ooe = if_else(y_ooe == 0, pseudo_ooe, y_ooe),\n      fc    = log2(y_ooe / x_ooe)\n    )\n  \n  plot_df_ooe$updown <- factor(plot_df_ooe$updown, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  p3 <- ggplot(plot_df_ooe, aes(x = updown, y = fc, fill = updown)) +\n    geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, show.legend = FALSE) + \n    geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n    theme_classic() + \n    stat_summary(\n      aes(group = updown), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    coord_cartesian(ylim = c(-3, 3)) +\n    scale_fill_manual(values = c(strong_red, \\grey30\\, strong_blue)) +\n    theme(\n      axis.title.x = element_blank(),\n      axis.title.y = element_text(\n        size = fontSizeM,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        size = fontSizeM,\n        angle = 45,      # Rotate x-axis labels 45 degrees\n        hjust = 1,       # Adjust horizontal justification\n        vjust = 1        # Adjust vertical justification\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) +labs(y = \\log2 fc of obs/exp\\)  +\n    geom_hline(yintercept = 0,\n               alpha = 1,\n               color = \\black\\,\n               size = lineThick*mmToLineUnit,\n               lineend = \\square\\) +\n    geom_hline(yintercept = c(-0.5, 0.5),\n               alpha = 0.5,\n               color = \\black\\,\n               size = lineThick*mmToLineUnit,\n               lineend = \\square\\, linetype = \\dashed\\)\n   \n  \n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch\n  fileName <- paste0(\\violin_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p3)\n  dev.off()  \n}\n\n\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_chromosight.tsv\\))\n\n\nplot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, \n                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,\n                                c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                  \\E-E\\, \\E-S\\, \\E-X\\,\n                                  \\S-S\\, \\S-X\\,\n                                  \\X-X\\),\n                                name = \\chromosight_score_all_dTAGvsDMSO\\,\n                                title = \\chromo_score_all_dTAGvsDMSO\\, figDir, commonLoopDir)\n```\n```"} -->

```r
```r
plot_loop_scores_and_save_bedpe <- function(df, col_x, col_y, 
                                            col_x_ooe, col_y_ooe, pseudo_ooe = 0.01,
                                            annoList,
                                            name, title, figDir, loopDir,
                                            diffCutoff = 0.2, density_n = 200,
                                            xmin = -0.5, xmax = 1,
                                            ymin = -0.5, ymax = 1) {
  col_x_q <- enquo(col_x)
  col_y_q <- enquo(col_y)
  
  col_x_ooe_q <- enquo(col_x_ooe)
  col_y_ooe_q <- enquo(col_y_ooe)
  
  # Create a single, unified dataframe for plotting and saving as bedpe
  df_temp <- df %>%
    dplyr::filter(Anno_simple %in% annoList) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, x = !!col_x_q, y = !!col_y_q,
                  x_ooe = !!col_x_ooe_q, y_ooe = !!col_y_ooe_q) %>%
    dplyr::mutate(diff = y-x,
                  density = get_density(x, y, n = density_n)) %>%
    dplyr::mutate(updown = case_when(
      diff > diffCutoff  ~ \UP\,
      diff < -diffCutoff ~ \DOWN\,
      TRUE               ~ \NO\))
  
  # Export as bedpe
  bedpeUP <- df_temp %>% dplyr::filter(updown == \UP\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)
  fwrite(bedpeUP, here(loopDir, paste0(name, \_diffCutoff\, diffCutoff, \_UP.bedpe\)), sep = \\t\, col.names = FALSE)
  bedpeNO <- df_temp %>% dplyr::filter(updown == \NO\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)
  fwrite(bedpeNO, here(loopDir, paste0(name, \_diffCutoff\, diffCutoff, \_NO.bedpe\)), sep = \\t\, col.names = FALSE)
  bedpeDOWN <- df_temp %>% dplyr::filter(updown == \DOWN\) %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)
  fwrite(bedpeDOWN, here(loopDir, paste0(name, \_diffCutoff\, diffCutoff, \_DOWN.bedpe\)), sep = \\t\, col.names = FALSE)
  
  
  plot_df <- df_temp %>%
    dplyr::select(id, x, y, updown, density) %>%
    arrange(density)
  
  plot_df$updown <- factor(plot_df$updown, c(\UP\, \NO\, \DOWN\))
  
  # Calculate a global density range to make scales comparable
  density_limits <- range(plot_df$density, na.rm = TRUE)
  
  # ------ Scatterplot ------ 
  p1 <- ggplot(plot_df, aes(x = x, y = y)) +
    # Layer 1: Plot \NO\ points with a grey scale
    geom_point(data = . %>% filter(updown == \NO\) %>% arrange(density),
               aes(color = density), size = 0.1) +
    scale_color_gradient(
      low = \grey85\, high = \grey30\,
      limits = density_limits, name = \Density (NO)\
    ) +
    
    # Introduce a new scale for the \UP\ points
    new_scale_color() +
    # Layer 2: Plot \UP\ points with a red scale
    geom_point(data = . %>% filter(updown == \UP\) %>% arrange(density),
               aes(color = density), size = 0.1) +
    scale_color_gradient(
      low = weak_red, high = strong_red, # Light to dark red
      limits = density_limits, name = \Density (UP)\
    ) +
    
    # Introduce a new scale for the \DOWN\ points
    new_scale_color() +
    # Layer 3: Plot \DOWN\ points with a blue scale
    geom_point(data = . %>% filter(updown == \DOWN\) %>% arrange(density),
               aes(color = density), size = 0.1) +
    scale_color_gradient(
      low = weak_blue, high = strong_blue, # Light to dark blue
      limits = density_limits, name = \Density (DOWN)\
    ) +
    
    # Add annotations and theme elements
    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    theme_classic() +
    theme(
      legend.position = \none\,
      plot.title = element_text(
        hjust = 0.5,
        size = fontSizeS,
        family = fontType
      ),
      axis.title = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.line = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
    ) +
    labs(x = quo_name(col_x_q), y = quo_name(col_y_q)) +
    ggtitle(title)
  
  width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.5)*mmToInch  
  
  fileName <- paste0(\scatterplot_\, name)
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = width, height = height)
  print(p1)
  dev.off()
  
  png(here(figDir, paste0(fileName, \.png\)), 
      width = width, height = height, units = \in\, res = 600)
  print(p1)
  dev.off()
  
  # ------ Pie chart ------ 
  pie_df <- plot_df %>%
    dplyr::count(updown) %>%
    mutate(
      pct   = n / sum(n) * 100,
      label = paste0(updown, \\n\, n, \\n(\, round(pct, 1), \%)\)
    )
  
  p2 <- ggplot(pie_df, aes(x = \\, y = n, fill = updown)) +
    geom_col(color = \white\) +
    coord_polar(theta = \y\) +
    geom_text(
      aes(label = label),
      position = position_stack(vjust = 0.5),
      size     = fontSizeM / 2
    ) +
    theme_void() + theme(legend.position = \none\) +
    scale_fill_manual(values = c(\UP\ = strong_red, \NO\ = no_grey, \DOWN\ = strong_blue))
  
  fileName <- here(figDir, paste0(\piechart_\, name))
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  svglite(paste0(fileName, \.svg\), width = width, height = height)
  print(p2)
  dev.off()
  
  
  # ------ Violin plot of ooe ------ 
  plot_df_ooe <- df_temp %>%
    dplyr::select(id, x_ooe, y_ooe, updown) %>%
    dplyr::filter(!is.na(x_ooe), !is.na(y_ooe)) %>%
    dplyr::mutate(
      x_ooe = if_else(x_ooe == 0, pseudo_ooe, x_ooe),
      y_ooe = if_else(y_ooe == 0, pseudo_ooe, y_ooe),
      fc    = log2(y_ooe / x_ooe)
    )
  
  plot_df_ooe$updown <- factor(plot_df_ooe$updown, levels = c(\UP\, \NO\, \DOWN\))
  
  p3 <- ggplot(plot_df_ooe, aes(x = updown, y = fc, fill = updown)) +
    geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, show.legend = FALSE) + 
    geom_boxplot(width = 0.3, color = \black\,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\,
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
    theme_classic() + 
    stat_summary(
      aes(group = updown), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) +
    coord_cartesian(ylim = c(-3, 3)) +
    scale_fill_manual(values = c(strong_red, \grey30\, strong_blue)) +
    theme(
      axis.title.x = element_blank(),
      axis.title.y = element_text(
        size = fontSizeM,
        family = fontType,
        color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.text.x = element_text(
        size = fontSizeM,
        angle = 45,      # Rotate x-axis labels 45 degrees
        hjust = 1,       # Adjust horizontal justification
        vjust = 1        # Adjust vertical justification
      ),
      axis.line = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    ) +labs(y = \log2 fc of obs/exp\)  +
    geom_hline(yintercept = 0,
               alpha = 1,
               color = \black\,
               size = lineThick*mmToLineUnit,
               lineend = \square\) +
    geom_hline(yintercept = c(-0.5, 0.5),
               alpha = 0.5,
               color = \black\,
               size = lineThick*mmToLineUnit,
               lineend = \square\, linetype = \dashed\)
   
  
  width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.5)*mmToInch
  fileName <- paste0(\violin_\, name)
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p3)
  dev.off()  
}


commonLoopDir <- here(\../data/loop_analysis\)
figDir <- here(\../figure/loop_analysis\)
dir.create(figDir, showWarnings = FALSE, recursive = TRUE)

data <- fread(here(commonLoopDir, \loopScore_chromosight.tsv\))


plot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, 
                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,
                                c(\P-P\, \P-E\, \P-S\, \P-X\,
                                  \E-E\, \E-S\, \E-X\,
                                  \S-S\, \S-X\,
                                  \X-X\),
                                name = \chromosight_score_all_dTAGvsDMSO\,
                                title = \chromo_score_all_dTAGvsDMSO\, figDir, commonLoopDir)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiV2FybmluZyA6RHVwbGljYXRlZCBhZXN0aGV0aWNzIGFmdGVyIG5hbWUgc3RhbmRhcmRpc2F0aW9uOiBjb2xvdXJcbldhcm5pbmcgOkR1cGxpY2F0ZWQgYWVzdGhldGljcyBhZnRlciBuYW1lIHN0YW5kYXJkaXNhdGlvbjogY29sb3VyXG5XYXJuaW5nIDpEdXBsaWNhdGVkIGFlc3RoZXRpY3MgYWZ0ZXIgbmFtZSBzdGFuZGFyZGlzYXRpb246IGNvbG91clxuV2FybmluZyA6RHVwbGljYXRlZCBhZXN0aGV0aWNzIGFmdGVyIG5hbWUgc3RhbmRhcmRpc2F0aW9uOiBjb2xvdXJcbldhcm5pbmcgOkR1cGxpY2F0ZWQgYWVzdGhldGljcyBhZnRlciBuYW1lIHN0YW5kYXJkaXNhdGlvbjogY29sb3VyXG5udWxsIGRldmljZSBcbiAgICAgICAgICAxIFxuIn0= -->

```
Warning :Duplicated aesthetics after name standardisation: colour
Warning :Duplicated aesthetics after name standardisation: colour
Warning :Duplicated aesthetics after name standardisation: colour
Warning :Duplicated aesthetics after name standardisation: colour
Warning :Duplicated aesthetics after name standardisation: colour
null device 
          1 
```



<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

## [2] Visualizing loop annotation
### [FIG] Loop Anno pie chart

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVYRzVrY21GM1gyUnZiblYwSUR3dElHWjFibU4wYVc5dUtHeHZiM0FzSUc1aGJXVXBlMXh1SUNCdUlEd3RJRzV5YjNjb2JHOXZjQ2xjYmlBZ2RHVnRjQ0E4TFNCc2IyOXdJQ1UrSlNCa2NHeDVjam82YzJWc1pXTjBLR2xrTENCQmJtNXZLU0FsUGlWY2JpQWdJQ0JrY0d4NWNqbzZiWFYwWVhSbEtFRnVibTlIY205MWNDQTlJR05oYzJWZmQyaGxiaWhjYmlBZ0lDQWdJRUZ1Ym04Z0pXbHVKU0JqS0Z3aVVDMVFYQ0lzSUZ3aVVDMUZYQ0lzSUZ3aVJTMUZYQ0lwSUg0Z1hDSnlaV2RmY21WblhDSXNYRzRnSUNBZ0lDQkJibTV2SUNWcGJpVWdZeWhjSWxBdFUxQmNJaXdnWENKUUxWTkZYQ0lzSUZ3aVJTMVRVRndpTENCY0lrVXRVMFZjSWlrZ2ZpQmNJbkpsWjE5emRISlNaV2RjSWl4Y2JpQWdJQ0FnSUVGdWJtOGdKV2x1SlNCaktGd2lVQzFUWENJc0lGd2lSUzFUWENJcElINGdYQ0p5WldkZmMzUnlYQ0lzWEc0Z0lDQWdJQ0JCYm01dklDVnBiaVVnWXloY0lsTlFMVk5RWENJc0lGd2lVMUF0VTBWY0lpd2dYQ0pUUlMxVFJWd2lLU0IrSUZ3aWMzUnlVbVZuWDNOMGNsSmxaMXdpTEZ4dUlDQWdJQ0FnUVc1dWJ5QWxhVzRsSUdNb1hDSlRVQzFUWENJc0lGd2lVMFV0VTF3aUtTQitJRndpYzNSeVVtVm5YM04wY2x3aUxGeHVJQ0FnSUNBZ1FXNXVieUFsYVc0bElHTW9YQ0pRTFZoY0lpd2dYQ0pGTFZoY0lpa2dmaUJjSW5KbFoxOXZkR2hsY2x3aUxGeHVJQ0FnSUNBZ1FXNXVieUFsYVc0bElHTW9YQ0pUVUMxWVhDSXNJRndpVTBVdFdGd2lLU0IrSUZ3aWMzUnlVbVZuWDI5MGFHVnlYQ0lzWEc0Z0lDQWdJQ0JCYm01dklDVnBiaVVnWXloY0lsTXRVMXdpTENCY0lsTXRXRndpS1NCK0lGd2ljM1J5WENJc1hHNGdJQ0FnSUNCQmJtNXZJQ1ZwYmlVZ1l5aGNJbGd0V0Z3aUtTQitJRndpYjNSb1pYSmNJaXhjYmlBZ0lDQWdJRlJTVlVVZ2ZpQk9RVnh1SUNBZ0lDa3BYRzRnSUZ4dUlDQmNiaUFnZEdWdGNDUkJibTV2UjNKdmRYQWdQQzBnWm1GamRHOXlLSFJsYlhBa1FXNXViMGR5YjNWd0xDQnNaWFpsYkhNZ1BTQmpLRndpY21WblgzSmxaMXdpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hDSnlaV2RmYzNSeVVtVm5YQ0lzSUZ3aWNtVm5YM04wY2x3aUxGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p6ZEhKU1pXZGZjM1J5VW1WblhDSXNJRndpYzNSeVVtVm5YM04wY2x3aUxGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p5WldkZmIzUm9aWEpjSWl3Z1hDSnpkSEpTWldkZmIzUm9aWEpjSWl3Z1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbk4wY2x3aUxDQmNJbTkwYUdWeVhDSXBLVnh1SUNCY2JpQWdYRzRnSUhCcFpWOWtaaUE4TFNCMFpXMXdJQ1UrSlZ4dUlDQWdJR0Z6WDNScFltSnNaU2dwSUNVK0pTQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0l5QnBaaUIwWlcxd0lIZGhjeUJoSUd4cGMzUXNJSFJvYVhNZ2QybHNiQ0JsY25KdmNpQmxZWEpzZVZ4dUlDQWdJR2R5YjNWd1gySjVLRUZ1Ym05SGNtOTFjQ2tnSlQ0bFhHNGdJQ0FnYzNWdGJXRnlhWE5sS0c0Z1BTQnVLQ2tzSUM1bmNtOTFjSE1nUFNCY0ltUnliM0JjSWlrZ0pUNGxYRzRnSUNBZ2JYVjBZWFJsS0d4aFltVnNJRDBnY0dGemRHVXdLRUZ1Ym05SGNtOTFjQ3dnWENKY1hHNG9YQ0lzSUc0c0lGd2lLVndpS1NsY2JpQWdYRzRnSUhBZ1BDMGdaMmR3Ykc5MEtIQnBaVjlrWml3Z1lXVnpLSGdnUFNBeUxDQjVJRDBnYml3Z1ptbHNiQ0E5SUVGdWJtOUhjbTkxY0NrcElDdGNiaUFnSUNCblpXOXRYMk52YkNoamIyeHZjaUE5SUZ3aVlteGhZMnRjSWl3Z2QybGtkR2dnUFNBeEtTQXJYRzRnSUNBZ1kyOXZjbVJmY0c5c1lYSW9kR2hsZEdFZ1BTQmNJbmxjSWlrZ0sxeHVJQ0FnSUhoc2FXMG9NQzQxTENBeUxqVXBJQ3NnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJeUE4TFNCamNtVmhkR1Z6SUhSb1pTRGlnSnhvYjJ4bDRvQ2RJR0o1SUdOc2FYQndhVzVuSUhSb1pTQmpaVzUwWlhKY2JpQWdJQ0JuWlc5dFgzUmxlSFFvWVdWektHeGhZbVZzSUQwZ2JHRmlaV3dwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0J3YjNOcGRHbHZiaUE5SUhCdmMybDBhVzl1WDNOMFlXTnJLSFpxZFhOMElEMGdNQzQxS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnYzJsNlpTQTlJRE1wSUN0Y2JpQWdJQ0IwYUdWdFpWOTJiMmxrS0NrZ0sxeHVJQ0FnSUhSb1pXMWxLR3hsWjJWdVpDNXdiM05wZEdsdmJpQTlJRndpYm05dVpWd2lMRnh1SUNBZ0lDQWdJQ0FnSUhCc2IzUXVkR2wwYkdVZ1BTQmxiR1Z0Wlc1MFgzUmxlSFFvYUdwMWMzUWdQU0F3TGpVcFhHNGdJQ0FnS1NBclhHNGdJQ0FnWjJkMGFYUnNaU2h3WVhOMFpUQW9ibUZ0WlN3Z1hDSmNYRzVjSWl3Z2Jpd2dYQ0lnYkc5dmNITmNJaWtwWEc0Z0lGeHVJQ0JjYmlBZ2QybGtkR2dnUFNBelhHNGdJR2hsYVdkb2RDQTlJRE5jYmlBZ2MzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lIQmhjM1JsTUNoY0ltUnZiblYwWDJ4dmIzQkJibTV2WDF3aUxDQnVZVzFsTENCY0lpNXpkbWRjSWlrcExGeHVJQ0FnSUNBZ0lDQWdJSGRwWkhSb0lEMGdkMmxrZEdnc0lHaGxhV2RvZENBOUlHaGxhV2RvZENsY2JpQWdjR3h2ZENod0tWeHVJQ0JrWlhZdWIyWm1LQ2xjYm4xY2JseHVaSEpoZDE5a2IyNTFkQ2hzYjI5d1gyTm9jbTl0Ynl3Z1hDSmphSEp2Ylc5emFXZG9kRndpS1Z4dVpISmhkMTlrYjI1MWRDaHNiMjl3WDJocFkyUmpjQ3dnWENKb2FXTmtZM0JjSWlsY2JtUnlZWGRmWkc5dWRYUW9iRzl2Y0Y5SVlXNXpaVzRzSUZ3aVNHRnVjMlZ1WENJcFhHNWNibUJnWUNKOSAtLT5cblxuYGBgclxuXG5kcmF3X2RvbnV0IDwtIGZ1bmN0aW9uKGxvb3AsIG5hbWUpe1xuICBuIDwtIG5yb3cobG9vcClcbiAgdGVtcCA8LSBsb29wICU+JSBkcGx5cjo6c2VsZWN0KGlkLCBBbm5vKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKEFubm9Hcm91cCA9IGNhc2Vfd2hlbihcbiAgICAgIEFubm8gJWluJSBjKFwiUC1QXCIsIFwiUC1FXCIsIFwiRS1FXCIpIH4gXCJyZWdfcmVnXCIsXG4gICAgICBBbm5vICVpbiUgYyhcIlAtU1BcIiwgXCJQLVNFXCIsIFwiRS1TUFwiLCBcIkUtU0VcIikgfiBcInJlZ19zdHJSZWdcIixcbiAgICAgIEFubm8gJWluJSBjKFwiUC1TXCIsIFwiRS1TXCIpIH4gXCJyZWdfc3RyXCIsXG4gICAgICBBbm5vICVpbiUgYyhcIlNQLVNQXCIsIFwiU1AtU0VcIiwgXCJTRS1TRVwiKSB+IFwic3RyUmVnX3N0clJlZ1wiLFxuICAgICAgQW5ubyAlaW4lIGMoXCJTUC1TXCIsIFwiU0UtU1wiKSB+IFwic3RyUmVnX3N0clwiLFxuICAgICAgQW5ubyAlaW4lIGMoXCJQLVhcIiwgXCJFLVhcIikgfiBcInJlZ19vdGhlclwiLFxuICAgICAgQW5ubyAlaW4lIGMoXCJTUC1YXCIsIFwiU0UtWFwiKSB+IFwic3RyUmVnX290aGVyXCIsXG4gICAgICBBbm5vICVpbiUgYyhcIlMtU1wiLCBcIlMtWFwiKSB+IFwic3RyXCIsXG4gICAgICBBbm5vICVpbiUgYyhcIlgtWFwiKSB+IFwib3RoZXJcIixcbiAgICAgIFRSVUUgfiBOQVxuICAgICkpXG4gIFxuICBcbiAgdGVtcCRBbm5vR3JvdXAgPC0gZmFjdG9yKHRlbXAkQW5ub0dyb3VwLCBsZXZlbHMgPSBjKFwicmVnX3JlZ1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJyZWdfc3RyUmVnXCIsIFwicmVnX3N0clwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJzdHJSZWdfc3RyUmVnXCIsIFwic3RyUmVnX3N0clwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJyZWdfb3RoZXJcIiwgXCJzdHJSZWdfb3RoZXJcIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInN0clwiLCBcIm90aGVyXCIpKVxuICBcbiAgXG4gIHBpZV9kZiA8LSB0ZW1wICU+JVxuICAgIGFzX3RpYmJsZSgpICU+JSAgICAgICAgICAgICAgICAgICAgICAgICAgIyBpZiB0ZW1wIHdhcyBhIGxpc3QsIHRoaXMgd2lsbCBlcnJvciBlYXJseVxuICAgIGdyb3VwX2J5KEFubm9Hcm91cCkgJT4lXG4gICAgc3VtbWFyaXNlKG4gPSBuKCksIC5ncm91cHMgPSBcImRyb3BcIikgJT4lXG4gICAgbXV0YXRlKGxhYmVsID0gcGFzdGUwKEFubm9Hcm91cCwgXCJcXG4oXCIsIG4sIFwiKVwiKSlcbiAgXG4gIHAgPC0gZ2dwbG90KHBpZV9kZiwgYWVzKHggPSAyLCB5ID0gbiwgZmlsbCA9IEFubm9Hcm91cCkpICtcbiAgICBnZW9tX2NvbChjb2xvciA9IFwiYmxhY2tcIiwgd2lkdGggPSAxKSArXG4gICAgY29vcmRfcG9sYXIodGhldGEgPSBcInlcIikgK1xuICAgIHhsaW0oMC41LCAyLjUpICsgICAgICAgICAgICAgICAgIyA8LSBjcmVhdGVzIHRoZSDigJxob2xl4oCdIGJ5IGNsaXBwaW5nIHRoZSBjZW50ZXJcbiAgICBnZW9tX3RleHQoYWVzKGxhYmVsID0gbGFiZWwpLFxuICAgICAgICAgICAgICBwb3NpdGlvbiA9IHBvc2l0aW9uX3N0YWNrKHZqdXN0ID0gMC41KSxcbiAgICAgICAgICAgICAgc2l6ZSA9IDMpICtcbiAgICB0aGVtZV92b2lkKCkgK1xuICAgIHRoZW1lKGxlZ2VuZC5wb3NpdGlvbiA9IFwibm9uZVwiLFxuICAgICAgICAgIHBsb3QudGl0bGUgPSBlbGVtZW50X3RleHQoaGp1c3QgPSAwLjUpXG4gICAgKSArXG4gICAgZ2d0aXRsZShwYXN0ZTAobmFtZSwgXCJcXG5cIiwgbiwgXCIgbG9vcHNcIikpXG4gIFxuICBcbiAgd2lkdGggPSAzXG4gIGhlaWdodCA9IDNcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpcixcbiAgICAgICAgICAgICAgIHBhc3RlMChcImRvbnV0X2xvb3BBbm5vX1wiLCBuYW1lLCBcIi5zdmdcIikpLFxuICAgICAgICAgIHdpZHRoID0gd2lkdGgsIGhlaWdodCA9IGhlaWdodClcbiAgcGxvdChwKVxuICBkZXYub2ZmKClcbn1cblxuZHJhd19kb251dChsb29wX2Nocm9tbywgXCJjaHJvbW9zaWdodFwiKVxuZHJhd19kb251dChsb29wX2hpY2RjcCwgXCJoaWNkY3BcIilcbmRyYXdfZG9udXQobG9vcF9IYW5zZW4sIFwiSGFuc2VuXCIpXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5kcmF3X2RvbnV0IDwtIGZ1bmN0aW9uKGxvb3AsIG5hbWUpe1xuICBuIDwtIG5yb3cobG9vcClcbiAgdGVtcCA8LSBsb29wICU+JSBkcGx5cjo6c2VsZWN0KGlkLCBBbm5vKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKEFubm9Hcm91cCA9IGNhc2Vfd2hlbihcbiAgICAgIEFubm8gJWluJSBjKFwiUC1QXCIsIFwiUC1FXCIsIFwiRS1FXCIpIH4gXCJyZWdfcmVnXCIsXG4gICAgICBBbm5vICVpbiUgYyhcIlAtU1BcIiwgXCJQLVNFXCIsIFwiRS1TUFwiLCBcIkUtU0VcIikgfiBcInJlZ19zdHJSZWdcIixcbiAgICAgIEFubm8gJWluJSBjKFwiUC1TXCIsIFwiRS1TXCIpIH4gXCJyZWdfc3RyXCIsXG4gICAgICBBbm5vICVpbiUgYyhcIlNQLVNQXCIsIFwiU1AtU0VcIiwgXCJTRS1TRVwiKSB+IFwic3RyUmVnX3N0clJlZ1wiLFxuICAgICAgQW5ubyAlaW4lIGMoXCJTUC1TXCIsIFwiU0UtU1wiKSB+IFwic3RyUmVnX3N0clwiLFxuICAgICAgQW5ubyAlaW4lIGMoXCJQLVhcIiwgXCJFLVhcIikgfiBcInJlZ19vdGhlclwiLFxuICAgICAgQW5ubyAlaW4lIGMoXCJTUC1YXCIsIFwiU0UtWFwiKSB+IFwic3RyUmVnX290aGVyXCIsXG4gICAgICBBbm5vICVpbiUgYyhcIlMtU1wiLCBcIlMtWFwiKSB+IFwic3RyXCIsXG4gICAgICBBbm5vICVpbiUgYyhcIlgtWFwiKSB+IFwib3RoZXJcIixcbiAgICAgIFRSVUUgfiBOQVxuICAgICkpXG4gIFxuICBcbiAgdGVtcCRBbm5vR3JvdXAgPC0gZmFjdG9yKHRlbXAkQW5ub0dyb3VwLCBsZXZlbHMgPSBjKFwicmVnX3JlZ1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJyZWdfc3RyUmVnXCIsIFwicmVnX3N0clwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJzdHJSZWdfc3RyUmVnXCIsIFwic3RyUmVnX3N0clwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJyZWdfb3RoZXJcIiwgXCJzdHJSZWdfb3RoZXJcIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInN0clwiLCBcIm90aGVyXCIpKVxuICBcbiAgXG4gIHBpZV9kZiA8LSB0ZW1wICU+JVxuICAgIGFzX3RpYmJsZSgpICU+JSAgICAgICAgICAgICAgICAgICAgICAgICAgIyBpZiB0ZW1wIHdhcyBhIGxpc3QsIHRoaXMgd2lsbCBlcnJvciBlYXJseVxuICAgIGdyb3VwX2J5KEFubm9Hcm91cCkgJT4lXG4gICAgc3VtbWFyaXNlKG4gPSBuKCksIC5ncm91cHMgPSBcImRyb3BcIikgJT4lXG4gICAgbXV0YXRlKGxhYmVsID0gcGFzdGUwKEFubm9Hcm91cCwgXCJcXG4oXCIsIG4sIFwiKVwiKSlcbiAgXG4gIHAgPC0gZ2dwbG90KHBpZV9kZiwgYWVzKHggPSAyLCB5ID0gbiwgZmlsbCA9IEFubm9Hcm91cCkpICtcbiAgICBnZW9tX2NvbChjb2xvciA9IFwiYmxhY2tcIiwgd2lkdGggPSAxKSArXG4gICAgY29vcmRfcG9sYXIodGhldGEgPSBcInlcIikgK1xuICAgIHhsaW0oMC41LCAyLjUpICsgICAgICAgICAgICAgICAgIyA8LSBjcmVhdGVzIHRoZSDigJxob2xl4oCdIGJ5IGNsaXBwaW5nIHRoZSBjZW50ZXJcbiAgICBnZW9tX3RleHQoYWVzKGxhYmVsID0gbGFiZWwpLFxuICAgICAgICAgICAgICBwb3NpdGlvbiA9IHBvc2l0aW9uX3N0YWNrKHZqdXN0ID0gMC41KSxcbiAgICAgICAgICAgICAgc2l6ZSA9IDMpICtcbiAgICB0aGVtZV92b2lkKCkgK1xuICAgIHRoZW1lKGxlZ2VuZC5wb3NpdGlvbiA9IFwibm9uZVwiLFxuICAgICAgICAgIHBsb3QudGl0bGUgPSBlbGVtZW50X3RleHQoaGp1c3QgPSAwLjUpXG4gICAgKSArXG4gICAgZ2d0aXRsZShwYXN0ZTAobmFtZSwgXCJcXG5cIiwgbiwgXCIgbG9vcHNcIikpXG4gIFxuICBcbiAgd2lkdGggPSAzXG4gIGhlaWdodCA9IDNcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpcixcbiAgICAgICAgICAgICAgIHBhc3RlMChcImRvbnV0X2xvb3BBbm5vX1wiLCBuYW1lLCBcIi5zdmdcIikpLFxuICAgICAgICAgIHdpZHRoID0gd2lkdGgsIGhlaWdodCA9IGhlaWdodClcbiAgcGxvdChwKVxuICBkZXYub2ZmKClcbn1cblxuZHJhd19kb251dChsb29wX2Nocm9tbywgXCJjaHJvbW9zaWdodFwiKVxuZHJhd19kb251dChsb29wX2hpY2RjcCwgXCJoaWNkY3BcIilcbmRyYXdfZG9udXQobG9vcF9IYW5zZW4sIFwiSGFuc2VuXCIpXG5cbmBgYCJ9 -->

```r

draw_donut <- function(loop, name){
  n <- nrow(loop)
  temp <- loop %>% dplyr::select(id, Anno) %>%
    dplyr::mutate(AnnoGroup = case_when(
      Anno %in% c("P-P", "P-E", "E-E") ~ "reg_reg",
      Anno %in% c("P-SP", "P-SE", "E-SP", "E-SE") ~ "reg_strReg",
      Anno %in% c("P-S", "E-S") ~ "reg_str",
      Anno %in% c("SP-SP", "SP-SE", "SE-SE") ~ "strReg_strReg",
      Anno %in% c("SP-S", "SE-S") ~ "strReg_str",
      Anno %in% c("P-X", "E-X") ~ "reg_other",
      Anno %in% c("SP-X", "SE-X") ~ "strReg_other",
      Anno %in% c("S-S", "S-X") ~ "str",
      Anno %in% c("X-X") ~ "other",
      TRUE ~ NA
    ))
  
  
  temp$AnnoGroup <- factor(temp$AnnoGroup, levels = c("reg_reg",
                                                      "reg_strReg", "reg_str",
                                                      "strReg_strReg", "strReg_str",
                                                      "reg_other", "strReg_other", 
                                                      "str", "other"))
  
  
  pie_df <- temp %>%
    as_tibble() %>%                          # if temp was a list, this will error early
    group_by(AnnoGroup) %>%
    summarise(n = n(), .groups = "drop") %>%
    mutate(label = paste0(AnnoGroup, "\n(", n, ")"))
  
  p <- ggplot(pie_df, aes(x = 2, y = n, fill = AnnoGroup)) +
    geom_col(color = "black", width = 1) +
    coord_polar(theta = "y") +
    xlim(0.5, 2.5) +                # <- creates the “hole” by clipping the center
    geom_text(aes(label = label),
              position = position_stack(vjust = 0.5),
              size = 3) +
    theme_void() +
    theme(legend.position = "none",
          plot.title = element_text(hjust = 0.5)
    ) +
    ggtitle(paste0(name, "\n", n, " loops"))
  
  
  width = 3
  height = 3
  svglite(here(figDir,
               paste0("donut_loopAnno_", name, ".svg")),
          width = width, height = height)
  plot(p)
  dev.off()
}

draw_donut(loop_chromo, "chromosight")
draw_donut(loop_hicdcp, "hicdcp")
draw_donut(loop_Hansen, "Hansen")

```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

## [3] Loop analysis
### Chromosight
#### [FIG] Scatterplot

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVYRzV3Ykc5MFgyeHZiM0JmYzJOdmNtVnpYMkZ1WkY5ellYWmxYMkpsWkhCbEtHUmhkR0VzSUhOamIzSmxYMFJOVTA4c0lITmpiM0psWDJSVVFVY3NJRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnZiMlZmUkUxVFR5d2diMjlsWDJSVVFVY3NJSEJ6WlhWa2IxOXZiMlVnUFNBd0xqQXhMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmpLRndpVUMxUVhDSXNJRndpVUMxRlhDSXNJRndpUlMxRlhDSXBMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnVZVzFsSUQwZ1hDSmphSEp2Ylc5emFXZG9kRjl6WTI5eVpWOWpiMjF3YkdWNFgzSmxaMTlrVkVGSGRuTkVUVk5QWENJc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUhScGRHeGxJRDBnWENKamFISnZiVzlmYzJOdmNtVmZZMjl0Y0d4bGVGOXlaV2RmWkZSQlIzWnpSRTFUVDF3aUxDQm1hV2RFYVhJc0lHTnZiVzF2Ymt4dmIzQkVhWElzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR0Z1Ym05ZlkyOXNJRDBnWENKQmJtNXZYQ0lwWEc1Y2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5cbnBsb3RfbG9vcF9zY29yZXNfYW5kX3NhdmVfYmVkcGUoZGF0YSwgc2NvcmVfRE1TTywgc2NvcmVfZFRBRywgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG9vZV9ETVNPLCBvb2VfZFRBRywgcHNldWRvX29vZSA9IDAuMDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGMoXCJQLVBcIiwgXCJQLUVcIiwgXCJFLUVcIiksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5hbWUgPSBcImNocm9tb3NpZ2h0X3Njb3JlX2NvbXBsZXhfcmVnX2RUQUd2c0RNU09cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGl0bGUgPSBcImNocm9tb19zY29yZV9jb21wbGV4X3JlZ19kVEFHdnNETVNPXCIsIGZpZ0RpciwgY29tbW9uTG9vcERpcixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYW5ub19jb2wgPSBcIkFubm9cIilcblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5wbG90X2xvb3Bfc2NvcmVzX2FuZF9zYXZlX2JlZHBlKGRhdGEsIHNjb3JlX0RNU08sIHNjb3JlX2RUQUcsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBvb2VfRE1TTywgb29lX2RUQUcsIHBzZXVkb19vb2UgPSAwLjAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjKFwiUC1QXCIsIFwiUC1FXCIsIFwiRS1FXCIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBuYW1lID0gXCJjaHJvbW9zaWdodF9zY29yZV9jb21wbGV4X3JlZ19kVEFHdnNETVNPXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRpdGxlID0gXCJjaHJvbW9fc2NvcmVfY29tcGxleF9yZWdfZFRBR3ZzRE1TT1wiLCBmaWdEaXIsIGNvbW1vbkxvb3BEaXIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9fY29sID0gXCJBbm5vXCIpXG5cbmBgYCJ9 -->

```r

plot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, 
                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,
                                c("P-P", "P-E", "E-E"),
                                name = "chromosight_score_complex_reg_dTAGvsDMSO",
                                title = "chromo_score_complex_reg_dTAGvsDMSO", figDir, commonLoopDir,
                                anno_col = "Anno")

```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoibnVsbCBkZXZpY2UgXG4gICAgICAgICAgMSBcbiJ9 -->

```
null device 
          1 
```



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjR3h2ZEY5c2IyOXdYM05qYjNKbGMxOWhibVJmYzJGMlpWOWlaV1J3WlNoa1lYUmhMQ0J6WTI5eVpWOUVUVk5QTENCelkyOXlaVjlrVkVGSExDQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2IyOWxYMFJOVTA4c0lHOXZaVjlrVkVGSExDQndjMlYxWkc5ZmIyOWxJRDBnTUM0d01TeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1l5aGNJbE10VTF3aUxDQmNJbE10V0Z3aUtTeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JtRnRaU0E5SUZ3aVkyaHliMjF2YzJsbmFIUmZjMk52Y21WZlkyOXRjR3hsZUY5emRISmZaRlJCUjNaelJFMVRUMXdpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0IwYVhSc1pTQTlJRndpWTJoeWIyMXZYM05qYjNKbFgyTnZiWEJzWlhoZmMzUnlYMlJVUVVkMmMwUk5VMDljSWl3Z1ptbG5SR2x5TENCamIyMXRiMjVNYjI5d1JHbHlMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmhibTV2WDJOdmJDQTlJRndpUVc1dWIxd2lLVnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbnBsb3RfbG9vcF9zY29yZXNfYW5kX3NhdmVfYmVkcGUoZGF0YSwgc2NvcmVfRE1TTywgc2NvcmVfZFRBRywgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG9vZV9ETVNPLCBvb2VfZFRBRywgcHNldWRvX29vZSA9IDAuMDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGMoXCJTLVNcIiwgXCJTLVhcIiksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5hbWUgPSBcImNocm9tb3NpZ2h0X3Njb3JlX2NvbXBsZXhfc3RyX2RUQUd2c0RNU09cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGl0bGUgPSBcImNocm9tb19zY29yZV9jb21wbGV4X3N0cl9kVEFHdnNETVNPXCIsIGZpZ0RpciwgY29tbW9uTG9vcERpcixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYW5ub19jb2wgPSBcIkFubm9cIilcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxucGxvdF9sb29wX3Njb3Jlc19hbmRfc2F2ZV9iZWRwZShkYXRhLCBzY29yZV9ETVNPLCBzY29yZV9kVEFHLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgb29lX0RNU08sIG9vZV9kVEFHLCBwc2V1ZG9fb29lID0gMC4wMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYyhcIlMtU1wiLCBcIlMtWFwiKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbmFtZSA9IFwiY2hyb21vc2lnaHRfc2NvcmVfY29tcGxleF9zdHJfZFRBR3ZzRE1TT1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aXRsZSA9IFwiY2hyb21vX3Njb3JlX2NvbXBsZXhfc3RyX2RUQUd2c0RNU09cIiwgZmlnRGlyLCBjb21tb25Mb29wRGlyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vX2NvbCA9IFwiQW5ub1wiKVxuYGBgIn0= -->

```r
plot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, 
                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,
                                c("S-S", "S-X"),
                                name = "chromosight_score_complex_str_dTAGvsDMSO",
                                title = "chromo_score_complex_str_dTAGvsDMSO", figDir, commonLoopDir,
                                anno_col = "Anno")
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoibnVsbCBkZXZpY2UgXG4gICAgICAgICAgMSBcbiJ9 -->

```
null device 
          1 
```



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjR3h2ZEY5c2IyOXdYM05qYjNKbGMxOWhibVJmYzJGMlpWOWlaV1J3WlNoa1lYUmhMQ0J6WTI5eVpWOUVUVk5QTENCelkyOXlaVjlrVkVGSExDQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2IyOWxYMFJOVTA4c0lHOXZaVjlrVkVGSExDQndjMlYxWkc5ZmIyOWxJRDBnTUM0d01TeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1l5aGNJbE10VTF3aUtTeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JtRnRaU0E5SUZ3aVkyaHliMjF2YzJsbmFIUmZjMk52Y21WZlkyOXRjR3hsZUY5emRISXlYMlJVUVVkMmMwUk5VMDljSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnZEdsMGJHVWdQU0JjSW1Ob2NtOXRiMTl6WTI5eVpWOWpiMjF3YkdWNFgzTjBjakpmWDJSVVFVZDJjMFJOVTA5Y0lpd2dabWxuUkdseUxDQmpiMjF0YjI1TWIyOXdSR2x5TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JoYm01dlgyTnZiQ0E5SUZ3aVFXNXViMXdpS1Z4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG5wbG90X2xvb3Bfc2NvcmVzX2FuZF9zYXZlX2JlZHBlKGRhdGEsIHNjb3JlX0RNU08sIHNjb3JlX2RUQUcsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBvb2VfRE1TTywgb29lX2RUQUcsIHBzZXVkb19vb2UgPSAwLjAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjKFwiUy1TXCIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBuYW1lID0gXCJjaHJvbW9zaWdodF9zY29yZV9jb21wbGV4X3N0cjJfZFRBR3ZzRE1TT1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aXRsZSA9IFwiY2hyb21vX3Njb3JlX2NvbXBsZXhfc3RyMl9fZFRBR3ZzRE1TT1wiLCBmaWdEaXIsIGNvbW1vbkxvb3BEaXIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9fY29sID0gXCJBbm5vXCIpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxucGxvdF9sb29wX3Njb3Jlc19hbmRfc2F2ZV9iZWRwZShkYXRhLCBzY29yZV9ETVNPLCBzY29yZV9kVEFHLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgb29lX0RNU08sIG9vZV9kVEFHLCBwc2V1ZG9fb29lID0gMC4wMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYyhcIlMtU1wiKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbmFtZSA9IFwiY2hyb21vc2lnaHRfc2NvcmVfY29tcGxleF9zdHIyX2RUQUd2c0RNU09cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGl0bGUgPSBcImNocm9tb19zY29yZV9jb21wbGV4X3N0cjJfX2RUQUd2c0RNU09cIiwgZmlnRGlyLCBjb21tb25Mb29wRGlyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vX2NvbCA9IFwiQW5ub1wiKVxuYGBgIn0= -->

```r
plot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, 
                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,
                                c("S-S"),
                                name = "chromosight_score_complex_str2_dTAGvsDMSO",
                                title = "chromo_score_complex_str2__dTAGvsDMSO", figDir, commonLoopDir,
                                anno_col = "Anno")
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoibnVsbCBkZXZpY2UgXG4gICAgICAgICAgMSBcbiJ9 -->

```
null device 
          1 
```



<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### [FIG] LOLA on anchor

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeTB0TFMwdExTMHRMUzB0TFMwdExTMHRMUzB0TFMwdExTMHRMUzB0TFMwdExTMHRMUzB0TFMwdExTMHRMUzB0TFMwdExTMHRMUzB0TFMwdExTMHRMUzB0TFMwdExTMHRMUzB0TFMwdExTMWNiaU1nVEU5QlJFbE9SeUJNVDB4QklFUkNYRzVzYVdKeVlYSjVLRndpYzJsdGNHeGxRMkZqYUdWY0lpbGNibXhwWW5KaGNua29YQ0pNVDB4QlhDSXBYRzVzYjJ4aFJFSWdQU0JzYjJGa1VtVm5hVzl1UkVJb1hDSXZWbTlzZFcxbGN5OVZTMHBKVGw5VFUwUXZUWFJ2UnpGZllXNWhiSGx6YVhOZlkyOWtaUzl5WldabGNtVnVZMlV2VEU5TVFVTnZjbVZmWTJGamFHVmtMMjF0TVRCY0lpbGNibHh1SXlCR1ZVNURWRWxQVGxOY2JtVjRkSEpoWTNSQmJtTm9iM0lnUEMwZ1puVnVZM1JwYjI0b2JHOXZjQ2w3WEc0Z0lHRnVZMmh2Y2pFZ1BDMGdiRzl2Y0NBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoaktERXNJRElzSURNcEtWeHVJQ0JqYjJ4dVlXMWxjeWhoYm1Ob2IzSXhLU0E4TFNCaktGd2lZMmh5WENJc0lGd2ljM1JoY25SY0lpd2dYQ0psYm1SY0lpbGNiaUFnWVc1amFHOXlNaUE4TFNCc2IyOXdJQ1UrSlNCa2NHeDVjam82YzJWc1pXTjBLR01vTkN3Z05Td2dOaWtwWEc0Z0lHTnZiRzVoYldWektHRnVZMmh2Y2pJcElEd3RJR01vWENKamFISmNJaXdnWENKemRHRnlkRndpTENCY0ltVnVaRndpS1Z4dUlDQmhibU5vYjNKeklEd3RJSEpsWkhWalpTaHRZV3RsUjFKaGJtZGxjMFp5YjIxRVlYUmhSbkpoYldVb1ltbHVaRjl5YjNkektHRnVZMmh2Y2pFc0lHRnVZMmh2Y2pJcEtTbGNiaUFnSUNCeVpYUjFjbTRvWVc1amFHOXljeWxjYm4xY2JseHVZWFJoWXlBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYQ0p0YlRFd1hDSXNJRndpUjFOTk16RXdOakkxTjE5QlZFRkRYMFZUUTE4eExtSmxaRndpS1NrZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1ZqRXNJRll5TENCV015bGNibU52Ykc1aGJXVnpLR0YwWVdNcElEd3RJR01vWENKamFISmNJaXdnWENKemRHRnlkRndpTENCY0ltVnVaRndpS1Z4dVlYUmhZeTVuY2lBOExTQnRZV3RsUjFKaGJtZGxjMFp5YjIxRVlYUmhSbkpoYldVb1lYUmhZeWxjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbiMtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG4jIExPQURJTkcgTE9MQSBEQlxubGlicmFyeShcInNpbXBsZUNhY2hlXCIpXG5saWJyYXJ5KFwiTE9MQVwiKVxubG9sYURCID0gbG9hZFJlZ2lvbkRCKFwiL1ZvbHVtZXMvVUtKSU5fU1NEL010b0cxX2FuYWx5c2lzX2NvZGUvcmVmZXJlbmNlL0xPTEFDb3JlX2NhY2hlZC9tbTEwXCIpXG5cbiMgRlVOQ1RJT05TXG5leHRyYWN0QW5jaG9yIDwtIGZ1bmN0aW9uKGxvb3Ape1xuICBhbmNob3IxIDwtIGxvb3AgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzKSlcbiAgY29sbmFtZXMoYW5jaG9yMSkgPC0gYyhcImNoclwiLCBcInN0YXJ0XCIsIFwiZW5kXCIpXG4gIGFuY2hvcjIgPC0gbG9vcCAlPiUgZHBseXI6OnNlbGVjdChjKDQsIDUsIDYpKVxuICBjb2xuYW1lcyhhbmNob3IyKSA8LSBjKFwiY2hyXCIsIFwic3RhcnRcIiwgXCJlbmRcIilcbiAgYW5jaG9ycyA8LSByZWR1Y2UobWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGJpbmRfcm93cyhhbmNob3IxLCBhbmNob3IyKSkpXG4gICAgcmV0dXJuKGFuY2hvcnMpXG59XG5cbmF0YWMgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwibW0xMFwiLCBcIkdTTTMxMDYyNTdfQVRBQ19FU0NfMS5iZWRcIikpICU+JSBkcGx5cjo6c2VsZWN0KFYxLCBWMiwgVjMpXG5jb2xuYW1lcyhhdGFjKSA8LSBjKFwiY2hyXCIsIFwic3RhcnRcIiwgXCJlbmRcIilcbmF0YWMuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGF0YWMpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbiMgTE9BRElORyBMT0xBIERCXG5saWJyYXJ5KFwic2ltcGxlQ2FjaGVcIilcbmxpYnJhcnkoXCJMT0xBXCIpXG5sb2xhREIgPSBsb2FkUmVnaW9uREIoXCIvVm9sdW1lcy9VS0pJTl9TU0QvTXRvRzFfYW5hbHlzaXNfY29kZS9yZWZlcmVuY2UvTE9MQUNvcmVfY2FjaGVkL21tMTBcIilcblxuIyBGVU5DVElPTlNcbmV4dHJhY3RBbmNob3IgPC0gZnVuY3Rpb24obG9vcCl7XG4gIGFuY2hvcjEgPC0gbG9vcCAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuICBjb2xuYW1lcyhhbmNob3IxKSA8LSBjKFwiY2hyXCIsIFwic3RhcnRcIiwgXCJlbmRcIilcbiAgYW5jaG9yMiA8LSBsb29wICU+JSBkcGx5cjo6c2VsZWN0KGMoNCwgNSwgNikpXG4gIGNvbG5hbWVzKGFuY2hvcjIpIDwtIGMoXCJjaHJcIiwgXCJzdGFydFwiLCBcImVuZFwiKVxuICBhbmNob3JzIDwtIHJlZHVjZShtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoYmluZF9yb3dzKGFuY2hvcjEsIGFuY2hvcjIpKSlcbiAgICByZXR1cm4oYW5jaG9ycylcbn1cblxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJtbTEwXCIsIFwiR1NNMzEwNjI1N19BVEFDX0VTQ18xLmJlZFwiKSkgJT4lIGRwbHlyOjpzZWxlY3QoVjEsIFYyLCBWMylcbmNvbG5hbWVzKGF0YWMpIDwtIGMoXCJjaHJcIiwgXCJzdGFydFwiLCBcImVuZFwiKVxuYXRhYy5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoYXRhYylcbmBgYCJ9 -->

```r
#-------------------------------------------------------------------------------
# LOADING LOLA DB
library("simpleCache")
library("LOLA")
lolaDB = loadRegionDB("/Volumes/UKJIN_SSD/MtoG1_analysis_code/reference/LOLACore_cached/mm10")

# FUNCTIONS
extractAnchor <- function(loop){
  anchor1 <- loop %>% dplyr::select(c(1, 2, 3))
  colnames(anchor1) <- c("chr", "start", "end")
  anchor2 <- loop %>% dplyr::select(c(4, 5, 6))
  colnames(anchor2) <- c("chr", "start", "end")
  anchors <- reduce(makeGRangesFromDataFrame(bind_rows(anchor1, anchor2)))
    return(anchors)
}

atac <- fread(here(refDir, "mm10", "GSM3106257_ATAC_ESC_1.bed")) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c("chr", "start", "end")
atac.gr <- makeGRangesFromDataFrame(atac)
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### All loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVkR1Z0Y0NBOExTQjBaVzF3SUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0hSaGNtZGxkQ0FsYVc0bElIUmhjbWRsZEV4cGMzUXBYRzUwWlcxd0pIUmhjbWRsZENBOExTQm1ZV04wYjNJb2RHVnRjQ1IwWVhKblpYUXNJR3hsZG1Wc2N5QTlJSEpsZGloMFlYSm5aWFJNYVhOMEtTbGNibHh1WEc1eFZtRnNkV1ZNYjJkTllYZ2dQQzBnTlRCY2JuUmxiWEF5SUR3dElIUmxiWEFnSlQ0bElHUndiSGx5T2pwdGRYUmhkR1VvY1ZaaGJIVmxURzluSUQwZ2JXbHVLSEZXWVd4MVpVeHZaeXdnY1ZaaGJIVmxURzluVFdGNEtTbGNibHh1Y0NBOExTQm5aM0JzYjNRb2RHVnRjRElzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCMFlYSm5aWFFzSUdacGJHd2dQU0J2WkdSelVtRjBhVzhzSUhOcGVtVWdQU0J4Vm1Gc2RXVk1iMmNwS1NBclhHNGdJR2RsYjIxZmNHOXBiblFvYzJoaGNHVWdQU0F5TVN3Z0lDQWdJQ0FnSUNNZ1JXNXpkWEpsY3lCaElIQnZhVzUwSUhkcGRHZ2dZVzRnYjNWMGJHbHVaVnh1SUNBZ0lDQWdJQ0FnSUNBZ0lITjBjbTlyWlNBOUlERXFjSFJVYjAxTklDQWdJQ0FnSXlCTWFXNWxJSGRwWkhSb0lHWnZjaUIwYUdVZ1ltOXlaR1Z5WEc0Z0lDa2dLeUIwYUdWdFpWOWlkeWdwSUNzZ1hHNGdJSE5qWVd4bFgzTnBlbVZmWTI5dWRHbHVkVzkxY3loeVlXNW5aU0E5SUdNb01DNDFMQ0F5S1NrZ0t5QWdJeUJUWlhRZ2JXbHVJR0Z1WkNCdFlYZ2djRzlwYm5RZ2MybDZaWE1nYUdWeVpWeHVJQ0J6WTJGc1pWOW1hV3hzWDJkeVlXUnBaVzUwS0d4dmR5QTlJRndpZDJocGRHVmNJaXdnYUdsbmFDQTlJRndpSTBOQ016TXpRVndpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3hwYldsMGN5QTlJR01vTVN3Z015a3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2IyOWlJRDBnYzJOaGJHVnpPanB6Y1hWcGMyZ3NJQ01nUkdWbWFXNWxJR2R5WVdScFpXNTBJR052Ykc5eWMxeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdkMWFXUmxJRDBnWjNWcFpHVmZZMjlzYjNKaVlYSW9YRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmlZWEozYVdSMGFDQTlJREV1TlM4MUxqQTRMQ0FnSXlCQlpHcDFjM1FnZDJsa2RHZ2diMllnZEdobElHTnZiRzl5SUdKaGNseHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1ltRnlhR1ZwWjJoMElEMGdNVFV2TlM0d09DQWdJQ01nUVdScWRYTjBJR2hsYVdkb2RDQnZaaUIwYUdVZ1kyOXNiM0lnWW1GeVhHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnS1Z4dUlDQXBJQ3NnWEc0Z0lHeGhZbk1vZUNBOUlFNVZURXdzSUhrZ1BTQk9WVXhNS1NBZ0sxeHVJQ0IwYUdWdFpTaGNiaUFnSUNCaGVHbHpMblJwZEd4bElEMGdaV3hsYldWdWRGOTBaWGgwS0Z4dUlDQWdJQ0FnYzJsNlpTQTlJR1p2Ym5SVGFYcGxVeXhjYmlBZ0lDQWdJR1poYldsc2VTQTlJR1p2Ym5SVWVYQmxMRnh1SUNBZ0lDQWdZMjlzYjNJZ1BTQmNJaU13TURBd01EQmNJbHh1SUNBZ0lDa3NYRzRnSUNBZ1lYaHBjeTUwWlhoMElEMGdaV3hsYldWdWRGOTBaWGgwS0Z4dUlDQWdJQ0FnYzJsNlpTQTlJR1p2Ym5SVGFYcGxVeXhjYmlBZ0lDQWdJR1poYldsc2VTQTlJR1p2Ym5SVWVYQmxMRnh1SUNBZ0lDQWdZMjlzYjNJZ1BTQmNJaU13TURBd01EQmNJbHh1SUNBZ0lDa3NYRzRnSUNBZ1lYaHBjeTUwWlhoMExuZ2dQU0JsYkdWdFpXNTBYM1JsZUhRb1hHNGdJQ0FnSUNCaGJtZHNaU0E5SURRMUxDQWdJQ0FnSUNNZ1VtOTBZWFJsSUhndFlYaHBjeUJzWVdKbGJITWdORFVnWkdWbmNtVmxjMXh1SUNBZ0lDQWdhR3AxYzNRZ1BTQXhMQ0FnSUNBZ0lDQWpJRUZrYW5WemRDQm9iM0pwZW05dWRHRnNJR3AxYzNScFptbGpZWFJwYjI1Y2JpQWdJQ0FnSUhacWRYTjBJRDBnTVNBZ0lDQWdJQ0FnSXlCQlpHcDFjM1FnZG1WeWRHbGpZV3dnYW5WemRHbG1hV05oZEdsdmJseHVJQ0FnSUNrc1hHNGdJQ0FnWVhocGN5NXNhVzVsSUQwZ1pXeGxiV1Z1ZEY5c2FXNWxLRnh1SUNBZ0lDQWdZMjlzYjNJZ1BTQmNJaU13TURBd01EQmNJaXhjYmlBZ0lDQWdJSE5wZW1VZ1BTQnNhVzVsVkdocFkyc3FiVzFVYjB4cGJtVlZibWwwTEZ4dUlDQWdJQ0FnYkdsdVpXVnVaQ0E5SUZ3aWMzRjFZWEpsWENKY2JpQWdJQ0FwTEZ4dUlDQWdJR0Y0YVhNdWRHbGphM01nUFNCbGJHVnRaVzUwWDJ4cGJtVW9YRzRnSUNBZ0lDQmpiMnh2Y2lBOUlGd2lJekF3TURBd01Gd2lMRnh1SUNBZ0lDQWdjMmw2WlNBOUlHeHBibVZVYUdsamF5cHRiVlJ2VEdsdVpWVnVhWFFzWEc0Z0lDQWdJQ0JzYVc1bFpXNWtJRDBnWENKemNYVmhjbVZjSWx4dUlDQWdJQ2tzWEc0Z0lDQWdjR0Z1Wld3dVltRmphMmR5YjNWdVpDQTlJR1ZzWlcxbGJuUmZjbVZqZENobWFXeHNJRDBnWENKMGNtRnVjM0JoY21WdWRGd2lLU3hjYmlBZ0lDQnNaV2RsYm1RdWRHVjRkQ0E5SUdWc1pXMWxiblJmZEdWNGRDaG1ZVzFwYkhrZ1BTQm1iMjUwVkhsd1pTd2djMmw2WlNBOUlHWnZiblJUYVhwbFV5a3NYRzRnSUNBZ2JHVm5aVzVrTG5ScGRHeGxJRDBnWld4bGJXVnVkRjkwWlhoMEtHWmhiV2xzZVNBOUlHWnZiblJVZVhCbExDQnphWHBsSUQwZ1ptOXVkRk5wZW1WVEtWeHVJQ0FwWEc1Y2JtWnBaMFJwY2lBOExTQm9aWEpsS0Z3aUxpNHZabWxuZFhKbEwyeHZiM0JmWVc1aGJIbHphWE5jSWlsY2JseHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRndpVEU5TVFWOWNJaXdnYm1GdFpTbGNibmRwWkhSb0lEd3RJSEJoYm1Wc1UybDZaU2d4TGpVcEttMXRWRzlKYm1Ob1hHNW9aV2xuYUhRZ1BDMGdjR0Z1Wld4VGFYcGxLREV1T1NrcWJXMVViMGx1WTJoY2JuQnVaeWhvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY0lpNXdibWRjSWlrcExDQnlaWE1nUFNBMk1EQXNJSFZ1YVhRZ1BTQmNJbWx1WENJc0lHaGxhV2RvZENBOUlHaGxhV2RvZEN3Z2QybGtkR2dnUFNCM2FXUjBhQ2xjYm5CeWFXNTBLSEFwWEc1a1pYWXViMlptS0NsY2JseHVZR0JnSW4wPSAtLT5cblxuYGBgclxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKHRhcmdldCAlaW4lIHRhcmdldExpc3QpXG50ZW1wJHRhcmdldCA8LSBmYWN0b3IodGVtcCR0YXJnZXQsIGxldmVscyA9IHJldih0YXJnZXRMaXN0KSlcblxuXG5xVmFsdWVMb2dNYXggPC0gNTBcbnRlbXAyIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUocVZhbHVlTG9nID0gbWluKHFWYWx1ZUxvZywgcVZhbHVlTG9nTWF4KSlcblxucCA8LSBnZ3Bsb3QodGVtcDIsIGFlcyh4ID0gZ3JvdXAsIHkgPSB0YXJnZXQsIGZpbGwgPSBvZGRzUmF0aW8sIHNpemUgPSBxVmFsdWVMb2cpKSArXG4gIGdlb21fcG9pbnQoc2hhcGUgPSAyMSwgICAgICAgICMgRW5zdXJlcyBhIHBvaW50IHdpdGggYW4gb3V0bGluZVxuICAgICAgICAgICAgIHN0cm9rZSA9IDEqcHRUb01NICAgICAgIyBMaW5lIHdpZHRoIGZvciB0aGUgYm9yZGVyXG4gICkgKyB0aGVtZV9idygpICsgXG4gIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMC41LCAyKSkgKyAgIyBTZXQgbWluIGFuZCBtYXggcG9pbnQgc2l6ZXMgaGVyZVxuICBzY2FsZV9maWxsX2dyYWRpZW50KGxvdyA9IFwid2hpdGVcIiwgaGlnaCA9IFwiI0NCMzMzQVwiLFxuICAgICAgICAgICAgICAgICAgICAgIGxpbWl0cyA9IGMoMSwgMyksXG4gICAgICAgICAgICAgICAgICAgICAgb29iID0gc2NhbGVzOjpzcXVpc2gsICMgRGVmaW5lIGdyYWRpZW50IGNvbG9yc1xuICAgICAgICAgICAgICAgICAgICAgIGd1aWRlID0gZ3VpZGVfY29sb3JiYXIoXG4gICAgICAgICAgICAgICAgICAgICAgICBiYXJ3aWR0aCA9IDEuNS81LjA4LCAgIyBBZGp1c3Qgd2lkdGggb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyaGVpZ2h0ID0gMTUvNS4wOCAgICMgQWRqdXN0IGhlaWdodCBvZiB0aGUgY29sb3IgYmFyXG4gICAgICAgICAgICAgICAgICAgICAgKVxuICApICsgXG4gIGxhYnMoeCA9IE5VTEwsIHkgPSBOVUxMKSAgK1xuICB0aGVtZShcbiAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUyxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUyxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCAgICAgICMgUm90YXRlIHgtYXhpcyBsYWJlbHMgNDUgZGVncmVlc1xuICAgICAgaGp1c3QgPSAxLCAgICAgICAjIEFkanVzdCBob3Jpem9udGFsIGp1c3RpZmljYXRpb25cbiAgICAgIHZqdXN0ID0gMSAgICAgICAgIyBBZGp1c3QgdmVydGljYWwganVzdGlmaWNhdGlvblxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXCJ0cmFuc3BhcmVudFwiKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApXG5cbmZpZ0RpciA8LSBoZXJlKFwiLi4vZmlndXJlL2xvb3BfYW5hbHlzaXNcIilcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwiTE9MQV9cIiwgbmFtZSlcbndpZHRoIDwtIHBhbmVsU2l6ZSgxLjUpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuOSkqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKHRhcmdldCAlaW4lIHRhcmdldExpc3QpXG50ZW1wJHRhcmdldCA8LSBmYWN0b3IodGVtcCR0YXJnZXQsIGxldmVscyA9IHJldih0YXJnZXRMaXN0KSlcblxuXG5xVmFsdWVMb2dNYXggPC0gNTBcbnRlbXAyIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUocVZhbHVlTG9nID0gbWluKHFWYWx1ZUxvZywgcVZhbHVlTG9nTWF4KSlcblxucCA8LSBnZ3Bsb3QodGVtcDIsIGFlcyh4ID0gZ3JvdXAsIHkgPSB0YXJnZXQsIGZpbGwgPSBvZGRzUmF0aW8sIHNpemUgPSBxVmFsdWVMb2cpKSArXG4gIGdlb21fcG9pbnQoc2hhcGUgPSAyMSwgICAgICAgICMgRW5zdXJlcyBhIHBvaW50IHdpdGggYW4gb3V0bGluZVxuICAgICAgICAgICAgIHN0cm9rZSA9IDEqcHRUb01NICAgICAgIyBMaW5lIHdpZHRoIGZvciB0aGUgYm9yZGVyXG4gICkgKyB0aGVtZV9idygpICsgXG4gIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMC41LCAyKSkgKyAgIyBTZXQgbWluIGFuZCBtYXggcG9pbnQgc2l6ZXMgaGVyZVxuICBzY2FsZV9maWxsX2dyYWRpZW50KGxvdyA9IFwid2hpdGVcIiwgaGlnaCA9IFwiI0NCMzMzQVwiLFxuICAgICAgICAgICAgICAgICAgICAgIGxpbWl0cyA9IGMoMSwgMyksXG4gICAgICAgICAgICAgICAgICAgICAgb29iID0gc2NhbGVzOjpzcXVpc2gsICMgRGVmaW5lIGdyYWRpZW50IGNvbG9yc1xuICAgICAgICAgICAgICAgICAgICAgIGd1aWRlID0gZ3VpZGVfY29sb3JiYXIoXG4gICAgICAgICAgICAgICAgICAgICAgICBiYXJ3aWR0aCA9IDEuNS81LjA4LCAgIyBBZGp1c3Qgd2lkdGggb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyaGVpZ2h0ID0gMTUvNS4wOCAgICMgQWRqdXN0IGhlaWdodCBvZiB0aGUgY29sb3IgYmFyXG4gICAgICAgICAgICAgICAgICAgICAgKVxuICApICsgXG4gIGxhYnMoeCA9IE5VTEwsIHkgPSBOVUxMKSAgK1xuICB0aGVtZShcbiAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUyxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUyxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCAgICAgICMgUm90YXRlIHgtYXhpcyBsYWJlbHMgNDUgZGVncmVlc1xuICAgICAgaGp1c3QgPSAxLCAgICAgICAjIEFkanVzdCBob3Jpem9udGFsIGp1c3RpZmljYXRpb25cbiAgICAgIHZqdXN0ID0gMSAgICAgICAgIyBBZGp1c3QgdmVydGljYWwganVzdGlmaWNhdGlvblxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXCJ0cmFuc3BhcmVudFwiKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApXG5cbmZpZ0RpciA8LSBoZXJlKFwiLi4vZmlndXJlL2xvb3BfYW5hbHlzaXNcIilcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwiTE9MQV9cIiwgbmFtZSlcbndpZHRoIDwtIHBhbmVsU2l6ZSgxLjUpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuOSkqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcblxuYGBgIn0= -->

```r
temp <- temp %>% dplyr::filter(target %in% targetList)
temp$target <- factor(temp$target, levels = rev(targetList))


qValueLogMax <- 50
temp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))

p <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = "white", high = "#CB333A",
                      limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

figDir <- here("../figure/loop_analysis")

fileName <- paste0("LOLA_", name)
width <- panelSize(1.5)*mmToInch
height <- panelSize(1.9)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()

```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoibnVsbCBkZXZpY2UgXG4gICAgICAgICAgMSBcbiJ9 -->

```
null device 
          1 
```



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjSWk1emRtZGNJaWtwTENBZ2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmBgYCJ9 -->

```r
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVaR1YyTG05bVppZ3BYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmRldi5vZmYoKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZGV2Lm9mZigpXG5gYGAifQ== -->

```r
dev.off()
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoibnVsbCBkZXZpY2UgXG4gICAgICAgICAgMSBcbiJ9 -->

```
null device 
          1 
```



<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### Reg loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n#-------------------------------------------------------------------------------\n# LOADING LOOPS\n### Importing differential regulatory loops & extract anchor\ncommonLoopDir <- here(\"../data/loop_analysis\")\nloop.all <- fread(here(commonLoopDir, \"loopScore_chromosight.tsv\"))\nanchor.all <- (extractAnchor(loop.all))\noverlaps <- findOverlaps(anchor.all, atac.gr)\nanchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.up <- fread(here(commonLoopDir, \"chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_UP.bedpe\"))\nanchor.up <- (extractAnchor(loop.up))\noverlaps <- findOverlaps(anchor.up, atac.gr)\nanchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.no <- fread(here(commonLoopDir, \"chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_NO.bedpe\"))\nanchor.no <- (extractAnchor(loop.no))\noverlaps <- findOverlaps(anchor.no, atac.gr)\nanchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.upno <- bind_rows(loop.up, loop.no)\nanchor.upno <- (extractAnchor(loop.upno))\noverlaps <- findOverlaps(anchor.upno, atac.gr)\nanchor.upno <- pintersect(anchor.upno[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.down <- fread(here(commonLoopDir, \"chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_DOWN.bedpe\"))\nanchor.down <- (extractAnchor(loop.down))\noverlaps <- findOverlaps(anchor.down, atac.gr)\nanchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\n#-------------------------------------------------------------------------------\n# RUNNING LOLA\n# UP\nlolaDir <- here(commonLoopDir, \"LOLA\")\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n\nname <- \"chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2\"\nresult <- runLOLA(anchor.up, anchor.all, lolaDB)\ntb <- as_tibble(result)\nfwrite(tb, here(lolaDir, paste0(\"LOLA_\", name, \"UP_ATAC.tsv\")), sep = \"\\t\")\n\n# NO\nresult <- runLOLA(anchor.no, anchor.all, lolaDB)\ntb <- as_tibble(result)\nfwrite(tb, here(lolaDir, paste0(\"LOLA_\", name, \"NO_ATAC.tsv\")), sep = \"\\t\")\n\n# UPNO\nresult <- runLOLA(anchor.upno, anchor.all, lolaDB)\ntb <- as_tibble(result)\nfwrite(tb, here(lolaDir, paste0(\"LOLA_\", name, \"UPNO_ATAC.tsv\")), sep = \"\\t\")\n\n# DOWN\nresult <- runLOLA(anchor.down, anchor.all, lolaDB)\ntb <- as_tibble(result)\nfwrite(tb, here(lolaDir, paste0(\"LOLA_\", name, \"DOWN_ATAC.tsv\")), sep = \"\\t\")\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, paste0(\"LOLA_\", name, \"UP_ATAC.tsv\"))) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \"UP\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, paste0(\"LOLA_\", name, \"NO_ATAC.tsv\"))) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \"NO\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.upno <- fread(here(lolaDir, paste0(\"LOLA_\", name, \"UPNO_ATAC.tsv\"))) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \"UP/NO\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\nfwrite(tb.upno %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, paste0(\"LOLA_\", name, \"UPNO_ATAC_pub.tsv\")), sep = \"\\t\")\n\ntb.down <- fread(here(lolaDir, paste0(\"LOLA_\", name, \"DOWN_ATAC.tsv\"))) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \"DOWN\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.down %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, paste0(\"LOLA_\", name, \"DOWN_ATAC__pub.tsv\")), sep = \"\\t\")\n\n\ntemp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.upno, temp.down)\n\norder <- c((temp %>% dplyr::filter(group == \"UP/NO\") %>% arrange(desc(oddsRatio)))$target,\n           (temp %>% dplyr::filter(group == \"DOWN\") %>% arrange(desc(oddsRatio)))$target)\norder <- unique(order)\n\ntemp$target <- factor(temp$target, levels = rev(order))\ntemp$group <- factor(temp$group, levels = c(\"UP/NO\", \"DOWN\"))\n\ntargetList <- c(\"POLR2A\", \"CTR9\", \"ARR4\", \"ELL2\",\n                \"MED1\", \"MED12\", \"TBP\", \"TAF1\", \"TAF2\",\n                \"ESRRB\", \"KLF4\", \"NANOG\", \"POU5F1\", \"SOX2\", \"MYCN\", \"GASTA4\", \"STAT3\", \"E2F1\", \"YY1\",\n                \"P300\", \"DPY30\", \"RBBP5\", \"KDM2B\", \"KDM4B\", \"KDM6B\", \"TET1\",\n                \"CBX7\", \"RING1B\", \"RNF2\", \"EZH2\", \"SUZ12\", \"JARID2\", \"MTF2\", \"PHF19\")\n\ntemp <- temp %>% dplyr::filter(target %in% targetList)\ntemp$target <- factor(temp$target, levels = rev(targetList))\n\n\nqValueLogMax <- 50\ntemp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))\n\np <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \"white\", high = \"#CB333A\",\n                      limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfigDir <- here(\"../figure/loop_analysis\")\n\nfileName <- paste0(\"LOLA_\", name)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(1.9)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\n#-------------------------------------------------------------------------------\n# LOADING LOOPS\n### Importing differential regulatory loops & extract anchor\ncommonLoopDir <- here(\"../data/loop_analysis\")\nloop.all <- fread(here(commonLoopDir, \"loopScore_chromosight.tsv\"))\nanchor.all <- (extractAnchor(loop.all))\noverlaps <- findOverlaps(anchor.all, atac.gr)\nanchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.up <- fread(here(commonLoopDir, \"chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_UP.bedpe\"))\nanchor.up <- (extractAnchor(loop.up))\noverlaps <- findOverlaps(anchor.up, atac.gr)\nanchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.no <- fread(here(commonLoopDir, \"chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_NO.bedpe\"))\nanchor.no <- (extractAnchor(loop.no))\noverlaps <- findOverlaps(anchor.no, atac.gr)\nanchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.upno <- bind_rows(loop.up, loop.no)\nanchor.upno <- (extractAnchor(loop.upno))\noverlaps <- findOverlaps(anchor.upno, atac.gr)\nanchor.upno <- pintersect(anchor.upno[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.down <- fread(here(commonLoopDir, \"chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_DOWN.bedpe\"))\nanchor.down <- (extractAnchor(loop.down))\noverlaps <- findOverlaps(anchor.down, atac.gr)\nanchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\n#-------------------------------------------------------------------------------\n# RUNNING LOLA\n# UP\nlolaDir <- here(commonLoopDir, \"LOLA\")\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n\nname <- \"chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2\"\nresult <- runLOLA(anchor.up, anchor.all, lolaDB)\ntb <- as_tibble(result)\nfwrite(tb, here(lolaDir, paste0(\"LOLA_\", name, \"UP_ATAC.tsv\")), sep = \"\\t\")\n\n# NO\nresult <- runLOLA(anchor.no, anchor.all, lolaDB)\ntb <- as_tibble(result)\nfwrite(tb, here(lolaDir, paste0(\"LOLA_\", name, \"NO_ATAC.tsv\")), sep = \"\\t\")\n\n# UPNO\nresult <- runLOLA(anchor.upno, anchor.all, lolaDB)\ntb <- as_tibble(result)\nfwrite(tb, here(lolaDir, paste0(\"LOLA_\", name, \"UPNO_ATAC.tsv\")), sep = \"\\t\")\n\n# DOWN\nresult <- runLOLA(anchor.down, anchor.all, lolaDB)\ntb <- as_tibble(result)\nfwrite(tb, here(lolaDir, paste0(\"LOLA_\", name, \"DOWN_ATAC.tsv\")), sep = \"\\t\")\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, paste0(\"LOLA_\", name, \"UP_ATAC.tsv\"))) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \"UP\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, paste0(\"LOLA_\", name, \"NO_ATAC.tsv\"))) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \"NO\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.upno <- fread(here(lolaDir, paste0(\"LOLA_\", name, \"UPNO_ATAC.tsv\"))) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \"UP/NO\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\nfwrite(tb.upno %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, paste0(\"LOLA_\", name, \"UPNO_ATAC_pub.tsv\")), sep = \"\\t\")\n\ntb.down <- fread(here(lolaDir, paste0(\"LOLA_\", name, \"DOWN_ATAC.tsv\"))) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \"DOWN\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.down %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, paste0(\"LOLA_\", name, \"DOWN_ATAC__pub.tsv\")), sep = \"\\t\")\n\n\ntemp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.upno, temp.down)\n\norder <- c((temp %>% dplyr::filter(group == \"UP/NO\") %>% arrange(desc(oddsRatio)))$target,\n           (temp %>% dplyr::filter(group == \"DOWN\") %>% arrange(desc(oddsRatio)))$target)\norder <- unique(order)\n\ntemp$target <- factor(temp$target, levels = rev(order))\ntemp$group <- factor(temp$group, levels = c(\"UP/NO\", \"DOWN\"))\n\ntargetList <- c(\"POLR2A\", \"CTR9\", \"ARR4\", \"ELL2\",\n                \"MED1\", \"MED12\", \"TBP\", \"TAF1\", \"TAF2\",\n                \"ESRRB\", \"KLF4\", \"NANOG\", \"POU5F1\", \"SOX2\", \"MYCN\", \"GASTA4\", \"STAT3\", \"E2F1\", \"YY1\",\n                \"P300\", \"DPY30\", \"RBBP5\", \"KDM2B\", \"KDM4B\", \"KDM6B\", \"TET1\",\n                \"CBX7\", \"RING1B\", \"RNF2\", \"EZH2\", \"SUZ12\", \"JARID2\", \"MTF2\", \"PHF19\")\n\ntemp <- temp %>% dplyr::filter(target %in% targetList)\ntemp$target <- factor(temp$target, levels = rev(targetList))\n\n\nqValueLogMax <- 50\ntemp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))\n\np <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \"white\", high = \"#CB333A\",\n                      limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfigDir <- here(\"../figure/loop_analysis\")\n\nfileName <- paste0(\"LOLA_\", name)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(1.9)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n#-------------------------------------------------------------------------------\n# LOADING LOOPS\n### Importing differential regulatory loops & extract anchor\ncommonLoopDir <- here(\"../data/loop_analysis\")\nloop.all <- fread(here(commonLoopDir, \"loopScore_chromosight.tsv\"))\nanchor.all <- (extractAnchor(loop.all))\noverlaps <- findOverlaps(anchor.all, atac.gr)\nanchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.up <- fread(here(commonLoopDir, \"chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_UP.bedpe\"))\nanchor.up <- (extractAnchor(loop.up))\noverlaps <- findOverlaps(anchor.up, atac.gr)\nanchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.no <- fread(here(commonLoopDir, \"chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_NO.bedpe\"))\nanchor.no <- (extractAnchor(loop.no))\noverlaps <- findOverlaps(anchor.no, atac.gr)\nanchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.upno <- bind_rows(loop.up, loop.no)\nanchor.upno <- (extractAnchor(loop.upno))\noverlaps <- findOverlaps(anchor.upno, atac.gr)\nanchor.upno <- pintersect(anchor.upno[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.down <- fread(here(commonLoopDir, \"chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_DOWN.bedpe\"))\nanchor.down <- (extractAnchor(loop.down))\noverlaps <- findOverlaps(anchor.down, atac.gr)\nanchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\n#-------------------------------------------------------------------------------\n# RUNNING LOLA\n# UP\nlolaDir <- here(commonLoopDir, \"LOLA\")\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n\nname <- \"chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2\"\nresult <- runLOLA(anchor.up, anchor.all, lolaDB)\ntb <- as_tibble(result)\nfwrite(tb, here(lolaDir, paste0(\"LOLA_\", name, \"UP_ATAC.tsv\")), sep = \"\\t\")\n\n# NO\nresult <- runLOLA(anchor.no, anchor.all, lolaDB)\ntb <- as_tibble(result)\nfwrite(tb, here(lolaDir, paste0(\"LOLA_\", name, \"NO_ATAC.tsv\")), sep = \"\\t\")\n\n# UPNO\nresult <- runLOLA(anchor.upno, anchor.all, lolaDB)\ntb <- as_tibble(result)\nfwrite(tb, here(lolaDir, paste0(\"LOLA_\", name, \"UPNO_ATAC.tsv\")), sep = \"\\t\")\n\n# DOWN\nresult <- runLOLA(anchor.down, anchor.all, lolaDB)\ntb <- as_tibble(result)\nfwrite(tb, here(lolaDir, paste0(\"LOLA_\", name, \"DOWN_ATAC.tsv\")), sep = \"\\t\")\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, paste0(\"LOLA_\", name, \"UP_ATAC.tsv\"))) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \"UP\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, paste0(\"LOLA_\", name, \"NO_ATAC.tsv\"))) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \"NO\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.upno <- fread(here(lolaDir, paste0(\"LOLA_\", name, \"UPNO_ATAC.tsv\"))) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \"UP/NO\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\nfwrite(tb.upno %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, paste0(\"LOLA_\", name, \"UPNO_ATAC_pub.tsv\")), sep = \"\\t\")\n\ntb.down <- fread(here(lolaDir, paste0(\"LOLA_\", name, \"DOWN_ATAC.tsv\"))) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \"DOWN\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.down %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, paste0(\"LOLA_\", name, \"DOWN_ATAC__pub.tsv\")), sep = \"\\t\")\n\n\ntemp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.upno, temp.down)\n\norder <- c((temp %>% dplyr::filter(group == \"UP/NO\") %>% arrange(desc(oddsRatio)))$target,\n           (temp %>% dplyr::filter(group == \"DOWN\") %>% arrange(desc(oddsRatio)))$target)\norder <- unique(order)\n\ntemp$target <- factor(temp$target, levels = rev(order))\ntemp$group <- factor(temp$group, levels = c(\"UP/NO\", \"DOWN\"))\n\ntargetList <- c(\"POLR2A\", \"CTR9\", \"ARR4\", \"ELL2\",\n                \"MED1\", \"MED12\", \"TBP\", \"TAF1\", \"TAF2\",\n                \"ESRRB\", \"KLF4\", \"NANOG\", \"POU5F1\", \"SOX2\", \"MYCN\", \"GASTA4\", \"STAT3\", \"E2F1\", \"YY1\",\n                \"P300\", \"DPY30\", \"RBBP5\", \"KDM2B\", \"KDM4B\", \"KDM6B\", \"TET1\",\n                \"CBX7\", \"RING1B\", \"RNF2\", \"EZH2\", \"SUZ12\", \"JARID2\", \"MTF2\", \"PHF19\")\n\ntemp <- temp %>% dplyr::filter(target %in% targetList)\ntemp$target <- factor(temp$target, levels = rev(targetList))\n\n\nqValueLogMax <- 50\ntemp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))\n\np <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \"white\", high = \"#CB333A\",\n                      limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfigDir <- here(\"../figure/loop_analysis\")\n\nfileName <- paste0(\"LOLA_\", name)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(1.9)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\n```"} -->

```r
#-------------------------------------------------------------------------------
# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
commonLoopDir <- here("../data/loop_analysis")
loop.all <- fread(here(commonLoopDir, "loopScore_chromosight.tsv"))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(commonLoopDir, "chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_UP.bedpe"))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(commonLoopDir, "chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_NO.bedpe"))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.upno <- bind_rows(loop.up, loop.no)
anchor.upno <- (extractAnchor(loop.upno))
overlaps <- findOverlaps(anchor.upno, atac.gr)
anchor.upno <- pintersect(anchor.upno[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.down <- fread(here(commonLoopDir, "chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_DOWN.bedpe"))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

#-------------------------------------------------------------------------------
# RUNNING LOLA
# UP
lolaDir <- here(commonLoopDir, "LOLA")
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)


name <- "chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2"
result <- runLOLA(anchor.up, anchor.all, lolaDB)
tb <- as_tibble(result)
fwrite(tb, here(lolaDir, paste0("LOLA_", name, "UP_ATAC.tsv")), sep = "\t")

# NO
result <- runLOLA(anchor.no, anchor.all, lolaDB)
tb <- as_tibble(result)
fwrite(tb, here(lolaDir, paste0("LOLA_", name, "NO_ATAC.tsv")), sep = "\t")

# UPNO
result <- runLOLA(anchor.upno, anchor.all, lolaDB)
tb <- as_tibble(result)
fwrite(tb, here(lolaDir, paste0("LOLA_", name, "UPNO_ATAC.tsv")), sep = "\t")

# DOWN
result <- runLOLA(anchor.down, anchor.all, lolaDB)
tb <- as_tibble(result)
fwrite(tb, here(lolaDir, paste0("LOLA_", name, "DOWN_ATAC.tsv")), sep = "\t")


### Visualizing p-value and OR
alpha <- 0.05
tb.up <- fread(here(lolaDir, paste0("LOLA_", name, "UP_ATAC.tsv"))) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "UP") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, paste0("LOLA_", name, "NO_ATAC.tsv"))) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "NO") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.upno <- fread(here(lolaDir, paste0("LOLA_", name, "UPNO_ATAC.tsv"))) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = "UP/NO") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

fwrite(tb.upno %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, paste0("LOLA_", name, "UPNO_ATAC_pub.tsv")), sep = "\t")

tb.down <- fread(here(lolaDir, paste0("LOLA_", name, "DOWN_ATAC.tsv"))) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = "DOWN") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.down %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, paste0("LOLA_", name, "DOWN_ATAC__pub.tsv")), sep = "\t")


temp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.upno, temp.down)

order <- c((temp %>% dplyr::filter(group == "UP/NO") %>% arrange(desc(oddsRatio)))$target,
           (temp %>% dplyr::filter(group == "DOWN") %>% arrange(desc(oddsRatio)))$target)
order <- unique(order)

temp$target <- factor(temp$target, levels = rev(order))
temp$group <- factor(temp$group, levels = c("UP/NO", "DOWN"))

targetList <- c("POLR2A", "CTR9", "ARR4", "ELL2",
                "MED1", "MED12", "TBP", "TAF1", "TAF2",
                "ESRRB", "KLF4", "NANOG", "POU5F1", "SOX2", "MYCN", "GASTA4", "STAT3", "E2F1", "YY1",
                "P300", "DPY30", "RBBP5", "KDM2B", "KDM4B", "KDM6B", "TET1",
                "CBX7", "RING1B", "RNF2", "EZH2", "SUZ12", "JARID2", "MTF2", "PHF19")

temp <- temp %>% dplyr::filter(target %in% targetList)
temp$target <- factor(temp$target, levels = rev(targetList))


qValueLogMax <- 50
temp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))

p <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = "white", high = "#CB333A",
                      limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

figDir <- here("../figure/loop_analysis")

fileName <- paste0("LOLA_", name)
width <- panelSize(1.5)*mmToInch
height <- panelSize(1.9)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoibnVsbCBkZXZpY2UgXG4gICAgICAgICAgMSBcbiJ9 -->

```
null device 
          1 
```



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjSWk1emRtZGNJaWtwTENBZ2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuYGBgIn0= -->

```r
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgIn0= -->

```r
print(p)
dev.off()
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoibnVsbCBkZXZpY2UgXG4gICAgICAgICAgMSBcbiJ9 -->

```
null device 
          1 
```



<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### [FIG] Distance vs OOE plot per group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVYRzUzYVdSMGFDQThMU0J3WVc1bGJGTnBlbVVvTWk0MUtTcHRiVlJ2U1c1amFGeHVhR1ZwWjJoMElEd3RJSEJoYm1Wc1UybDZaU2d4TGpjMUtTcHRiVlJ2U1c1amFGeHVjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGd2lMbkJ1WjF3aUtTa3NJRnh1SUNBZ0lISmxjeUE5SURZd01Dd2dkVzVwZEhNZ1BTQmNJbWx1WENJc0lIZHBaSFJvSUQwZ2QybGtkR2dzSUdobGFXZG9kQ0E5SUdobGFXZG9kQ2xjYm5CeWFXNTBLSEFwWEc1a1pYWXViMlptS0NsY2JseHVZR0JnSW4wPSAtLT5cblxuYGBgclxuXG53aWR0aCA8LSBwYW5lbFNpemUoMi41KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjc1KSptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIFxuICAgIHJlcyA9IDYwMCwgdW5pdHMgPSBcImluXCIsIHdpZHRoID0gd2lkdGgsIGhlaWdodCA9IGhlaWdodClcbnByaW50KHApXG5kZXYub2ZmKClcblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG53aWR0aCA8LSBwYW5lbFNpemUoMi41KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjc1KSptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIFxuICAgIHJlcyA9IDYwMCwgdW5pdHMgPSBcImluXCIsIHdpZHRoID0gd2lkdGgsIGhlaWdodCA9IGhlaWdodClcbnByaW50KHApXG5kZXYub2ZmKClcblxuYGBgIn0= -->

```r

width <- panelSize(2.5)*mmToInch
height <- panelSize(1.75)*mmToInch
png(here(figDir, paste0(fileName, ".png")), 
    res = 600, units = "in", width = width, height = height)
print(p)
dev.off()

```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoibnVsbCBkZXZpY2UgXG4gICAgICAgICAgMSBcbiJ9 -->

```
null device 
          1 
```



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjSWk1emRtZGNJaWtwTENCY2JpQWdJQ0FnSUNBZ2QybGtkR2dnUFNCM2FXUjBhQ3dnYUdWcFoyaDBJRDBnYUdWcFoyaDBLVnh1Y0hKcGJuUW9jQ2xjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgXG4gICAgICAgIHdpZHRoID0gd2lkdGgsIGhlaWdodCA9IGhlaWdodClcbnByaW50KHApXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCBcbiAgICAgICAgd2lkdGggPSB3aWR0aCwgaGVpZ2h0ID0gaGVpZ2h0KVxucHJpbnQocClcbmBgYCJ9 -->

```r
svglite(here(figDir, paste0(fileName, ".svg")), 
        width = width, height = height)
print(p)
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVaR1YyTG05bVppZ3BYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmRldi5vZmYoKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZGV2Lm9mZigpXG5gYGAifQ== -->

```r
dev.off()
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoibnVsbCBkZXZpY2UgXG4gICAgICAgICAgMSBcbiJ9 -->

```
null device 
          1 
```



<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



## EXPLORATORY
### Chromosight scores
#### Scatterplots

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZV3h3YUdFZ1BDMGdNQzR3TlZ4dVptTkRkWFJ2Wm1ZZ1BDMGdNQzQxWEc1Y2JtTnZiVzF2Ymt4dmIzQkVhWElnUEMwZ2FHVnlaU2hjSWk0dUwyUmhkR0V2Ykc5dmNGOWhibUZzZVhOcGMxd2lLVnh1WkdsbVprUnBjaUE4TFNCb1pYSmxLRndpTGk0dlpHRjBZUzlTVGtGZlpHbG1abHdpS1Z4dWJtRnRaU0E4TFNCY0ltTm9jbTl0YjNOcFoyaDBYQ0pjYm1kbGJtVkJibTV2UkdGMFlTQThMU0JzYjJGa1RHOXZjRUZ1Ym05RVlYUmhLR2hsY21Vb1kyOXRiVzl1VEc5dmNFUnBjaXdnY0dGemRHVXdLRndpYkc5dmNGTmpiM0psWDF3aUxDQnVZVzFsTENCY0lsOXdMVzVmYzJsdGNHeGxYMlZ1YzJWdFlteE1hWE4wTG5SemRsd2lLU2twSUNVK0pWeHVJQ0JrY0d4NWNqbzZiWFYwWVhSbEtHUnBabVlnUFNCelkyOXlaVjlrVkVGSElDMGdjMk52Y21WZlJFMVRUeWxjYmx4dVpHbG1aaTVTVGtFZ1BDMGdabkpsWVdRb2FHVnlaU2hrYVdabVJHbHlMQ0JjSW1ScFptWmZSekV1WkZSQlIxOUhNUzR5YVM1a1ZFRkhYM1p6WDBjeExqSnBMa1JOVTA4dWRITjJYQ0lwS1NBbFBpVmNiaUFnWkhCc2VYSTZPbk5sYkdWamRDaGxibk5sYldKc1gyZGxibVZmYVdRc0lHeHZaekpHYjJ4a1EyaGhibWRsTENCemFISnBibXRsWkY5c2IyY3lSa01zSUhCaFpHb3NJR1Y0ZEdWeWJtRnNYMmRsYm1WZmJtRnRaU2xjYm1kbGJtVk1hWE4wTG1SdmQyNHVVazVCSUR3dElDaGthV1ptTGxKT1FTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHphSEpwYm10bFpGOXNiMmN5UmtNZ1BEMGdNQ3dnY0dGa2FpQThJR0ZzY0doaEtTa2taVzV6WlcxaWJGOW5aVzVsWDJsa1hHNW5aVzVsVEdsemRDNTFjQzVTVGtFZ1BDMGdLR1JwWm1ZdVVrNUJJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLSE5vY21sdWEyVmtYMnh2WnpKR1F5QStJREFzSUhCaFpHb2dQQ0JoYkhCb1lTa3BKR1Z1YzJWdFlteGZaMlZ1WlY5cFpGeHVYRzVjYm0xaGVFeHZaekpHUXlBOExTQXlYRzVjYm5SbGJYQWdQQzBnWjJWdVpVRnVibTlFWVhSaElDVStKU0JrY0d4NWNqbzZjMlZzWldOMEtHUnBabVlzSUdkbGJtVXBJQ1UrSlNCY2JpQWdkVzV1WlhOMEtHZGxibVVwSUNVK0pTQm5jbTkxY0Y5aWVTaG5aVzVsS1NBbFBpVmNiaUFnYzNWdGJXRnlhWHBsS0cxbFlXNWZaR2xtWmw5elkyOXlaU0E5SUcxbFlXNG9aR2xtWmlrc0lDNW5jbTkxY0hNZ1BTQW5aSEp2Y0NjcFhHNWNiblJsYlhBZ1BDMGdiR1ZtZEY5cWIybHVLSFJsYlhBc0lHUnBabVl1VWs1QkxDQmllU0E5SUdNb1hDSm5aVzVsWENJZ1BTQmNJbVZ1YzJWdFlteGZaMlZ1WlY5cFpGd2lLU2tnSlQ0bElGeHVJQ0JrY0d4NWNqbzZiWFYwWVhSbEtHWnNZV2NnUFNCcFptVnNjMlVvWjJWdVpTQWxhVzRsSUdkbGJtVk1hWE4wTG1SdmQyNHVVazVCTENCY0lqSkVUMWRPWENJc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JwWm1Wc2MyVW9aMlZ1WlNBbGFXNGxJR2RsYm1WTWFYTjBMblZ3TGxKT1FTd2dYQ0l4VlZCY0lpd2dYQ0l3VGs5Y0lpa3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRzFoZUVac1lXY2dQU0FvWVdKektITm9jbWx1YTJWa1gyeHZaekpHUXlrZ1BpQnRZWGhNYjJjeVJrTXBMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJSE5vY214dlp6Sm1ZMDFoZUNBOUlIQnRZWGdvY0cxcGJpaHphSEpwYm10bFpGOXNiMmN5UmtNc0lHMWhlRXh2WnpKR1F5a3NJQzF0WVhoTWIyY3lSa01wS1NBbFBpVWdYRzRnSUdSd2JIbHlPanBoY25KaGJtZGxLR1pzWVdjcFhHNWNibkFnUEMwZ1oyZHdiRzkwS0hSbGJYQXNJR0ZsY3loNElEMGdjMmh5Ykc5bk1tWmpUV0Y0TENCNUlEMGdiV1ZoYmw5a2FXWm1YM05qYjNKbExDQmpiMnh2Y2lBOUlHWnNZV2NzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiR0ZpWld3Z1BTQnBabVZzYzJVb1pteGhaeUFoUFNCY0lqQk9UMXdpTENCbGVIUmxjbTVoYkY5blpXNWxYMjVoYldVc0lFNUJLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnphR0Z3WlNBOUlHRnpMbVpoWTNSdmNpaHRZWGhHYkdGbktTa3BJQ3RjYmlBZ1oyVnZiVjl3YjJsdWRDZ3BJQ3NnWjJWdmJWOTBaWGgwWDNKbGNHVnNLQ2tnS3lCMGFHVnRaVjlqYkdGemMybGpLQ2tnSzF4dUlDQm5aM1JwZEd4bEtIQmhjM1JsTUNodVlXMWxMQ0JjSWw5elkyOXlaVjl6YVcxd2JHVkJibTV2WENJcEtTQXJYRzRnSUdkbGIyMWZhR3hwYm1Vb2VXbHVkR1Z5WTJWd2RDQTlJREFwSUN0Y2JpQWdaMlZ2YlY5b2JHbHVaU2g1YVc1MFpYSmpaWEIwSUQwZ1pHbG1aa04xZEc5bVppd2diR2x1WlhSNWNHVWdQU0JjSW1SaGMyaGxaRndpS1NBclhHNGdJR2RsYjIxZmFHeHBibVVvZVdsdWRHVnlZMlZ3ZENBOUlDMGdaR2xtWmtOMWRHOW1aaXdnYkdsdVpYUjVjR1VnUFNCY0ltUmhjMmhsWkZ3aUtTQXJYRzRnSUdkbGIyMWZkbXhwYm1Vb2VHbHVkR1Z5WTJWd2RDQTlJREFwSUN0Y2JpQWdaMlZ2YlY5MmJHbHVaU2g0YVc1MFpYSmpaWEIwSUQwZ1ptTkRkWFJ2Wm1Zc0lHeHBibVYwZVhCbElEMGdYQ0prWVhOb1pXUmNJaWtnSzF4dUlDQm5aVzl0WDNac2FXNWxLSGhwYm5SbGNtTmxjSFFnUFNBdFptTkRkWFJ2Wm1Zc0lHeHBibVYwZVhCbElEMGdYQ0prWVhOb1pXUmNJaWtnSzF4dUlDQnpZMkZzWlY5amIyeHZjbDl0WVc1MVlXd29kbUZzZFdWeklEMGdZeWhjSWpCT1Qxd2lJRDBnWENKbmNtVjVYQ0lzSUZ3aU1WVlFYQ0lnUFNCY0luSmxaRndpTENCY0lqSkVUMWRPWENJZ1BTQmNJbUpzZFdWY0lpa3BJQ3NnSUNNZ1EyOXljbVZqZEdWa0lHTnZiRzl5SUcxaGNIQnBibWRjYmlBZ2MyTmhiR1ZmYzJoaGNHVmZiV0Z1ZFdGc0tIWmhiSFZsY3lBOUlHTW9YQ0pVVWxWRlhDSWdQU0F5TENCY0lrWkJURk5GWENJZ1BTQXhPU2twWEc1Y2JtWnBiR1ZPWVcxbElEd3RJSEJoYzNSbE1DaGNJbEpPUVhaelRHOXZjRjljSWl3Z2JtRnRaU3dnWENKZmMyTnZjbVZmYzJsdGNHeGxRVzV1YjF3aUtWeHVhR1ZwWjJoMElEd3RJRFJjYm5kcFpIUm9JRHd0SURkY2JuQnVaeWhvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY0lpNXdibWRjSWlrcExDQnlaWE1nUFNBMk1EQXNJSFZ1YVhRZ1BTQmNJbWx1WENJc0lHaGxhV2RvZENBOUlHaGxhV2RvZEN3Z2QybGtkR2dnUFNCM2FXUjBhQ2xjYm5CeWFXNTBLSEFwWEc1a1pYWXViMlptS0NsY2JuTjJaMnhwZEdVb2FHVnlaU2htYVdkRWFYSXNJSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYQ0l1YzNablhDSXBLU3dnSUdobGFXZG9kQ0E5SUdobGFXZG9kQ3dnZDJsa2RHZ2dQU0IzYVdSMGFDbGNibkJ5YVc1MEtIQXBYRzVrWlhZdWIyWm1LQ2xjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbmFscGhhIDwtIDAuMDVcbmZjQ3V0b2ZmIDwtIDAuNVxuXG5jb21tb25Mb29wRGlyIDwtIGhlcmUoXFwuLi9kYXRhL2xvb3BfYW5hbHlzaXNcXClcbmRpZmZEaXIgPC0gaGVyZShcXC4uL2RhdGEvUk5BX2RpZmZcXClcbm5hbWUgPC0gXFxjaHJvbW9zaWdodFxcXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbW1vbkxvb3BEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9cXCwgbmFtZSwgXFxfcC1uX3NpbXBsZV9lbnNlbWJsTGlzdC50c3ZcXCkpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShkaWZmID0gc2NvcmVfZFRBRyAtIHNjb3JlX0RNU08pXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUoZGlmZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibF9nZW5lX2lkLCBsb2cyRm9sZENoYW5nZSwgc2hyaW5rZWRfbG9nMkZDLCBwYWRqLCBleHRlcm5hbF9nZW5lX25hbWUpXG5nZW5lTGlzdC5kb3duLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDIDw9IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuZ2VuZUxpc3QudXAuUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPiAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcblxuXG5tYXhMb2cyRkMgPC0gMlxuXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmYpLCAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHBseXI6Om11dGF0ZShmbGFnID0gaWZlbHNlKGdlbmUgJWluJSBnZW5lTGlzdC5kb3duLlJOQSwgXFwyRE9XTlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lTGlzdC51cC5STkEsIFxcMVVQXFwsIFxcME5PXFwpKSxcbiAgICAgICAgICAgICAgICBtYXhGbGFnID0gKGFicyhzaHJpbmtlZF9sb2cyRkMpID4gbWF4TG9nMkZDKSxcbiAgICAgICAgICAgICAgICBzaHJsb2cyZmNNYXggPSBwbWF4KHBtaW4oc2hyaW5rZWRfbG9nMkZDLCBtYXhMb2cyRkMpLCAtbWF4TG9nMkZDKSkgJT4lIFxuICBkcGx5cjo6YXJyYW5nZShmbGFnKVxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHNocmxvZzJmY01heCwgeSA9IG1lYW5fZGlmZl9zY29yZSwgY29sb3IgPSBmbGFnLFxuICAgICAgICAgICAgICAgICAgICAgIGxhYmVsID0gaWZlbHNlKGZsYWcgIT0gXFwwTk9cXCwgZXh0ZXJuYWxfZ2VuZV9uYW1lLCBOQSksXG4gICAgICAgICAgICAgICAgICAgICAgc2hhcGUgPSBhcy5mYWN0b3IobWF4RmxhZykpKSArXG4gIGdlb21fcG9pbnQoKSArIGdlb21fdGV4dF9yZXBlbCgpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgZ2d0aXRsZShwYXN0ZTAobmFtZSwgXFxfc2NvcmVfc2ltcGxlQW5ub1xcKSkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAtIGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IGZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gLWZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgc2NhbGVfY29sb3JfbWFudWFsKHZhbHVlcyA9IGMoXFwwTk9cXCA9IFxcZ3JleVxcLCBcXDFVUFxcID0gXFxyZWRcXCwgXFwyRE9XTlxcID0gXFxibHVlXFwpKSArICAjIENvcnJlY3RlZCBjb2xvciBtYXBwaW5nXG4gIHNjYWxlX3NoYXBlX21hbnVhbCh2YWx1ZXMgPSBjKFxcVFJVRVxcID0gMiwgXFxGQUxTRVxcID0gMTkpKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxSTkF2c0xvb3BfXFwsIG5hbWUsIFxcX3Njb3JlX3NpbXBsZUFubm9cXClcbmhlaWdodCA8LSA0XG53aWR0aCA8LSA3XG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
alpha <- 0.05
fcCutoff <- 0.5

commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \chromosight\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_simple_ensemblList.tsv\))) %>%
  dplyr::mutate(diff = score_dTAG - score_DMSO)

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_score_simpleAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_score_simpleAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVlXeHdhR0VnUEMwZ01DNHdOVnh1Wm1ORGRYUnZabVlnUEMwZ01DNDFYRzVjYm1OdmJXMXZia3h2YjNCRWFYSWdQQzBnYUdWeVpTaGNYQzR1TDJSaGRHRXZiRzl2Y0Y5aGJtRnNlWE5wYzF4Y0tWeHVaR2xtWmtScGNpQThMU0JvWlhKbEtGeGNMaTR2WkdGMFlTOVNUa0ZmWkdsbVpseGNLVnh1Ym1GdFpTQThMU0JjWEdOb2NtOXRiM05wWjJoMFhGeGNibWRsYm1WQmJtNXZSR0YwWVNBOExTQnNiMkZrVEc5dmNFRnVibTlFWVhSaEtHaGxjbVVvWTI5dGJXOXVURzl2Y0VScGNpd2djR0Z6ZEdVd0tGeGNiRzl2Y0ZOamIzSmxYMXhjTENCdVlXMWxMQ0JjWEY5d0xXNWZjMmx0Y0d4bFgyVnVjMlZ0WW14TWFYTjBMblJ6ZGx4Y0tTa3BJQ1UrSlZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0dScFptWWdQU0J6WTI5eVpWOWtWRUZISUMwZ2MyTnZjbVZmUkUxVFR5bGNibHh1WkdsbVppNVNUa0VnUEMwZ1puSmxZV1FvYUdWeVpTaGthV1ptUkdseUxDQmNYR1JwWm1aZlJ6RXVaRlJCUjE5SE1TNHlhUzVrVkVGSFgzWnpYMGN4TGpKcExrUk5VMDh1ZEhOMlhGd3BLU0FsUGlWY2JpQWdaSEJzZVhJNk9uTmxiR1ZqZENobGJuTmxiV0pzWDJkbGJtVmZhV1FzSUd4dlp6SkdiMnhrUTJoaGJtZGxMQ0J6YUhKcGJtdGxaRjlzYjJjeVJrTXNJSEJoWkdvc0lHVjRkR1Z5Ym1Gc1gyZGxibVZmYm1GdFpTbGNibWRsYm1WTWFYTjBMbVJ2ZDI0dVVrNUJJRHd0SUNoa2FXWm1MbEpPUVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2loemFISnBibXRsWkY5c2IyY3lSa01nUEQwZ01Dd2djR0ZrYWlBOElHRnNjR2hoS1Nra1pXNXpaVzFpYkY5blpXNWxYMmxrWEc1blpXNWxUR2x6ZEM1MWNDNVNUa0VnUEMwZ0tHUnBabVl1VWs1QklDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtITm9jbWx1YTJWa1gyeHZaekpHUXlBK0lEQXNJSEJoWkdvZ1BDQmhiSEJvWVNrcEpHVnVjMlZ0WW14ZloyVnVaVjlwWkZ4dVhHNWNibTFoZUV4dlp6SkdReUE4TFNBeVhHNWNiblJsYlhBZ1BDMGdaMlZ1WlVGdWJtOUVZWFJoSUNVK0pTQmtjR3g1Y2pvNmMyVnNaV04wS0dScFptWXNJR2RsYm1VcElDVStKU0JjYmlBZ2RXNXVaWE4wS0dkbGJtVXBJQ1UrSlNCbmNtOTFjRjlpZVNoblpXNWxLU0FsUGlWY2JpQWdjM1Z0YldGeWFYcGxLRzFsWVc1ZlpHbG1abDl6WTI5eVpTQTlJRzFsWVc0b1pHbG1aaWtzSUM1bmNtOTFjSE1nUFNBblpISnZjQ2NwWEc1Y2JuUmxiWEFnUEMwZ2JHVm1kRjlxYjJsdUtIUmxiWEFzSUdScFptWXVVazVCTENCaWVTQTlJR01vWEZ4blpXNWxYRndnUFNCY1hHVnVjMlZ0WW14ZloyVnVaVjlwWkZ4Y0tTa2dKVDRsSUZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0dac1lXY2dQU0JwWm1Wc2MyVW9aMlZ1WlNBbGFXNGxJR2RsYm1WTWFYTjBMbVJ2ZDI0dVVrNUJMQ0JjWERKRVQxZE9YRndzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnBabVZzYzJVb1oyVnVaU0FsYVc0bElHZGxibVZNYVhOMExuVndMbEpPUVN3Z1hGd3hWVkJjWEN3Z1hGd3dUazljWENrcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHMWhlRVpzWVdjZ1BTQW9ZV0p6S0hOb2NtbHVhMlZrWDJ4dlp6SkdReWtnUGlCdFlYaE1iMmN5UmtNcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lITm9jbXh2WnpKbVkwMWhlQ0E5SUhCdFlYZ29jRzFwYmloemFISnBibXRsWkY5c2IyY3lSa01zSUcxaGVFeHZaekpHUXlrc0lDMXRZWGhNYjJjeVJrTXBLU0FsUGlVZ1hHNGdJR1J3YkhseU9qcGhjbkpoYm1kbEtHWnNZV2NwWEc1Y2JuQWdQQzBnWjJkd2JHOTBLSFJsYlhBc0lHRmxjeWg0SUQwZ2MyaHliRzluTW1aalRXRjRMQ0I1SUQwZ2JXVmhibDlrYVdabVgzTmpiM0psTENCamIyeHZjaUE5SUdac1lXY3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JHRmlaV3dnUFNCcFptVnNjMlVvWm14aFp5QWhQU0JjWERCT1QxeGNMQ0JsZUhSbGNtNWhiRjluWlc1bFgyNWhiV1VzSUU1QktTeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCemFHRndaU0E5SUdGekxtWmhZM1J2Y2lodFlYaEdiR0ZuS1NrcElDdGNiaUFnWjJWdmJWOXdiMmx1ZENncElDc2daMlZ2YlY5MFpYaDBYM0psY0dWc0tDa2dLeUIwYUdWdFpWOWpiR0Z6YzJsaktDa2dLMXh1SUNCblozUnBkR3hsS0hCaGMzUmxNQ2h1WVcxbExDQmNYRjl6WTI5eVpWOXphVzF3YkdWQmJtNXZYRndwS1NBclhHNGdJR2RsYjIxZmFHeHBibVVvZVdsdWRHVnlZMlZ3ZENBOUlEQXBJQ3RjYmlBZ1oyVnZiVjlvYkdsdVpTaDVhVzUwWlhKalpYQjBJRDBnWkdsbVprTjFkRzltWml3Z2JHbHVaWFI1Y0dVZ1BTQmNYR1JoYzJobFpGeGNLU0FyWEc0Z0lHZGxiMjFmYUd4cGJtVW9lV2x1ZEdWeVkyVndkQ0E5SUMwZ1pHbG1aa04xZEc5bVppd2diR2x1WlhSNWNHVWdQU0JjWEdSaGMyaGxaRnhjS1NBclhHNGdJR2RsYjIxZmRteHBibVVvZUdsdWRHVnlZMlZ3ZENBOUlEQXBJQ3RjYmlBZ1oyVnZiVjkyYkdsdVpTaDRhVzUwWlhKalpYQjBJRDBnWm1ORGRYUnZabVlzSUd4cGJtVjBlWEJsSUQwZ1hGeGtZWE5vWldSY1hDa2dLMXh1SUNCblpXOXRYM1pzYVc1bEtIaHBiblJsY21ObGNIUWdQU0F0Wm1ORGRYUnZabVlzSUd4cGJtVjBlWEJsSUQwZ1hGeGtZWE5vWldSY1hDa2dLMXh1SUNCelkyRnNaVjlqYjJ4dmNsOXRZVzUxWVd3b2RtRnNkV1Z6SUQwZ1l5aGNYREJPVDF4Y0lEMGdYRnhuY21WNVhGd3NJRnhjTVZWUVhGd2dQU0JjWEhKbFpGeGNMQ0JjWERKRVQxZE9YRndnUFNCY1hHSnNkV1ZjWENrcElDc2dJQ01nUTI5eWNtVmpkR1ZrSUdOdmJHOXlJRzFoY0hCcGJtZGNiaUFnYzJOaGJHVmZjMmhoY0dWZmJXRnVkV0ZzS0haaGJIVmxjeUE5SUdNb1hGeFVVbFZGWEZ3Z1BTQXlMQ0JjWEVaQlRGTkZYRndnUFNBeE9Ta3BYRzVjYm1acGJHVk9ZVzFsSUR3dElIQmhjM1JsTUNoY1hGSk9RWFp6VEc5dmNGOWNYQ3dnYm1GdFpTd2dYRnhmYzJOdmNtVmZjMmx0Y0d4bFFXNXViMXhjS1Z4dWFHVnBaMmgwSUR3dElEUmNibmRwWkhSb0lEd3RJRGRjYm5CdVp5aG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjWEM1d2JtZGNYQ2twTENCeVpYTWdQU0EyTURBc0lIVnVhWFFnUFNCY1hHbHVYRndzSUdobGFXZG9kQ0E5SUdobGFXZG9kQ3dnZDJsa2RHZ2dQU0IzYVdSMGFDbGNibkJ5YVc1MEtIQXBYRzVrWlhZdWIyWm1LQ2xjYm5OMloyeHBkR1VvYUdWeVpTaG1hV2RFYVhJc0lIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hGd3VjM1puWEZ3cEtTd2dJR2hsYVdkb2RDQTlJR2hsYVdkb2RDd2dkMmxrZEdnZ1BTQjNhV1IwYUNsY2JuQnlhVzUwS0hBcFhHNWtaWFl1YjJabUtDbGNibUJnWUZ4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG5gYGByXG5hbHBoYSA8LSAwLjA1XG5mY0N1dG9mZiA8LSAwLjVcblxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcY2hyb21vc2lnaHRcXFxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb21tb25Mb29wRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIG5hbWUsIFxcX3Atbl9zaW1wbGVfZW5zZW1ibExpc3QudHN2XFwpKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoZGlmZiA9IHNjb3JlX2RUQUcgLSBzY29yZV9ETVNPKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKGRpZmZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuZ2VuZUxpc3QuZG93bi5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA8PSAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcbmdlbmVMaXN0LnVwLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDID4gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5cblxubWF4TG9nMkZDIDwtIDJcblxudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZiwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmKSwgLmdyb3VwcyA9ICdkcm9wJylcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcXGdlbmVcXCA9IFxcZW5zZW1ibF9nZW5lX2lkXFwpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoZmxhZyA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QuZG93bi5STkEsIFxcMkRPV05cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QudXAuUk5BLCBcXDFVUFxcLCBcXDBOT1xcKSksXG4gICAgICAgICAgICAgICAgbWF4RmxhZyA9IChhYnMoc2hyaW5rZWRfbG9nMkZDKSA+IG1heExvZzJGQyksXG4gICAgICAgICAgICAgICAgc2hybG9nMmZjTWF4ID0gcG1heChwbWluKHNocmlua2VkX2xvZzJGQywgbWF4TG9nMkZDKSwgLW1heExvZzJGQykpICU+JSBcbiAgZHBseXI6OmFycmFuZ2UoZmxhZylcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBzaHJsb2cyZmNNYXgsIHkgPSBtZWFuX2RpZmZfc2NvcmUsIGNvbG9yID0gZmxhZyxcbiAgICAgICAgICAgICAgICAgICAgICBsYWJlbCA9IGlmZWxzZShmbGFnICE9IFxcME5PXFwsIGV4dGVybmFsX2dlbmVfbmFtZSwgTkEpLFxuICAgICAgICAgICAgICAgICAgICAgIHNoYXBlID0gYXMuZmFjdG9yKG1heEZsYWcpKSkgK1xuICBnZW9tX3BvaW50KCkgKyBnZW9tX3RleHRfcmVwZWwoKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdndGl0bGUocGFzdGUwKG5hbWUsIFxcX3Njb3JlX3NpbXBsZUFubm9cXCkpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gLSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBmY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IC1mY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIHNjYWxlX2NvbG9yX21hbnVhbCh2YWx1ZXMgPSBjKFxcME5PXFwgPSBcXGdyZXlcXCwgXFwxVVBcXCA9IFxccmVkXFwsIFxcMkRPV05cXCA9IFxcYmx1ZVxcKSkgKyAgIyBDb3JyZWN0ZWQgY29sb3IgbWFwcGluZ1xuICBzY2FsZV9zaGFwZV9tYW51YWwodmFsdWVzID0gYyhcXFRSVUVcXCA9IDIsIFxcRkFMU0VcXCA9IDE5KSlcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcUk5BdnNMb29wX1xcLCBuYW1lLCBcXF9zY29yZV9zaW1wbGVBbm5vXFwpXG5oZWlnaHQgPC0gNFxud2lkdGggPC0gN1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5cbmNvbW1vbkxvb3BEaXIgPC0gaGVyZShcXC4uL2RhdGEvbG9vcF9hbmFseXNpc1xcKVxuZGlmZkRpciA8LSBoZXJlKFxcLi4vZGF0YS9STkFfZGlmZlxcKVxubmFtZSA8LSBcXGNocm9tb3NpZ2h0XFxcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBuYW1lLCBcXF9wLW5fc2ltcGxlX2Vuc2VtYmxMaXN0LnRzdlxcKSkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGRpZmYgPSBzY29yZV9kVEFHIC0gc2NvcmVfRE1TTylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShkaWZmRGlyLCBcXGRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcbmdlbmVMaXN0LmRvd24uUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPD0gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5nZW5lTGlzdC51cC5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA+IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuXG5cbm1heExvZzJGQyA8LSAyXG5cbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmYsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZiksIC5ncm91cHMgPSAnZHJvcCcpXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGZsYWcgPSBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LmRvd24uUk5BLCBcXDJET1dOXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LnVwLlJOQSwgXFwxVVBcXCwgXFwwTk9cXCkpLFxuICAgICAgICAgICAgICAgIG1heEZsYWcgPSAoYWJzKHNocmlua2VkX2xvZzJGQykgPiBtYXhMb2cyRkMpLFxuICAgICAgICAgICAgICAgIHNocmxvZzJmY01heCA9IHBtYXgocG1pbihzaHJpbmtlZF9sb2cyRkMsIG1heExvZzJGQyksIC1tYXhMb2cyRkMpKSAlPiUgXG4gIGRwbHlyOjphcnJhbmdlKGZsYWcpXG5cbnAgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gc2hybG9nMmZjTWF4LCB5ID0gbWVhbl9kaWZmX3Njb3JlLCBjb2xvciA9IGZsYWcsXG4gICAgICAgICAgICAgICAgICAgICAgbGFiZWwgPSBpZmVsc2UoZmxhZyAhPSBcXDBOT1xcLCBleHRlcm5hbF9nZW5lX25hbWUsIE5BKSxcbiAgICAgICAgICAgICAgICAgICAgICBzaGFwZSA9IGFzLmZhY3RvcihtYXhGbGFnKSkpICtcbiAgZ2VvbV9wb2ludCgpICsgZ2VvbV90ZXh0X3JlcGVsKCkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICBnZ3RpdGxlKHBhc3RlMChuYW1lLCBcXF9zY29yZV9zaW1wbGVBbm5vXFwpKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IC0gZGlmZkN1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDApICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gZmNDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAtZmNDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBzY2FsZV9jb2xvcl9tYW51YWwodmFsdWVzID0gYyhcXDBOT1xcID0gXFxncmV5XFwsIFxcMVVQXFwgPSBcXHJlZFxcLCBcXDJET1dOXFwgPSBcXGJsdWVcXCkpICsgICMgQ29ycmVjdGVkIGNvbG9yIG1hcHBpbmdcbiAgc2NhbGVfc2hhcGVfbWFudWFsKHZhbHVlcyA9IGMoXFxUUlVFXFwgPSAyLCBcXEZBTFNFXFwgPSAxOSkpXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXFJOQXZzTG9vcF9cXCwgbmFtZSwgXFxfc2NvcmVfc2ltcGxlQW5ub1xcKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDdcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
alpha <- 0.05
fcCutoff <- 0.5

commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \chromosight\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_simple_ensemblList.tsv\))) %>%
  dplyr::mutate(diff = score_dTAG - score_DMSO)

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_score_simpleAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_score_simpleAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### RNA-seq loopscore scatterplot

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZV3h3YUdFZ1BDMGdNQzR3TlZ4dVptTkRkWFJ2Wm1ZZ1BDMGdNQzQxWEc1Y2JtTnZiVzF2Ymt4dmIzQkVhWElnUEMwZ2FHVnlaU2hjSWk0dUwyUmhkR0V2Ykc5dmNGOWhibUZzZVhOcGMxd2lLVnh1WkdsbVprUnBjaUE4TFNCb1pYSmxLRndpTGk0dlpHRjBZUzlTVGtGZlpHbG1abHdpS1Z4dWJtRnRaU0E4TFNCY0ltTm9jbTl0YjNOcFoyaDBYQ0pjYm1kbGJtVkJibTV2UkdGMFlTQThMU0JzYjJGa1RHOXZjRUZ1Ym05RVlYUmhLR2hsY21Vb1kyOXRiVzl1VEc5dmNFUnBjaXdnY0dGemRHVXdLRndpYkc5dmNGTmpiM0psWDF3aUxDQnVZVzFsTENCY0lsOXdMVzVmWTI5dGNHeGxlRjlsYm5ObGJXSnNUR2x6ZEM1MGMzWmNJaWtwS1NBbFBpVmNiaUFnWkhCc2VYSTZPbTExZEdGMFpTaGthV1ptSUQwZ2MyTnZjbVZmWkZSQlJ5QXRJSE5qYjNKbFgwUk5VMDhwWEc1Y2JtUnBabVl1VWs1QklEd3RJR1p5WldGa0tHaGxjbVVvWkdsbVprUnBjaXdnWENKa2FXWm1YMGN4TG1SVVFVZGZSekV1TW1rdVpGUkJSMTkyYzE5SE1TNHlhUzVFVFZOUExuUnpkbHdpS1NrZ0pUNGxYRzRnSUdSd2JIbHlPanB6Wld4bFkzUW9aVzV6WlcxaWJGOW5aVzVsWDJsa0xDQnNiMmN5Um05c1pFTm9ZVzVuWlN3Z2MyaHlhVzVyWldSZmJHOW5Na1pETENCd1lXUnFMQ0JsZUhSbGNtNWhiRjluWlc1bFgyNWhiV1VwWEc1blpXNWxUR2x6ZEM1a2IzZHVMbEpPUVNBOExTQW9aR2xtWmk1U1RrRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9jMmh5YVc1clpXUmZiRzluTWtaRElEdzlJREFzSUhCaFpHb2dQQ0JoYkhCb1lTa3BKR1Z1YzJWdFlteGZaMlZ1WlY5cFpGeHVaMlZ1WlV4cGMzUXVkWEF1VWs1QklEd3RJQ2hrYVdabUxsSk9RU0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWh6YUhKcGJtdGxaRjlzYjJjeVJrTWdQaUF3TENCd1lXUnFJRHdnWVd4d2FHRXBLU1JsYm5ObGJXSnNYMmRsYm1WZmFXUmNibHh1WEc1dFlYaE1iMmN5UmtNZ1BDMGdNbHh1WEc1MFpXMXdJRHd0SUdkbGJtVkJibTV2UkdGMFlTQWxQaVVnWkhCc2VYSTZPbk5sYkdWamRDaGthV1ptTENCblpXNWxLU0FsUGlVZ1hHNGdJSFZ1Ym1WemRDaG5aVzVsS1NBbFBpVWdaM0p2ZFhCZllua29aMlZ1WlNrZ0pUNGxYRzRnSUhOMWJXMWhjbWw2WlNodFpXRnVYMlJwWm1aZmMyTnZjbVVnUFNCdFpXRnVLR1JwWm1ZcExDQXVaM0p2ZFhCeklEMGdKMlJ5YjNBbktWeHVYRzUwWlcxd0lEd3RJR3hsWm5SZmFtOXBiaWgwWlcxd0xDQmthV1ptTGxKT1FTd2dZbmtnUFNCaktGd2laMlZ1WlZ3aUlEMGdYQ0psYm5ObGJXSnNYMmRsYm1WZmFXUmNJaWtwSUNVK0pTQmNiaUFnWkhCc2VYSTZPbTExZEdGMFpTaG1iR0ZuSUQwZ2FXWmxiSE5sS0dkbGJtVWdKV2x1SlNCblpXNWxUR2x6ZEM1a2IzZHVMbEpPUVN3Z1hDSXlSRTlYVGx3aUxGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0JuWlc1bFRHbHpkQzUxY0M1U1RrRXNJRndpTVZWUVhDSXNJRndpTUU1UFhDSXBLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J0WVhoR2JHRm5JRDBnS0dGaWN5aHphSEpwYm10bFpGOXNiMmN5UmtNcElENGdiV0Y0VEc5bk1rWkRLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J6YUhKc2IyY3labU5OWVhnZ1BTQndiV0Y0S0hCdGFXNG9jMmh5YVc1clpXUmZiRzluTWtaRExDQnRZWGhNYjJjeVJrTXBMQ0F0YldGNFRHOW5Na1pES1NrZ0pUNGxJRnh1SUNCa2NHeDVjam82WVhKeVlXNW5aU2htYkdGbktWeHVYRzV3SUR3dElHZG5jR3h2ZENoMFpXMXdMQ0JoWlhNb2VDQTlJSE5vY214dlp6Sm1ZMDFoZUN3Z2VTQTlJRzFsWVc1ZlpHbG1abDl6WTI5eVpTd2dZMjlzYjNJZ1BTQm1iR0ZuTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3hoWW1Wc0lEMGdhV1psYkhObEtHWnNZV2NnSVQwZ1hDSXdUazljSWl3Z1pYaDBaWEp1WVd4ZloyVnVaVjl1WVcxbExDQk9RU2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdjMmhoY0dVZ1BTQmhjeTVtWVdOMGIzSW9iV0Y0Um14aFp5a3BLU0FyWEc0Z0lHZGxiMjFmY0c5cGJuUW9LU0FySUdkbGIyMWZkR1Y0ZEY5eVpYQmxiQ2dwSUNzZ2RHaGxiV1ZmWTJ4aGMzTnBZeWdwSUN0Y2JpQWdaMmQwYVhSc1pTaHdZWE4wWlRBb2JtRnRaU3dnWENKZmMyTnZjbVZmWTI5dGNHeGxlRUZ1Ym05Y0lpa3BJQ3RjYmlBZ1oyVnZiVjlvYkdsdVpTaDVhVzUwWlhKalpYQjBJRDBnTUNrZ0sxeHVJQ0JuWlc5dFgyaHNhVzVsS0hscGJuUmxjbU5sY0hRZ1BTQmthV1ptUTNWMGIyWm1MQ0JzYVc1bGRIbHdaU0E5SUZ3aVpHRnphR1ZrWENJcElDdGNiaUFnWjJWdmJWOW9iR2x1WlNoNWFXNTBaWEpqWlhCMElEMGdMU0JrYVdabVEzVjBiMlptTENCc2FXNWxkSGx3WlNBOUlGd2laR0Z6YUdWa1hDSXBJQ3RjYmlBZ1oyVnZiVjkyYkdsdVpTaDRhVzUwWlhKalpYQjBJRDBnTUNrZ0sxeHVJQ0JuWlc5dFgzWnNhVzVsS0hocGJuUmxjbU5sY0hRZ1BTQm1ZME4xZEc5bVppd2diR2x1WlhSNWNHVWdQU0JjSW1SaGMyaGxaRndpS1NBclhHNGdJR2RsYjIxZmRteHBibVVvZUdsdWRHVnlZMlZ3ZENBOUlDMW1ZME4xZEc5bVppd2diR2x1WlhSNWNHVWdQU0JjSW1SaGMyaGxaRndpS1NBclhHNGdJSE5qWVd4bFgyTnZiRzl5WDIxaGJuVmhiQ2gyWVd4MVpYTWdQU0JqS0Z3aU1FNVBYQ0lnUFNCY0ltZHlaWGxjSWl3Z1hDSXhWVkJjSWlBOUlGd2ljbVZrWENJc0lGd2lNa1JQVjA1Y0lpQTlJRndpWW14MVpWd2lLU2tnS3lBZ0l5QkRiM0p5WldOMFpXUWdZMjlzYjNJZ2JXRndjR2x1WjF4dUlDQnpZMkZzWlY5emFHRndaVjl0WVc1MVlXd29kbUZzZFdWeklEMGdZeWhjSWxSU1ZVVmNJaUE5SURJc0lGd2lSa0ZNVTBWY0lpQTlJREU1S1NsY2JseHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRndpVWs1QmRuTk1iMjl3WDF3aUxDQnVZVzFsTENCY0lsOXpZMjl5WlY5amIyMXdiR1Y0UVc1dWIxd2lLVnh1YUdWcFoyaDBJRHd0SURSY2JuZHBaSFJvSUR3dElEZGNibkJ1Wnlob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNJaTV3Ym1kY0lpa3BMQ0J5WlhNZ1BTQTJNREFzSUhWdWFYUWdQU0JjSW1sdVhDSXNJR2hsYVdkb2RDQTlJR2hsYVdkb2RDd2dkMmxrZEdnZ1BTQjNhV1IwYUNsY2JuQnlhVzUwS0hBcFhHNWtaWFl1YjJabUtDbGNibk4yWjJ4cGRHVW9hR1Z5WlNobWFXZEVhWElzSUhCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWENJdWMzWm5YQ0lwS1N3Z0lHaGxhV2RvZENBOUlHaGxhV2RvZEN3Z2QybGtkR2dnUFNCM2FXUjBhQ2xjYm5CeWFXNTBLSEFwWEc1a1pYWXViMlptS0NsY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5hbHBoYSA8LSAwLjA1XG5mY0N1dG9mZiA8LSAwLjVcblxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcY2hyb21vc2lnaHRcXFxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb21tb25Mb29wRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIG5hbWUsIFxcX3Atbl9jb21wbGV4X2Vuc2VtYmxMaXN0LnRzdlxcKSkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGRpZmYgPSBzY29yZV9kVEFHIC0gc2NvcmVfRE1TTylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShkaWZmRGlyLCBcXGRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcbmdlbmVMaXN0LmRvd24uUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPD0gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5nZW5lTGlzdC51cC5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA+IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuXG5cbm1heExvZzJGQyA8LSAyXG5cbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmYsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZiksIC5ncm91cHMgPSAnZHJvcCcpXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGZsYWcgPSBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LmRvd24uUk5BLCBcXDJET1dOXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LnVwLlJOQSwgXFwxVVBcXCwgXFwwTk9cXCkpLFxuICAgICAgICAgICAgICAgIG1heEZsYWcgPSAoYWJzKHNocmlua2VkX2xvZzJGQykgPiBtYXhMb2cyRkMpLFxuICAgICAgICAgICAgICAgIHNocmxvZzJmY01heCA9IHBtYXgocG1pbihzaHJpbmtlZF9sb2cyRkMsIG1heExvZzJGQyksIC1tYXhMb2cyRkMpKSAlPiUgXG4gIGRwbHlyOjphcnJhbmdlKGZsYWcpXG5cbnAgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gc2hybG9nMmZjTWF4LCB5ID0gbWVhbl9kaWZmX3Njb3JlLCBjb2xvciA9IGZsYWcsXG4gICAgICAgICAgICAgICAgICAgICAgbGFiZWwgPSBpZmVsc2UoZmxhZyAhPSBcXDBOT1xcLCBleHRlcm5hbF9nZW5lX25hbWUsIE5BKSxcbiAgICAgICAgICAgICAgICAgICAgICBzaGFwZSA9IGFzLmZhY3RvcihtYXhGbGFnKSkpICtcbiAgZ2VvbV9wb2ludCgpICsgZ2VvbV90ZXh0X3JlcGVsKCkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICBnZ3RpdGxlKHBhc3RlMChuYW1lLCBcXF9zY29yZV9jb21wbGV4QW5ub1xcKSkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAtIGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IGZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gLWZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgc2NhbGVfY29sb3JfbWFudWFsKHZhbHVlcyA9IGMoXFwwTk9cXCA9IFxcZ3JleVxcLCBcXDFVUFxcID0gXFxyZWRcXCwgXFwyRE9XTlxcID0gXFxibHVlXFwpKSArICAjIENvcnJlY3RlZCBjb2xvciBtYXBwaW5nXG4gIHNjYWxlX3NoYXBlX21hbnVhbCh2YWx1ZXMgPSBjKFxcVFJVRVxcID0gMiwgXFxGQUxTRVxcID0gMTkpKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxSTkF2c0xvb3BfXFwsIG5hbWUsIFxcX3Njb3JlX2NvbXBsZXhBbm5vXFwpXG5oZWlnaHQgPC0gNFxud2lkdGggPC0gN1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
alpha <- 0.05
fcCutoff <- 0.5

commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \chromosight\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_complex_ensemblList.tsv\))) %>%
  dplyr::mutate(diff = score_dTAG - score_DMSO)

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_score_complexAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_score_complexAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVlXeHdhR0VnUEMwZ01DNHdOVnh1Wm1ORGRYUnZabVlnUEMwZ01DNDFYRzVjYm1OdmJXMXZia3h2YjNCRWFYSWdQQzBnYUdWeVpTaGNYQzR1TDJSaGRHRXZiRzl2Y0Y5aGJtRnNlWE5wYzF4Y0tWeHVaR2xtWmtScGNpQThMU0JvWlhKbEtGeGNMaTR2WkdGMFlTOVNUa0ZmWkdsbVpseGNLVnh1Ym1GdFpTQThMU0JjWEdOb2NtOXRiM05wWjJoMFhGeGNibWRsYm1WQmJtNXZSR0YwWVNBOExTQnNiMkZrVEc5dmNFRnVibTlFWVhSaEtHaGxjbVVvWTI5dGJXOXVURzl2Y0VScGNpd2djR0Z6ZEdVd0tGeGNiRzl2Y0ZOamIzSmxYMXhjTENCdVlXMWxMQ0JjWEY5d0xXNWZZMjl0Y0d4bGVGOWxibk5sYldKc1RHbHpkQzUwYzNaY1hDa3BLU0FsUGlWY2JpQWdaSEJzZVhJNk9tMTFkR0YwWlNoa2FXWm1JRDBnYzJOdmNtVmZaRlJCUnlBdElITmpiM0psWDBSTlUwOHBYRzVjYm1ScFptWXVVazVCSUR3dElHWnlaV0ZrS0dobGNtVW9aR2xtWmtScGNpd2dYRnhrYVdabVgwY3hMbVJVUVVkZlJ6RXVNbWt1WkZSQlIxOTJjMTlITVM0eWFTNUVUVk5QTG5SemRseGNLU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHpaV3hsWTNRb1pXNXpaVzFpYkY5blpXNWxYMmxrTENCc2IyY3lSbTlzWkVOb1lXNW5aU3dnYzJoeWFXNXJaV1JmYkc5bk1rWkRMQ0J3WVdScUxDQmxlSFJsY201aGJGOW5aVzVsWDI1aGJXVXBYRzVuWlc1bFRHbHpkQzVrYjNkdUxsSk9RU0E4TFNBb1pHbG1aaTVTVGtFZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb2MyaHlhVzVyWldSZmJHOW5Na1pESUR3OUlEQXNJSEJoWkdvZ1BDQmhiSEJvWVNrcEpHVnVjMlZ0WW14ZloyVnVaVjlwWkZ4dVoyVnVaVXhwYzNRdWRYQXVVazVCSUR3dElDaGthV1ptTGxKT1FTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHphSEpwYm10bFpGOXNiMmN5UmtNZ1BpQXdMQ0J3WVdScUlEd2dZV3h3YUdFcEtTUmxibk5sYldKc1gyZGxibVZmYVdSY2JseHVYRzV0WVhoTWIyY3lSa01nUEMwZ01seHVYRzUwWlcxd0lEd3RJR2RsYm1WQmJtNXZSR0YwWVNBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoa2FXWm1MQ0JuWlc1bEtTQWxQaVVnWEc0Z0lIVnVibVZ6ZENoblpXNWxLU0FsUGlVZ1ozSnZkWEJmWW5rb1oyVnVaU2tnSlQ0bFhHNGdJSE4xYlcxaGNtbDZaU2h0WldGdVgyUnBabVpmYzJOdmNtVWdQU0J0WldGdUtHUnBabVlwTENBdVozSnZkWEJ6SUQwZ0oyUnliM0FuS1Z4dVhHNTBaVzF3SUR3dElHeGxablJmYW05cGJpaDBaVzF3TENCa2FXWm1MbEpPUVN3Z1lua2dQU0JqS0Z4Y1oyVnVaVnhjSUQwZ1hGeGxibk5sYldKc1gyZGxibVZmYVdSY1hDa3BJQ1UrSlNCY2JpQWdaSEJzZVhJNk9tMTFkR0YwWlNobWJHRm5JRDBnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0JuWlc1bFRHbHpkQzVrYjNkdUxsSk9RU3dnWEZ3eVJFOVhUbHhjTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHZGxibVVnSldsdUpTQm5aVzVsVEdsemRDNTFjQzVTVGtFc0lGeGNNVlZRWEZ3c0lGeGNNRTVQWEZ3cEtTeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnRZWGhHYkdGbklEMGdLR0ZpY3loemFISnBibXRsWkY5c2IyY3lSa01wSUQ0Z2JXRjRURzluTWtaREtTeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnphSEpzYjJjeVptTk5ZWGdnUFNCd2JXRjRLSEJ0YVc0b2MyaHlhVzVyWldSZmJHOW5Na1pETENCdFlYaE1iMmN5UmtNcExDQXRiV0Y0VEc5bk1rWkRLU2tnSlQ0bElGeHVJQ0JrY0d4NWNqbzZZWEp5WVc1blpTaG1iR0ZuS1Z4dVhHNXdJRHd0SUdkbmNHeHZkQ2gwWlcxd0xDQmhaWE1vZUNBOUlITm9jbXh2WnpKbVkwMWhlQ3dnZVNBOUlHMWxZVzVmWkdsbVpsOXpZMjl5WlN3Z1kyOXNiM0lnUFNCbWJHRm5MRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHeGhZbVZzSUQwZ2FXWmxiSE5sS0dac1lXY2dJVDBnWEZ3d1RrOWNYQ3dnWlhoMFpYSnVZV3hmWjJWdVpWOXVZVzFsTENCT1FTa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2MyaGhjR1VnUFNCaGN5NW1ZV04wYjNJb2JXRjRSbXhoWnlrcEtTQXJYRzRnSUdkbGIyMWZjRzlwYm5Rb0tTQXJJR2RsYjIxZmRHVjRkRjl5WlhCbGJDZ3BJQ3NnZEdobGJXVmZZMnhoYzNOcFl5Z3BJQ3RjYmlBZ1oyZDBhWFJzWlNod1lYTjBaVEFvYm1GdFpTd2dYRnhmYzJOdmNtVmZZMjl0Y0d4bGVFRnVibTljWENrcElDdGNiaUFnWjJWdmJWOW9iR2x1WlNoNWFXNTBaWEpqWlhCMElEMGdNQ2tnSzF4dUlDQm5aVzl0WDJoc2FXNWxLSGxwYm5SbGNtTmxjSFFnUFNCa2FXWm1RM1YwYjJabUxDQnNhVzVsZEhsd1pTQTlJRnhjWkdGemFHVmtYRndwSUN0Y2JpQWdaMlZ2YlY5b2JHbHVaU2g1YVc1MFpYSmpaWEIwSUQwZ0xTQmthV1ptUTNWMGIyWm1MQ0JzYVc1bGRIbHdaU0E5SUZ4Y1pHRnphR1ZrWEZ3cElDdGNiaUFnWjJWdmJWOTJiR2x1WlNoNGFXNTBaWEpqWlhCMElEMGdNQ2tnSzF4dUlDQm5aVzl0WDNac2FXNWxLSGhwYm5SbGNtTmxjSFFnUFNCbVkwTjFkRzltWml3Z2JHbHVaWFI1Y0dVZ1BTQmNYR1JoYzJobFpGeGNLU0FyWEc0Z0lHZGxiMjFmZG14cGJtVW9lR2x1ZEdWeVkyVndkQ0E5SUMxbVkwTjFkRzltWml3Z2JHbHVaWFI1Y0dVZ1BTQmNYR1JoYzJobFpGeGNLU0FyWEc0Z0lITmpZV3hsWDJOdmJHOXlYMjFoYm5WaGJDaDJZV3gxWlhNZ1BTQmpLRnhjTUU1UFhGd2dQU0JjWEdkeVpYbGNYQ3dnWEZ3eFZWQmNYQ0E5SUZ4Y2NtVmtYRndzSUZ4Y01rUlBWMDVjWENBOUlGeGNZbXgxWlZ4Y0tTa2dLeUFnSXlCRGIzSnlaV04wWldRZ1kyOXNiM0lnYldGd2NHbHVaMXh1SUNCelkyRnNaVjl6YUdGd1pWOXRZVzUxWVd3b2RtRnNkV1Z6SUQwZ1l5aGNYRlJTVlVWY1hDQTlJRElzSUZ4Y1JrRk1VMFZjWENBOUlERTVLU2xjYmx4dVptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGeGNVazVCZG5OTWIyOXdYMXhjTENCdVlXMWxMQ0JjWEY5elkyOXlaVjlqYjIxd2JHVjRRVzV1YjF4Y0tWeHVhR1ZwWjJoMElEd3RJRFJjYm5kcFpIUm9JRHd0SURkY2JuQnVaeWhvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY1hDNXdibWRjWENrcExDQnlaWE1nUFNBMk1EQXNJSFZ1YVhRZ1BTQmNYR2x1WEZ3c0lHaGxhV2RvZENBOUlHaGxhV2RvZEN3Z2QybGtkR2dnUFNCM2FXUjBhQ2xjYm5CeWFXNTBLSEFwWEc1a1pYWXViMlptS0NsY2JuTjJaMnhwZEdVb2FHVnlaU2htYVdkRWFYSXNJSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYRnd1YzNablhGd3BLU3dnSUdobGFXZG9kQ0E5SUdobGFXZG9kQ3dnZDJsa2RHZ2dQU0IzYVdSMGFDbGNibkJ5YVc1MEtIQXBYRzVrWlhZdWIyWm1LQ2xjYm1CZ1lGeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5cbmNvbW1vbkxvb3BEaXIgPC0gaGVyZShcXC4uL2RhdGEvbG9vcF9hbmFseXNpc1xcKVxuZGlmZkRpciA8LSBoZXJlKFxcLi4vZGF0YS9STkFfZGlmZlxcKVxubmFtZSA8LSBcXGNocm9tb3NpZ2h0XFxcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBuYW1lLCBcXF9wLW5fY29tcGxleF9lbnNlbWJsTGlzdC50c3ZcXCkpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShkaWZmID0gc2NvcmVfZFRBRyAtIHNjb3JlX0RNU08pXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUoZGlmZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibF9nZW5lX2lkLCBsb2cyRm9sZENoYW5nZSwgc2hyaW5rZWRfbG9nMkZDLCBwYWRqLCBleHRlcm5hbF9nZW5lX25hbWUpXG5nZW5lTGlzdC5kb3duLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDIDw9IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuZ2VuZUxpc3QudXAuUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPiAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcblxuXG5tYXhMb2cyRkMgPC0gMlxuXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmYpLCAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHBseXI6Om11dGF0ZShmbGFnID0gaWZlbHNlKGdlbmUgJWluJSBnZW5lTGlzdC5kb3duLlJOQSwgXFwyRE9XTlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lTGlzdC51cC5STkEsIFxcMVVQXFwsIFxcME5PXFwpKSxcbiAgICAgICAgICAgICAgICBtYXhGbGFnID0gKGFicyhzaHJpbmtlZF9sb2cyRkMpID4gbWF4TG9nMkZDKSxcbiAgICAgICAgICAgICAgICBzaHJsb2cyZmNNYXggPSBwbWF4KHBtaW4oc2hyaW5rZWRfbG9nMkZDLCBtYXhMb2cyRkMpLCAtbWF4TG9nMkZDKSkgJT4lIFxuICBkcGx5cjo6YXJyYW5nZShmbGFnKVxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHNocmxvZzJmY01heCwgeSA9IG1lYW5fZGlmZl9zY29yZSwgY29sb3IgPSBmbGFnLFxuICAgICAgICAgICAgICAgICAgICAgIGxhYmVsID0gaWZlbHNlKGZsYWcgIT0gXFwwTk9cXCwgZXh0ZXJuYWxfZ2VuZV9uYW1lLCBOQSksXG4gICAgICAgICAgICAgICAgICAgICAgc2hhcGUgPSBhcy5mYWN0b3IobWF4RmxhZykpKSArXG4gIGdlb21fcG9pbnQoKSArIGdlb21fdGV4dF9yZXBlbCgpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgZ2d0aXRsZShwYXN0ZTAobmFtZSwgXFxfc2NvcmVfY29tcGxleEFubm9cXCkpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gLSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBmY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IC1mY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIHNjYWxlX2NvbG9yX21hbnVhbCh2YWx1ZXMgPSBjKFxcME5PXFwgPSBcXGdyZXlcXCwgXFwxVVBcXCA9IFxccmVkXFwsIFxcMkRPV05cXCA9IFxcYmx1ZVxcKSkgKyAgIyBDb3JyZWN0ZWQgY29sb3IgbWFwcGluZ1xuICBzY2FsZV9zaGFwZV9tYW51YWwodmFsdWVzID0gYyhcXFRSVUVcXCA9IDIsIFxcRkFMU0VcXCA9IDE5KSlcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcUk5BdnNMb29wX1xcLCBuYW1lLCBcXF9zY29yZV9jb21wbGV4QW5ub1xcKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDdcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5cbmNvbW1vbkxvb3BEaXIgPC0gaGVyZShcXC4uL2RhdGEvbG9vcF9hbmFseXNpc1xcKVxuZGlmZkRpciA8LSBoZXJlKFxcLi4vZGF0YS9STkFfZGlmZlxcKVxubmFtZSA8LSBcXGNocm9tb3NpZ2h0XFxcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBuYW1lLCBcXF9wLW5fY29tcGxleF9lbnNlbWJsTGlzdC50c3ZcXCkpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShkaWZmID0gc2NvcmVfZFRBRyAtIHNjb3JlX0RNU08pXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUoZGlmZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibF9nZW5lX2lkLCBsb2cyRm9sZENoYW5nZSwgc2hyaW5rZWRfbG9nMkZDLCBwYWRqLCBleHRlcm5hbF9nZW5lX25hbWUpXG5nZW5lTGlzdC5kb3duLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDIDw9IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuZ2VuZUxpc3QudXAuUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPiAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcblxuXG5tYXhMb2cyRkMgPC0gMlxuXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmYpLCAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHBseXI6Om11dGF0ZShmbGFnID0gaWZlbHNlKGdlbmUgJWluJSBnZW5lTGlzdC5kb3duLlJOQSwgXFwyRE9XTlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lTGlzdC51cC5STkEsIFxcMVVQXFwsIFxcME5PXFwpKSxcbiAgICAgICAgICAgICAgICBtYXhGbGFnID0gKGFicyhzaHJpbmtlZF9sb2cyRkMpID4gbWF4TG9nMkZDKSxcbiAgICAgICAgICAgICAgICBzaHJsb2cyZmNNYXggPSBwbWF4KHBtaW4oc2hyaW5rZWRfbG9nMkZDLCBtYXhMb2cyRkMpLCAtbWF4TG9nMkZDKSkgJT4lIFxuICBkcGx5cjo6YXJyYW5nZShmbGFnKVxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHNocmxvZzJmY01heCwgeSA9IG1lYW5fZGlmZl9zY29yZSwgY29sb3IgPSBmbGFnLFxuICAgICAgICAgICAgICAgICAgICAgIGxhYmVsID0gaWZlbHNlKGZsYWcgIT0gXFwwTk9cXCwgZXh0ZXJuYWxfZ2VuZV9uYW1lLCBOQSksXG4gICAgICAgICAgICAgICAgICAgICAgc2hhcGUgPSBhcy5mYWN0b3IobWF4RmxhZykpKSArXG4gIGdlb21fcG9pbnQoKSArIGdlb21fdGV4dF9yZXBlbCgpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgZ2d0aXRsZShwYXN0ZTAobmFtZSwgXFxfc2NvcmVfY29tcGxleEFubm9cXCkpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gLSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBmY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IC1mY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIHNjYWxlX2NvbG9yX21hbnVhbCh2YWx1ZXMgPSBjKFxcME5PXFwgPSBcXGdyZXlcXCwgXFwxVVBcXCA9IFxccmVkXFwsIFxcMkRPV05cXCA9IFxcYmx1ZVxcKSkgKyAgIyBDb3JyZWN0ZWQgY29sb3IgbWFwcGluZ1xuICBzY2FsZV9zaGFwZV9tYW51YWwodmFsdWVzID0gYyhcXFRSVUVcXCA9IDIsIFxcRkFMU0VcXCA9IDE5KSlcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcUk5BdnNMb29wX1xcLCBuYW1lLCBcXF9zY29yZV9jb21wbGV4QW5ub1xcKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDdcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
alpha <- 0.05
fcCutoff <- 0.5

commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \chromosight\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_complex_ensemblList.tsv\))) %>%
  dplyr::mutate(diff = score_dTAG - score_DMSO)

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_score_complexAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_score_complexAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\nplot_loop_scores <- function(df, col_x, col_y, annoList,\n                             name, title, figDir,\n                             diffCutoff = 0.5, density_n = 200,\n                             xmin = -0.5, xmax = 1,\n                             ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  # Scatterplot\n  df2 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps),\n      density = get_density(lx, ly, n = density_n)\n    ) %>%\n    arrange(density)\n  \n  p1 <- ggplot(df2, aes(x = lx, y = ly, color = density)) +\n    geom_point() +\n    scale_color_viridis() +\n    scale_x_continuous(\n      name   = paste0(\"log2(\", quo_name(col_x_q), \")\")\n    ) +\n    scale_y_continuous(\n      name   = paste0(\"log2(\", quo_name(col_y_q), \")\")\n    ) +\n    coord_fixed() +\n    geom_abline(slope = 1, intercept = 0,\n                colour = \"grey50\", linetype = \"dashed\") +\n    geom_hline(yintercept = 0, alpha = 0.5, colour = \"grey\") +\n    geom_vline(xintercept = 0, alpha = 0.5, colour = \"grey\") +\n    geom_abline(slope = 1, intercept = -(2**diffCutoff),\n                colour = \"grey\", linetype = \"dotted\") +\n    geom_abline(slope = 1, intercept = (2**diffCutoff),\n                colour = \"grey\", linetype = \"dotted\") +\n    theme_classic() +\n    labs(x = quo_name(col_x_q),\n         y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  fileName <- paste0(\"scatterplot_\", name)\n  svglite(here(figDir, paste0(fileName, \".svg\")), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \".png\")), \n      width = 3.5, height = 3, units = \"in\", res = 600)\n  print(p1)\n  dev.off()\n  \n  # Pie chart\n  df3 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    ) %>%\n    mutate(diff = ly - lx) %>%\n    mutate(updown = ifelse(diff > diffCutoff, \"UP\",\n                           ifelse(diff < -diffCutoff, \"DOWN\", \"NO\")))\n  df3$updown <- factor(df3$updown, c(\"UP\", \"NO\", \"DOWN\"))\n  \n  pie_df <- df3 %>%\n    dplyr::count(updown) %>%\n    mutate(pct   = n / sum(n) * 100,\n           label = paste0(updown, \"\\n\", n, \"\\n(\", round(pct,1), \"%)\"))\n\n  p2 <- ggplot(pie_df, aes(x = \"\", y = n, fill = updown)) +\n    geom_col(color = \"white\") +\n    coord_polar(theta = \"y\") +\n    geom_text(aes(label = label),\n              position = position_stack(vjust = 0.5),\n              size     = fontSizeM/2) +\n    theme_void() +   theme(legend.position = \"none\") +\n    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))\n  fileName <- here(figDir, paste0(\"piechart_\", name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \".svg\"), width = width, height = height)\n  print(p2)\n  dev.off()\n}\n\n\ncommonLoopDir <- here(\"../data/loop_analysis\")\nfigDir <- here(\"../figure/loop_analysis\")\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \"loopScore_chromosight.tsv\"))\n\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\"P-P\", \"P-E\", \"P-S\", \"P-X\",\n                                                 \"E-E\", \"E-S\", \"E-X\",\n                                                 \"S-S\", \"S-X\",\n                                                 \"X-X\"),\n                 name = \"chromosight_ooe_all_dTAGvDMSO\",\n                 title = \"chromo_ooe_all_dTAGvDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\"S-S\"),\n                 name = \"chromosight_ooe_str_dTAGvDMSO\",\n                 title = \"chromo_ooe_str_dTAGvDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\"S-S\", \"S-X\"),\n                 name = \"chromosight_ooe_str2_dTAGvDMSO\",\n                 title = \"chromo_ooe_str2_dTAGvDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\"P-P\", \"P-E\", \"E-E\"),\n                 name = \"chromosight_ooe_reg_dTAGvDMSO\",\n                 title = \"chromo_ooe_reg_dTAGvDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\"P-S\", \"E-S\"),\n                 name = \"chromosight_ooe_regStr_dTAGvDMSO\",\n                 title = \"chromo_ooe_regStr_dTAGvDMSO\", figDir)\n\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\"P-P\", \"P-E\", \"P-S\", \"P-X\",\n                                                 \"E-E\", \"E-S\", \"E-X\",\n                                                 \"S-S\", \"S-X\",\n                                                 \"X-X\"),\n                 name = \"chromosight_ooe_all_A485vDMSO\",\n                 title = \"chromo_ooe_all_A485vDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\"S-S\"),\n                 name = \"chromosight_ooe_str_A485vDMSO\",\n                 title = \"chromo_ooe_str_A485vDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\"S-S\", \"S-X\"),\n                 name = \"chromosight_ooe_str2_A485vDMSO\",\n                 title = \"chromo_ooe_str2_A485vDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\"P-P\", \"P-E\", \"E-E\"),\n                 name = \"chromosight_ooe_reg_A485vDMSO\",\n                 title = \"chromo_ooe_reg_A485vDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\"P-S\", \"E-S\"),\n                 name = \"chromosight_ooe_regStr_A485vDMSO\",\n                 title = \"chromo_ooe_regStr_A485vDMSO\", figDir)\n\n\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\"P-P\", \"P-E\", \"P-S\", \"P-X\",\n                                                 \"E-E\", \"E-S\", \"E-X\",\n                                                 \"S-S\", \"S-X\",\n                                                 \"X-X\"),\n                 name = \"chromosight_ooe_all_EpidTAGvEpiDMSO\",\n                 title = \"chromo_ooe_all_EpidTAGvEpiDMSO\", figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\"S-S\"),\n                 name = \"chromosight_ooe_str_EpidTAGvEpiDMSO\",\n                 title = \"chromo_ooe_str_EpidTAGvEpiDMSO\", figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\"S-S\", \"S-X\"),\n                 name = \"chromosight_ooe_str2_EpidTAGvEpiDMSO\",\n                 title = \"chromo_ooe_str2_EpidTAGvEpiDMSO\", figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\"P-P\", \"P-E\", \"E-E\"),\n                 name = \"chromosight_ooe_reg_EpidTAGvEpiDMSO\",\n                 title = \"chromo_ooe_reg_EpidTAGvEpiDMSO\", figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\"P-S\", \"E-S\"),\n                 name = \"chromosight_ooe_regStr_EpidTAGvEpiDMSO\",\n                 title = \"chromo_ooe_regStr_EpidTAGvEpiDMSO\", figDir)\n\n\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\"P-P\", \"P-E\", \"P-S\", \"P-X\",\n                                                 \"E-E\", \"E-S\", \"E-X\",\n                                                 \"S-S\", \"S-X\",\n                                                 \"X-X\"),\n                 name = \"chromosight_ooe_all_AIDvUT\",\n                 title = \"chromo_ooe_all_AIDvUT\", figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\"S-S\"),\n                 name = \"chromosight_ooe_str_AIDvUT\",\n                 title = \"chromo_ooe_str_AIDvUT\", figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\"S-S\", \"S-X\"),\n                 name = \"chromosight_ooe_str2_AIDvUT\",\n                 title = \"chromo_ooe_str2_AIDvUT\", figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\"P-P\", \"P-E\", \"E-E\"),\n                 name = \"chromosight_ooe_reg_AIDvUT\",\n                 title = \"chromo_ooe_reg_AIDvUT\", figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\"P-S\", \"E-S\"),\n                 name = \"chromosight_ooe_regStr_AIDvUT\",\n                 title = \"chromo_ooe_regStr_AIDvUT\", figDir)\n\n\n```"} -->\n\n```r\nplot_loop_scores <- function(df, col_x, col_y, annoList,\n                             name, title, figDir,\n                             diffCutoff = 0.5, density_n = 200,\n                             xmin = -0.5, xmax = 1,\n                             ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  # Scatterplot\n  df2 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps),\n      density = get_density(lx, ly, n = density_n)\n    ) %>%\n    arrange(density)\n  \n  p1 <- ggplot(df2, aes(x = lx, y = ly, color = density)) +\n    geom_point() +\n    scale_color_viridis() +\n    scale_x_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_x_q), \\)\\)\n    ) +\n    scale_y_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_y_q), \\)\\)\n    ) +\n    coord_fixed() +\n    geom_abline(slope = 1, intercept = 0,\n                colour = \\grey50\\, linetype = \\dashed\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_abline(slope = 1, intercept = -(2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = (2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    theme_classic() +\n    labs(x = quo_name(col_x_q),\n         y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  fileName <- paste0(\\scatterplot_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      width = 3.5, height = 3, units = \\in\\, res = 600)\n  print(p1)\n  dev.off()\n  \n  # Pie chart\n  df3 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    ) %>%\n    mutate(diff = ly - lx) %>%\n    mutate(updown = ifelse(diff > diffCutoff, \\UP\\,\n                           ifelse(diff < -diffCutoff, \\DOWN\\, \\NO\\)))\n  df3$updown <- factor(df3$updown, c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  pie_df <- df3 %>%\n    dplyr::count(updown) %>%\n    mutate(pct   = n / sum(n) * 100,\n           label = paste0(updown, \\\\n\\, n, \\\\n(\\, round(pct,1), \\%)\\))\n\n  p2 <- ggplot(pie_df, aes(x = \\\\, y = n, fill = updown)) +\n    geom_col(color = \\white\\) +\n    coord_polar(theta = \\y\\) +\n    geom_text(aes(label = label),\n              position = position_stack(vjust = 0.5),\n              size     = fontSizeM/2) +\n    theme_void() +   theme(legend.position = \\none\\) +\n    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))\n  fileName <- here(figDir, paste0(\\piechart_\\, name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(p2)\n  dev.off()\n}\n\n\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_chromosight.tsv\\))\n\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_dTAGvDMSO\\,\n                 title = \\chromo_ooe_all_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_dTAGvDMSO\\,\n                 title = \\chromo_ooe_str_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_dTAGvDMSO\\,\n                 title = \\chromo_ooe_str2_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_dTAGvDMSO\\,\n                 title = \\chromo_ooe_reg_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_dTAGvDMSO\\,\n                 title = \\chromo_ooe_regStr_dTAGvDMSO\\, figDir)\n\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_A485vDMSO\\,\n                 title = \\chromo_ooe_all_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_A485vDMSO\\,\n                 title = \\chromo_ooe_str_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_A485vDMSO\\,\n                 title = \\chromo_ooe_str2_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_A485vDMSO\\,\n                 title = \\chromo_ooe_reg_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_A485vDMSO\\,\n                 title = \\chromo_ooe_regStr_A485vDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_all_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_str_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_str2_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_reg_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_regStr_EpidTAGvEpiDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_AIDvUT\\,\n                 title = \\chromo_ooe_all_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_AIDvUT\\,\n                 title = \\chromo_ooe_str_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_AIDvUT\\,\n                 title = \\chromo_ooe_str2_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_AIDvUT\\,\n                 title = \\chromo_ooe_reg_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_AIDvUT\\,\n                 title = \\chromo_ooe_regStr_AIDvUT\\, figDir)\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
plot_loop_scores <- function(df, col_x, col_y, annoList,
                             name, title, figDir,
                             diffCutoff = 0.5, density_n = 200,
                             xmin = -0.5, xmax = 1,
                             ymin = -0.5, ymax = 1) {
  col_x_q <- enquo(col_x)
  col_y_q <- enquo(col_y)
  
  # Scatterplot
  df2 <- df %>%
    filter(Anno_simple %in% annoList) %>%
    select(id, x = !!col_x_q, y = !!col_y_q) %>%
    mutate(
      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),
      eps    = minpos * 0.1,
      lx     = log2(x + eps),
      ly     = log2(y + eps),
      density = get_density(lx, ly, n = density_n)
    ) %>%
    arrange(density)
  
  p1 <- ggplot(df2, aes(x = lx, y = ly, color = density)) +
    geom_point() +
    scale_color_viridis() +
    scale_x_continuous(
      name   = paste0(\log2(\, quo_name(col_x_q), \)\)
    ) +
    scale_y_continuous(
      name   = paste0(\log2(\, quo_name(col_y_q), \)\)
    ) +
    coord_fixed() +
    geom_abline(slope = 1, intercept = 0,
                colour = \grey50\, linetype = \dashed\) +
    geom_hline(yintercept = 0, alpha = 0.5, colour = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, colour = \grey\) +
    geom_abline(slope = 1, intercept = -(2**diffCutoff),
                colour = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept = (2**diffCutoff),
                colour = \grey\, linetype = \dotted\) +
    theme_classic() +
    labs(x = quo_name(col_x_q),
         y = quo_name(col_y_q)) +
    ggtitle(title)
  
  fileName <- paste0(\scatterplot_\, name)
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()
  
  png(here(figDir, paste0(fileName, \.png\)), 
      width = 3.5, height = 3, units = \in\, res = 600)
  print(p1)
  dev.off()
  
  # Pie chart
  df3 <- df %>%
    filter(Anno_simple %in% annoList) %>%
    select(id, x = !!col_x_q, y = !!col_y_q) %>%
    mutate(
      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),
      eps    = minpos * 0.1,
      lx     = log2(x + eps),
      ly     = log2(y + eps)
    ) %>%
    mutate(diff = ly - lx) %>%
    mutate(updown = ifelse(diff > diffCutoff, \UP\,
                           ifelse(diff < -diffCutoff, \DOWN\, \NO\)))
  df3$updown <- factor(df3$updown, c(\UP\, \NO\, \DOWN\))
  
  pie_df <- df3 %>%
    dplyr::count(updown) %>%
    mutate(pct   = n / sum(n) * 100,
           label = paste0(updown, \\n\, n, \\n(\, round(pct,1), \%)\))

  p2 <- ggplot(pie_df, aes(x = \\, y = n, fill = updown)) +
    geom_col(color = \white\) +
    coord_polar(theta = \y\) +
    geom_text(aes(label = label),
              position = position_stack(vjust = 0.5),
              size     = fontSizeM/2) +
    theme_void() +   theme(legend.position = \none\) +
    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))
  fileName <- here(figDir, paste0(\piechart_\, name))
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  svglite(paste0(fileName, \.svg\), width = width, height = height)
  print(p2)
  dev.off()
}


commonLoopDir <- here(\../data/loop_analysis\)
figDir <- here(\../figure/loop_analysis\)
dir.create(figDir, showWarnings = FALSE, recursive = TRUE)

data <- fread(here(commonLoopDir, \loopScore_chromosight.tsv\))

plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \chromosight_ooe_all_dTAGvDMSO\,
                 title = \chromo_ooe_all_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\S-S\),
                 name = \chromosight_ooe_str_dTAGvDMSO\,
                 title = \chromo_ooe_str_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\S-S\, \S-X\),
                 name = \chromosight_ooe_str2_dTAGvDMSO\,
                 title = \chromo_ooe_str2_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-P\, \P-E\, \E-E\),
                 name = \chromosight_ooe_reg_dTAGvDMSO\,
                 title = \chromo_ooe_reg_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-S\, \E-S\),
                 name = \chromosight_ooe_regStr_dTAGvDMSO\,
                 title = \chromo_ooe_regStr_dTAGvDMSO\, figDir)

plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \chromosight_ooe_all_A485vDMSO\,
                 title = \chromo_ooe_all_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\S-S\),
                 name = \chromosight_ooe_str_A485vDMSO\,
                 title = \chromo_ooe_str_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\S-S\, \S-X\),
                 name = \chromosight_ooe_str2_A485vDMSO\,
                 title = \chromo_ooe_str2_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-P\, \P-E\, \E-E\),
                 name = \chromosight_ooe_reg_A485vDMSO\,
                 title = \chromo_ooe_reg_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-S\, \E-S\),
                 name = \chromosight_ooe_regStr_A485vDMSO\,
                 title = \chromo_ooe_regStr_A485vDMSO\, figDir)


plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \chromosight_ooe_all_EpidTAGvEpiDMSO\,
                 title = \chromo_ooe_all_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\S-S\),
                 name = \chromosight_ooe_str_EpidTAGvEpiDMSO\,
                 title = \chromo_ooe_str_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\S-S\, \S-X\),
                 name = \chromosight_ooe_str2_EpidTAGvEpiDMSO\,
                 title = \chromo_ooe_str2_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-P\, \P-E\, \E-E\),
                 name = \chromosight_ooe_reg_EpidTAGvEpiDMSO\,
                 title = \chromo_ooe_reg_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-S\, \E-S\),
                 name = \chromosight_ooe_regStr_EpidTAGvEpiDMSO\,
                 title = \chromo_ooe_regStr_EpidTAGvEpiDMSO\, figDir)


plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \chromosight_ooe_all_AIDvUT\,
                 title = \chromo_ooe_all_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\S-S\),
                 name = \chromosight_ooe_str_AIDvUT\,
                 title = \chromo_ooe_str_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\S-S\, \S-X\),
                 name = \chromosight_ooe_str2_AIDvUT\,
                 title = \chromo_ooe_str2_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-P\, \P-E\, \E-E\),
                 name = \chromosight_ooe_reg_AIDvUT\,
                 title = \chromo_ooe_reg_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-S\, \E-S\),
                 name = \chromosight_ooe_regStr_AIDvUT\,
                 title = \chromo_ooe_regStr_AIDvUT\, figDir)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\nplot_loop_scores <- function(df, col_x, col_y, annoList,\n                             name, title, figDir,\n                             diffCutoff = 0.5, density_n = 200,\n                             xmin = -0.5, xmax = 1,\n                             ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  # Scatterplot\n  df2 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps),\n      density = get_density(lx, ly, n = density_n)\n    ) %>%\n    arrange(density)\n  \n  p1 <- ggplot(df2, aes(x = lx, y = ly, color = density)) +\n    geom_point() +\n    scale_color_viridis() +\n    scale_x_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_x_q), \\)\\)\n    ) +\n    scale_y_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_y_q), \\)\\)\n    ) +\n    coord_fixed() +\n    geom_abline(slope = 1, intercept = 0,\n                colour = \\grey50\\, linetype = \\dashed\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_abline(slope = 1, intercept = -(2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = (2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    theme_classic() +\n    labs(x = quo_name(col_x_q),\n         y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  fileName <- paste0(\\scatterplot_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      width = 3.5, height = 3, units = \\in\\, res = 600)\n  print(p1)\n  dev.off()\n  \n  # Pie chart\n  df3 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    ) %>%\n    mutate(diff = ly - lx) %>%\n    mutate(updown = ifelse(diff > diffCutoff, \\UP\\,\n                           ifelse(diff < -diffCutoff, \\DOWN\\, \\NO\\)))\n  df3$updown <- factor(df3$updown, c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  pie_df <- df3 %>%\n    dplyr::count(updown) %>%\n    mutate(pct   = n / sum(n) * 100,\n           label = paste0(updown, \\\\n\\, n, \\\\n(\\, round(pct,1), \\%)\\))\n\n  p2 <- ggplot(pie_df, aes(x = \\\\, y = n, fill = updown)) +\n    geom_col(color = \\white\\) +\n    coord_polar(theta = \\y\\) +\n    geom_text(aes(label = label),\n              position = position_stack(vjust = 0.5),\n              size     = fontSizeM/2) +\n    theme_void() +   theme(legend.position = \\none\\) +\n    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))\n  fileName <- here(figDir, paste0(\\piechart_\\, name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(p2)\n  dev.off()\n}\n\n\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_chromosight.tsv\\))\n\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_dTAGvDMSO\\,\n                 title = \\chromo_ooe_all_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_dTAGvDMSO\\,\n                 title = \\chromo_ooe_str_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_dTAGvDMSO\\,\n                 title = \\chromo_ooe_str2_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_dTAGvDMSO\\,\n                 title = \\chromo_ooe_reg_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_dTAGvDMSO\\,\n                 title = \\chromo_ooe_regStr_dTAGvDMSO\\, figDir)\n\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_A485vDMSO\\,\n                 title = \\chromo_ooe_all_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_A485vDMSO\\,\n                 title = \\chromo_ooe_str_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_A485vDMSO\\,\n                 title = \\chromo_ooe_str2_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_A485vDMSO\\,\n                 title = \\chromo_ooe_reg_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_A485vDMSO\\,\n                 title = \\chromo_ooe_regStr_A485vDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_all_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_str_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_str2_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_reg_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_regStr_EpidTAGvEpiDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_AIDvUT\\,\n                 title = \\chromo_ooe_all_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_AIDvUT\\,\n                 title = \\chromo_ooe_str_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_AIDvUT\\,\n                 title = \\chromo_ooe_str2_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_AIDvUT\\,\n                 title = \\chromo_ooe_reg_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_AIDvUT\\,\n                 title = \\chromo_ooe_regStr_AIDvUT\\, figDir)\n\n\n```\n```"} -->\n\n```r\n```r\nplot_loop_scores <- function(df, col_x, col_y, annoList,\n                             name, title, figDir,\n                             diffCutoff = 0.5, density_n = 200,\n                             xmin = -0.5, xmax = 1,\n                             ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  # Scatterplot\n  df2 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps),\n      density = get_density(lx, ly, n = density_n)\n    ) %>%\n    arrange(density)\n  \n  p1 <- ggplot(df2, aes(x = lx, y = ly, color = density)) +\n    geom_point() +\n    scale_color_viridis() +\n    scale_x_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_x_q), \\)\\)\n    ) +\n    scale_y_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_y_q), \\)\\)\n    ) +\n    coord_fixed() +\n    geom_abline(slope = 1, intercept = 0,\n                colour = \\grey50\\, linetype = \\dashed\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_abline(slope = 1, intercept = -(2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = (2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    theme_classic() +\n    labs(x = quo_name(col_x_q),\n         y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  fileName <- paste0(\\scatterplot_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      width = 3.5, height = 3, units = \\in\\, res = 600)\n  print(p1)\n  dev.off()\n  \n  # Pie chart\n  df3 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    ) %>%\n    mutate(diff = ly - lx) %>%\n    mutate(updown = ifelse(diff > diffCutoff, \\UP\\,\n                           ifelse(diff < -diffCutoff, \\DOWN\\, \\NO\\)))\n  df3$updown <- factor(df3$updown, c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  pie_df <- df3 %>%\n    dplyr::count(updown) %>%\n    mutate(pct   = n / sum(n) * 100,\n           label = paste0(updown, \\\\n\\, n, \\\\n(\\, round(pct,1), \\%)\\))\n\n  p2 <- ggplot(pie_df, aes(x = \\\\, y = n, fill = updown)) +\n    geom_col(color = \\white\\) +\n    coord_polar(theta = \\y\\) +\n    geom_text(aes(label = label),\n              position = position_stack(vjust = 0.5),\n              size     = fontSizeM/2) +\n    theme_void() +   theme(legend.position = \\none\\) +\n    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))\n  fileName <- here(figDir, paste0(\\piechart_\\, name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(p2)\n  dev.off()\n}\n\n\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_chromosight.tsv\\))\n\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_dTAGvDMSO\\,\n                 title = \\chromo_ooe_all_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_dTAGvDMSO\\,\n                 title = \\chromo_ooe_str_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_dTAGvDMSO\\,\n                 title = \\chromo_ooe_str2_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_dTAGvDMSO\\,\n                 title = \\chromo_ooe_reg_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_dTAGvDMSO\\,\n                 title = \\chromo_ooe_regStr_dTAGvDMSO\\, figDir)\n\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_A485vDMSO\\,\n                 title = \\chromo_ooe_all_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_A485vDMSO\\,\n                 title = \\chromo_ooe_str_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_A485vDMSO\\,\n                 title = \\chromo_ooe_str2_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_A485vDMSO\\,\n                 title = \\chromo_ooe_reg_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_A485vDMSO\\,\n                 title = \\chromo_ooe_regStr_A485vDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_all_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_str_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_str2_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_reg_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_regStr_EpidTAGvEpiDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_AIDvUT\\,\n                 title = \\chromo_ooe_all_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_AIDvUT\\,\n                 title = \\chromo_ooe_str_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_AIDvUT\\,\n                 title = \\chromo_ooe_str2_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_AIDvUT\\,\n                 title = \\chromo_ooe_reg_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_AIDvUT\\,\n                 title = \\chromo_ooe_regStr_AIDvUT\\, figDir)\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\nplot_loop_scores <- function(df, col_x, col_y, annoList,\n                             name, title, figDir,\n                             diffCutoff = 0.5, density_n = 200,\n                             xmin = -0.5, xmax = 1,\n                             ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  # Scatterplot\n  df2 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps),\n      density = get_density(lx, ly, n = density_n)\n    ) %>%\n    arrange(density)\n  \n  p1 <- ggplot(df2, aes(x = lx, y = ly, color = density)) +\n    geom_point() +\n    scale_color_viridis() +\n    scale_x_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_x_q), \\)\\)\n    ) +\n    scale_y_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_y_q), \\)\\)\n    ) +\n    coord_fixed() +\n    geom_abline(slope = 1, intercept = 0,\n                colour = \\grey50\\, linetype = \\dashed\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_abline(slope = 1, intercept = -(2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = (2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    theme_classic() +\n    labs(x = quo_name(col_x_q),\n         y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  fileName <- paste0(\\scatterplot_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      width = 3.5, height = 3, units = \\in\\, res = 600)\n  print(p1)\n  dev.off()\n  \n  # Pie chart\n  df3 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    ) %>%\n    mutate(diff = ly - lx) %>%\n    mutate(updown = ifelse(diff > diffCutoff, \\UP\\,\n                           ifelse(diff < -diffCutoff, \\DOWN\\, \\NO\\)))\n  df3$updown <- factor(df3$updown, c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  pie_df <- df3 %>%\n    dplyr::count(updown) %>%\n    mutate(pct   = n / sum(n) * 100,\n           label = paste0(updown, \\\\n\\, n, \\\\n(\\, round(pct,1), \\%)\\))\n\n  p2 <- ggplot(pie_df, aes(x = \\\\, y = n, fill = updown)) +\n    geom_col(color = \\white\\) +\n    coord_polar(theta = \\y\\) +\n    geom_text(aes(label = label),\n              position = position_stack(vjust = 0.5),\n              size     = fontSizeM/2) +\n    theme_void() +   theme(legend.position = \\none\\) +\n    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))\n  fileName <- here(figDir, paste0(\\piechart_\\, name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(p2)\n  dev.off()\n}\n\n\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_chromosight.tsv\\))\n\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_dTAGvDMSO\\,\n                 title = \\chromo_ooe_all_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_dTAGvDMSO\\,\n                 title = \\chromo_ooe_str_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_dTAGvDMSO\\,\n                 title = \\chromo_ooe_str2_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_dTAGvDMSO\\,\n                 title = \\chromo_ooe_reg_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_dTAGvDMSO\\,\n                 title = \\chromo_ooe_regStr_dTAGvDMSO\\, figDir)\n\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_A485vDMSO\\,\n                 title = \\chromo_ooe_all_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_A485vDMSO\\,\n                 title = \\chromo_ooe_str_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_A485vDMSO\\,\n                 title = \\chromo_ooe_str2_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_A485vDMSO\\,\n                 title = \\chromo_ooe_reg_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_A485vDMSO\\,\n                 title = \\chromo_ooe_regStr_A485vDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_all_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_str_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_str2_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_reg_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_EpidTAGvEpiDMSO\\,\n                 title = \\chromo_ooe_regStr_EpidTAGvEpiDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\chromosight_ooe_all_AIDvUT\\,\n                 title = \\chromo_ooe_all_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\),\n                 name = \\chromosight_ooe_str_AIDvUT\\,\n                 title = \\chromo_ooe_str_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\, \\S-X\\),\n                 name = \\chromosight_ooe_str2_AIDvUT\\,\n                 title = \\chromo_ooe_str2_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\chromosight_ooe_reg_AIDvUT\\,\n                 title = \\chromo_ooe_reg_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-S\\, \\E-S\\),\n                 name = \\chromosight_ooe_regStr_AIDvUT\\,\n                 title = \\chromo_ooe_regStr_AIDvUT\\, figDir)\n\n\n```\n```"} -->

```r
```r
plot_loop_scores <- function(df, col_x, col_y, annoList,
                             name, title, figDir,
                             diffCutoff = 0.5, density_n = 200,
                             xmin = -0.5, xmax = 1,
                             ymin = -0.5, ymax = 1) {
  col_x_q <- enquo(col_x)
  col_y_q <- enquo(col_y)
  
  # Scatterplot
  df2 <- df %>%
    filter(Anno_simple %in% annoList) %>%
    select(id, x = !!col_x_q, y = !!col_y_q) %>%
    mutate(
      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),
      eps    = minpos * 0.1,
      lx     = log2(x + eps),
      ly     = log2(y + eps),
      density = get_density(lx, ly, n = density_n)
    ) %>%
    arrange(density)
  
  p1 <- ggplot(df2, aes(x = lx, y = ly, color = density)) +
    geom_point() +
    scale_color_viridis() +
    scale_x_continuous(
      name   = paste0(\log2(\, quo_name(col_x_q), \)\)
    ) +
    scale_y_continuous(
      name   = paste0(\log2(\, quo_name(col_y_q), \)\)
    ) +
    coord_fixed() +
    geom_abline(slope = 1, intercept = 0,
                colour = \grey50\, linetype = \dashed\) +
    geom_hline(yintercept = 0, alpha = 0.5, colour = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, colour = \grey\) +
    geom_abline(slope = 1, intercept = -(2**diffCutoff),
                colour = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept = (2**diffCutoff),
                colour = \grey\, linetype = \dotted\) +
    theme_classic() +
    labs(x = quo_name(col_x_q),
         y = quo_name(col_y_q)) +
    ggtitle(title)
  
  fileName <- paste0(\scatterplot_\, name)
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()
  
  png(here(figDir, paste0(fileName, \.png\)), 
      width = 3.5, height = 3, units = \in\, res = 600)
  print(p1)
  dev.off()
  
  # Pie chart
  df3 <- df %>%
    filter(Anno_simple %in% annoList) %>%
    select(id, x = !!col_x_q, y = !!col_y_q) %>%
    mutate(
      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),
      eps    = minpos * 0.1,
      lx     = log2(x + eps),
      ly     = log2(y + eps)
    ) %>%
    mutate(diff = ly - lx) %>%
    mutate(updown = ifelse(diff > diffCutoff, \UP\,
                           ifelse(diff < -diffCutoff, \DOWN\, \NO\)))
  df3$updown <- factor(df3$updown, c(\UP\, \NO\, \DOWN\))
  
  pie_df <- df3 %>%
    dplyr::count(updown) %>%
    mutate(pct   = n / sum(n) * 100,
           label = paste0(updown, \\n\, n, \\n(\, round(pct,1), \%)\))

  p2 <- ggplot(pie_df, aes(x = \\, y = n, fill = updown)) +
    geom_col(color = \white\) +
    coord_polar(theta = \y\) +
    geom_text(aes(label = label),
              position = position_stack(vjust = 0.5),
              size     = fontSizeM/2) +
    theme_void() +   theme(legend.position = \none\) +
    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))
  fileName <- here(figDir, paste0(\piechart_\, name))
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  svglite(paste0(fileName, \.svg\), width = width, height = height)
  print(p2)
  dev.off()
}


commonLoopDir <- here(\../data/loop_analysis\)
figDir <- here(\../figure/loop_analysis\)
dir.create(figDir, showWarnings = FALSE, recursive = TRUE)

data <- fread(here(commonLoopDir, \loopScore_chromosight.tsv\))

plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \chromosight_ooe_all_dTAGvDMSO\,
                 title = \chromo_ooe_all_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\S-S\),
                 name = \chromosight_ooe_str_dTAGvDMSO\,
                 title = \chromo_ooe_str_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\S-S\, \S-X\),
                 name = \chromosight_ooe_str2_dTAGvDMSO\,
                 title = \chromo_ooe_str2_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-P\, \P-E\, \E-E\),
                 name = \chromosight_ooe_reg_dTAGvDMSO\,
                 title = \chromo_ooe_reg_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-S\, \E-S\),
                 name = \chromosight_ooe_regStr_dTAGvDMSO\,
                 title = \chromo_ooe_regStr_dTAGvDMSO\, figDir)

plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \chromosight_ooe_all_A485vDMSO\,
                 title = \chromo_ooe_all_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\S-S\),
                 name = \chromosight_ooe_str_A485vDMSO\,
                 title = \chromo_ooe_str_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\S-S\, \S-X\),
                 name = \chromosight_ooe_str2_A485vDMSO\,
                 title = \chromo_ooe_str2_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-P\, \P-E\, \E-E\),
                 name = \chromosight_ooe_reg_A485vDMSO\,
                 title = \chromo_ooe_reg_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-S\, \E-S\),
                 name = \chromosight_ooe_regStr_A485vDMSO\,
                 title = \chromo_ooe_regStr_A485vDMSO\, figDir)


plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \chromosight_ooe_all_EpidTAGvEpiDMSO\,
                 title = \chromo_ooe_all_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\S-S\),
                 name = \chromosight_ooe_str_EpidTAGvEpiDMSO\,
                 title = \chromo_ooe_str_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\S-S\, \S-X\),
                 name = \chromosight_ooe_str2_EpidTAGvEpiDMSO\,
                 title = \chromo_ooe_str2_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-P\, \P-E\, \E-E\),
                 name = \chromosight_ooe_reg_EpidTAGvEpiDMSO\,
                 title = \chromo_ooe_reg_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-S\, \E-S\),
                 name = \chromosight_ooe_regStr_EpidTAGvEpiDMSO\,
                 title = \chromo_ooe_regStr_EpidTAGvEpiDMSO\, figDir)


plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \chromosight_ooe_all_AIDvUT\,
                 title = \chromo_ooe_all_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\S-S\),
                 name = \chromosight_ooe_str_AIDvUT\,
                 title = \chromo_ooe_str_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\S-S\, \S-X\),
                 name = \chromosight_ooe_str2_AIDvUT\,
                 title = \chromo_ooe_str2_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-P\, \P-E\, \E-E\),
                 name = \chromosight_ooe_reg_AIDvUT\,
                 title = \chromo_ooe_reg_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-S\, \E-S\),
                 name = \chromosight_ooe_regStr_AIDvUT\,
                 title = \chromo_ooe_regStr_AIDvUT\, figDir)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHViRzloWkV4dmIzQkJibTV2UkdGMFlTQThMU0JtZFc1amRHbHZiaWhtYVd4bFRtRnRaU2w3WEc0Z0lHUmhkR0VnUEMwZ1lYTmZkR2xpWW14bEtHWnlaV0ZrS0dacGJHVk9ZVzFsS1NrZ0pUNGxYRzRnSUNBZ1pIQnNlWEk2T20xMWRHRjBaU2huWlc1bElEMGdjM1J5YzNCc2FYUW9aMlZ1WlN3Z0oxeGNYRng4SnlrcFhHNGdJSEpsZEhWeWJpaGtZWFJoS1Z4dWZWeHVZR0JnSW4wPSAtLT5cblxuYGBgclxubG9hZExvb3BBbm5vRGF0YSA8LSBmdW5jdGlvbihmaWxlTmFtZSl7XG4gIGRhdGEgPC0gYXNfdGliYmxlKGZyZWFkKGZpbGVOYW1lKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShnZW5lID0gc3Ryc3BsaXQoZ2VuZSwgJ1xcXFx8JykpXG4gIHJldHVybihkYXRhKVxufVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
loadLoopAnnoData <- function(fileName){
  data <- as_tibble(fread(fileName)) %>%
    dplyr::mutate(gene = strsplit(gene, '\\|'))
  return(data)
}



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJHOWhaRXh2YjNCQmJtNXZSR0YwWVNBOExTQm1kVzVqZEdsdmJpaG1hV3hsVG1GdFpTbDdYRzRnSUdSaGRHRWdQQzBnWVhOZmRHbGlZbXhsS0daeVpXRmtLR1pwYkdWT1lXMWxLU2tnSlQ0bFhHNGdJQ0FnWkhCc2VYSTZPbTExZEdGMFpTaG5aVzVsSUQwZ2MzUnljM0JzYVhRb1oyVnVaU3dnSjF4Y1hGeDhKeWtwWEc0Z0lISmxkSFZ5Ymloa1lYUmhLVnh1ZlZ4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbmxvYWRMb29wQW5ub0RhdGEgPC0gZnVuY3Rpb24oZmlsZU5hbWUpe1xuICBkYXRhIDwtIGFzX3RpYmJsZShmcmVhZChmaWxlTmFtZSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoZ2VuZSA9IHN0cnNwbGl0KGdlbmUsICdcXFxcfCcpKVxuICByZXR1cm4oZGF0YSlcbn1cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubG9hZExvb3BBbm5vRGF0YSA8LSBmdW5jdGlvbihmaWxlTmFtZSl7XG4gIGRhdGEgPC0gYXNfdGliYmxlKGZyZWFkKGZpbGVOYW1lKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShnZW5lID0gc3Ryc3BsaXQoZ2VuZSwgJ1xcXFx8JykpXG4gIHJldHVybihkYXRhKVxufVxuYGBgXG5gYGAifQ== -->

```r
```r
loadLoopAnnoData <- function(fileName){
  data <- as_tibble(fread(fileName)) %>%
    dplyr::mutate(gene = strsplit(gene, '\\|'))
  return(data)
}
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### Obs/exp score
#### Scatterplot - Chromosight

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFwiLi4vZGF0YS9sb29wX2FuYWx5c2lzXCIpXG5kaWZmRGlyIDwtIGhlcmUoXCIuLi9kYXRhL1JOQV9kaWZmXCIpXG5uYW1lIDwtIFwiY2hyb21vc2lnaHRcIlxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb21tb25Mb29wRGlyLCBwYXN0ZTAoXCJsb29wU2NvcmVfXCIsIG5hbWUsIFwiX3Atbl9zaW1wbGVfZW5zZW1ibExpc3QudHN2XCIpKSkgJT4lXG4gIHJvd3dpc2UoKSAlPiUgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICMgd29yayBvbmUgcm93IGF0IGEgdGltZVxuICBtdXRhdGUoXG4gICAgbWlucG9zID0gbWluKGMob29lX2RUQUcsIG9vZV9ETVNPKVtjKG9vZV9kVEFHLCBvb2VfRE1TTykgPiAwXSwgbmEucm0gPSBUUlVFKSxcbiAgICBlcHMgICAgPSBpZmVsc2UoaXMuZmluaXRlKG1pbnBvcyksIG1pbnBvcyAqIDAuMSwgMC4wMSksICAgICAgIyBmYWxsYmFjayBpZiBib3RoIGFyZSAwXG4gICAgZGlmZiAgID0gbG9nMigob29lX2RUQUcgKyBlcHMpIC8gKG9vZV9ETVNPICsgZXBzKSlcbiAgKSAlPiUgXG4gIHVuZ3JvdXAoKSAlPiUgXG4gIHNlbGVjdCgtbWlucG9zLCAtZXBzKSBcbiAgI2RwbHlyOjptdXRhdGUoZGlmZiA9IGxvZzIob29lX2RUQUcpIC0gbG9nMihvb2VfRE1TTykpXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUoZGlmZkRpciwgXCJkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlwiKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibF9nZW5lX2lkLCBsb2cyRm9sZENoYW5nZSwgc2hyaW5rZWRfbG9nMkZDLCBwYWRqLCBleHRlcm5hbF9nZW5lX25hbWUpXG5nZW5lTGlzdC5kb3duLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDIDw9IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuZ2VuZUxpc3QudXAuUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPiAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcblxuXG5tYXhMb2cyRkMgPC0gMlxuXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmYpLCAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFwiZ2VuZVwiID0gXCJlbnNlbWJsX2dlbmVfaWRcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShmbGFnID0gaWZlbHNlKGdlbmUgJWluJSBnZW5lTGlzdC5kb3duLlJOQSwgXCIyRE9XTlwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lTGlzdC51cC5STkEsIFwiMVVQXCIsIFwiME5PXCIpKSxcbiAgICAgICAgICAgICAgICBtYXhGbGFnID0gKGFicyhzaHJpbmtlZF9sb2cyRkMpID4gbWF4TG9nMkZDKSxcbiAgICAgICAgICAgICAgICBzaHJsb2cyZmNNYXggPSBwbWF4KHBtaW4oc2hyaW5rZWRfbG9nMkZDLCBtYXhMb2cyRkMpLCAtbWF4TG9nMkZDKSkgJT4lIFxuICBkcGx5cjo6YXJyYW5nZShmbGFnKVxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHNocmxvZzJmY01heCwgeSA9IG1lYW5fZGlmZl9zY29yZSwgY29sb3IgPSBmbGFnLFxuICAgICAgICAgICAgICAgICAgICAgIGxhYmVsID0gaWZlbHNlKGZsYWcgIT0gXCIwTk9cIiwgZXh0ZXJuYWxfZ2VuZV9uYW1lLCBOQSksXG4gICAgICAgICAgICAgICAgICAgICAgc2hhcGUgPSBhcy5mYWN0b3IobWF4RmxhZykpKSArXG4gIGdlb21fcG9pbnQoKSArIGdlb21fdGV4dF9yZXBlbCgpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgZ2d0aXRsZShwYXN0ZTAobmFtZSwgXCJfb29lX3NpbXBsZUFubm9cIikpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFwiZGFzaGVkXCIpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gLSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFwiZGFzaGVkXCIpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBmY0N1dG9mZiwgbGluZXR5cGUgPSBcImRhc2hlZFwiKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IC1mY0N1dG9mZiwgbGluZXR5cGUgPSBcImRhc2hlZFwiKSArXG4gIHNjYWxlX2NvbG9yX21hbnVhbCh2YWx1ZXMgPSBjKFwiME5PXCIgPSBcImdyZXlcIiwgXCIxVVBcIiA9IFwicmVkXCIsIFwiMkRPV05cIiA9IFwiYmx1ZVwiKSkgKyAgIyBDb3JyZWN0ZWQgY29sb3IgbWFwcGluZ1xuICBzY2FsZV9zaGFwZV9tYW51YWwodmFsdWVzID0gYyhcIlRSVUVcIiA9IDIsIFwiRkFMU0VcIiA9IDE5KSlcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwiUk5BdnNMb29wX1wiLCBuYW1lLCBcIl9vb2Vfc2ltcGxlQW5ub1wiKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDdcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYCJ9 -->\n\n```r\nalpha <- 0.05\nfcCutoff <- 0.5\ndiffCutoff <- 0.5\ncommonLoopDir <- here(\\../data/loop_analysis\\)\ndiffDir <- here(\\../data/RNA_diff\\)\nname <- \\chromosight\\\ngeneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\\loopScore_\\, name, \\_p-n_simple_ensemblList.tsv\\))) %>%\n  rowwise() %>%                                # work one row at a time\n  mutate(\n    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),\n    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0\n    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))\n  ) %>% \n  ungroup() %>% \n  select(-minpos, -eps) \n  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))\n\ndiff.RNA <- fread(here(diffDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id\n\n\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() +\n  ggtitle(paste0(name, \\_ooe_simpleAnno\\)) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\RNAvsLoop_\\, name, \\_ooe_simpleAnno\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \chromosight\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_simple_ensemblList.tsv\))) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_ooe_simpleAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_ooe_simpleAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcY2hyb21vc2lnaHRcXFxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb21tb25Mb29wRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIG5hbWUsIFxcX3Atbl9zaW1wbGVfZW5zZW1ibExpc3QudHN2XFwpKSkgJT4lXG4gIHJvd3dpc2UoKSAlPiUgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICMgd29yayBvbmUgcm93IGF0IGEgdGltZVxuICBtdXRhdGUoXG4gICAgbWlucG9zID0gbWluKGMob29lX2RUQUcsIG9vZV9ETVNPKVtjKG9vZV9kVEFHLCBvb2VfRE1TTykgPiAwXSwgbmEucm0gPSBUUlVFKSxcbiAgICBlcHMgICAgPSBpZmVsc2UoaXMuZmluaXRlKG1pbnBvcyksIG1pbnBvcyAqIDAuMSwgMC4wMSksICAgICAgIyBmYWxsYmFjayBpZiBib3RoIGFyZSAwXG4gICAgZGlmZiAgID0gbG9nMigob29lX2RUQUcgKyBlcHMpIC8gKG9vZV9ETVNPICsgZXBzKSlcbiAgKSAlPiUgXG4gIHVuZ3JvdXAoKSAlPiUgXG4gIHNlbGVjdCgtbWlucG9zLCAtZXBzKSBcbiAgI2RwbHlyOjptdXRhdGUoZGlmZiA9IGxvZzIob29lX2RUQUcpIC0gbG9nMihvb2VfRE1TTykpXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUoZGlmZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibF9nZW5lX2lkLCBsb2cyRm9sZENoYW5nZSwgc2hyaW5rZWRfbG9nMkZDLCBwYWRqLCBleHRlcm5hbF9nZW5lX25hbWUpXG5nZW5lTGlzdC5kb3duLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDIDw9IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuZ2VuZUxpc3QudXAuUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPiAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcblxuXG5tYXhMb2cyRkMgPC0gMlxuXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmYpLCAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHBseXI6Om11dGF0ZShmbGFnID0gaWZlbHNlKGdlbmUgJWluJSBnZW5lTGlzdC5kb3duLlJOQSwgXFwyRE9XTlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lTGlzdC51cC5STkEsIFxcMVVQXFwsIFxcME5PXFwpKSxcbiAgICAgICAgICAgICAgICBtYXhGbGFnID0gKGFicyhzaHJpbmtlZF9sb2cyRkMpID4gbWF4TG9nMkZDKSxcbiAgICAgICAgICAgICAgICBzaHJsb2cyZmNNYXggPSBwbWF4KHBtaW4oc2hyaW5rZWRfbG9nMkZDLCBtYXhMb2cyRkMpLCAtbWF4TG9nMkZDKSkgJT4lIFxuICBkcGx5cjo6YXJyYW5nZShmbGFnKVxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHNocmxvZzJmY01heCwgeSA9IG1lYW5fZGlmZl9zY29yZSwgY29sb3IgPSBmbGFnLFxuICAgICAgICAgICAgICAgICAgICAgIGxhYmVsID0gaWZlbHNlKGZsYWcgIT0gXFwwTk9cXCwgZXh0ZXJuYWxfZ2VuZV9uYW1lLCBOQSksXG4gICAgICAgICAgICAgICAgICAgICAgc2hhcGUgPSBhcy5mYWN0b3IobWF4RmxhZykpKSArXG4gIGdlb21fcG9pbnQoKSArIGdlb21fdGV4dF9yZXBlbCgpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgZ2d0aXRsZShwYXN0ZTAobmFtZSwgXFxfb29lX3NpbXBsZUFubm9cXCkpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gLSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBmY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IC1mY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIHNjYWxlX2NvbG9yX21hbnVhbCh2YWx1ZXMgPSBjKFxcME5PXFwgPSBcXGdyZXlcXCwgXFwxVVBcXCA9IFxccmVkXFwsIFxcMkRPV05cXCA9IFxcYmx1ZVxcKSkgKyAgIyBDb3JyZWN0ZWQgY29sb3IgbWFwcGluZ1xuICBzY2FsZV9zaGFwZV9tYW51YWwodmFsdWVzID0gYyhcXFRSVUVcXCA9IDIsIFxcRkFMU0VcXCA9IDE5KSlcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcUk5BdnNMb29wX1xcLCBuYW1lLCBcXF9vb2Vfc2ltcGxlQW5ub1xcKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDdcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\nalpha <- 0.05\nfcCutoff <- 0.5\ndiffCutoff <- 0.5\ncommonLoopDir <- here(\\../data/loop_analysis\\)\ndiffDir <- here(\\../data/RNA_diff\\)\nname <- \\chromosight\\\ngeneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\\loopScore_\\, name, \\_p-n_simple_ensemblList.tsv\\))) %>%\n  rowwise() %>%                                # work one row at a time\n  mutate(\n    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),\n    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0\n    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))\n  ) %>% \n  ungroup() %>% \n  select(-minpos, -eps) \n  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))\n\ndiff.RNA <- fread(here(diffDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id\n\n\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() +\n  ggtitle(paste0(name, \\_ooe_simpleAnno\\)) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\RNAvsLoop_\\, name, \\_ooe_simpleAnno\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcY2hyb21vc2lnaHRcXFxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb21tb25Mb29wRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIG5hbWUsIFxcX3Atbl9zaW1wbGVfZW5zZW1ibExpc3QudHN2XFwpKSkgJT4lXG4gIHJvd3dpc2UoKSAlPiUgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICMgd29yayBvbmUgcm93IGF0IGEgdGltZVxuICBtdXRhdGUoXG4gICAgbWlucG9zID0gbWluKGMob29lX2RUQUcsIG9vZV9ETVNPKVtjKG9vZV9kVEFHLCBvb2VfRE1TTykgPiAwXSwgbmEucm0gPSBUUlVFKSxcbiAgICBlcHMgICAgPSBpZmVsc2UoaXMuZmluaXRlKG1pbnBvcyksIG1pbnBvcyAqIDAuMSwgMC4wMSksICAgICAgIyBmYWxsYmFjayBpZiBib3RoIGFyZSAwXG4gICAgZGlmZiAgID0gbG9nMigob29lX2RUQUcgKyBlcHMpIC8gKG9vZV9ETVNPICsgZXBzKSlcbiAgKSAlPiUgXG4gIHVuZ3JvdXAoKSAlPiUgXG4gIHNlbGVjdCgtbWlucG9zLCAtZXBzKSBcbiAgI2RwbHlyOjptdXRhdGUoZGlmZiA9IGxvZzIob29lX2RUQUcpIC0gbG9nMihvb2VfRE1TTykpXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUoZGlmZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibF9nZW5lX2lkLCBsb2cyRm9sZENoYW5nZSwgc2hyaW5rZWRfbG9nMkZDLCBwYWRqLCBleHRlcm5hbF9nZW5lX25hbWUpXG5nZW5lTGlzdC5kb3duLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDIDw9IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuZ2VuZUxpc3QudXAuUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPiAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcblxuXG5tYXhMb2cyRkMgPC0gMlxuXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmYpLCAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHBseXI6Om11dGF0ZShmbGFnID0gaWZlbHNlKGdlbmUgJWluJSBnZW5lTGlzdC5kb3duLlJOQSwgXFwyRE9XTlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lTGlzdC51cC5STkEsIFxcMVVQXFwsIFxcME5PXFwpKSxcbiAgICAgICAgICAgICAgICBtYXhGbGFnID0gKGFicyhzaHJpbmtlZF9sb2cyRkMpID4gbWF4TG9nMkZDKSxcbiAgICAgICAgICAgICAgICBzaHJsb2cyZmNNYXggPSBwbWF4KHBtaW4oc2hyaW5rZWRfbG9nMkZDLCBtYXhMb2cyRkMpLCAtbWF4TG9nMkZDKSkgJT4lIFxuICBkcGx5cjo6YXJyYW5nZShmbGFnKVxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHNocmxvZzJmY01heCwgeSA9IG1lYW5fZGlmZl9zY29yZSwgY29sb3IgPSBmbGFnLFxuICAgICAgICAgICAgICAgICAgICAgIGxhYmVsID0gaWZlbHNlKGZsYWcgIT0gXFwwTk9cXCwgZXh0ZXJuYWxfZ2VuZV9uYW1lLCBOQSksXG4gICAgICAgICAgICAgICAgICAgICAgc2hhcGUgPSBhcy5mYWN0b3IobWF4RmxhZykpKSArXG4gIGdlb21fcG9pbnQoKSArIGdlb21fdGV4dF9yZXBlbCgpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgZ2d0aXRsZShwYXN0ZTAobmFtZSwgXFxfb29lX3NpbXBsZUFubm9cXCkpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gLSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBmY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IC1mY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIHNjYWxlX2NvbG9yX21hbnVhbCh2YWx1ZXMgPSBjKFxcME5PXFwgPSBcXGdyZXlcXCwgXFwxVVBcXCA9IFxccmVkXFwsIFxcMkRPV05cXCA9IFxcYmx1ZVxcKSkgKyAgIyBDb3JyZWN0ZWQgY29sb3IgbWFwcGluZ1xuICBzY2FsZV9zaGFwZV9tYW51YWwodmFsdWVzID0gYyhcXFRSVUVcXCA9IDIsIFxcRkFMU0VcXCA9IDE5KSlcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcUk5BdnNMb29wX1xcLCBuYW1lLCBcXF9vb2Vfc2ltcGxlQW5ub1xcKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDdcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \chromosight\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_simple_ensemblList.tsv\))) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_ooe_simpleAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_ooe_simpleAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### RNA-seq loopscore scatterplot

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFwiLi4vZGF0YS9sb29wX2FuYWx5c2lzXCIpXG5kaWZmRGlyIDwtIGhlcmUoXCIuLi9kYXRhL1JOQV9kaWZmXCIpXG5uYW1lIDwtIFwiY2hyb21vc2lnaHRcIlxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb21tb25Mb29wRGlyLCBwYXN0ZTAoXCJsb29wU2NvcmVfXCIsIG5hbWUsIFwiX3Atbl9jb21wbGV4X2Vuc2VtYmxMaXN0LnRzdlwiKSkpICU+JVxuICByb3d3aXNlKCkgJT4lICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAjIHdvcmsgb25lIHJvdyBhdCBhIHRpbWVcbiAgbXV0YXRlKFxuICAgIG1pbnBvcyA9IG1pbihjKG9vZV9kVEFHLCBvb2VfRE1TTylbYyhvb2VfZFRBRywgb29lX0RNU08pID4gMF0sIG5hLnJtID0gVFJVRSksXG4gICAgZXBzICAgID0gaWZlbHNlKGlzLmZpbml0ZShtaW5wb3MpLCBtaW5wb3MgKiAwLjEsIDAuMDEpLCAgICAgICMgZmFsbGJhY2sgaWYgYm90aCBhcmUgMFxuICAgIGRpZmYgICA9IGxvZzIoKG9vZV9kVEFHICsgZXBzKSAvIChvb2VfRE1TTyArIGVwcykpXG4gICkgJT4lIFxuICB1bmdyb3VwKCkgJT4lIFxuICBzZWxlY3QoLW1pbnBvcywgLWVwcykgXG4gICNkcGx5cjo6bXV0YXRlKGRpZmYgPSBsb2cyKG9vZV9kVEFHKSAtIGxvZzIob29lX0RNU08pKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKGRpZmZEaXIsIFwiZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcIikpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuZ2VuZUxpc3QuZG93bi5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA8PSAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcbmdlbmVMaXN0LnVwLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDID4gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5cblxubWF4TG9nMkZDIDwtIDJcblxudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZiwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmKSwgLmdyb3VwcyA9ICdkcm9wJylcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcImdlbmVcIiA9IFwiZW5zZW1ibF9nZW5lX2lkXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoZmxhZyA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QuZG93bi5STkEsIFwiMkRPV05cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QudXAuUk5BLCBcIjFVUFwiLCBcIjBOT1wiKSksXG4gICAgICAgICAgICAgICAgbWF4RmxhZyA9IChhYnMoc2hyaW5rZWRfbG9nMkZDKSA+IG1heExvZzJGQyksXG4gICAgICAgICAgICAgICAgc2hybG9nMmZjTWF4ID0gcG1heChwbWluKHNocmlua2VkX2xvZzJGQywgbWF4TG9nMkZDKSwgLW1heExvZzJGQykpICU+JSBcbiAgZHBseXI6OmFycmFuZ2UoZmxhZylcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBzaHJsb2cyZmNNYXgsIHkgPSBtZWFuX2RpZmZfc2NvcmUsIGNvbG9yID0gZmxhZyxcbiAgICAgICAgICAgICAgICAgICAgICBsYWJlbCA9IGlmZWxzZShmbGFnICE9IFwiME5PXCIsIGV4dGVybmFsX2dlbmVfbmFtZSwgTkEpLFxuICAgICAgICAgICAgICAgICAgICAgIHNoYXBlID0gYXMuZmFjdG9yKG1heEZsYWcpKSkgK1xuICBnZW9tX3BvaW50KCkgKyBnZW9tX3RleHRfcmVwZWwoKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdndGl0bGUocGFzdGUwKG5hbWUsIFwiX29vZV9jb21wbGV4QW5ub1wiKSkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXCJkYXNoZWRcIikgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAtIGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXCJkYXNoZWRcIikgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IGZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFwiZGFzaGVkXCIpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gLWZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFwiZGFzaGVkXCIpICtcbiAgc2NhbGVfY29sb3JfbWFudWFsKHZhbHVlcyA9IGMoXCIwTk9cIiA9IFwiZ3JleVwiLCBcIjFVUFwiID0gXCJyZWRcIiwgXCIyRE9XTlwiID0gXCJibHVlXCIpKSArICAjIENvcnJlY3RlZCBjb2xvciBtYXBwaW5nXG4gIHNjYWxlX3NoYXBlX21hbnVhbCh2YWx1ZXMgPSBjKFwiVFJVRVwiID0gMiwgXCJGQUxTRVwiID0gMTkpKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJSTkF2c0xvb3BfXCIsIG5hbWUsIFwiX29vZV9jb21wbGV4QW5ub1wiKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDdcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYCJ9 -->\n\n```r\nalpha <- 0.05\nfcCutoff <- 0.5\ndiffCutoff <- 0.5\ncommonLoopDir <- here(\\../data/loop_analysis\\)\ndiffDir <- here(\\../data/RNA_diff\\)\nname <- \\chromosight\\\ngeneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\\loopScore_\\, name, \\_p-n_complex_ensemblList.tsv\\))) %>%\n  rowwise() %>%                                # work one row at a time\n  mutate(\n    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),\n    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0\n    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))\n  ) %>% \n  ungroup() %>% \n  select(-minpos, -eps) \n  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))\n\ndiff.RNA <- fread(here(diffDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id\n\n\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() +\n  ggtitle(paste0(name, \\_ooe_complexAnno\\)) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\RNAvsLoop_\\, name, \\_ooe_complexAnno\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \chromosight\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_complex_ensemblList.tsv\))) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_ooe_complexAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_ooe_complexAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcY2hyb21vc2lnaHRcXFxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb21tb25Mb29wRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIG5hbWUsIFxcX3Atbl9jb21wbGV4X2Vuc2VtYmxMaXN0LnRzdlxcKSkpICU+JVxuICByb3d3aXNlKCkgJT4lICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAjIHdvcmsgb25lIHJvdyBhdCBhIHRpbWVcbiAgbXV0YXRlKFxuICAgIG1pbnBvcyA9IG1pbihjKG9vZV9kVEFHLCBvb2VfRE1TTylbYyhvb2VfZFRBRywgb29lX0RNU08pID4gMF0sIG5hLnJtID0gVFJVRSksXG4gICAgZXBzICAgID0gaWZlbHNlKGlzLmZpbml0ZShtaW5wb3MpLCBtaW5wb3MgKiAwLjEsIDAuMDEpLCAgICAgICMgZmFsbGJhY2sgaWYgYm90aCBhcmUgMFxuICAgIGRpZmYgICA9IGxvZzIoKG9vZV9kVEFHICsgZXBzKSAvIChvb2VfRE1TTyArIGVwcykpXG4gICkgJT4lIFxuICB1bmdyb3VwKCkgJT4lIFxuICBzZWxlY3QoLW1pbnBvcywgLWVwcykgXG4gICNkcGx5cjo6bXV0YXRlKGRpZmYgPSBsb2cyKG9vZV9kVEFHKSAtIGxvZzIob29lX0RNU08pKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKGRpZmZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuZ2VuZUxpc3QuZG93bi5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA8PSAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcbmdlbmVMaXN0LnVwLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDID4gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5cblxubWF4TG9nMkZDIDwtIDJcblxudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZiwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmKSwgLmdyb3VwcyA9ICdkcm9wJylcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcXGdlbmVcXCA9IFxcZW5zZW1ibF9nZW5lX2lkXFwpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoZmxhZyA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QuZG93bi5STkEsIFxcMkRPV05cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QudXAuUk5BLCBcXDFVUFxcLCBcXDBOT1xcKSksXG4gICAgICAgICAgICAgICAgbWF4RmxhZyA9IChhYnMoc2hyaW5rZWRfbG9nMkZDKSA+IG1heExvZzJGQyksXG4gICAgICAgICAgICAgICAgc2hybG9nMmZjTWF4ID0gcG1heChwbWluKHNocmlua2VkX2xvZzJGQywgbWF4TG9nMkZDKSwgLW1heExvZzJGQykpICU+JSBcbiAgZHBseXI6OmFycmFuZ2UoZmxhZylcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBzaHJsb2cyZmNNYXgsIHkgPSBtZWFuX2RpZmZfc2NvcmUsIGNvbG9yID0gZmxhZyxcbiAgICAgICAgICAgICAgICAgICAgICBsYWJlbCA9IGlmZWxzZShmbGFnICE9IFxcME5PXFwsIGV4dGVybmFsX2dlbmVfbmFtZSwgTkEpLFxuICAgICAgICAgICAgICAgICAgICAgIHNoYXBlID0gYXMuZmFjdG9yKG1heEZsYWcpKSkgK1xuICBnZW9tX3BvaW50KCkgKyBnZW9tX3RleHRfcmVwZWwoKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdndGl0bGUocGFzdGUwKG5hbWUsIFxcX29vZV9jb21wbGV4QW5ub1xcKSkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAtIGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IGZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gLWZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgc2NhbGVfY29sb3JfbWFudWFsKHZhbHVlcyA9IGMoXFwwTk9cXCA9IFxcZ3JleVxcLCBcXDFVUFxcID0gXFxyZWRcXCwgXFwyRE9XTlxcID0gXFxibHVlXFwpKSArICAjIENvcnJlY3RlZCBjb2xvciBtYXBwaW5nXG4gIHNjYWxlX3NoYXBlX21hbnVhbCh2YWx1ZXMgPSBjKFxcVFJVRVxcID0gMiwgXFxGQUxTRVxcID0gMTkpKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxSTkF2c0xvb3BfXFwsIG5hbWUsIFxcX29vZV9jb21wbGV4QW5ub1xcKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDdcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\nalpha <- 0.05\nfcCutoff <- 0.5\ndiffCutoff <- 0.5\ncommonLoopDir <- here(\\../data/loop_analysis\\)\ndiffDir <- here(\\../data/RNA_diff\\)\nname <- \\chromosight\\\ngeneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\\loopScore_\\, name, \\_p-n_complex_ensemblList.tsv\\))) %>%\n  rowwise() %>%                                # work one row at a time\n  mutate(\n    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),\n    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0\n    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))\n  ) %>% \n  ungroup() %>% \n  select(-minpos, -eps) \n  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))\n\ndiff.RNA <- fread(here(diffDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id\n\n\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() +\n  ggtitle(paste0(name, \\_ooe_complexAnno\\)) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\RNAvsLoop_\\, name, \\_ooe_complexAnno\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcY2hyb21vc2lnaHRcXFxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb21tb25Mb29wRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIG5hbWUsIFxcX3Atbl9jb21wbGV4X2Vuc2VtYmxMaXN0LnRzdlxcKSkpICU+JVxuICByb3d3aXNlKCkgJT4lICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAjIHdvcmsgb25lIHJvdyBhdCBhIHRpbWVcbiAgbXV0YXRlKFxuICAgIG1pbnBvcyA9IG1pbihjKG9vZV9kVEFHLCBvb2VfRE1TTylbYyhvb2VfZFRBRywgb29lX0RNU08pID4gMF0sIG5hLnJtID0gVFJVRSksXG4gICAgZXBzICAgID0gaWZlbHNlKGlzLmZpbml0ZShtaW5wb3MpLCBtaW5wb3MgKiAwLjEsIDAuMDEpLCAgICAgICMgZmFsbGJhY2sgaWYgYm90aCBhcmUgMFxuICAgIGRpZmYgICA9IGxvZzIoKG9vZV9kVEFHICsgZXBzKSAvIChvb2VfRE1TTyArIGVwcykpXG4gICkgJT4lIFxuICB1bmdyb3VwKCkgJT4lIFxuICBzZWxlY3QoLW1pbnBvcywgLWVwcykgXG4gICNkcGx5cjo6bXV0YXRlKGRpZmYgPSBsb2cyKG9vZV9kVEFHKSAtIGxvZzIob29lX0RNU08pKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKGRpZmZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuZ2VuZUxpc3QuZG93bi5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA8PSAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcbmdlbmVMaXN0LnVwLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDID4gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5cblxubWF4TG9nMkZDIDwtIDJcblxudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZiwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmKSwgLmdyb3VwcyA9ICdkcm9wJylcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcXGdlbmVcXCA9IFxcZW5zZW1ibF9nZW5lX2lkXFwpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoZmxhZyA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QuZG93bi5STkEsIFxcMkRPV05cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QudXAuUk5BLCBcXDFVUFxcLCBcXDBOT1xcKSksXG4gICAgICAgICAgICAgICAgbWF4RmxhZyA9IChhYnMoc2hyaW5rZWRfbG9nMkZDKSA+IG1heExvZzJGQyksXG4gICAgICAgICAgICAgICAgc2hybG9nMmZjTWF4ID0gcG1heChwbWluKHNocmlua2VkX2xvZzJGQywgbWF4TG9nMkZDKSwgLW1heExvZzJGQykpICU+JSBcbiAgZHBseXI6OmFycmFuZ2UoZmxhZylcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBzaHJsb2cyZmNNYXgsIHkgPSBtZWFuX2RpZmZfc2NvcmUsIGNvbG9yID0gZmxhZyxcbiAgICAgICAgICAgICAgICAgICAgICBsYWJlbCA9IGlmZWxzZShmbGFnICE9IFxcME5PXFwsIGV4dGVybmFsX2dlbmVfbmFtZSwgTkEpLFxuICAgICAgICAgICAgICAgICAgICAgIHNoYXBlID0gYXMuZmFjdG9yKG1heEZsYWcpKSkgK1xuICBnZW9tX3BvaW50KCkgKyBnZW9tX3RleHRfcmVwZWwoKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdndGl0bGUocGFzdGUwKG5hbWUsIFxcX29vZV9jb21wbGV4QW5ub1xcKSkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAtIGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IGZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gLWZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgc2NhbGVfY29sb3JfbWFudWFsKHZhbHVlcyA9IGMoXFwwTk9cXCA9IFxcZ3JleVxcLCBcXDFVUFxcID0gXFxyZWRcXCwgXFwyRE9XTlxcID0gXFxibHVlXFwpKSArICAjIENvcnJlY3RlZCBjb2xvciBtYXBwaW5nXG4gIHNjYWxlX3NoYXBlX21hbnVhbCh2YWx1ZXMgPSBjKFxcVFJVRVxcID0gMiwgXFxGQUxTRVxcID0gMTkpKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxSTkF2c0xvb3BfXFwsIG5hbWUsIFxcX29vZV9jb21wbGV4QW5ub1xcKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDdcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \chromosight\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_complex_ensemblList.tsv\))) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_ooe_complexAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_ooe_complexAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuY29tbW9uTG9vcERpciA8LSBoZXJlKFwiLi4vZGF0YS9sb29wX2FuYWx5c2lzXCIpXG5maWdEaXIgPC0gaGVyZShcIi4uL2ZpZ3VyZS9sb29wX2FuYWx5c2lzXCIpXG5kaXIuY3JlYXRlKGZpZ0Rpciwgc2hvd1dhcm5pbmdzID0gRkFMU0UsIHJlY3Vyc2l2ZSA9IFRSVUUpXG5cbmRhdGEgPC0gZnJlYWQoaGVyZShjb21tb25Mb29wRGlyLCBcImxvb3BTY29yZV9oaWNkY3AudHN2XCIpKVxuXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9ETVNPLCBvb2VfZFRBRywgYyhcIlAtUFwiLCBcIlAtRVwiLCBcIlAtU1wiLCBcIlAtWFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiRS1FXCIsIFwiRS1TXCIsIFwiRS1YXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJTLVNcIiwgXCJTLVhcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIlgtWFwiKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFwiaGljZGNwX29vZV9hbGxfZFRBR3ZETVNPXCIsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXCJoaWNkY3Bfb29lX2FsbF9kVEFHdkRNU09cIiwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfRE1TTywgb29lX2RUQUcsIGMoXCJTLVNcIiksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcImhpY2RjcF9vb2Vfc3RyX2RUQUd2RE1TT1wiLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFwiaGljZGNwX29vZV9zdHJfZFRBR3ZETVNPXCIsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0RNU08sIG9vZV9kVEFHLCBjKFwiUy1TXCIsIFwiUy1YXCIpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXCJoaWNkY3Bfb29lX3N0cjJfZFRBR3ZETVNPXCIsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXCJoaWNkY3Bfb29lX3N0cjJfZFRBR3ZETVNPXCIsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0RNU08sIG9vZV9kVEFHLCBjKFwiUC1QXCIsIFwiUC1FXCIsIFwiRS1FXCIpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXCJoaWNkY3Bfb29lX3JlZ19kVEFHdkRNU09cIixcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcImhpY2RjcF9vb2VfcmVnX2RUQUd2RE1TT1wiLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9ETVNPLCBvb2VfZFRBRywgYyhcIlAtU1wiLCBcIkUtU1wiKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFwiaGljZGNwX29vZV9yZWdTdHJfZFRBR3ZETVNPXCIsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXCJoaWNkY3Bfb29lX3JlZ1N0cl9kVEFHdkRNU09cIiwgZmlnRGlyKVxuXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9ETVNPLCBvb2VfQTQ4NSwgYyhcIlAtUFwiLCBcIlAtRVwiLCBcIlAtU1wiLCBcIlAtWFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiRS1FXCIsIFwiRS1TXCIsIFwiRS1YXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJTLVNcIiwgXCJTLVhcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIlgtWFwiKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFwiaGljZGNwX29vZV9hbGxfQTQ4NXZETVNPXCIsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXCJoaWNkY3Bfb29lX2FsbF9BNDg1dkRNU09cIiwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfRE1TTywgb29lX0E0ODUsIGMoXCJTLVNcIiksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcImhpY2RjcF9vb2Vfc3RyX0E0ODV2RE1TT1wiLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFwiaGljZGNwX29vZV9zdHJfQTQ4NXZETVNPXCIsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0RNU08sIG9vZV9BNDg1LCBjKFwiUy1TXCIsIFwiUy1YXCIpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXCJoaWNkY3Bfb29lX3N0cjJfQTQ4NXZETVNPXCIsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXCJoaWNkY3Bfb29lX3N0cjJfQTQ4NXZETVNPXCIsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0RNU08sIG9vZV9BNDg1LCBjKFwiUC1QXCIsIFwiUC1FXCIsIFwiRS1FXCIpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXCJoaWNkY3Bfb29lX3JlZ19BNDg1dkRNU09cIixcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcImhpY2RjcF9vb2VfcmVnX0E0ODV2RE1TT1wiLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9ETVNPLCBvb2VfQTQ4NSwgYyhcIlAtU1wiLCBcIkUtU1wiKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFwiaGljZGNwX29vZV9yZWdTdHJfQTQ4NXZETVNPXCIsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXCJoaWNkY3Bfb29lX3JlZ1N0cl9BNDg1dkRNU09cIiwgZmlnRGlyKVxuXG5cbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0VwaURNU08sIG9vZV9FcGlkVEFHLCBjKFwiUC1QXCIsIFwiUC1FXCIsIFwiUC1TXCIsIFwiUC1YXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJFLUVcIiwgXCJFLVNcIiwgXCJFLVhcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIlMtU1wiLCBcIlMtWFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiWC1YXCIpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXCJoaWNkY3Bfb29lX2FsbF9FcGlkVEFHdkVwaURNU09cIixcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcImhpY2RjcF9vb2VfYWxsX0VwaWRUQUd2RXBpRE1TT1wiLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9FcGlETVNPLCBvb2VfRXBpZFRBRywgYyhcIlMtU1wiKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFwiaGljZGNwX29vZV9zdHJfRXBpZFRBR3ZFcGlETVNPXCIsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXCJoaWNkY3Bfb29lX3N0cl9FcGlkVEFHdkVwaURNU09cIiwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfRXBpRE1TTywgb29lX0VwaWRUQUcsIGMoXCJTLVNcIiwgXCJTLVhcIiksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcImhpY2RjcF9vb2Vfc3RyMl9FcGlkVEFHdkVwaURNU09cIixcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcImhpY2RjcF9vb2Vfc3RyMl9FcGlkVEFHdkVwaURNU09cIiwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfRXBpRE1TTywgb29lX0VwaWRUQUcsIGMoXCJQLVBcIiwgXCJQLUVcIiwgXCJFLUVcIiksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcImhpY2RjcF9vb2VfcmVnX0VwaWRUQUd2RXBpRE1TT1wiLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFwiaGljZGNwX29vZV9yZWdfRXBpZFRBR3ZFcGlETVNPXCIsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0VwaURNU08sIG9vZV9FcGlkVEFHLCBjKFwiUC1TXCIsIFwiRS1TXCIpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXCJoaWNkY3Bfb29lX3JlZ1N0cl9FcGlkVEFHdkVwaURNU09cIixcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcImhpY2RjcF9vb2VfcmVnU3RyX0VwaWRUQUd2RXBpRE1TT1wiLCBmaWdEaXIpXG5cblxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfVVQsIG9vZV9BSUQsIGMoXCJQLVBcIiwgXCJQLUVcIiwgXCJQLVNcIiwgXCJQLVhcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIkUtRVwiLCBcIkUtU1wiLCBcIkUtWFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiUy1TXCIsIFwiUy1YXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJYLVhcIiksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcImhpY2RjcF9vb2VfYWxsX0FJRHZVVFwiLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFwiaGljZGNwX29vZV9hbGxfQUlEdlVUXCIsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX1VULCBvb2VfQUlELCBjKFwiUy1TXCIpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXCJoaWNkY3Bfb29lX3N0cl9BSUR2VVRcIixcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcImhpY2RjcF9vb2Vfc3RyX0FJRHZVVFwiLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9VVCwgb29lX0FJRCwgYyhcIlMtU1wiLCBcIlMtWFwiKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFwiaGljZGNwX29vZV9zdHIyX0FJRHZVVFwiLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFwiaGljZGNwX29vZV9zdHIyX0FJRHZVVFwiLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9VVCwgb29lX0FJRCwgYyhcIlAtUFwiLCBcIlAtRVwiLCBcIkUtRVwiKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFwiaGljZGNwX29vZV9yZWdfQUlEdlVUXCIsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXCJoaWNkY3Bfb29lX3JlZ19BSUR2VVRcIiwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfVVQsIG9vZV9BSUQsIGMoXCJQLVNcIiwgXCJFLVNcIiksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcImhpY2RjcF9vb2VfcmVnU3RyX0FJRHZVVFwiLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFwiaGljZGNwX29vZV9yZWdTdHJfQUlEdlVUXCIsIGZpZ0RpcilcblxuYGBgIn0= -->\n\n```r\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_hicdcp.tsv\\))\n\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\hicdcp_ooe_all_dTAGvDMSO\\,\n                 title = \\hicdcp_ooe_all_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\),\n                 name = \\hicdcp_ooe_str_dTAGvDMSO\\,\n                 title = \\hicdcp_ooe_str_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\hicdcp_ooe_str2_dTAGvDMSO\\,\n                 title = \\hicdcp_ooe_str2_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\hicdcp_ooe_reg_dTAGvDMSO\\,\n                 title = \\hicdcp_ooe_reg_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\hicdcp_ooe_regStr_dTAGvDMSO\\,\n                 title = \\hicdcp_ooe_regStr_dTAGvDMSO\\, figDir)\n\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\hicdcp_ooe_all_A485vDMSO\\,\n                 title = \\hicdcp_ooe_all_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\),\n                 name = \\hicdcp_ooe_str_A485vDMSO\\,\n                 title = \\hicdcp_ooe_str_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\, \\S-X\\),\n                 name = \\hicdcp_ooe_str2_A485vDMSO\\,\n                 title = \\hicdcp_ooe_str2_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\hicdcp_ooe_reg_A485vDMSO\\,\n                 title = \\hicdcp_ooe_reg_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-S\\, \\E-S\\),\n                 name = \\hicdcp_ooe_regStr_A485vDMSO\\,\n                 title = \\hicdcp_ooe_regStr_A485vDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\hicdcp_ooe_all_EpidTAGvEpiDMSO\\,\n                 title = \\hicdcp_ooe_all_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\),\n                 name = \\hicdcp_ooe_str_EpidTAGvEpiDMSO\\,\n                 title = \\hicdcp_ooe_str_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\hicdcp_ooe_str2_EpidTAGvEpiDMSO\\,\n                 title = \\hicdcp_ooe_str2_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\hicdcp_ooe_reg_EpidTAGvEpiDMSO\\,\n                 title = \\hicdcp_ooe_reg_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\hicdcp_ooe_regStr_EpidTAGvEpiDMSO\\,\n                 title = \\hicdcp_ooe_regStr_EpidTAGvEpiDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\hicdcp_ooe_all_AIDvUT\\,\n                 title = \\hicdcp_ooe_all_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\),\n                 name = \\hicdcp_ooe_str_AIDvUT\\,\n                 title = \\hicdcp_ooe_str_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\, \\S-X\\),\n                 name = \\hicdcp_ooe_str2_AIDvUT\\,\n                 title = \\hicdcp_ooe_str2_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\hicdcp_ooe_reg_AIDvUT\\,\n                 title = \\hicdcp_ooe_reg_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-S\\, \\E-S\\),\n                 name = \\hicdcp_ooe_regStr_AIDvUT\\,\n                 title = \\hicdcp_ooe_regStr_AIDvUT\\, figDir)\n\n```\n\n<!-- rnb-source-end -->\n"} -->
commonLoopDir <- here(\../data/loop_analysis\)
figDir <- here(\../figure/loop_analysis\)
dir.create(figDir, showWarnings = FALSE, recursive = TRUE)

data <- fread(here(commonLoopDir, \loopScore_hicdcp.tsv\))

plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \hicdcp_ooe_all_dTAGvDMSO\,
                 title = \hicdcp_ooe_all_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\S-S\),
                 name = \hicdcp_ooe_str_dTAGvDMSO\,
                 title = \hicdcp_ooe_str_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\S-S\, \S-X\),
                 name = \hicdcp_ooe_str2_dTAGvDMSO\,
                 title = \hicdcp_ooe_str2_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-P\, \P-E\, \E-E\),
                 name = \hicdcp_ooe_reg_dTAGvDMSO\,
                 title = \hicdcp_ooe_reg_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-S\, \E-S\),
                 name = \hicdcp_ooe_regStr_dTAGvDMSO\,
                 title = \hicdcp_ooe_regStr_dTAGvDMSO\, figDir)

plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \hicdcp_ooe_all_A485vDMSO\,
                 title = \hicdcp_ooe_all_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\S-S\),
                 name = \hicdcp_ooe_str_A485vDMSO\,
                 title = \hicdcp_ooe_str_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\S-S\, \S-X\),
                 name = \hicdcp_ooe_str2_A485vDMSO\,
                 title = \hicdcp_ooe_str2_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-P\, \P-E\, \E-E\),
                 name = \hicdcp_ooe_reg_A485vDMSO\,
                 title = \hicdcp_ooe_reg_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-S\, \E-S\),
                 name = \hicdcp_ooe_regStr_A485vDMSO\,
                 title = \hicdcp_ooe_regStr_A485vDMSO\, figDir)


plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \hicdcp_ooe_all_EpidTAGvEpiDMSO\,
                 title = \hicdcp_ooe_all_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\S-S\),
                 name = \hicdcp_ooe_str_EpidTAGvEpiDMSO\,
                 title = \hicdcp_ooe_str_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\S-S\, \S-X\),
                 name = \hicdcp_ooe_str2_EpidTAGvEpiDMSO\,
                 title = \hicdcp_ooe_str2_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-P\, \P-E\, \E-E\),
                 name = \hicdcp_ooe_reg_EpidTAGvEpiDMSO\,
                 title = \hicdcp_ooe_reg_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-S\, \E-S\),
                 name = \hicdcp_ooe_regStr_EpidTAGvEpiDMSO\,
                 title = \hicdcp_ooe_regStr_EpidTAGvEpiDMSO\, figDir)


plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \hicdcp_ooe_all_AIDvUT\,
                 title = \hicdcp_ooe_all_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\S-S\),
                 name = \hicdcp_ooe_str_AIDvUT\,
                 title = \hicdcp_ooe_str_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\S-S\, \S-X\),
                 name = \hicdcp_ooe_str2_AIDvUT\,
                 title = \hicdcp_ooe_str2_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-P\, \P-E\, \E-E\),
                 name = \hicdcp_ooe_reg_AIDvUT\,
                 title = \hicdcp_ooe_reg_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-S\, \E-S\),
                 name = \hicdcp_ooe_regStr_AIDvUT\,
                 title = \hicdcp_ooe_regStr_AIDvUT\, figDir)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5maWdEaXIgPC0gaGVyZShcXC4uL2ZpZ3VyZS9sb29wX2FuYWx5c2lzXFwpXG5kaXIuY3JlYXRlKGZpZ0Rpciwgc2hvd1dhcm5pbmdzID0gRkFMU0UsIHJlY3Vyc2l2ZSA9IFRSVUUpXG5cbmRhdGEgPC0gZnJlYWQoaGVyZShjb21tb25Mb29wRGlyLCBcXGxvb3BTY29yZV9oaWNkY3AudHN2XFwpKVxuXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9ETVNPLCBvb2VfZFRBRywgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcRS1FXFwsIFxcRS1TXFwsIFxcRS1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxTLVNcXCwgXFxTLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFgtWFxcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9hbGxfZFRBR3ZETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX2FsbF9kVEFHdkRNU09cXCwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfRE1TTywgb29lX2RUQUcsIGMoXFxTLVNcXCksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcXGhpY2RjcF9vb2Vfc3RyX2RUQUd2RE1TT1xcLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFxcaGljZGNwX29vZV9zdHJfZFRBR3ZETVNPXFwsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0RNU08sIG9vZV9kVEFHLCBjKFxcUy1TXFwsIFxcUy1YXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX3N0cjJfZFRBR3ZETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX3N0cjJfZFRBR3ZETVNPXFwsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0RNU08sIG9vZV9kVEFHLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX3JlZ19kVEFHdkRNU09cXCxcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcXGhpY2RjcF9vb2VfcmVnX2RUQUd2RE1TT1xcLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9ETVNPLCBvb2VfZFRBRywgYyhcXFAtU1xcLCBcXEUtU1xcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9yZWdTdHJfZFRBR3ZETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX3JlZ1N0cl9kVEFHdkRNU09cXCwgZmlnRGlyKVxuXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9ETVNPLCBvb2VfQTQ4NSwgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcRS1FXFwsIFxcRS1TXFwsIFxcRS1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxTLVNcXCwgXFxTLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFgtWFxcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9hbGxfQTQ4NXZETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX2FsbF9BNDg1dkRNU09cXCwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfRE1TTywgb29lX0E0ODUsIGMoXFxTLVNcXCksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcXGhpY2RjcF9vb2Vfc3RyX0E0ODV2RE1TT1xcLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFxcaGljZGNwX29vZV9zdHJfQTQ4NXZETVNPXFwsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0RNU08sIG9vZV9BNDg1LCBjKFxcUy1TXFwsIFxcUy1YXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX3N0cjJfQTQ4NXZETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX3N0cjJfQTQ4NXZETVNPXFwsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0RNU08sIG9vZV9BNDg1LCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX3JlZ19BNDg1dkRNU09cXCxcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcXGhpY2RjcF9vb2VfcmVnX0E0ODV2RE1TT1xcLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9ETVNPLCBvb2VfQTQ4NSwgYyhcXFAtU1xcLCBcXEUtU1xcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9yZWdTdHJfQTQ4NXZETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX3JlZ1N0cl9BNDg1dkRNU09cXCwgZmlnRGlyKVxuXG5cbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0VwaURNU08sIG9vZV9FcGlkVEFHLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcUC1TXFwsIFxcUC1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxFLUVcXCwgXFxFLVNcXCwgXFxFLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFMtU1xcLCBcXFMtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcWC1YXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX2FsbF9FcGlkVEFHdkVwaURNU09cXCxcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcXGhpY2RjcF9vb2VfYWxsX0VwaWRUQUd2RXBpRE1TT1xcLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9FcGlETVNPLCBvb2VfRXBpZFRBRywgYyhcXFMtU1xcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9zdHJfRXBpZFRBR3ZFcGlETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX3N0cl9FcGlkVEFHdkVwaURNU09cXCwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfRXBpRE1TTywgb29lX0VwaWRUQUcsIGMoXFxTLVNcXCwgXFxTLVhcXCksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcXGhpY2RjcF9vb2Vfc3RyMl9FcGlkVEFHdkVwaURNU09cXCxcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcXGhpY2RjcF9vb2Vfc3RyMl9FcGlkVEFHdkVwaURNU09cXCwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfRXBpRE1TTywgb29lX0VwaWRUQUcsIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcXGhpY2RjcF9vb2VfcmVnX0VwaWRUQUd2RXBpRE1TT1xcLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFxcaGljZGNwX29vZV9yZWdfRXBpZFRBR3ZFcGlETVNPXFwsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0VwaURNU08sIG9vZV9FcGlkVEFHLCBjKFxcUC1TXFwsIFxcRS1TXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX3JlZ1N0cl9FcGlkVEFHdkVwaURNU09cXCxcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcXGhpY2RjcF9vb2VfcmVnU3RyX0VwaWRUQUd2RXBpRE1TT1xcLCBmaWdEaXIpXG5cblxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfVVQsIG9vZV9BSUQsIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXEUtRVxcLCBcXEUtU1xcLCBcXEUtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcUy1TXFwsIFxcUy1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxYLVhcXCksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcXGhpY2RjcF9vb2VfYWxsX0FJRHZVVFxcLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFxcaGljZGNwX29vZV9hbGxfQUlEdlVUXFwsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX1VULCBvb2VfQUlELCBjKFxcUy1TXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX3N0cl9BSUR2VVRcXCxcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcXGhpY2RjcF9vb2Vfc3RyX0FJRHZVVFxcLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9VVCwgb29lX0FJRCwgYyhcXFMtU1xcLCBcXFMtWFxcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9zdHIyX0FJRHZVVFxcLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFxcaGljZGNwX29vZV9zdHIyX0FJRHZVVFxcLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9VVCwgb29lX0FJRCwgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9yZWdfQUlEdlVUXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX3JlZ19BSUR2VVRcXCwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfVVQsIG9vZV9BSUQsIGMoXFxQLVNcXCwgXFxFLVNcXCksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcXGhpY2RjcF9vb2VfcmVnU3RyX0FJRHZVVFxcLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFxcaGljZGNwX29vZV9yZWdTdHJfQUlEdlVUXFwsIGZpZ0RpcilcblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_hicdcp.tsv\\))\n\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\hicdcp_ooe_all_dTAGvDMSO\\,\n                 title = \\hicdcp_ooe_all_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\),\n                 name = \\hicdcp_ooe_str_dTAGvDMSO\\,\n                 title = \\hicdcp_ooe_str_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\hicdcp_ooe_str2_dTAGvDMSO\\,\n                 title = \\hicdcp_ooe_str2_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\hicdcp_ooe_reg_dTAGvDMSO\\,\n                 title = \\hicdcp_ooe_reg_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\hicdcp_ooe_regStr_dTAGvDMSO\\,\n                 title = \\hicdcp_ooe_regStr_dTAGvDMSO\\, figDir)\n\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\hicdcp_ooe_all_A485vDMSO\\,\n                 title = \\hicdcp_ooe_all_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\),\n                 name = \\hicdcp_ooe_str_A485vDMSO\\,\n                 title = \\hicdcp_ooe_str_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\, \\S-X\\),\n                 name = \\hicdcp_ooe_str2_A485vDMSO\\,\n                 title = \\hicdcp_ooe_str2_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\hicdcp_ooe_reg_A485vDMSO\\,\n                 title = \\hicdcp_ooe_reg_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-S\\, \\E-S\\),\n                 name = \\hicdcp_ooe_regStr_A485vDMSO\\,\n                 title = \\hicdcp_ooe_regStr_A485vDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\hicdcp_ooe_all_EpidTAGvEpiDMSO\\,\n                 title = \\hicdcp_ooe_all_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\),\n                 name = \\hicdcp_ooe_str_EpidTAGvEpiDMSO\\,\n                 title = \\hicdcp_ooe_str_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\hicdcp_ooe_str2_EpidTAGvEpiDMSO\\,\n                 title = \\hicdcp_ooe_str2_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\hicdcp_ooe_reg_EpidTAGvEpiDMSO\\,\n                 title = \\hicdcp_ooe_reg_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\hicdcp_ooe_regStr_EpidTAGvEpiDMSO\\,\n                 title = \\hicdcp_ooe_regStr_EpidTAGvEpiDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\hicdcp_ooe_all_AIDvUT\\,\n                 title = \\hicdcp_ooe_all_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\),\n                 name = \\hicdcp_ooe_str_AIDvUT\\,\n                 title = \\hicdcp_ooe_str_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\, \\S-X\\),\n                 name = \\hicdcp_ooe_str2_AIDvUT\\,\n                 title = \\hicdcp_ooe_str2_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\hicdcp_ooe_reg_AIDvUT\\,\n                 title = \\hicdcp_ooe_reg_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-S\\, \\E-S\\),\n                 name = \\hicdcp_ooe_regStr_AIDvUT\\,\n                 title = \\hicdcp_ooe_regStr_AIDvUT\\, figDir)\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5maWdEaXIgPC0gaGVyZShcXC4uL2ZpZ3VyZS9sb29wX2FuYWx5c2lzXFwpXG5kaXIuY3JlYXRlKGZpZ0Rpciwgc2hvd1dhcm5pbmdzID0gRkFMU0UsIHJlY3Vyc2l2ZSA9IFRSVUUpXG5cbmRhdGEgPC0gZnJlYWQoaGVyZShjb21tb25Mb29wRGlyLCBcXGxvb3BTY29yZV9oaWNkY3AudHN2XFwpKVxuXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9ETVNPLCBvb2VfZFRBRywgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcRS1FXFwsIFxcRS1TXFwsIFxcRS1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxTLVNcXCwgXFxTLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFgtWFxcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9hbGxfZFRBR3ZETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX2FsbF9kVEFHdkRNU09cXCwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfRE1TTywgb29lX2RUQUcsIGMoXFxTLVNcXCksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcXGhpY2RjcF9vb2Vfc3RyX2RUQUd2RE1TT1xcLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFxcaGljZGNwX29vZV9zdHJfZFRBR3ZETVNPXFwsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0RNU08sIG9vZV9kVEFHLCBjKFxcUy1TXFwsIFxcUy1YXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX3N0cjJfZFRBR3ZETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX3N0cjJfZFRBR3ZETVNPXFwsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0RNU08sIG9vZV9kVEFHLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX3JlZ19kVEFHdkRNU09cXCxcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcXGhpY2RjcF9vb2VfcmVnX2RUQUd2RE1TT1xcLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9ETVNPLCBvb2VfZFRBRywgYyhcXFAtU1xcLCBcXEUtU1xcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9yZWdTdHJfZFRBR3ZETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX3JlZ1N0cl9kVEFHdkRNU09cXCwgZmlnRGlyKVxuXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9ETVNPLCBvb2VfQTQ4NSwgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcRS1FXFwsIFxcRS1TXFwsIFxcRS1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxTLVNcXCwgXFxTLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFgtWFxcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9hbGxfQTQ4NXZETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX2FsbF9BNDg1dkRNU09cXCwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfRE1TTywgb29lX0E0ODUsIGMoXFxTLVNcXCksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcXGhpY2RjcF9vb2Vfc3RyX0E0ODV2RE1TT1xcLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFxcaGljZGNwX29vZV9zdHJfQTQ4NXZETVNPXFwsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0RNU08sIG9vZV9BNDg1LCBjKFxcUy1TXFwsIFxcUy1YXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX3N0cjJfQTQ4NXZETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX3N0cjJfQTQ4NXZETVNPXFwsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0RNU08sIG9vZV9BNDg1LCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX3JlZ19BNDg1dkRNU09cXCxcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcXGhpY2RjcF9vb2VfcmVnX0E0ODV2RE1TT1xcLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9ETVNPLCBvb2VfQTQ4NSwgYyhcXFAtU1xcLCBcXEUtU1xcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9yZWdTdHJfQTQ4NXZETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX3JlZ1N0cl9BNDg1dkRNU09cXCwgZmlnRGlyKVxuXG5cbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0VwaURNU08sIG9vZV9FcGlkVEFHLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcUC1TXFwsIFxcUC1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxFLUVcXCwgXFxFLVNcXCwgXFxFLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFMtU1xcLCBcXFMtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcWC1YXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX2FsbF9FcGlkVEFHdkVwaURNU09cXCxcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcXGhpY2RjcF9vb2VfYWxsX0VwaWRUQUd2RXBpRE1TT1xcLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9FcGlETVNPLCBvb2VfRXBpZFRBRywgYyhcXFMtU1xcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9zdHJfRXBpZFRBR3ZFcGlETVNPXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX3N0cl9FcGlkVEFHdkVwaURNU09cXCwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfRXBpRE1TTywgb29lX0VwaWRUQUcsIGMoXFxTLVNcXCwgXFxTLVhcXCksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcXGhpY2RjcF9vb2Vfc3RyMl9FcGlkVEFHdkVwaURNU09cXCxcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcXGhpY2RjcF9vb2Vfc3RyMl9FcGlkVEFHdkVwaURNU09cXCwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfRXBpRE1TTywgb29lX0VwaWRUQUcsIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcXGhpY2RjcF9vb2VfcmVnX0VwaWRUQUd2RXBpRE1TT1xcLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFxcaGljZGNwX29vZV9yZWdfRXBpZFRBR3ZFcGlETVNPXFwsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX0VwaURNU08sIG9vZV9FcGlkVEFHLCBjKFxcUC1TXFwsIFxcRS1TXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX3JlZ1N0cl9FcGlkVEFHdkVwaURNU09cXCxcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcXGhpY2RjcF9vb2VfcmVnU3RyX0VwaWRUQUd2RXBpRE1TT1xcLCBmaWdEaXIpXG5cblxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfVVQsIG9vZV9BSUQsIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXEUtRVxcLCBcXEUtU1xcLCBcXEUtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcUy1TXFwsIFxcUy1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxYLVhcXCksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcXGhpY2RjcF9vb2VfYWxsX0FJRHZVVFxcLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFxcaGljZGNwX29vZV9hbGxfQUlEdlVUXFwsIGZpZ0RpcilcbnBsb3RfbG9vcF9zY29yZXMoZGF0YSwgb29lX1VULCBvb2VfQUlELCBjKFxcUy1TXFwpLFxuICAgICAgICAgICAgICAgICBuYW1lID0gXFxoaWNkY3Bfb29lX3N0cl9BSUR2VVRcXCxcbiAgICAgICAgICAgICAgICAgdGl0bGUgPSBcXGhpY2RjcF9vb2Vfc3RyX0FJRHZVVFxcLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9VVCwgb29lX0FJRCwgYyhcXFMtU1xcLCBcXFMtWFxcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9zdHIyX0FJRHZVVFxcLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFxcaGljZGNwX29vZV9zdHIyX0FJRHZVVFxcLCBmaWdEaXIpXG5wbG90X2xvb3Bfc2NvcmVzKGRhdGEsIG9vZV9VVCwgb29lX0FJRCwgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSxcbiAgICAgICAgICAgICAgICAgbmFtZSA9IFxcaGljZGNwX29vZV9yZWdfQUlEdlVUXFwsXG4gICAgICAgICAgICAgICAgIHRpdGxlID0gXFxoaWNkY3Bfb29lX3JlZ19BSUR2VVRcXCwgZmlnRGlyKVxucGxvdF9sb29wX3Njb3JlcyhkYXRhLCBvb2VfVVQsIG9vZV9BSUQsIGMoXFxQLVNcXCwgXFxFLVNcXCksXG4gICAgICAgICAgICAgICAgIG5hbWUgPSBcXGhpY2RjcF9vb2VfcmVnU3RyX0FJRHZVVFxcLFxuICAgICAgICAgICAgICAgICB0aXRsZSA9IFxcaGljZGNwX29vZV9yZWdTdHJfQUlEdlVUXFwsIGZpZ0RpcilcblxuYGBgXG5gYGAifQ== -->

```r
```r
commonLoopDir <- here(\../data/loop_analysis\)
figDir <- here(\../figure/loop_analysis\)
dir.create(figDir, showWarnings = FALSE, recursive = TRUE)

data <- fread(here(commonLoopDir, \loopScore_hicdcp.tsv\))

plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \hicdcp_ooe_all_dTAGvDMSO\,
                 title = \hicdcp_ooe_all_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\S-S\),
                 name = \hicdcp_ooe_str_dTAGvDMSO\,
                 title = \hicdcp_ooe_str_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\S-S\, \S-X\),
                 name = \hicdcp_ooe_str2_dTAGvDMSO\,
                 title = \hicdcp_ooe_str2_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-P\, \P-E\, \E-E\),
                 name = \hicdcp_ooe_reg_dTAGvDMSO\,
                 title = \hicdcp_ooe_reg_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-S\, \E-S\),
                 name = \hicdcp_ooe_regStr_dTAGvDMSO\,
                 title = \hicdcp_ooe_regStr_dTAGvDMSO\, figDir)

plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \hicdcp_ooe_all_A485vDMSO\,
                 title = \hicdcp_ooe_all_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\S-S\),
                 name = \hicdcp_ooe_str_A485vDMSO\,
                 title = \hicdcp_ooe_str_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\S-S\, \S-X\),
                 name = \hicdcp_ooe_str2_A485vDMSO\,
                 title = \hicdcp_ooe_str2_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-P\, \P-E\, \E-E\),
                 name = \hicdcp_ooe_reg_A485vDMSO\,
                 title = \hicdcp_ooe_reg_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-S\, \E-S\),
                 name = \hicdcp_ooe_regStr_A485vDMSO\,
                 title = \hicdcp_ooe_regStr_A485vDMSO\, figDir)


plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \hicdcp_ooe_all_EpidTAGvEpiDMSO\,
                 title = \hicdcp_ooe_all_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\S-S\),
                 name = \hicdcp_ooe_str_EpidTAGvEpiDMSO\,
                 title = \hicdcp_ooe_str_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\S-S\, \S-X\),
                 name = \hicdcp_ooe_str2_EpidTAGvEpiDMSO\,
                 title = \hicdcp_ooe_str2_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-P\, \P-E\, \E-E\),
                 name = \hicdcp_ooe_reg_EpidTAGvEpiDMSO\,
                 title = \hicdcp_ooe_reg_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-S\, \E-S\),
                 name = \hicdcp_ooe_regStr_EpidTAGvEpiDMSO\,
                 title = \hicdcp_ooe_regStr_EpidTAGvEpiDMSO\, figDir)


plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \hicdcp_ooe_all_AIDvUT\,
                 title = \hicdcp_ooe_all_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\S-S\),
                 name = \hicdcp_ooe_str_AIDvUT\,
                 title = \hicdcp_ooe_str_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\S-S\, \S-X\),
                 name = \hicdcp_ooe_str2_AIDvUT\,
                 title = \hicdcp_ooe_str2_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-P\, \P-E\, \E-E\),
                 name = \hicdcp_ooe_reg_AIDvUT\,
                 title = \hicdcp_ooe_reg_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-S\, \E-S\),
                 name = \hicdcp_ooe_regStr_AIDvUT\,
                 title = \hicdcp_ooe_regStr_AIDvUT\, figDir)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFwiLi4vZGF0YS9sb29wX2FuYWx5c2lzXCIpXG5kaWZmRGlyIDwtIGhlcmUoXCIuLi9kYXRhL1JOQV9kaWZmXCIpXG5uYW1lIDwtIFwiaGljZGNwXCJcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFwibG9vcFNjb3JlX1wiLCBuYW1lLCBcIl9wLW5fc2ltcGxlX2Vuc2VtYmxMaXN0LnRzdlwiKSkpICU+JVxuICByb3d3aXNlKCkgJT4lICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAjIHdvcmsgb25lIHJvdyBhdCBhIHRpbWVcbiAgbXV0YXRlKFxuICAgIG1pbnBvcyA9IG1pbihjKG9vZV9kVEFHLCBvb2VfRE1TTylbYyhvb2VfZFRBRywgb29lX0RNU08pID4gMF0sIG5hLnJtID0gVFJVRSksXG4gICAgZXBzICAgID0gaWZlbHNlKGlzLmZpbml0ZShtaW5wb3MpLCBtaW5wb3MgKiAwLjEsIDAuMDEpLCAgICAgICMgZmFsbGJhY2sgaWYgYm90aCBhcmUgMFxuICAgIGRpZmYgICA9IGxvZzIoKG9vZV9kVEFHICsgZXBzKSAvIChvb2VfRE1TTyArIGVwcykpXG4gICkgJT4lIFxuICB1bmdyb3VwKCkgJT4lIFxuICBzZWxlY3QoLW1pbnBvcywgLWVwcykgXG4gICNkcGx5cjo6bXV0YXRlKGRpZmYgPSBsb2cyKG9vZV9kVEFHKSAtIGxvZzIob29lX0RNU08pKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKGRpZmZEaXIsIFwiZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcIikpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuZ2VuZUxpc3QuZG93bi5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA8PSAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcbmdlbmVMaXN0LnVwLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDID4gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5cblxubWF4TG9nMkZDIDwtIDJcblxudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZiwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmKSwgLmdyb3VwcyA9ICdkcm9wJylcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcImdlbmVcIiA9IFwiZW5zZW1ibF9nZW5lX2lkXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoZmxhZyA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QuZG93bi5STkEsIFwiMkRPV05cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QudXAuUk5BLCBcIjFVUFwiLCBcIjBOT1wiKSksXG4gICAgICAgICAgICAgICAgbWF4RmxhZyA9IChhYnMoc2hyaW5rZWRfbG9nMkZDKSA+IG1heExvZzJGQyksXG4gICAgICAgICAgICAgICAgc2hybG9nMmZjTWF4ID0gcG1heChwbWluKHNocmlua2VkX2xvZzJGQywgbWF4TG9nMkZDKSwgLW1heExvZzJGQykpICU+JSBcbiAgZHBseXI6OmFycmFuZ2UoZmxhZylcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBzaHJsb2cyZmNNYXgsIHkgPSBtZWFuX2RpZmZfc2NvcmUsIGNvbG9yID0gZmxhZyxcbiAgICAgICAgICAgICAgICAgICAgICBsYWJlbCA9IGlmZWxzZShmbGFnICE9IFwiME5PXCIsIGV4dGVybmFsX2dlbmVfbmFtZSwgTkEpLFxuICAgICAgICAgICAgICAgICAgICAgIHNoYXBlID0gYXMuZmFjdG9yKG1heEZsYWcpKSkgK1xuICBnZW9tX3BvaW50KCkgKyBnZW9tX3RleHRfcmVwZWwoKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdndGl0bGUocGFzdGUwKG5hbWUsIFwiX29vZV9zaW1wbGVBbm5vXCIpKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgbGluZXR5cGUgPSBcImRhc2hlZFwiKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IC0gZGlmZkN1dG9mZiwgbGluZXR5cGUgPSBcImRhc2hlZFwiKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDApICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gZmNDdXRvZmYsIGxpbmV0eXBlID0gXCJkYXNoZWRcIikgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAtZmNDdXRvZmYsIGxpbmV0eXBlID0gXCJkYXNoZWRcIikgK1xuICBzY2FsZV9jb2xvcl9tYW51YWwodmFsdWVzID0gYyhcIjBOT1wiID0gXCJncmV5XCIsIFwiMVVQXCIgPSBcInJlZFwiLCBcIjJET1dOXCIgPSBcImJsdWVcIikpICsgICMgQ29ycmVjdGVkIGNvbG9yIG1hcHBpbmdcbiAgc2NhbGVfc2hhcGVfbWFudWFsKHZhbHVlcyA9IGMoXCJUUlVFXCIgPSAyLCBcIkZBTFNFXCIgPSAxOSkpXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcIlJOQXZzTG9vcF9cIiwgbmFtZSwgXCJfb29lX3NpbXBsZUFubm9cIilcbmhlaWdodCA8LSA0XG53aWR0aCA8LSA3XG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGAifQ== -->\n\n```r\nalpha <- 0.05\nfcCutoff <- 0.5\ndiffCutoff <- 0.5\ncommonLoopDir <- here(\\../data/loop_analysis\\)\ndiffDir <- here(\\../data/RNA_diff\\)\nname <- \\hicdcp\\\ngeneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\\loopScore_\\, name, \\_p-n_simple_ensemblList.tsv\\))) %>%\n  rowwise() %>%                                # work one row at a time\n  mutate(\n    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),\n    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0\n    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))\n  ) %>% \n  ungroup() %>% \n  select(-minpos, -eps) \n  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))\n\ndiff.RNA <- fread(here(diffDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id\n\n\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() +\n  ggtitle(paste0(name, \\_ooe_simpleAnno\\)) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\RNAvsLoop_\\, name, \\_ooe_simpleAnno\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \hicdcp\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_simple_ensemblList.tsv\))) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_ooe_simpleAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_ooe_simpleAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcaGljZGNwXFxcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBuYW1lLCBcXF9wLW5fc2ltcGxlX2Vuc2VtYmxMaXN0LnRzdlxcKSkpICU+JVxuICByb3d3aXNlKCkgJT4lICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAjIHdvcmsgb25lIHJvdyBhdCBhIHRpbWVcbiAgbXV0YXRlKFxuICAgIG1pbnBvcyA9IG1pbihjKG9vZV9kVEFHLCBvb2VfRE1TTylbYyhvb2VfZFRBRywgb29lX0RNU08pID4gMF0sIG5hLnJtID0gVFJVRSksXG4gICAgZXBzICAgID0gaWZlbHNlKGlzLmZpbml0ZShtaW5wb3MpLCBtaW5wb3MgKiAwLjEsIDAuMDEpLCAgICAgICMgZmFsbGJhY2sgaWYgYm90aCBhcmUgMFxuICAgIGRpZmYgICA9IGxvZzIoKG9vZV9kVEFHICsgZXBzKSAvIChvb2VfRE1TTyArIGVwcykpXG4gICkgJT4lIFxuICB1bmdyb3VwKCkgJT4lIFxuICBzZWxlY3QoLW1pbnBvcywgLWVwcykgXG4gICNkcGx5cjo6bXV0YXRlKGRpZmYgPSBsb2cyKG9vZV9kVEFHKSAtIGxvZzIob29lX0RNU08pKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKGRpZmZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuZ2VuZUxpc3QuZG93bi5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA8PSAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcbmdlbmVMaXN0LnVwLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDID4gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5cblxubWF4TG9nMkZDIDwtIDJcblxudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZiwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmKSwgLmdyb3VwcyA9ICdkcm9wJylcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcXGdlbmVcXCA9IFxcZW5zZW1ibF9nZW5lX2lkXFwpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoZmxhZyA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QuZG93bi5STkEsIFxcMkRPV05cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QudXAuUk5BLCBcXDFVUFxcLCBcXDBOT1xcKSksXG4gICAgICAgICAgICAgICAgbWF4RmxhZyA9IChhYnMoc2hyaW5rZWRfbG9nMkZDKSA+IG1heExvZzJGQyksXG4gICAgICAgICAgICAgICAgc2hybG9nMmZjTWF4ID0gcG1heChwbWluKHNocmlua2VkX2xvZzJGQywgbWF4TG9nMkZDKSwgLW1heExvZzJGQykpICU+JSBcbiAgZHBseXI6OmFycmFuZ2UoZmxhZylcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBzaHJsb2cyZmNNYXgsIHkgPSBtZWFuX2RpZmZfc2NvcmUsIGNvbG9yID0gZmxhZyxcbiAgICAgICAgICAgICAgICAgICAgICBsYWJlbCA9IGlmZWxzZShmbGFnICE9IFxcME5PXFwsIGV4dGVybmFsX2dlbmVfbmFtZSwgTkEpLFxuICAgICAgICAgICAgICAgICAgICAgIHNoYXBlID0gYXMuZmFjdG9yKG1heEZsYWcpKSkgK1xuICBnZW9tX3BvaW50KCkgKyBnZW9tX3RleHRfcmVwZWwoKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdndGl0bGUocGFzdGUwKG5hbWUsIFxcX29vZV9zaW1wbGVBbm5vXFwpKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IC0gZGlmZkN1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDApICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gZmNDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAtZmNDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBzY2FsZV9jb2xvcl9tYW51YWwodmFsdWVzID0gYyhcXDBOT1xcID0gXFxncmV5XFwsIFxcMVVQXFwgPSBcXHJlZFxcLCBcXDJET1dOXFwgPSBcXGJsdWVcXCkpICsgICMgQ29ycmVjdGVkIGNvbG9yIG1hcHBpbmdcbiAgc2NhbGVfc2hhcGVfbWFudWFsKHZhbHVlcyA9IGMoXFxUUlVFXFwgPSAyLCBcXEZBTFNFXFwgPSAxOSkpXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXFJOQXZzTG9vcF9cXCwgbmFtZSwgXFxfb29lX3NpbXBsZUFubm9cXClcbmhlaWdodCA8LSA0XG53aWR0aCA8LSA3XG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\nalpha <- 0.05\nfcCutoff <- 0.5\ndiffCutoff <- 0.5\ncommonLoopDir <- here(\\../data/loop_analysis\\)\ndiffDir <- here(\\../data/RNA_diff\\)\nname <- \\hicdcp\\\ngeneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\\loopScore_\\, name, \\_p-n_simple_ensemblList.tsv\\))) %>%\n  rowwise() %>%                                # work one row at a time\n  mutate(\n    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),\n    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0\n    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))\n  ) %>% \n  ungroup() %>% \n  select(-minpos, -eps) \n  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))\n\ndiff.RNA <- fread(here(diffDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id\n\n\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() +\n  ggtitle(paste0(name, \\_ooe_simpleAnno\\)) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\RNAvsLoop_\\, name, \\_ooe_simpleAnno\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcaGljZGNwXFxcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBuYW1lLCBcXF9wLW5fc2ltcGxlX2Vuc2VtYmxMaXN0LnRzdlxcKSkpICU+JVxuICByb3d3aXNlKCkgJT4lICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAjIHdvcmsgb25lIHJvdyBhdCBhIHRpbWVcbiAgbXV0YXRlKFxuICAgIG1pbnBvcyA9IG1pbihjKG9vZV9kVEFHLCBvb2VfRE1TTylbYyhvb2VfZFRBRywgb29lX0RNU08pID4gMF0sIG5hLnJtID0gVFJVRSksXG4gICAgZXBzICAgID0gaWZlbHNlKGlzLmZpbml0ZShtaW5wb3MpLCBtaW5wb3MgKiAwLjEsIDAuMDEpLCAgICAgICMgZmFsbGJhY2sgaWYgYm90aCBhcmUgMFxuICAgIGRpZmYgICA9IGxvZzIoKG9vZV9kVEFHICsgZXBzKSAvIChvb2VfRE1TTyArIGVwcykpXG4gICkgJT4lIFxuICB1bmdyb3VwKCkgJT4lIFxuICBzZWxlY3QoLW1pbnBvcywgLWVwcykgXG4gICNkcGx5cjo6bXV0YXRlKGRpZmYgPSBsb2cyKG9vZV9kVEFHKSAtIGxvZzIob29lX0RNU08pKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKGRpZmZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuZ2VuZUxpc3QuZG93bi5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA8PSAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcbmdlbmVMaXN0LnVwLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDID4gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5cblxubWF4TG9nMkZDIDwtIDJcblxudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZiwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmKSwgLmdyb3VwcyA9ICdkcm9wJylcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcXGdlbmVcXCA9IFxcZW5zZW1ibF9nZW5lX2lkXFwpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoZmxhZyA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QuZG93bi5STkEsIFxcMkRPV05cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QudXAuUk5BLCBcXDFVUFxcLCBcXDBOT1xcKSksXG4gICAgICAgICAgICAgICAgbWF4RmxhZyA9IChhYnMoc2hyaW5rZWRfbG9nMkZDKSA+IG1heExvZzJGQyksXG4gICAgICAgICAgICAgICAgc2hybG9nMmZjTWF4ID0gcG1heChwbWluKHNocmlua2VkX2xvZzJGQywgbWF4TG9nMkZDKSwgLW1heExvZzJGQykpICU+JSBcbiAgZHBseXI6OmFycmFuZ2UoZmxhZylcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBzaHJsb2cyZmNNYXgsIHkgPSBtZWFuX2RpZmZfc2NvcmUsIGNvbG9yID0gZmxhZyxcbiAgICAgICAgICAgICAgICAgICAgICBsYWJlbCA9IGlmZWxzZShmbGFnICE9IFxcME5PXFwsIGV4dGVybmFsX2dlbmVfbmFtZSwgTkEpLFxuICAgICAgICAgICAgICAgICAgICAgIHNoYXBlID0gYXMuZmFjdG9yKG1heEZsYWcpKSkgK1xuICBnZW9tX3BvaW50KCkgKyBnZW9tX3RleHRfcmVwZWwoKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdndGl0bGUocGFzdGUwKG5hbWUsIFxcX29vZV9zaW1wbGVBbm5vXFwpKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IC0gZGlmZkN1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDApICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gZmNDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAtZmNDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBzY2FsZV9jb2xvcl9tYW51YWwodmFsdWVzID0gYyhcXDBOT1xcID0gXFxncmV5XFwsIFxcMVVQXFwgPSBcXHJlZFxcLCBcXDJET1dOXFwgPSBcXGJsdWVcXCkpICsgICMgQ29ycmVjdGVkIGNvbG9yIG1hcHBpbmdcbiAgc2NhbGVfc2hhcGVfbWFudWFsKHZhbHVlcyA9IGMoXFxUUlVFXFwgPSAyLCBcXEZBTFNFXFwgPSAxOSkpXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXFJOQXZzTG9vcF9cXCwgbmFtZSwgXFxfb29lX3NpbXBsZUFubm9cXClcbmhlaWdodCA8LSA0XG53aWR0aCA8LSA3XG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \hicdcp\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_simple_ensemblList.tsv\))) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_ooe_simpleAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_ooe_simpleAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Scatterplot - HiCDC+

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFwiLi4vZGF0YS9sb29wX2FuYWx5c2lzXCIpXG5kaWZmRGlyIDwtIGhlcmUoXCIuLi9kYXRhL1JOQV9kaWZmXCIpXG5uYW1lIDwtIFwiaGljZGNwXCJcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFwibG9vcFNjb3JlX1wiLCBuYW1lLCBcIl9wLW5fY29tcGxleF9lbnNlbWJsTGlzdC50c3ZcIikpKSAlPiVcbiAgcm93d2lzZSgpICU+JSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIyB3b3JrIG9uZSByb3cgYXQgYSB0aW1lXG4gIG11dGF0ZShcbiAgICBtaW5wb3MgPSBtaW4oYyhvb2VfZFRBRywgb29lX0RNU08pW2Mob29lX2RUQUcsIG9vZV9ETVNPKSA+IDBdLCBuYS5ybSA9IFRSVUUpLFxuICAgIGVwcyAgICA9IGlmZWxzZShpcy5maW5pdGUobWlucG9zKSwgbWlucG9zICogMC4xLCAwLjAxKSwgICAgICAjIGZhbGxiYWNrIGlmIGJvdGggYXJlIDBcbiAgICBkaWZmICAgPSBsb2cyKChvb2VfZFRBRyArIGVwcykgLyAob29lX0RNU08gKyBlcHMpKVxuICApICU+JSBcbiAgdW5ncm91cCgpICU+JSBcbiAgc2VsZWN0KC1taW5wb3MsIC1lcHMpIFxuICAjZHBseXI6Om11dGF0ZShkaWZmID0gbG9nMihvb2VfZFRBRykgLSBsb2cyKG9vZV9ETVNPKSlcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShkaWZmRGlyLCBcImRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XCIpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcbmdlbmVMaXN0LmRvd24uUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPD0gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5nZW5lTGlzdC51cC5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA+IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuXG5cbm1heExvZzJGQyA8LSAyXG5cbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmYsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZiksIC5ncm91cHMgPSAnZHJvcCcpXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXCJnZW5lXCIgPSBcImVuc2VtYmxfZ2VuZV9pZFwiKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGZsYWcgPSBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LmRvd24uUk5BLCBcIjJET1dOXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LnVwLlJOQSwgXCIxVVBcIiwgXCIwTk9cIikpLFxuICAgICAgICAgICAgICAgIG1heEZsYWcgPSAoYWJzKHNocmlua2VkX2xvZzJGQykgPiBtYXhMb2cyRkMpLFxuICAgICAgICAgICAgICAgIHNocmxvZzJmY01heCA9IHBtYXgocG1pbihzaHJpbmtlZF9sb2cyRkMsIG1heExvZzJGQyksIC1tYXhMb2cyRkMpKSAlPiUgXG4gIGRwbHlyOjphcnJhbmdlKGZsYWcpXG5cbnAgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gc2hybG9nMmZjTWF4LCB5ID0gbWVhbl9kaWZmX3Njb3JlLCBjb2xvciA9IGZsYWcsXG4gICAgICAgICAgICAgICAgICAgICAgbGFiZWwgPSBpZmVsc2UoZmxhZyAhPSBcIjBOT1wiLCBleHRlcm5hbF9nZW5lX25hbWUsIE5BKSxcbiAgICAgICAgICAgICAgICAgICAgICBzaGFwZSA9IGFzLmZhY3RvcihtYXhGbGFnKSkpICtcbiAgZ2VvbV9wb2ludCgpICsgZ2VvbV90ZXh0X3JlcGVsKCkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICBnZ3RpdGxlKHBhc3RlMChuYW1lLCBcIl9vb2VfY29tcGxleEFubm9cIikpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFwiZGFzaGVkXCIpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gLSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFwiZGFzaGVkXCIpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBmY0N1dG9mZiwgbGluZXR5cGUgPSBcImRhc2hlZFwiKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IC1mY0N1dG9mZiwgbGluZXR5cGUgPSBcImRhc2hlZFwiKSArXG4gIHNjYWxlX2NvbG9yX21hbnVhbCh2YWx1ZXMgPSBjKFwiME5PXCIgPSBcImdyZXlcIiwgXCIxVVBcIiA9IFwicmVkXCIsIFwiMkRPV05cIiA9IFwiYmx1ZVwiKSkgKyAgIyBDb3JyZWN0ZWQgY29sb3IgbWFwcGluZ1xuICBzY2FsZV9zaGFwZV9tYW51YWwodmFsdWVzID0gYyhcIlRSVUVcIiA9IDIsIFwiRkFMU0VcIiA9IDE5KSlcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwiUk5BdnNMb29wX1wiLCBuYW1lLCBcIl9vb2VfY29tcGxleEFubm9cIilcbmhlaWdodCA8LSA0XG53aWR0aCA8LSA3XG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGAifQ== -->\n\n```r\nalpha <- 0.05\nfcCutoff <- 0.5\ndiffCutoff <- 0.5\ncommonLoopDir <- here(\\../data/loop_analysis\\)\ndiffDir <- here(\\../data/RNA_diff\\)\nname <- \\hicdcp\\\ngeneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\\loopScore_\\, name, \\_p-n_complex_ensemblList.tsv\\))) %>%\n  rowwise() %>%                                # work one row at a time\n  mutate(\n    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),\n    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0\n    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))\n  ) %>% \n  ungroup() %>% \n  select(-minpos, -eps) \n  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))\n\ndiff.RNA <- fread(here(diffDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id\n\n\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() +\n  ggtitle(paste0(name, \\_ooe_complexAnno\\)) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\RNAvsLoop_\\, name, \\_ooe_complexAnno\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \hicdcp\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_complex_ensemblList.tsv\))) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_ooe_complexAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_ooe_complexAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcaGljZGNwXFxcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBuYW1lLCBcXF9wLW5fY29tcGxleF9lbnNlbWJsTGlzdC50c3ZcXCkpKSAlPiVcbiAgcm93d2lzZSgpICU+JSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIyB3b3JrIG9uZSByb3cgYXQgYSB0aW1lXG4gIG11dGF0ZShcbiAgICBtaW5wb3MgPSBtaW4oYyhvb2VfZFRBRywgb29lX0RNU08pW2Mob29lX2RUQUcsIG9vZV9ETVNPKSA+IDBdLCBuYS5ybSA9IFRSVUUpLFxuICAgIGVwcyAgICA9IGlmZWxzZShpcy5maW5pdGUobWlucG9zKSwgbWlucG9zICogMC4xLCAwLjAxKSwgICAgICAjIGZhbGxiYWNrIGlmIGJvdGggYXJlIDBcbiAgICBkaWZmICAgPSBsb2cyKChvb2VfZFRBRyArIGVwcykgLyAob29lX0RNU08gKyBlcHMpKVxuICApICU+JSBcbiAgdW5ncm91cCgpICU+JSBcbiAgc2VsZWN0KC1taW5wb3MsIC1lcHMpIFxuICAjZHBseXI6Om11dGF0ZShkaWZmID0gbG9nMihvb2VfZFRBRykgLSBsb2cyKG9vZV9ETVNPKSlcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShkaWZmRGlyLCBcXGRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcbmdlbmVMaXN0LmRvd24uUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPD0gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5nZW5lTGlzdC51cC5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA+IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuXG5cbm1heExvZzJGQyA8LSAyXG5cbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmYsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZiksIC5ncm91cHMgPSAnZHJvcCcpXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGZsYWcgPSBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LmRvd24uUk5BLCBcXDJET1dOXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LnVwLlJOQSwgXFwxVVBcXCwgXFwwTk9cXCkpLFxuICAgICAgICAgICAgICAgIG1heEZsYWcgPSAoYWJzKHNocmlua2VkX2xvZzJGQykgPiBtYXhMb2cyRkMpLFxuICAgICAgICAgICAgICAgIHNocmxvZzJmY01heCA9IHBtYXgocG1pbihzaHJpbmtlZF9sb2cyRkMsIG1heExvZzJGQyksIC1tYXhMb2cyRkMpKSAlPiUgXG4gIGRwbHlyOjphcnJhbmdlKGZsYWcpXG5cbnAgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gc2hybG9nMmZjTWF4LCB5ID0gbWVhbl9kaWZmX3Njb3JlLCBjb2xvciA9IGZsYWcsXG4gICAgICAgICAgICAgICAgICAgICAgbGFiZWwgPSBpZmVsc2UoZmxhZyAhPSBcXDBOT1xcLCBleHRlcm5hbF9nZW5lX25hbWUsIE5BKSxcbiAgICAgICAgICAgICAgICAgICAgICBzaGFwZSA9IGFzLmZhY3RvcihtYXhGbGFnKSkpICtcbiAgZ2VvbV9wb2ludCgpICsgZ2VvbV90ZXh0X3JlcGVsKCkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICBnZ3RpdGxlKHBhc3RlMChuYW1lLCBcXF9vb2VfY29tcGxleEFubm9cXCkpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gLSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBmY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IC1mY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIHNjYWxlX2NvbG9yX21hbnVhbCh2YWx1ZXMgPSBjKFxcME5PXFwgPSBcXGdyZXlcXCwgXFwxVVBcXCA9IFxccmVkXFwsIFxcMkRPV05cXCA9IFxcYmx1ZVxcKSkgKyAgIyBDb3JyZWN0ZWQgY29sb3IgbWFwcGluZ1xuICBzY2FsZV9zaGFwZV9tYW51YWwodmFsdWVzID0gYyhcXFRSVUVcXCA9IDIsIFxcRkFMU0VcXCA9IDE5KSlcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcUk5BdnNMb29wX1xcLCBuYW1lLCBcXF9vb2VfY29tcGxleEFubm9cXClcbmhlaWdodCA8LSA0XG53aWR0aCA8LSA3XG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\nalpha <- 0.05\nfcCutoff <- 0.5\ndiffCutoff <- 0.5\ncommonLoopDir <- here(\\../data/loop_analysis\\)\ndiffDir <- here(\\../data/RNA_diff\\)\nname <- \\hicdcp\\\ngeneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\\loopScore_\\, name, \\_p-n_complex_ensemblList.tsv\\))) %>%\n  rowwise() %>%                                # work one row at a time\n  mutate(\n    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),\n    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0\n    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))\n  ) %>% \n  ungroup() %>% \n  select(-minpos, -eps) \n  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))\n\ndiff.RNA <- fread(here(diffDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id\n\n\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() +\n  ggtitle(paste0(name, \\_ooe_complexAnno\\)) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\RNAvsLoop_\\, name, \\_ooe_complexAnno\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcaGljZGNwXFxcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBuYW1lLCBcXF9wLW5fY29tcGxleF9lbnNlbWJsTGlzdC50c3ZcXCkpKSAlPiVcbiAgcm93d2lzZSgpICU+JSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIyB3b3JrIG9uZSByb3cgYXQgYSB0aW1lXG4gIG11dGF0ZShcbiAgICBtaW5wb3MgPSBtaW4oYyhvb2VfZFRBRywgb29lX0RNU08pW2Mob29lX2RUQUcsIG9vZV9ETVNPKSA+IDBdLCBuYS5ybSA9IFRSVUUpLFxuICAgIGVwcyAgICA9IGlmZWxzZShpcy5maW5pdGUobWlucG9zKSwgbWlucG9zICogMC4xLCAwLjAxKSwgICAgICAjIGZhbGxiYWNrIGlmIGJvdGggYXJlIDBcbiAgICBkaWZmICAgPSBsb2cyKChvb2VfZFRBRyArIGVwcykgLyAob29lX0RNU08gKyBlcHMpKVxuICApICU+JSBcbiAgdW5ncm91cCgpICU+JSBcbiAgc2VsZWN0KC1taW5wb3MsIC1lcHMpIFxuICAjZHBseXI6Om11dGF0ZShkaWZmID0gbG9nMihvb2VfZFRBRykgLSBsb2cyKG9vZV9ETVNPKSlcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShkaWZmRGlyLCBcXGRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcbmdlbmVMaXN0LmRvd24uUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPD0gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5nZW5lTGlzdC51cC5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA+IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuXG5cbm1heExvZzJGQyA8LSAyXG5cbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmYsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZiksIC5ncm91cHMgPSAnZHJvcCcpXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGZsYWcgPSBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LmRvd24uUk5BLCBcXDJET1dOXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LnVwLlJOQSwgXFwxVVBcXCwgXFwwTk9cXCkpLFxuICAgICAgICAgICAgICAgIG1heEZsYWcgPSAoYWJzKHNocmlua2VkX2xvZzJGQykgPiBtYXhMb2cyRkMpLFxuICAgICAgICAgICAgICAgIHNocmxvZzJmY01heCA9IHBtYXgocG1pbihzaHJpbmtlZF9sb2cyRkMsIG1heExvZzJGQyksIC1tYXhMb2cyRkMpKSAlPiUgXG4gIGRwbHlyOjphcnJhbmdlKGZsYWcpXG5cbnAgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gc2hybG9nMmZjTWF4LCB5ID0gbWVhbl9kaWZmX3Njb3JlLCBjb2xvciA9IGZsYWcsXG4gICAgICAgICAgICAgICAgICAgICAgbGFiZWwgPSBpZmVsc2UoZmxhZyAhPSBcXDBOT1xcLCBleHRlcm5hbF9nZW5lX25hbWUsIE5BKSxcbiAgICAgICAgICAgICAgICAgICAgICBzaGFwZSA9IGFzLmZhY3RvcihtYXhGbGFnKSkpICtcbiAgZ2VvbV9wb2ludCgpICsgZ2VvbV90ZXh0X3JlcGVsKCkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICBnZ3RpdGxlKHBhc3RlMChuYW1lLCBcXF9vb2VfY29tcGxleEFubm9cXCkpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gLSBkaWZmQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gMCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBmY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IC1mY0N1dG9mZiwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIHNjYWxlX2NvbG9yX21hbnVhbCh2YWx1ZXMgPSBjKFxcME5PXFwgPSBcXGdyZXlcXCwgXFwxVVBcXCA9IFxccmVkXFwsIFxcMkRPV05cXCA9IFxcYmx1ZVxcKSkgKyAgIyBDb3JyZWN0ZWQgY29sb3IgbWFwcGluZ1xuICBzY2FsZV9zaGFwZV9tYW51YWwodmFsdWVzID0gYyhcXFRSVUVcXCA9IDIsIFxcRkFMU0VcXCA9IDE5KSlcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcUk5BdnNMb29wX1xcLCBuYW1lLCBcXF9vb2VfY29tcGxleEFubm9cXClcbmhlaWdodCA8LSA0XG53aWR0aCA8LSA3XG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \hicdcp\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_complex_ensemblList.tsv\))) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_ooe_complexAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_ooe_complexAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### RNA-seq loopscore scatterplot

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\nplot_loop_scores <- function(df, col_x, col_y, annoList,\n                             name, title, figDir,\n                             diffCutoff = 0.5, density_n = 100,\n                             xmin = -0.5, xmax = 1,\n                             ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  # Scatterplot\n  df2 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    )\n  \n  p1 <- ggplot(df2, aes(x = lx, y = ly)) +\n    geom_point() +\n    scale_color_viridis() +\n    scale_x_continuous(\n      name   = paste0(\"log2(\", quo_name(col_x_q), \")\")\n    ) +\n    scale_y_continuous(\n      name   = paste0(\"log2(\", quo_name(col_y_q), \")\")\n    ) +\n    coord_fixed() +\n    geom_abline(slope = 1, intercept = 0,\n                colour = \"grey50\", linetype = \"dashed\") +\n    geom_hline(yintercept = 0, alpha = 0.5, colour = \"grey\") +\n    geom_vline(xintercept = 0, alpha = 0.5, colour = \"grey\") +\n    geom_abline(slope = 1, intercept = -(2**diffCutoff),\n                colour = \"grey\", linetype = \"dotted\") +\n    geom_abline(slope = 1, intercept = (2**diffCutoff),\n                colour = \"grey\", linetype = \"dotted\") +\n    theme_classic() +\n    labs(x = quo_name(col_x_q),\n         y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  fileName <- paste0(\"scatterplot_\", name)\n  svglite(here(figDir, paste0(fileName, \".svg\")), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \".png\")), \n      width = 3.5, height = 3, units = \"in\", res = 600)\n  print(p1)\n  dev.off()\n  \n  # Pie chart\n  df3 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    ) %>%\n    mutate(diff = ly - lx) %>%\n    mutate(updown = ifelse(diff > diffCutoff, \"UP\",\n                           ifelse(diff < -diffCutoff, \"DOWN\", \"NO\")))\n  df3$updown <- factor(df3$updown, c(\"UP\", \"NO\", \"DOWN\"))\n  \n  pie_df <- df3 %>%\n    dplyr::count(updown) %>%\n    mutate(pct   = n / sum(n) * 100,\n           label = paste0(updown, \"\\n\", n, \"\\n(\", round(pct,1), \"%)\"))\n\n  p2 <- ggplot(pie_df, aes(x = \"\", y = n, fill = updown)) +\n    geom_col(color = \"white\") +\n    coord_polar(theta = \"y\") +\n    geom_text(aes(label = label),\n              position = position_stack(vjust = 0.5),\n              size     = fontSizeM/2) +\n    theme_void() +   theme(legend.position = \"none\") +\n    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))\n  fileName <- here(figDir, paste0(\"piechart_\", name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \".svg\"), width = width, height = height)\n  print(p2)\n  dev.off()\n}\n\ncommonLoopDir <- here(\"../data/loop_analysis\")\nfigDir <- here(\"../figure/loop_analysis\")\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \"loopScore_Hansen.tsv\"))\ndata <- data %>% \n  filter(\n    !if_all(starts_with(\"ooe\"), ~ .x == 0)   # drop rows where *every* ooe* value is 0\n)\n\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\"P-P\", \"P-E\", \"P-S\", \"P-X\",\n                                                 \"E-E\", \"E-S\", \"E-X\",\n                                                 \"S-S\", \"S-X\",\n                                                 \"X-X\"),\n                 name = \"Hansen_ooe_all_dTAGvDMSO\",\n                 title = \"Hansen_ooe_all_dTAGvDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\"S-S\"),\n                 name = \"Hansen_ooe_str_dTAGvDMSO\",\n                 title = \"Hansen_ooe_str_dTAGvDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\"S-S\", \"S-X\"),\n                 name = \"Hansen_ooe_str2_dTAGvDMSO\",\n                 title = \"Hansen_ooe_str2_dTAGvDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\"P-P\", \"P-E\", \"E-E\"),\n                 name = \"Hansen_ooe_reg_dTAGvDMSO\",\n                 title = \"Hansen_ooe_reg_dTAGvDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\"P-S\", \"E-S\"),\n                 name = \"Hansen_ooe_regStr_dTAGvDMSO\",\n                 title = \"Hansen_ooe_regStr_dTAGvDMSO\", figDir)\n\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\"P-P\", \"P-E\", \"P-S\", \"P-X\",\n                                                 \"E-E\", \"E-S\", \"E-X\",\n                                                 \"S-S\", \"S-X\",\n                                                 \"X-X\"),\n                 name = \"Hansen_ooe_all_A485vDMSO\",\n                 title = \"Hansen_ooe_all_A485vDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\"S-S\"),\n                 name = \"Hansen_ooe_str_A485vDMSO\",\n                 title = \"Hansen_ooe_str_A485vDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\"S-S\", \"S-X\"),\n                 name = \"Hansen_ooe_str2_A485vDMSO\",\n                 title = \"Hansen_ooe_str2_A485vDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\"P-P\", \"P-E\", \"E-E\"),\n                 name = \"Hansen_ooe_reg_A485vDMSO\",\n                 title = \"Hansen_ooe_reg_A485vDMSO\", figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\"P-S\", \"E-S\"),\n                 name = \"Hansen_ooe_regStr_A485vDMSO\",\n                 title = \"Hansen_ooe_regStr_A485vDMSO\", figDir)\n\n\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\"P-P\", \"P-E\", \"P-S\", \"P-X\",\n                                                 \"E-E\", \"E-S\", \"E-X\",\n                                                 \"S-S\", \"S-X\",\n                                                 \"X-X\"),\n                 name = \"Hansen_ooe_all_EpidTAGvEpiDMSO\",\n                 title = \"Hansen_ooe_all_EpidTAGvEpiDMSO\", figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\"S-S\"),\n                 name = \"Hansen_ooe_str_EpidTAGvEpiDMSO\",\n                 title = \"Hansen_ooe_str_EpidTAGvEpiDMSO\", figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\"S-S\", \"S-X\"),\n                 name = \"Hansen_ooe_str2_EpidTAGvEpiDMSO\",\n                 title = \"Hansen_ooe_str2_EpidTAGvEpiDMSO\", figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\"P-P\", \"P-E\", \"E-E\"),\n                 name = \"Hansen_ooe_reg_EpidTAGvEpiDMSO\",\n                 title = \"Hansen_ooe_reg_EpidTAGvEpiDMSO\", figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\"P-S\", \"E-S\"),\n                 name = \"Hansen_ooe_regStr_EpidTAGvEpiDMSO\",\n                 title = \"Hansen_ooe_regStr_EpidTAGvEpiDMSO\", figDir)\n\n\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\"P-P\", \"P-E\", \"P-S\", \"P-X\",\n                                                 \"E-E\", \"E-S\", \"E-X\",\n                                                 \"S-S\", \"S-X\",\n                                                 \"X-X\"),\n                 name = \"Hansen_ooe_all_AIDvUT\",\n                 title = \"Hansen_ooe_all_AIDvUT\", figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\"S-S\"),\n                 name = \"Hansen_ooe_str_AIDvUT\",\n                 title = \"Hansen_ooe_str_AIDvUT\", figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\"S-S\", \"S-X\"),\n                 name = \"Hansen_ooe_str2_AIDvUT\",\n                 title = \"Hansen_ooe_str2_AIDvUT\", figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\"P-P\", \"P-E\", \"E-E\"),\n                 name = \"Hansen_ooe_reg_AIDvUT\",\n                 title = \"Hansen_ooe_reg_AIDvUT\", figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\"P-S\", \"E-S\"),\n                 name = \"Hansen_ooe_regStr_AIDvUT\",\n                 title = \"Hansen_ooe_regStr_AIDvUT\", figDir)\n\n```"} -->\n\n```r\nplot_loop_scores <- function(df, col_x, col_y, annoList,\n                             name, title, figDir,\n                             diffCutoff = 0.5, density_n = 100,\n                             xmin = -0.5, xmax = 1,\n                             ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  # Scatterplot\n  df2 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    )\n  \n  p1 <- ggplot(df2, aes(x = lx, y = ly)) +\n    geom_point() +\n    scale_color_viridis() +\n    scale_x_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_x_q), \\)\\)\n    ) +\n    scale_y_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_y_q), \\)\\)\n    ) +\n    coord_fixed() +\n    geom_abline(slope = 1, intercept = 0,\n                colour = \\grey50\\, linetype = \\dashed\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_abline(slope = 1, intercept = -(2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = (2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    theme_classic() +\n    labs(x = quo_name(col_x_q),\n         y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  fileName <- paste0(\\scatterplot_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      width = 3.5, height = 3, units = \\in\\, res = 600)\n  print(p1)\n  dev.off()\n  \n  # Pie chart\n  df3 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    ) %>%\n    mutate(diff = ly - lx) %>%\n    mutate(updown = ifelse(diff > diffCutoff, \\UP\\,\n                           ifelse(diff < -diffCutoff, \\DOWN\\, \\NO\\)))\n  df3$updown <- factor(df3$updown, c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  pie_df <- df3 %>%\n    dplyr::count(updown) %>%\n    mutate(pct   = n / sum(n) * 100,\n           label = paste0(updown, \\\\n\\, n, \\\\n(\\, round(pct,1), \\%)\\))\n\n  p2 <- ggplot(pie_df, aes(x = \\\\, y = n, fill = updown)) +\n    geom_col(color = \\white\\) +\n    coord_polar(theta = \\y\\) +\n    geom_text(aes(label = label),\n              position = position_stack(vjust = 0.5),\n              size     = fontSizeM/2) +\n    theme_void() +   theme(legend.position = \\none\\) +\n    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))\n  fileName <- here(figDir, paste0(\\piechart_\\, name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(p2)\n  dev.off()\n}\n\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_Hansen.tsv\\))\ndata <- data %>% \n  filter(\n    !if_all(starts_with(\\ooe\\), ~ .x == 0)   # drop rows where *every* ooe* value is 0\n)\n\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_all_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_str_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_str2_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_reg_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_regStr_dTAGvDMSO\\, figDir)\n\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_A485vDMSO\\,\n                 title = \\Hansen_ooe_all_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_A485vDMSO\\,\n                 title = \\Hansen_ooe_str_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_A485vDMSO\\,\n                 title = \\Hansen_ooe_str2_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_A485vDMSO\\,\n                 title = \\Hansen_ooe_reg_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_A485vDMSO\\,\n                 title = \\Hansen_ooe_regStr_A485vDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_all_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_str_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_str2_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_reg_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_regStr_EpidTAGvEpiDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_AIDvUT\\,\n                 title = \\Hansen_ooe_all_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_AIDvUT\\,\n                 title = \\Hansen_ooe_str_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_AIDvUT\\,\n                 title = \\Hansen_ooe_str2_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_AIDvUT\\,\n                 title = \\Hansen_ooe_reg_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_AIDvUT\\,\n                 title = \\Hansen_ooe_regStr_AIDvUT\\, figDir)\n\n```\n\n<!-- rnb-source-end -->\n"} -->
plot_loop_scores <- function(df, col_x, col_y, annoList,
                             name, title, figDir,
                             diffCutoff = 0.5, density_n = 100,
                             xmin = -0.5, xmax = 1,
                             ymin = -0.5, ymax = 1) {
  col_x_q <- enquo(col_x)
  col_y_q <- enquo(col_y)
  
  # Scatterplot
  df2 <- df %>%
    filter(Anno_simple %in% annoList) %>%
    select(id, x = !!col_x_q, y = !!col_y_q) %>%
    mutate(
      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),
      eps    = minpos * 0.1,
      lx     = log2(x + eps),
      ly     = log2(y + eps)
    )
  
  p1 <- ggplot(df2, aes(x = lx, y = ly)) +
    geom_point() +
    scale_color_viridis() +
    scale_x_continuous(
      name   = paste0(\log2(\, quo_name(col_x_q), \)\)
    ) +
    scale_y_continuous(
      name   = paste0(\log2(\, quo_name(col_y_q), \)\)
    ) +
    coord_fixed() +
    geom_abline(slope = 1, intercept = 0,
                colour = \grey50\, linetype = \dashed\) +
    geom_hline(yintercept = 0, alpha = 0.5, colour = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, colour = \grey\) +
    geom_abline(slope = 1, intercept = -(2**diffCutoff),
                colour = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept = (2**diffCutoff),
                colour = \grey\, linetype = \dotted\) +
    theme_classic() +
    labs(x = quo_name(col_x_q),
         y = quo_name(col_y_q)) +
    ggtitle(title)
  
  fileName <- paste0(\scatterplot_\, name)
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()
  
  png(here(figDir, paste0(fileName, \.png\)), 
      width = 3.5, height = 3, units = \in\, res = 600)
  print(p1)
  dev.off()
  
  # Pie chart
  df3 <- df %>%
    filter(Anno_simple %in% annoList) %>%
    select(id, x = !!col_x_q, y = !!col_y_q) %>%
    mutate(
      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),
      eps    = minpos * 0.1,
      lx     = log2(x + eps),
      ly     = log2(y + eps)
    ) %>%
    mutate(diff = ly - lx) %>%
    mutate(updown = ifelse(diff > diffCutoff, \UP\,
                           ifelse(diff < -diffCutoff, \DOWN\, \NO\)))
  df3$updown <- factor(df3$updown, c(\UP\, \NO\, \DOWN\))
  
  pie_df <- df3 %>%
    dplyr::count(updown) %>%
    mutate(pct   = n / sum(n) * 100,
           label = paste0(updown, \\n\, n, \\n(\, round(pct,1), \%)\))

  p2 <- ggplot(pie_df, aes(x = \\, y = n, fill = updown)) +
    geom_col(color = \white\) +
    coord_polar(theta = \y\) +
    geom_text(aes(label = label),
              position = position_stack(vjust = 0.5),
              size     = fontSizeM/2) +
    theme_void() +   theme(legend.position = \none\) +
    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))
  fileName <- here(figDir, paste0(\piechart_\, name))
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  svglite(paste0(fileName, \.svg\), width = width, height = height)
  print(p2)
  dev.off()
}

commonLoopDir <- here(\../data/loop_analysis\)
figDir <- here(\../figure/loop_analysis\)
dir.create(figDir, showWarnings = FALSE, recursive = TRUE)

data <- fread(here(commonLoopDir, \loopScore_Hansen.tsv\))
data <- data %>% 
  filter(
    !if_all(starts_with(\ooe\), ~ .x == 0)   # drop rows where *every* ooe* value is 0
)

plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \Hansen_ooe_all_dTAGvDMSO\,
                 title = \Hansen_ooe_all_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\S-S\),
                 name = \Hansen_ooe_str_dTAGvDMSO\,
                 title = \Hansen_ooe_str_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\S-S\, \S-X\),
                 name = \Hansen_ooe_str2_dTAGvDMSO\,
                 title = \Hansen_ooe_str2_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-P\, \P-E\, \E-E\),
                 name = \Hansen_ooe_reg_dTAGvDMSO\,
                 title = \Hansen_ooe_reg_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-S\, \E-S\),
                 name = \Hansen_ooe_regStr_dTAGvDMSO\,
                 title = \Hansen_ooe_regStr_dTAGvDMSO\, figDir)

plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \Hansen_ooe_all_A485vDMSO\,
                 title = \Hansen_ooe_all_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\S-S\),
                 name = \Hansen_ooe_str_A485vDMSO\,
                 title = \Hansen_ooe_str_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\S-S\, \S-X\),
                 name = \Hansen_ooe_str2_A485vDMSO\,
                 title = \Hansen_ooe_str2_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-P\, \P-E\, \E-E\),
                 name = \Hansen_ooe_reg_A485vDMSO\,
                 title = \Hansen_ooe_reg_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-S\, \E-S\),
                 name = \Hansen_ooe_regStr_A485vDMSO\,
                 title = \Hansen_ooe_regStr_A485vDMSO\, figDir)


plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \Hansen_ooe_all_EpidTAGvEpiDMSO\,
                 title = \Hansen_ooe_all_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\S-S\),
                 name = \Hansen_ooe_str_EpidTAGvEpiDMSO\,
                 title = \Hansen_ooe_str_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\S-S\, \S-X\),
                 name = \Hansen_ooe_str2_EpidTAGvEpiDMSO\,
                 title = \Hansen_ooe_str2_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-P\, \P-E\, \E-E\),
                 name = \Hansen_ooe_reg_EpidTAGvEpiDMSO\,
                 title = \Hansen_ooe_reg_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-S\, \E-S\),
                 name = \Hansen_ooe_regStr_EpidTAGvEpiDMSO\,
                 title = \Hansen_ooe_regStr_EpidTAGvEpiDMSO\, figDir)


plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \Hansen_ooe_all_AIDvUT\,
                 title = \Hansen_ooe_all_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\S-S\),
                 name = \Hansen_ooe_str_AIDvUT\,
                 title = \Hansen_ooe_str_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\S-S\, \S-X\),
                 name = \Hansen_ooe_str2_AIDvUT\,
                 title = \Hansen_ooe_str2_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-P\, \P-E\, \E-E\),
                 name = \Hansen_ooe_reg_AIDvUT\,
                 title = \Hansen_ooe_reg_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-S\, \E-S\),
                 name = \Hansen_ooe_regStr_AIDvUT\,
                 title = \Hansen_ooe_regStr_AIDvUT\, figDir)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\nplot_loop_scores <- function(df, col_x, col_y, annoList,\n                             name, title, figDir,\n                             diffCutoff = 0.5, density_n = 100,\n                             xmin = -0.5, xmax = 1,\n                             ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  # Scatterplot\n  df2 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    )\n  \n  p1 <- ggplot(df2, aes(x = lx, y = ly)) +\n    geom_point() +\n    scale_color_viridis() +\n    scale_x_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_x_q), \\)\\)\n    ) +\n    scale_y_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_y_q), \\)\\)\n    ) +\n    coord_fixed() +\n    geom_abline(slope = 1, intercept = 0,\n                colour = \\grey50\\, linetype = \\dashed\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_abline(slope = 1, intercept = -(2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = (2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    theme_classic() +\n    labs(x = quo_name(col_x_q),\n         y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  fileName <- paste0(\\scatterplot_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      width = 3.5, height = 3, units = \\in\\, res = 600)\n  print(p1)\n  dev.off()\n  \n  # Pie chart\n  df3 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    ) %>%\n    mutate(diff = ly - lx) %>%\n    mutate(updown = ifelse(diff > diffCutoff, \\UP\\,\n                           ifelse(diff < -diffCutoff, \\DOWN\\, \\NO\\)))\n  df3$updown <- factor(df3$updown, c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  pie_df <- df3 %>%\n    dplyr::count(updown) %>%\n    mutate(pct   = n / sum(n) * 100,\n           label = paste0(updown, \\\\n\\, n, \\\\n(\\, round(pct,1), \\%)\\))\n\n  p2 <- ggplot(pie_df, aes(x = \\\\, y = n, fill = updown)) +\n    geom_col(color = \\white\\) +\n    coord_polar(theta = \\y\\) +\n    geom_text(aes(label = label),\n              position = position_stack(vjust = 0.5),\n              size     = fontSizeM/2) +\n    theme_void() +   theme(legend.position = \\none\\) +\n    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))\n  fileName <- here(figDir, paste0(\\piechart_\\, name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(p2)\n  dev.off()\n}\n\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_Hansen.tsv\\))\ndata <- data %>% \n  filter(\n    !if_all(starts_with(\\ooe\\), ~ .x == 0)   # drop rows where *every* ooe* value is 0\n)\n\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_all_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_str_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_str2_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_reg_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_regStr_dTAGvDMSO\\, figDir)\n\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_A485vDMSO\\,\n                 title = \\Hansen_ooe_all_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_A485vDMSO\\,\n                 title = \\Hansen_ooe_str_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_A485vDMSO\\,\n                 title = \\Hansen_ooe_str2_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_A485vDMSO\\,\n                 title = \\Hansen_ooe_reg_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_A485vDMSO\\,\n                 title = \\Hansen_ooe_regStr_A485vDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_all_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_str_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_str2_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_reg_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_regStr_EpidTAGvEpiDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_AIDvUT\\,\n                 title = \\Hansen_ooe_all_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_AIDvUT\\,\n                 title = \\Hansen_ooe_str_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_AIDvUT\\,\n                 title = \\Hansen_ooe_str2_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_AIDvUT\\,\n                 title = \\Hansen_ooe_reg_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_AIDvUT\\,\n                 title = \\Hansen_ooe_regStr_AIDvUT\\, figDir)\n\n```\n```"} -->\n\n```r\n```r\nplot_loop_scores <- function(df, col_x, col_y, annoList,\n                             name, title, figDir,\n                             diffCutoff = 0.5, density_n = 100,\n                             xmin = -0.5, xmax = 1,\n                             ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  # Scatterplot\n  df2 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    )\n  \n  p1 <- ggplot(df2, aes(x = lx, y = ly)) +\n    geom_point() +\n    scale_color_viridis() +\n    scale_x_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_x_q), \\)\\)\n    ) +\n    scale_y_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_y_q), \\)\\)\n    ) +\n    coord_fixed() +\n    geom_abline(slope = 1, intercept = 0,\n                colour = \\grey50\\, linetype = \\dashed\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_abline(slope = 1, intercept = -(2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = (2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    theme_classic() +\n    labs(x = quo_name(col_x_q),\n         y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  fileName <- paste0(\\scatterplot_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      width = 3.5, height = 3, units = \\in\\, res = 600)\n  print(p1)\n  dev.off()\n  \n  # Pie chart\n  df3 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    ) %>%\n    mutate(diff = ly - lx) %>%\n    mutate(updown = ifelse(diff > diffCutoff, \\UP\\,\n                           ifelse(diff < -diffCutoff, \\DOWN\\, \\NO\\)))\n  df3$updown <- factor(df3$updown, c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  pie_df <- df3 %>%\n    dplyr::count(updown) %>%\n    mutate(pct   = n / sum(n) * 100,\n           label = paste0(updown, \\\\n\\, n, \\\\n(\\, round(pct,1), \\%)\\))\n\n  p2 <- ggplot(pie_df, aes(x = \\\\, y = n, fill = updown)) +\n    geom_col(color = \\white\\) +\n    coord_polar(theta = \\y\\) +\n    geom_text(aes(label = label),\n              position = position_stack(vjust = 0.5),\n              size     = fontSizeM/2) +\n    theme_void() +   theme(legend.position = \\none\\) +\n    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))\n  fileName <- here(figDir, paste0(\\piechart_\\, name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(p2)\n  dev.off()\n}\n\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_Hansen.tsv\\))\ndata <- data %>% \n  filter(\n    !if_all(starts_with(\\ooe\\), ~ .x == 0)   # drop rows where *every* ooe* value is 0\n)\n\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_all_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_str_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_str2_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_reg_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_regStr_dTAGvDMSO\\, figDir)\n\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_A485vDMSO\\,\n                 title = \\Hansen_ooe_all_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_A485vDMSO\\,\n                 title = \\Hansen_ooe_str_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_A485vDMSO\\,\n                 title = \\Hansen_ooe_str2_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_A485vDMSO\\,\n                 title = \\Hansen_ooe_reg_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_A485vDMSO\\,\n                 title = \\Hansen_ooe_regStr_A485vDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_all_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_str_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_str2_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_reg_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_regStr_EpidTAGvEpiDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_AIDvUT\\,\n                 title = \\Hansen_ooe_all_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_AIDvUT\\,\n                 title = \\Hansen_ooe_str_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_AIDvUT\\,\n                 title = \\Hansen_ooe_str2_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_AIDvUT\\,\n                 title = \\Hansen_ooe_reg_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_AIDvUT\\,\n                 title = \\Hansen_ooe_regStr_AIDvUT\\, figDir)\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\nplot_loop_scores <- function(df, col_x, col_y, annoList,\n                             name, title, figDir,\n                             diffCutoff = 0.5, density_n = 100,\n                             xmin = -0.5, xmax = 1,\n                             ymin = -0.5, ymax = 1) {\n  col_x_q <- enquo(col_x)\n  col_y_q <- enquo(col_y)\n  \n  # Scatterplot\n  df2 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    )\n  \n  p1 <- ggplot(df2, aes(x = lx, y = ly)) +\n    geom_point() +\n    scale_color_viridis() +\n    scale_x_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_x_q), \\)\\)\n    ) +\n    scale_y_continuous(\n      name   = paste0(\\log2(\\, quo_name(col_y_q), \\)\\)\n    ) +\n    coord_fixed() +\n    geom_abline(slope = 1, intercept = 0,\n                colour = \\grey50\\, linetype = \\dashed\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, colour = \\grey\\) +\n    geom_abline(slope = 1, intercept = -(2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = (2**diffCutoff),\n                colour = \\grey\\, linetype = \\dotted\\) +\n    theme_classic() +\n    labs(x = quo_name(col_x_q),\n         y = quo_name(col_y_q)) +\n    ggtitle(title)\n  \n  fileName <- paste0(\\scatterplot_\\, name)\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      width = 3.5, height = 3, units = \\in\\, res = 600)\n  print(p1)\n  dev.off()\n  \n  # Pie chart\n  df3 <- df %>%\n    filter(Anno_simple %in% annoList) %>%\n    select(id, x = !!col_x_q, y = !!col_y_q) %>%\n    mutate(\n      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),\n      eps    = minpos * 0.1,\n      lx     = log2(x + eps),\n      ly     = log2(y + eps)\n    ) %>%\n    mutate(diff = ly - lx) %>%\n    mutate(updown = ifelse(diff > diffCutoff, \\UP\\,\n                           ifelse(diff < -diffCutoff, \\DOWN\\, \\NO\\)))\n  df3$updown <- factor(df3$updown, c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  pie_df <- df3 %>%\n    dplyr::count(updown) %>%\n    mutate(pct   = n / sum(n) * 100,\n           label = paste0(updown, \\\\n\\, n, \\\\n(\\, round(pct,1), \\%)\\))\n\n  p2 <- ggplot(pie_df, aes(x = \\\\, y = n, fill = updown)) +\n    geom_col(color = \\white\\) +\n    coord_polar(theta = \\y\\) +\n    geom_text(aes(label = label),\n              position = position_stack(vjust = 0.5),\n              size     = fontSizeM/2) +\n    theme_void() +   theme(legend.position = \\none\\) +\n    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))\n  fileName <- here(figDir, paste0(\\piechart_\\, name))\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(p2)\n  dev.off()\n}\n\ncommonLoopDir <- here(\\../data/loop_analysis\\)\nfigDir <- here(\\../figure/loop_analysis\\)\ndir.create(figDir, showWarnings = FALSE, recursive = TRUE)\n\ndata <- fread(here(commonLoopDir, \\loopScore_Hansen.tsv\\))\ndata <- data %>% \n  filter(\n    !if_all(starts_with(\\ooe\\), ~ .x == 0)   # drop rows where *every* ooe* value is 0\n)\n\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_all_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_str_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_str2_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_reg_dTAGvDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_dTAGvDMSO\\,\n                 title = \\Hansen_ooe_regStr_dTAGvDMSO\\, figDir)\n\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_A485vDMSO\\,\n                 title = \\Hansen_ooe_all_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_A485vDMSO\\,\n                 title = \\Hansen_ooe_str_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_A485vDMSO\\,\n                 title = \\Hansen_ooe_str2_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_A485vDMSO\\,\n                 title = \\Hansen_ooe_reg_A485vDMSO\\, figDir)\nplot_loop_scores(data, ooe_DMSO, ooe_A485, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_A485vDMSO\\,\n                 title = \\Hansen_ooe_regStr_A485vDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_all_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_str_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_str2_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_reg_EpidTAGvEpiDMSO\\, figDir)\nplot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_EpidTAGvEpiDMSO\\,\n                 title = \\Hansen_ooe_regStr_EpidTAGvEpiDMSO\\, figDir)\n\n\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\,\n                                                 \\E-E\\, \\E-S\\, \\E-X\\,\n                                                 \\S-S\\, \\S-X\\,\n                                                 \\X-X\\),\n                 name = \\Hansen_ooe_all_AIDvUT\\,\n                 title = \\Hansen_ooe_all_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\),\n                 name = \\Hansen_ooe_str_AIDvUT\\,\n                 title = \\Hansen_ooe_str_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\S-S\\, \\S-X\\),\n                 name = \\Hansen_ooe_str2_AIDvUT\\,\n                 title = \\Hansen_ooe_str2_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-P\\, \\P-E\\, \\E-E\\),\n                 name = \\Hansen_ooe_reg_AIDvUT\\,\n                 title = \\Hansen_ooe_reg_AIDvUT\\, figDir)\nplot_loop_scores(data, ooe_UT, ooe_AID, c(\\P-S\\, \\E-S\\),\n                 name = \\Hansen_ooe_regStr_AIDvUT\\,\n                 title = \\Hansen_ooe_regStr_AIDvUT\\, figDir)\n\n```\n```"} -->

```r
```r
plot_loop_scores <- function(df, col_x, col_y, annoList,
                             name, title, figDir,
                             diffCutoff = 0.5, density_n = 100,
                             xmin = -0.5, xmax = 1,
                             ymin = -0.5, ymax = 1) {
  col_x_q <- enquo(col_x)
  col_y_q <- enquo(col_y)
  
  # Scatterplot
  df2 <- df %>%
    filter(Anno_simple %in% annoList) %>%
    select(id, x = !!col_x_q, y = !!col_y_q) %>%
    mutate(
      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),
      eps    = minpos * 0.1,
      lx     = log2(x + eps),
      ly     = log2(y + eps)
    )
  
  p1 <- ggplot(df2, aes(x = lx, y = ly)) +
    geom_point() +
    scale_color_viridis() +
    scale_x_continuous(
      name   = paste0(\log2(\, quo_name(col_x_q), \)\)
    ) +
    scale_y_continuous(
      name   = paste0(\log2(\, quo_name(col_y_q), \)\)
    ) +
    coord_fixed() +
    geom_abline(slope = 1, intercept = 0,
                colour = \grey50\, linetype = \dashed\) +
    geom_hline(yintercept = 0, alpha = 0.5, colour = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, colour = \grey\) +
    geom_abline(slope = 1, intercept = -(2**diffCutoff),
                colour = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept = (2**diffCutoff),
                colour = \grey\, linetype = \dotted\) +
    theme_classic() +
    labs(x = quo_name(col_x_q),
         y = quo_name(col_y_q)) +
    ggtitle(title)
  
  fileName <- paste0(\scatterplot_\, name)
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()
  
  png(here(figDir, paste0(fileName, \.png\)), 
      width = 3.5, height = 3, units = \in\, res = 600)
  print(p1)
  dev.off()
  
  # Pie chart
  df3 <- df %>%
    filter(Anno_simple %in% annoList) %>%
    select(id, x = !!col_x_q, y = !!col_y_q) %>%
    mutate(
      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),
      eps    = minpos * 0.1,
      lx     = log2(x + eps),
      ly     = log2(y + eps)
    ) %>%
    mutate(diff = ly - lx) %>%
    mutate(updown = ifelse(diff > diffCutoff, \UP\,
                           ifelse(diff < -diffCutoff, \DOWN\, \NO\)))
  df3$updown <- factor(df3$updown, c(\UP\, \NO\, \DOWN\))
  
  pie_df <- df3 %>%
    dplyr::count(updown) %>%
    mutate(pct   = n / sum(n) * 100,
           label = paste0(updown, \\n\, n, \\n(\, round(pct,1), \%)\))

  p2 <- ggplot(pie_df, aes(x = \\, y = n, fill = updown)) +
    geom_col(color = \white\) +
    coord_polar(theta = \y\) +
    geom_text(aes(label = label),
              position = position_stack(vjust = 0.5),
              size     = fontSizeM/2) +
    theme_void() +   theme(legend.position = \none\) +
    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))
  fileName <- here(figDir, paste0(\piechart_\, name))
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  svglite(paste0(fileName, \.svg\), width = width, height = height)
  print(p2)
  dev.off()
}

commonLoopDir <- here(\../data/loop_analysis\)
figDir <- here(\../figure/loop_analysis\)
dir.create(figDir, showWarnings = FALSE, recursive = TRUE)

data <- fread(here(commonLoopDir, \loopScore_Hansen.tsv\))
data <- data %>% 
  filter(
    !if_all(starts_with(\ooe\), ~ .x == 0)   # drop rows where *every* ooe* value is 0
)

plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \Hansen_ooe_all_dTAGvDMSO\,
                 title = \Hansen_ooe_all_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\S-S\),
                 name = \Hansen_ooe_str_dTAGvDMSO\,
                 title = \Hansen_ooe_str_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\S-S\, \S-X\),
                 name = \Hansen_ooe_str2_dTAGvDMSO\,
                 title = \Hansen_ooe_str2_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-P\, \P-E\, \E-E\),
                 name = \Hansen_ooe_reg_dTAGvDMSO\,
                 title = \Hansen_ooe_reg_dTAGvDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c(\P-S\, \E-S\),
                 name = \Hansen_ooe_regStr_dTAGvDMSO\,
                 title = \Hansen_ooe_regStr_dTAGvDMSO\, figDir)

plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \Hansen_ooe_all_A485vDMSO\,
                 title = \Hansen_ooe_all_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\S-S\),
                 name = \Hansen_ooe_str_A485vDMSO\,
                 title = \Hansen_ooe_str_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\S-S\, \S-X\),
                 name = \Hansen_ooe_str2_A485vDMSO\,
                 title = \Hansen_ooe_str2_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-P\, \P-E\, \E-E\),
                 name = \Hansen_ooe_reg_A485vDMSO\,
                 title = \Hansen_ooe_reg_A485vDMSO\, figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c(\P-S\, \E-S\),
                 name = \Hansen_ooe_regStr_A485vDMSO\,
                 title = \Hansen_ooe_regStr_A485vDMSO\, figDir)


plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \Hansen_ooe_all_EpidTAGvEpiDMSO\,
                 title = \Hansen_ooe_all_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\S-S\),
                 name = \Hansen_ooe_str_EpidTAGvEpiDMSO\,
                 title = \Hansen_ooe_str_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\S-S\, \S-X\),
                 name = \Hansen_ooe_str2_EpidTAGvEpiDMSO\,
                 title = \Hansen_ooe_str2_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-P\, \P-E\, \E-E\),
                 name = \Hansen_ooe_reg_EpidTAGvEpiDMSO\,
                 title = \Hansen_ooe_reg_EpidTAGvEpiDMSO\, figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c(\P-S\, \E-S\),
                 name = \Hansen_ooe_regStr_EpidTAGvEpiDMSO\,
                 title = \Hansen_ooe_regStr_EpidTAGvEpiDMSO\, figDir)


plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-P\, \P-E\, \P-S\, \P-X\,
                                                 \E-E\, \E-S\, \E-X\,
                                                 \S-S\, \S-X\,
                                                 \X-X\),
                 name = \Hansen_ooe_all_AIDvUT\,
                 title = \Hansen_ooe_all_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\S-S\),
                 name = \Hansen_ooe_str_AIDvUT\,
                 title = \Hansen_ooe_str_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\S-S\, \S-X\),
                 name = \Hansen_ooe_str2_AIDvUT\,
                 title = \Hansen_ooe_str2_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-P\, \P-E\, \E-E\),
                 name = \Hansen_ooe_reg_AIDvUT\,
                 title = \Hansen_ooe_reg_AIDvUT\, figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c(\P-S\, \E-S\),
                 name = \Hansen_ooe_regStr_AIDvUT\,
                 title = \Hansen_ooe_regStr_AIDvUT\, figDir)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFwiLi4vZGF0YS9sb29wX2FuYWx5c2lzXCIpXG5kaWZmRGlyIDwtIGhlcmUoXCIuLi9kYXRhL1JOQV9kaWZmXCIpXG5uYW1lIDwtIFwiSGFuc2VuXCJcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFwibG9vcFNjb3JlX1wiLCBuYW1lLCBcIl9wLW5fc2ltcGxlX2Vuc2VtYmxMaXN0LnRzdlwiKSkpICU+JVxuICBmaWx0ZXIoXG4gICAgIWlmX2FsbChzdGFydHNfd2l0aChcIm9vZVwiKSwgfiAueCA9PSAwKSAgICMgZHJvcCByb3dzIHdoZXJlICpldmVyeSogb29lKiB2YWx1ZSBpcyAwXG4gICkgJT4lXG4gIHJvd3dpc2UoKSAlPiUgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICMgd29yayBvbmUgcm93IGF0IGEgdGltZVxuICBtdXRhdGUoXG4gICAgbWlucG9zID0gbWluKGMob29lX2RUQUcsIG9vZV9ETVNPKVtjKG9vZV9kVEFHLCBvb2VfRE1TTykgPiAwXSwgbmEucm0gPSBUUlVFKSxcbiAgICBlcHMgICAgPSBpZmVsc2UoaXMuZmluaXRlKG1pbnBvcyksIG1pbnBvcyAqIDAuMSwgMC4wMSksICAgICAgIyBmYWxsYmFjayBpZiBib3RoIGFyZSAwXG4gICAgZGlmZiAgID0gbG9nMigob29lX2RUQUcgKyBlcHMpIC8gKG9vZV9ETVNPICsgZXBzKSlcbiAgKSAlPiUgXG4gIHVuZ3JvdXAoKSAlPiUgXG4gIHNlbGVjdCgtbWlucG9zLCAtZXBzKSBcbiAgI2RwbHlyOjptdXRhdGUoZGlmZiA9IGxvZzIob29lX2RUQUcpIC0gbG9nMihvb2VfRE1TTykpXG5cblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShkaWZmRGlyLCBcImRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XCIpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcbmdlbmVMaXN0LmRvd24uUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPD0gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5nZW5lTGlzdC51cC5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA+IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuXG5cbm1heExvZzJGQyA8LSAyXG5cbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmYsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZiksIC5ncm91cHMgPSAnZHJvcCcpXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXCJnZW5lXCIgPSBcImVuc2VtYmxfZ2VuZV9pZFwiKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGZsYWcgPSBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LmRvd24uUk5BLCBcIjJET1dOXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LnVwLlJOQSwgXCIxVVBcIiwgXCIwTk9cIikpLFxuICAgICAgICAgICAgICAgIG1heEZsYWcgPSAoYWJzKHNocmlua2VkX2xvZzJGQykgPiBtYXhMb2cyRkMpLFxuICAgICAgICAgICAgICAgIHNocmxvZzJmY01heCA9IHBtYXgocG1pbihzaHJpbmtlZF9sb2cyRkMsIG1heExvZzJGQyksIC1tYXhMb2cyRkMpKSAlPiUgXG4gIGRwbHlyOjphcnJhbmdlKGZsYWcpXG5cbnAgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gc2hybG9nMmZjTWF4LCB5ID0gbWVhbl9kaWZmX3Njb3JlLCBjb2xvciA9IGZsYWcsXG4gICAgICAgICAgICAgICAgICAgICAgbGFiZWwgPSBpZmVsc2UoZmxhZyAhPSBcIjBOT1wiLCBleHRlcm5hbF9nZW5lX25hbWUsIE5BKSxcbiAgICAgICAgICAgICAgICAgICAgICBzaGFwZSA9IGFzLmZhY3RvcihtYXhGbGFnKSkpICtcbiAgZ2VvbV9wb2ludCgpICsgZ2VvbV90ZXh0X3JlcGVsKCkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICBnZ3RpdGxlKHBhc3RlMChuYW1lLCBcIl9vb2Vfc2ltcGxlQW5ub1wiKSkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXCJkYXNoZWRcIikgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAtIGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXCJkYXNoZWRcIikgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IGZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFwiZGFzaGVkXCIpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gLWZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFwiZGFzaGVkXCIpICtcbiAgc2NhbGVfY29sb3JfbWFudWFsKHZhbHVlcyA9IGMoXCIwTk9cIiA9IFwiZ3JleVwiLCBcIjFVUFwiID0gXCJyZWRcIiwgXCIyRE9XTlwiID0gXCJibHVlXCIpKSArICAjIENvcnJlY3RlZCBjb2xvciBtYXBwaW5nXG4gIHNjYWxlX3NoYXBlX21hbnVhbCh2YWx1ZXMgPSBjKFwiVFJVRVwiID0gMiwgXCJGQUxTRVwiID0gMTkpKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJSTkF2c0xvb3BfXCIsIG5hbWUsIFwiX29vZV9zaW1wbGVBbm5vXCIpXG5oZWlnaHQgPC0gNFxud2lkdGggPC0gN1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgIn0= -->\n\n```r\nalpha <- 0.05\nfcCutoff <- 0.5\ndiffCutoff <- 0.5\ncommonLoopDir <- here(\\../data/loop_analysis\\)\ndiffDir <- here(\\../data/RNA_diff\\)\nname <- \\Hansen\\\ngeneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\\loopScore_\\, name, \\_p-n_simple_ensemblList.tsv\\))) %>%\n  filter(\n    !if_all(starts_with(\\ooe\\), ~ .x == 0)   # drop rows where *every* ooe* value is 0\n  ) %>%\n  rowwise() %>%                                # work one row at a time\n  mutate(\n    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),\n    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0\n    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))\n  ) %>% \n  ungroup() %>% \n  select(-minpos, -eps) \n  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))\n\n\ndiff.RNA <- fread(here(diffDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id\n\n\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() +\n  ggtitle(paste0(name, \\_ooe_simpleAnno\\)) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\RNAvsLoop_\\, name, \\_ooe_simpleAnno\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \Hansen\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_simple_ensemblList.tsv\))) %>%
  filter(
    !if_all(starts_with(\ooe\), ~ .x == 0)   # drop rows where *every* ooe* value is 0
  ) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))


diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_ooe_simpleAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_ooe_simpleAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcSGFuc2VuXFxcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBuYW1lLCBcXF9wLW5fc2ltcGxlX2Vuc2VtYmxMaXN0LnRzdlxcKSkpICU+JVxuICBmaWx0ZXIoXG4gICAgIWlmX2FsbChzdGFydHNfd2l0aChcXG9vZVxcKSwgfiAueCA9PSAwKSAgICMgZHJvcCByb3dzIHdoZXJlICpldmVyeSogb29lKiB2YWx1ZSBpcyAwXG4gICkgJT4lXG4gIHJvd3dpc2UoKSAlPiUgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICMgd29yayBvbmUgcm93IGF0IGEgdGltZVxuICBtdXRhdGUoXG4gICAgbWlucG9zID0gbWluKGMob29lX2RUQUcsIG9vZV9ETVNPKVtjKG9vZV9kVEFHLCBvb2VfRE1TTykgPiAwXSwgbmEucm0gPSBUUlVFKSxcbiAgICBlcHMgICAgPSBpZmVsc2UoaXMuZmluaXRlKG1pbnBvcyksIG1pbnBvcyAqIDAuMSwgMC4wMSksICAgICAgIyBmYWxsYmFjayBpZiBib3RoIGFyZSAwXG4gICAgZGlmZiAgID0gbG9nMigob29lX2RUQUcgKyBlcHMpIC8gKG9vZV9ETVNPICsgZXBzKSlcbiAgKSAlPiUgXG4gIHVuZ3JvdXAoKSAlPiUgXG4gIHNlbGVjdCgtbWlucG9zLCAtZXBzKSBcbiAgI2RwbHlyOjptdXRhdGUoZGlmZiA9IGxvZzIob29lX2RUQUcpIC0gbG9nMihvb2VfRE1TTykpXG5cblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShkaWZmRGlyLCBcXGRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcbmdlbmVMaXN0LmRvd24uUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPD0gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5nZW5lTGlzdC51cC5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA+IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuXG5cbm1heExvZzJGQyA8LSAyXG5cbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmYsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZiksIC5ncm91cHMgPSAnZHJvcCcpXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGZsYWcgPSBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LmRvd24uUk5BLCBcXDJET1dOXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LnVwLlJOQSwgXFwxVVBcXCwgXFwwTk9cXCkpLFxuICAgICAgICAgICAgICAgIG1heEZsYWcgPSAoYWJzKHNocmlua2VkX2xvZzJGQykgPiBtYXhMb2cyRkMpLFxuICAgICAgICAgICAgICAgIHNocmxvZzJmY01heCA9IHBtYXgocG1pbihzaHJpbmtlZF9sb2cyRkMsIG1heExvZzJGQyksIC1tYXhMb2cyRkMpKSAlPiUgXG4gIGRwbHlyOjphcnJhbmdlKGZsYWcpXG5cbnAgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gc2hybG9nMmZjTWF4LCB5ID0gbWVhbl9kaWZmX3Njb3JlLCBjb2xvciA9IGZsYWcsXG4gICAgICAgICAgICAgICAgICAgICAgbGFiZWwgPSBpZmVsc2UoZmxhZyAhPSBcXDBOT1xcLCBleHRlcm5hbF9nZW5lX25hbWUsIE5BKSxcbiAgICAgICAgICAgICAgICAgICAgICBzaGFwZSA9IGFzLmZhY3RvcihtYXhGbGFnKSkpICtcbiAgZ2VvbV9wb2ludCgpICsgZ2VvbV90ZXh0X3JlcGVsKCkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICBnZ3RpdGxlKHBhc3RlMChuYW1lLCBcXF9vb2Vfc2ltcGxlQW5ub1xcKSkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAtIGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IGZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gLWZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgc2NhbGVfY29sb3JfbWFudWFsKHZhbHVlcyA9IGMoXFwwTk9cXCA9IFxcZ3JleVxcLCBcXDFVUFxcID0gXFxyZWRcXCwgXFwyRE9XTlxcID0gXFxibHVlXFwpKSArICAjIENvcnJlY3RlZCBjb2xvciBtYXBwaW5nXG4gIHNjYWxlX3NoYXBlX21hbnVhbCh2YWx1ZXMgPSBjKFxcVFJVRVxcID0gMiwgXFxGQUxTRVxcID0gMTkpKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxSTkF2c0xvb3BfXFwsIG5hbWUsIFxcX29vZV9zaW1wbGVBbm5vXFwpXG5oZWlnaHQgPC0gNFxud2lkdGggPC0gN1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\nalpha <- 0.05\nfcCutoff <- 0.5\ndiffCutoff <- 0.5\ncommonLoopDir <- here(\\../data/loop_analysis\\)\ndiffDir <- here(\\../data/RNA_diff\\)\nname <- \\Hansen\\\ngeneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\\loopScore_\\, name, \\_p-n_simple_ensemblList.tsv\\))) %>%\n  filter(\n    !if_all(starts_with(\\ooe\\), ~ .x == 0)   # drop rows where *every* ooe* value is 0\n  ) %>%\n  rowwise() %>%                                # work one row at a time\n  mutate(\n    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),\n    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0\n    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))\n  ) %>% \n  ungroup() %>% \n  select(-minpos, -eps) \n  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))\n\n\ndiff.RNA <- fread(here(diffDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id\n\n\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() +\n  ggtitle(paste0(name, \\_ooe_simpleAnno\\)) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\RNAvsLoop_\\, name, \\_ooe_simpleAnno\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcSGFuc2VuXFxcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBuYW1lLCBcXF9wLW5fc2ltcGxlX2Vuc2VtYmxMaXN0LnRzdlxcKSkpICU+JVxuICBmaWx0ZXIoXG4gICAgIWlmX2FsbChzdGFydHNfd2l0aChcXG9vZVxcKSwgfiAueCA9PSAwKSAgICMgZHJvcCByb3dzIHdoZXJlICpldmVyeSogb29lKiB2YWx1ZSBpcyAwXG4gICkgJT4lXG4gIHJvd3dpc2UoKSAlPiUgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICMgd29yayBvbmUgcm93IGF0IGEgdGltZVxuICBtdXRhdGUoXG4gICAgbWlucG9zID0gbWluKGMob29lX2RUQUcsIG9vZV9ETVNPKVtjKG9vZV9kVEFHLCBvb2VfRE1TTykgPiAwXSwgbmEucm0gPSBUUlVFKSxcbiAgICBlcHMgICAgPSBpZmVsc2UoaXMuZmluaXRlKG1pbnBvcyksIG1pbnBvcyAqIDAuMSwgMC4wMSksICAgICAgIyBmYWxsYmFjayBpZiBib3RoIGFyZSAwXG4gICAgZGlmZiAgID0gbG9nMigob29lX2RUQUcgKyBlcHMpIC8gKG9vZV9ETVNPICsgZXBzKSlcbiAgKSAlPiUgXG4gIHVuZ3JvdXAoKSAlPiUgXG4gIHNlbGVjdCgtbWlucG9zLCAtZXBzKSBcbiAgI2RwbHlyOjptdXRhdGUoZGlmZiA9IGxvZzIob29lX2RUQUcpIC0gbG9nMihvb2VfRE1TTykpXG5cblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShkaWZmRGlyLCBcXGRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcbmdlbmVMaXN0LmRvd24uUk5BIDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihzaHJpbmtlZF9sb2cyRkMgPD0gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5nZW5lTGlzdC51cC5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA+IDAsIHBhZGogPCBhbHBoYSkpJGVuc2VtYmxfZ2VuZV9pZFxuXG5cbm1heExvZzJGQyA8LSAyXG5cbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmYsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZiksIC5ncm91cHMgPSAnZHJvcCcpXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGZsYWcgPSBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LmRvd24uUk5BLCBcXDJET1dOXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmVMaXN0LnVwLlJOQSwgXFwxVVBcXCwgXFwwTk9cXCkpLFxuICAgICAgICAgICAgICAgIG1heEZsYWcgPSAoYWJzKHNocmlua2VkX2xvZzJGQykgPiBtYXhMb2cyRkMpLFxuICAgICAgICAgICAgICAgIHNocmxvZzJmY01heCA9IHBtYXgocG1pbihzaHJpbmtlZF9sb2cyRkMsIG1heExvZzJGQyksIC1tYXhMb2cyRkMpKSAlPiUgXG4gIGRwbHlyOjphcnJhbmdlKGZsYWcpXG5cbnAgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gc2hybG9nMmZjTWF4LCB5ID0gbWVhbl9kaWZmX3Njb3JlLCBjb2xvciA9IGZsYWcsXG4gICAgICAgICAgICAgICAgICAgICAgbGFiZWwgPSBpZmVsc2UoZmxhZyAhPSBcXDBOT1xcLCBleHRlcm5hbF9nZW5lX25hbWUsIE5BKSxcbiAgICAgICAgICAgICAgICAgICAgICBzaGFwZSA9IGFzLmZhY3RvcihtYXhGbGFnKSkpICtcbiAgZ2VvbV9wb2ludCgpICsgZ2VvbV90ZXh0X3JlcGVsKCkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICBnZ3RpdGxlKHBhc3RlMChuYW1lLCBcXF9vb2Vfc2ltcGxlQW5ub1xcKSkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAtIGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IGZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gLWZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgc2NhbGVfY29sb3JfbWFudWFsKHZhbHVlcyA9IGMoXFwwTk9cXCA9IFxcZ3JleVxcLCBcXDFVUFxcID0gXFxyZWRcXCwgXFwyRE9XTlxcID0gXFxibHVlXFwpKSArICAjIENvcnJlY3RlZCBjb2xvciBtYXBwaW5nXG4gIHNjYWxlX3NoYXBlX21hbnVhbCh2YWx1ZXMgPSBjKFxcVFJVRVxcID0gMiwgXFxGQUxTRVxcID0gMTkpKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxSTkF2c0xvb3BfXFwsIG5hbWUsIFxcX29vZV9zaW1wbGVBbm5vXFwpXG5oZWlnaHQgPC0gNFxud2lkdGggPC0gN1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \Hansen\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_simple_ensemblList.tsv\))) %>%
  filter(
    !if_all(starts_with(\ooe\), ~ .x == 0)   # drop rows where *every* ooe* value is 0
  ) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))


diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_ooe_simpleAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_ooe_simpleAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Scatterplot - Hansen

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFwiLi4vZGF0YS9sb29wX2FuYWx5c2lzXCIpXG5kaWZmRGlyIDwtIGhlcmUoXCIuLi9kYXRhL1JOQV9kaWZmXCIpXG5uYW1lIDwtIFwiSGFuc2VuXCJcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFwibG9vcFNjb3JlX1wiLCBuYW1lLCBcIl9wLW5fY29tcGxleF9lbnNlbWJsTGlzdC50c3ZcIikpKSAlPiVcbiAgZmlsdGVyKFxuICAgICFpZl9hbGwoc3RhcnRzX3dpdGgoXCJvb2VcIiksIH4gLnggPT0gMCkgICAjIGRyb3Agcm93cyB3aGVyZSAqZXZlcnkqIG9vZSogdmFsdWUgaXMgMFxuICApICU+JVxuICByb3d3aXNlKCkgJT4lICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAjIHdvcmsgb25lIHJvdyBhdCBhIHRpbWVcbiAgbXV0YXRlKFxuICAgIG1pbnBvcyA9IG1pbihjKG9vZV9kVEFHLCBvb2VfRE1TTylbYyhvb2VfZFRBRywgb29lX0RNU08pID4gMF0sIG5hLnJtID0gVFJVRSksXG4gICAgZXBzICAgID0gaWZlbHNlKGlzLmZpbml0ZShtaW5wb3MpLCBtaW5wb3MgKiAwLjEsIDAuMDEpLCAgICAgICMgZmFsbGJhY2sgaWYgYm90aCBhcmUgMFxuICAgIGRpZmYgICA9IGxvZzIoKG9vZV9kVEFHICsgZXBzKSAvIChvb2VfRE1TTyArIGVwcykpXG4gICkgJT4lIFxuICB1bmdyb3VwKCkgJT4lIFxuICBzZWxlY3QoLW1pbnBvcywgLWVwcykgXG4gICNkcGx5cjo6bXV0YXRlKGRpZmYgPSBsb2cyKG9vZV9kVEFHKSAtIGxvZzIob29lX0RNU08pKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKGRpZmZEaXIsIFwiZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcIikpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuZ2VuZUxpc3QuZG93bi5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA8PSAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcbmdlbmVMaXN0LnVwLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDID4gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5cblxubWF4TG9nMkZDIDwtIDJcblxudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZiwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmKSwgLmdyb3VwcyA9ICdkcm9wJylcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcImdlbmVcIiA9IFwiZW5zZW1ibF9nZW5lX2lkXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoZmxhZyA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QuZG93bi5STkEsIFwiMkRPV05cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QudXAuUk5BLCBcIjFVUFwiLCBcIjBOT1wiKSksXG4gICAgICAgICAgICAgICAgbWF4RmxhZyA9IChhYnMoc2hyaW5rZWRfbG9nMkZDKSA+IG1heExvZzJGQyksXG4gICAgICAgICAgICAgICAgc2hybG9nMmZjTWF4ID0gcG1heChwbWluKHNocmlua2VkX2xvZzJGQywgbWF4TG9nMkZDKSwgLW1heExvZzJGQykpICU+JSBcbiAgZHBseXI6OmFycmFuZ2UoZmxhZylcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBzaHJsb2cyZmNNYXgsIHkgPSBtZWFuX2RpZmZfc2NvcmUsIGNvbG9yID0gZmxhZyxcbiAgICAgICAgICAgICAgICAgICAgICBsYWJlbCA9IGlmZWxzZShmbGFnICE9IFwiME5PXCIsIGV4dGVybmFsX2dlbmVfbmFtZSwgTkEpLFxuICAgICAgICAgICAgICAgICAgICAgIHNoYXBlID0gYXMuZmFjdG9yKG1heEZsYWcpKSkgK1xuICBnZW9tX3BvaW50KCkgKyBnZW9tX3RleHRfcmVwZWwoKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdndGl0bGUocGFzdGUwKG5hbWUsIFwiX29vZV9jb21wbGV4QW5ub1wiKSkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXCJkYXNoZWRcIikgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAtIGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXCJkYXNoZWRcIikgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IGZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFwiZGFzaGVkXCIpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gLWZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFwiZGFzaGVkXCIpICtcbiAgc2NhbGVfY29sb3JfbWFudWFsKHZhbHVlcyA9IGMoXCIwTk9cIiA9IFwiZ3JleVwiLCBcIjFVUFwiID0gXCJyZWRcIiwgXCIyRE9XTlwiID0gXCJibHVlXCIpKSArICAjIENvcnJlY3RlZCBjb2xvciBtYXBwaW5nXG4gIHNjYWxlX3NoYXBlX21hbnVhbCh2YWx1ZXMgPSBjKFwiVFJVRVwiID0gMiwgXCJGQUxTRVwiID0gMTkpKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJSTkF2c0xvb3BfXCIsIG5hbWUsIFwiX29vZV9jb21wbGV4QW5ub1wiKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDdcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYCJ9 -->\n\n```r\nalpha <- 0.05\nfcCutoff <- 0.5\ndiffCutoff <- 0.5\ncommonLoopDir <- here(\\../data/loop_analysis\\)\ndiffDir <- here(\\../data/RNA_diff\\)\nname <- \\Hansen\\\ngeneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\\loopScore_\\, name, \\_p-n_complex_ensemblList.tsv\\))) %>%\n  filter(\n    !if_all(starts_with(\\ooe\\), ~ .x == 0)   # drop rows where *every* ooe* value is 0\n  ) %>%\n  rowwise() %>%                                # work one row at a time\n  mutate(\n    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),\n    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0\n    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))\n  ) %>% \n  ungroup() %>% \n  select(-minpos, -eps) \n  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))\n\ndiff.RNA <- fread(here(diffDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id\n\n\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() +\n  ggtitle(paste0(name, \\_ooe_complexAnno\\)) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\RNAvsLoop_\\, name, \\_ooe_complexAnno\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \Hansen\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_complex_ensemblList.tsv\))) %>%
  filter(
    !if_all(starts_with(\ooe\), ~ .x == 0)   # drop rows where *every* ooe* value is 0
  ) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_ooe_complexAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_ooe_complexAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcSGFuc2VuXFxcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBuYW1lLCBcXF9wLW5fY29tcGxleF9lbnNlbWJsTGlzdC50c3ZcXCkpKSAlPiVcbiAgZmlsdGVyKFxuICAgICFpZl9hbGwoc3RhcnRzX3dpdGgoXFxvb2VcXCksIH4gLnggPT0gMCkgICAjIGRyb3Agcm93cyB3aGVyZSAqZXZlcnkqIG9vZSogdmFsdWUgaXMgMFxuICApICU+JVxuICByb3d3aXNlKCkgJT4lICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAjIHdvcmsgb25lIHJvdyBhdCBhIHRpbWVcbiAgbXV0YXRlKFxuICAgIG1pbnBvcyA9IG1pbihjKG9vZV9kVEFHLCBvb2VfRE1TTylbYyhvb2VfZFRBRywgb29lX0RNU08pID4gMF0sIG5hLnJtID0gVFJVRSksXG4gICAgZXBzICAgID0gaWZlbHNlKGlzLmZpbml0ZShtaW5wb3MpLCBtaW5wb3MgKiAwLjEsIDAuMDEpLCAgICAgICMgZmFsbGJhY2sgaWYgYm90aCBhcmUgMFxuICAgIGRpZmYgICA9IGxvZzIoKG9vZV9kVEFHICsgZXBzKSAvIChvb2VfRE1TTyArIGVwcykpXG4gICkgJT4lIFxuICB1bmdyb3VwKCkgJT4lIFxuICBzZWxlY3QoLW1pbnBvcywgLWVwcykgXG4gICNkcGx5cjo6bXV0YXRlKGRpZmYgPSBsb2cyKG9vZV9kVEFHKSAtIGxvZzIob29lX0RNU08pKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKGRpZmZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuZ2VuZUxpc3QuZG93bi5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA8PSAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcbmdlbmVMaXN0LnVwLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDID4gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5cblxubWF4TG9nMkZDIDwtIDJcblxudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZiwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmKSwgLmdyb3VwcyA9ICdkcm9wJylcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcXGdlbmVcXCA9IFxcZW5zZW1ibF9nZW5lX2lkXFwpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoZmxhZyA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QuZG93bi5STkEsIFxcMkRPV05cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QudXAuUk5BLCBcXDFVUFxcLCBcXDBOT1xcKSksXG4gICAgICAgICAgICAgICAgbWF4RmxhZyA9IChhYnMoc2hyaW5rZWRfbG9nMkZDKSA+IG1heExvZzJGQyksXG4gICAgICAgICAgICAgICAgc2hybG9nMmZjTWF4ID0gcG1heChwbWluKHNocmlua2VkX2xvZzJGQywgbWF4TG9nMkZDKSwgLW1heExvZzJGQykpICU+JSBcbiAgZHBseXI6OmFycmFuZ2UoZmxhZylcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBzaHJsb2cyZmNNYXgsIHkgPSBtZWFuX2RpZmZfc2NvcmUsIGNvbG9yID0gZmxhZyxcbiAgICAgICAgICAgICAgICAgICAgICBsYWJlbCA9IGlmZWxzZShmbGFnICE9IFxcME5PXFwsIGV4dGVybmFsX2dlbmVfbmFtZSwgTkEpLFxuICAgICAgICAgICAgICAgICAgICAgIHNoYXBlID0gYXMuZmFjdG9yKG1heEZsYWcpKSkgK1xuICBnZW9tX3BvaW50KCkgKyBnZW9tX3RleHRfcmVwZWwoKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdndGl0bGUocGFzdGUwKG5hbWUsIFxcX29vZV9jb21wbGV4QW5ub1xcKSkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAtIGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IGZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gLWZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgc2NhbGVfY29sb3JfbWFudWFsKHZhbHVlcyA9IGMoXFwwTk9cXCA9IFxcZ3JleVxcLCBcXDFVUFxcID0gXFxyZWRcXCwgXFwyRE9XTlxcID0gXFxibHVlXFwpKSArICAjIENvcnJlY3RlZCBjb2xvciBtYXBwaW5nXG4gIHNjYWxlX3NoYXBlX21hbnVhbCh2YWx1ZXMgPSBjKFxcVFJVRVxcID0gMiwgXFxGQUxTRVxcID0gMTkpKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxSTkF2c0xvb3BfXFwsIG5hbWUsIFxcX29vZV9jb21wbGV4QW5ub1xcKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDdcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\nalpha <- 0.05\nfcCutoff <- 0.5\ndiffCutoff <- 0.5\ncommonLoopDir <- here(\\../data/loop_analysis\\)\ndiffDir <- here(\\../data/RNA_diff\\)\nname <- \\Hansen\\\ngeneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\\loopScore_\\, name, \\_p-n_complex_ensemblList.tsv\\))) %>%\n  filter(\n    !if_all(starts_with(\\ooe\\), ~ .x == 0)   # drop rows where *every* ooe* value is 0\n  ) %>%\n  rowwise() %>%                                # work one row at a time\n  mutate(\n    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),\n    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0\n    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))\n  ) %>% \n  ungroup() %>% \n  select(-minpos, -eps) \n  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))\n\ndiff.RNA <- fread(here(diffDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id\n\n\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() +\n  ggtitle(paste0(name, \\_ooe_complexAnno\\)) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\RNAvsLoop_\\, name, \\_ooe_complexAnno\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYWxwaGEgPC0gMC4wNVxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuNVxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5kaWZmRGlyIDwtIGhlcmUoXFwuLi9kYXRhL1JOQV9kaWZmXFwpXG5uYW1lIDwtIFxcSGFuc2VuXFxcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29tbW9uTG9vcERpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBuYW1lLCBcXF9wLW5fY29tcGxleF9lbnNlbWJsTGlzdC50c3ZcXCkpKSAlPiVcbiAgZmlsdGVyKFxuICAgICFpZl9hbGwoc3RhcnRzX3dpdGgoXFxvb2VcXCksIH4gLnggPT0gMCkgICAjIGRyb3Agcm93cyB3aGVyZSAqZXZlcnkqIG9vZSogdmFsdWUgaXMgMFxuICApICU+JVxuICByb3d3aXNlKCkgJT4lICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAjIHdvcmsgb25lIHJvdyBhdCBhIHRpbWVcbiAgbXV0YXRlKFxuICAgIG1pbnBvcyA9IG1pbihjKG9vZV9kVEFHLCBvb2VfRE1TTylbYyhvb2VfZFRBRywgb29lX0RNU08pID4gMF0sIG5hLnJtID0gVFJVRSksXG4gICAgZXBzICAgID0gaWZlbHNlKGlzLmZpbml0ZShtaW5wb3MpLCBtaW5wb3MgKiAwLjEsIDAuMDEpLCAgICAgICMgZmFsbGJhY2sgaWYgYm90aCBhcmUgMFxuICAgIGRpZmYgICA9IGxvZzIoKG9vZV9kVEFHICsgZXBzKSAvIChvb2VfRE1TTyArIGVwcykpXG4gICkgJT4lIFxuICB1bmdyb3VwKCkgJT4lIFxuICBzZWxlY3QoLW1pbnBvcywgLWVwcykgXG4gICNkcGx5cjo6bXV0YXRlKGRpZmYgPSBsb2cyKG9vZV9kVEFHKSAtIGxvZzIob29lX0RNU08pKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKGRpZmZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuZ2VuZUxpc3QuZG93bi5STkEgPC0gKGRpZmYuUk5BICU+JSBkcGx5cjo6ZmlsdGVyKHNocmlua2VkX2xvZzJGQyA8PSAwLCBwYWRqIDwgYWxwaGEpKSRlbnNlbWJsX2dlbmVfaWRcbmdlbmVMaXN0LnVwLlJOQSA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoc2hyaW5rZWRfbG9nMkZDID4gMCwgcGFkaiA8IGFscGhhKSkkZW5zZW1ibF9nZW5lX2lkXG5cblxubWF4TG9nMkZDIDwtIDJcblxudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZiwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmKSwgLmdyb3VwcyA9ICdkcm9wJylcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcXGdlbmVcXCA9IFxcZW5zZW1ibF9nZW5lX2lkXFwpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoZmxhZyA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QuZG93bi5STkEsIFxcMkRPV05cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZUxpc3QudXAuUk5BLCBcXDFVUFxcLCBcXDBOT1xcKSksXG4gICAgICAgICAgICAgICAgbWF4RmxhZyA9IChhYnMoc2hyaW5rZWRfbG9nMkZDKSA+IG1heExvZzJGQyksXG4gICAgICAgICAgICAgICAgc2hybG9nMmZjTWF4ID0gcG1heChwbWluKHNocmlua2VkX2xvZzJGQywgbWF4TG9nMkZDKSwgLW1heExvZzJGQykpICU+JSBcbiAgZHBseXI6OmFycmFuZ2UoZmxhZylcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBzaHJsb2cyZmNNYXgsIHkgPSBtZWFuX2RpZmZfc2NvcmUsIGNvbG9yID0gZmxhZyxcbiAgICAgICAgICAgICAgICAgICAgICBsYWJlbCA9IGlmZWxzZShmbGFnICE9IFxcME5PXFwsIGV4dGVybmFsX2dlbmVfbmFtZSwgTkEpLFxuICAgICAgICAgICAgICAgICAgICAgIHNoYXBlID0gYXMuZmFjdG9yKG1heEZsYWcpKSkgK1xuICBnZW9tX3BvaW50KCkgKyBnZW9tX3RleHRfcmVwZWwoKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdndGl0bGUocGFzdGUwKG5hbWUsIFxcX29vZV9jb21wbGV4QW5ub1xcKSkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAtIGRpZmZDdXRvZmYsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IGZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gLWZjQ3V0b2ZmLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgc2NhbGVfY29sb3JfbWFudWFsKHZhbHVlcyA9IGMoXFwwTk9cXCA9IFxcZ3JleVxcLCBcXDFVUFxcID0gXFxyZWRcXCwgXFwyRE9XTlxcID0gXFxibHVlXFwpKSArICAjIENvcnJlY3RlZCBjb2xvciBtYXBwaW5nXG4gIHNjYWxlX3NoYXBlX21hbnVhbCh2YWx1ZXMgPSBjKFxcVFJVRVxcID0gMiwgXFxGQUxTRVxcID0gMTkpKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxSTkF2c0xvb3BfXFwsIG5hbWUsIFxcX29vZV9jb21wbGV4QW5ub1xcKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDdcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here(\../data/loop_analysis\)
diffDir <- here(\../data/RNA_diff\)
name <- \Hansen\
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0(\loopScore_\, name, \_p-n_complex_ensemblList.tsv\))) %>%
  filter(
    !if_all(starts_with(\ooe\), ~ .x == 0)   # drop rows where *every* ooe* value is 0
  ) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, \_ooe_complexAnno\)) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\RNAvsLoop_\, name, \_ooe_complexAnno\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### RNA-seq loopscore scatterplot

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZMjl0Ylc5dVRHOXZjRVJwY2lBOExTQm9aWEpsS0Z3aUxpNHZaR0YwWVM5c2IyOXdYMkZ1WVd4NWMybHpYQ0lwWEc1Y2JtUnBabVpEZFhSdlptWWdQQzBnTUM0eVhHNWNibVJoZEdFZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjIxdGIyNU1iMjl3UkdseUxDQmNJbXh2YjNCVFkyOXlaVjlqYUhKdmJXOXphV2RvZEM1MGMzWmNJaWtwWEc1Y2JuTmpiM0psTG5SaUlEd3RJR1JoZEdFZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1FXNXViMTl6YVcxd2JHVWdKV2x1SlNCaktGd2lVeTFUWENJcEtTQWxQaVZjYmlBZ1pIQnNlWEk2T25ObGJHVmpkQ2hwWkN3Z2MyTnZjbVZmUkUxVFR5d2djMk52Y21WZlpGUkJSeWxjYmx4dVhHNGpJeU1nVURFdUlGVlVJSFp6SUVGSlJGeHVjMk52Y21VdWRHSWtaR1Z1YzJsMGVTQThMU0JuWlhSZlpHVnVjMmwwZVNoelkyOXlaUzUwWWlSelkyOXlaVjlFVFZOUExDQnpZMjl5WlM1MFlpUnpZMjl5WlY5a1ZFRkhMQ0J1SUQwZ01qQXdLVnh1YzJOdmNtVXVkR0lnUEMwZ2MyTnZjbVV1ZEdJZ0pUNGxJR1J3YkhseU9qcGhjbkpoYm1kbEtHUmxibk5wZEhrcFhHNXdNU0E4TFNCblozQnNiM1FvYzJOdmNtVXVkR0lzSUdGbGN5aDRJRDBnYzJOdmNtVmZSRTFUVHl3Z2VTQTlJSE5qYjNKbFgyUlVRVWNzSUdOdmJHOXlJRDBnWkdWdWMybDBlU2twSUN0Y2JpQWdaMlZ2YlY5d2IybHVkQ2dwSUNzZ1hHNGdJSE5qWVd4bFgyTnZiRzl5WDNacGNtbGthWE1vS1NBclhHNGdJSGhzYVcwb0xUQXVOU3dnTVNrZ0t5QjViR2x0S0Mwd0xqVXNJREVwSUN0Y2JpQWdZMjl2Y21SZlptbDRaV1FvS1NBclhHNGdJR2RsYjIxZllXSnNhVzVsS0hOc2IzQmxJRDBnTVN3Z2FXNTBaWEpqWlhCMElEMGdNQ3dnWTI5c0lEMGdYQ0puY21WNU5UQmNJaXdnYkdsdVpYUjVjR1VnUFNCY0ltUmhjMmhsWkZ3aUtTQXJYRzRnSUdkbGIyMWZhR3hwYm1Vb2VXbHVkR1Z5WTJWd2RDQTlJREFzSUdGc2NHaGhJRDBnTUM0MUxDQmpiMnh2Y2lBOUlGd2laM0psZVZ3aUtTQXJYRzRnSUdkbGIyMWZkbXhwYm1Vb2VHbHVkR1Z5WTJWd2RDQTlJREFzSUdGc2NHaGhJRDBnTUM0MUxDQmpiMnh2Y2lBOUlGd2laM0psZVZ3aUtTQXJYRzRnSUdkbGIyMWZZV0pzYVc1bEtITnNiM0JsSUQwZ01Td2dhVzUwWlhKalpYQjBJRDBnTFdScFptWkRkWFJ2Wm1Zc0lHTnZiQ0E5SUZ3aVozSmxlVndpTENCc2FXNWxkSGx3WlNBOUlGd2laRzkwZEdWa1hDSXBJQ3RjYmlBZ1oyVnZiVjloWW14cGJtVW9jMnh2Y0dVZ1BTQXhMQ0JwYm5SbGNtTmxjSFFnUFNCa2FXWm1RM1YwYjJabUxDQmpiMndnUFNCY0ltZHlaWGxjSWl3Z2JHbHVaWFI1Y0dVZ1BTQmNJbVJ2ZEhSbFpGd2lLU0FyWEc0Z0lIUm9aVzFsWDJOc1lYTnphV01vS1NBcklHZG5kR2wwYkdVb2NHRnpkR1V3S0Z3aVEyOXVjMlZ1YzNWeklHeHZiM0FnYzJOdmNtVmNJaWtwWEc1Y2JseHVJeUJFWldacGJtVWdkR2hsSUdSaGRHRmNibU5oZEdWbmIzSnBaWE1nUEMwZ1l5aGNJbFZ3WENJc0lGd2lUbTljSWl3Z1hDSkViM2R1WENJcFhHNTJZV3gxWlhNZ1BDMGdZeWd5TWpnc0lEa3dPRFFzSURVM01UWTVLVnh1WEc0aklFTmhiR04xYkdGMFpTQndaWEpqWlc1MFlXZGxjMXh1Y0dWeVkyVnVkR0ZuWlhNZ1BDMGdjbTkxYm1Rb0tIWmhiSFZsY3lBdklITjFiU2gyWVd4MVpYTXBLU0FxSURFd01Dd2dNaWxjYmx4dUl5QkRiMjFpYVc1bElIWmhiSFZsY3lCaGJtUWdjR1Z5WTJWdWRHRm5aWE1nWm05eUlHeGhZbVZzYzF4dWJHRmlaV3h6SUR3dElIQmhjM1JsS0dOaGRHVm5iM0pwWlhNc0lGd2lYRnh1WENJc0lIWmhiSFZsY3l3Z1hDSmNYRzRvWENJc0lIQmxjbU5sYm5SaFoyVnpMQ0JjSWlVcFhDSXNJSE5sY0NBOUlGd2lYQ0lwWEc1Y2JtWnBiR1ZPWVcxbElEd3RJR2hsY21Vb1ptbG5SR2x5TENCY0luQnBaV05vWVhKMFgzVnVhVzl1VEc5dmNITmNJaWxjYm5kcFpIUm9JRHd0SUhCaGJtVnNVMmw2WlNneUtTcHRiVlJ2U1c1amFGeHVhR1ZwWjJoMElEd3RJSEJoYm1Wc1UybDZaU2d5S1NwdGJWUnZTVzVqYUZ4dWMzWm5iR2wwWlNod1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ3aUxuTjJaMXdpS1N3Z2QybGtkR2dnUFNCM2FXUjBhQ3dnYUdWcFoyaDBJRDFvWldsbmFIUXBYRzV3YVdVb2RtRnNkV1Z6TENCY2JpQWdJQ0JzWVdKbGJITWdQU0JzWVdKbGJITXNJRnh1SUNBZ0lHTnZiQ0E5SUdNb2MzUnliMjVuWDNKbFpDd2dibTlmWjNKbGVTd2djM1J5YjI1blgySnNkV1VwTENCY2JpQWdJQ0JqWlhnZ1BTQm1iMjUwVTJsNlpVMHZNVElwWEc1a1pYWXViMlptS0NsY2JseHVZR0JnSW4wPSAtLT5cblxuYGBgclxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5cbmRpZmZDdXRvZmYgPC0gMC4yXG5cbmRhdGEgPC0gZnJlYWQoaGVyZShjb21tb25Mb29wRGlyLCBcXGxvb3BTY29yZV9jaHJvbW9zaWdodC50c3ZcXCkpXG5cbnNjb3JlLnRiIDwtIGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ub19zaW1wbGUgJWluJSBjKFxcUy1TXFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChpZCwgc2NvcmVfRE1TTywgc2NvcmVfZFRBRylcblxuXG4jIyMgUDEuIFVUIHZzIEFJRFxuc2NvcmUudGIkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eShzY29yZS50YiRzY29yZV9ETVNPLCBzY29yZS50YiRzY29yZV9kVEFHLCBuID0gMjAwKVxuc2NvcmUudGIgPC0gc2NvcmUudGIgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5wMSA8LSBnZ3Bsb3Qoc2NvcmUudGIsIGFlcyh4ID0gc2NvcmVfRE1TTywgeSA9IHNjb3JlX2RUQUcsIGNvbG9yID0gZGVuc2l0eSkpICtcbiAgZ2VvbV9wb2ludCgpICsgXG4gIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArXG4gIHhsaW0oLTAuNSwgMSkgKyB5bGltKC0wLjUsIDEpICtcbiAgY29vcmRfZml4ZWQoKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCwgY29sID0gXFxncmV5NTBcXCwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gLWRpZmZDdXRvZmYsIGNvbCA9IFxcZ3JleVxcLCBsaW5ldHlwZSA9IFxcZG90dGVkXFwpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBjb2wgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUocGFzdGUwKFxcQ29uc2Vuc3VzIGxvb3Agc2NvcmVcXCkpXG5cblxuIyBEZWZpbmUgdGhlIGRhdGFcbmNhdGVnb3JpZXMgPC0gYyhcXFVwXFwsIFxcTm9cXCwgXFxEb3duXFwpXG52YWx1ZXMgPC0gYygyMjgsIDkwODQsIDU3MTY5KVxuXG4jIENhbGN1bGF0ZSBwZXJjZW50YWdlc1xucGVyY2VudGFnZXMgPC0gcm91bmQoKHZhbHVlcyAvIHN1bSh2YWx1ZXMpKSAqIDEwMCwgMilcblxuIyBDb21iaW5lIHZhbHVlcyBhbmQgcGVyY2VudGFnZXMgZm9yIGxhYmVsc1xubGFiZWxzIDwtIHBhc3RlKGNhdGVnb3JpZXMsIFxcXFxuXFwsIHZhbHVlcywgXFxcXG4oXFwsIHBlcmNlbnRhZ2VzLCBcXCUpXFwsIHNlcCA9IFxcXFwpXG5cbmZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBcXHBpZWNoYXJ0X3VuaW9uTG9vcHNcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSgyKSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgyKSptbVRvSW5jaFxuc3ZnbGl0ZShwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSwgd2lkdGggPSB3aWR0aCwgaGVpZ2h0ID1oZWlnaHQpXG5waWUodmFsdWVzLCBcbiAgICBsYWJlbHMgPSBsYWJlbHMsIFxuICAgIGNvbCA9IGMoc3Ryb25nX3JlZCwgbm9fZ3JleSwgc3Ryb25nX2JsdWUpLCBcbiAgICBjZXggPSBmb250U2l6ZU0vMTIpXG5kZXYub2ZmKClcblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
commonLoopDir <- here(\../data/loop_analysis\)

diffCutoff <- 0.2

data <- fread(here(commonLoopDir, \loopScore_chromosight.tsv\))

score.tb <- data %>% dplyr::filter(Anno_simple %in% c(\S-S\)) %>%
  dplyr::select(id, score_DMSO, score_dTAG)


### P1. UT vs AID
score.tb$density <- get_density(score.tb$score_DMSO, score.tb$score_dTAG, n = 200)
score.tb <- score.tb %>% dplyr::arrange(density)
p1 <- ggplot(score.tb, aes(x = score_DMSO, y = score_dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\))


# Define the data
categories <- c(\Up\, \No\, \Down\)
values <- c(228, 9084, 57169)

# Calculate percentages
percentages <- round((values / sum(values)) * 100, 2)

# Combine values and percentages for labels
labels <- paste(categories, \\n\, values, \\n(\, percentages, \%)\, sep = \\)

fileName <- here(figDir, \piechart_unionLoops\)
width <- panelSize(2)*mmToInch
height <- panelSize(2)*mmToInch
svglite(paste0(fileName, \.svg\), width = width, height =height)
pie(values, 
    labels = labels, 
    col = c(strong_red, no_grey, strong_blue), 
    cex = fontSizeM/12)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVkyOXRiVzl1VEc5dmNFUnBjaUE4TFNCb1pYSmxLRnhjTGk0dlpHRjBZUzlzYjI5d1gyRnVZV3g1YzJselhGd3BYRzVjYm1ScFptWkRkWFJ2Wm1ZZ1BDMGdNQzR5WEc1Y2JtUmhkR0VnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjF0YjI1TWIyOXdSR2x5TENCY1hHeHZiM0JUWTI5eVpWOWphSEp2Ylc5emFXZG9kQzUwYzNaY1hDa3BYRzVjYm5OamIzSmxMblJpSUR3dElHUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvUVc1dWIxOXphVzF3YkdVZ0pXbHVKU0JqS0Z4Y1V5MVRYRndwS1NBbFBpVmNiaUFnWkhCc2VYSTZPbk5sYkdWamRDaHBaQ3dnYzJOdmNtVmZSRTFUVHl3Z2MyTnZjbVZmWkZSQlJ5bGNibHh1WEc0akl5TWdVREV1SUZWVUlIWnpJRUZKUkZ4dWMyTnZjbVV1ZEdJa1pHVnVjMmwwZVNBOExTQm5aWFJmWkdWdWMybDBlU2h6WTI5eVpTNTBZaVJ6WTI5eVpWOUVUVk5QTENCelkyOXlaUzUwWWlSelkyOXlaVjlrVkVGSExDQnVJRDBnTWpBd0tWeHVjMk52Y21VdWRHSWdQQzBnYzJOdmNtVXVkR0lnSlQ0bElHUndiSGx5T2pwaGNuSmhibWRsS0dSbGJuTnBkSGtwWEc1d01TQThMU0JuWjNCc2IzUW9jMk52Y21VdWRHSXNJR0ZsY3loNElEMGdjMk52Y21WZlJFMVRUeXdnZVNBOUlITmpiM0psWDJSVVFVY3NJR052Ykc5eUlEMGdaR1Z1YzJsMGVTa3BJQ3RjYmlBZ1oyVnZiVjl3YjJsdWRDZ3BJQ3NnWEc0Z0lITmpZV3hsWDJOdmJHOXlYM1pwY21sa2FYTW9LU0FyWEc0Z0lIaHNhVzBvTFRBdU5Td2dNU2tnS3lCNWJHbHRLQzB3TGpVc0lERXBJQ3RjYmlBZ1kyOXZjbVJmWm1sNFpXUW9LU0FyWEc0Z0lHZGxiMjFmWVdKc2FXNWxLSE5zYjNCbElEMGdNU3dnYVc1MFpYSmpaWEIwSUQwZ01Dd2dZMjlzSUQwZ1hGeG5jbVY1TlRCY1hDd2diR2x1WlhSNWNHVWdQU0JjWEdSaGMyaGxaRnhjS1NBclhHNGdJR2RsYjIxZmFHeHBibVVvZVdsdWRHVnlZMlZ3ZENBOUlEQXNJR0ZzY0doaElEMGdNQzQxTENCamIyeHZjaUE5SUZ4Y1ozSmxlVnhjS1NBclhHNGdJR2RsYjIxZmRteHBibVVvZUdsdWRHVnlZMlZ3ZENBOUlEQXNJR0ZzY0doaElEMGdNQzQxTENCamIyeHZjaUE5SUZ4Y1ozSmxlVnhjS1NBclhHNGdJR2RsYjIxZllXSnNhVzVsS0hOc2IzQmxJRDBnTVN3Z2FXNTBaWEpqWlhCMElEMGdMV1JwWm1aRGRYUnZabVlzSUdOdmJDQTlJRnhjWjNKbGVWeGNMQ0JzYVc1bGRIbHdaU0E5SUZ4Y1pHOTBkR1ZrWEZ3cElDdGNiaUFnWjJWdmJWOWhZbXhwYm1Vb2MyeHZjR1VnUFNBeExDQnBiblJsY21ObGNIUWdQU0JrYVdabVEzVjBiMlptTENCamIyd2dQU0JjWEdkeVpYbGNYQ3dnYkdsdVpYUjVjR1VnUFNCY1hHUnZkSFJsWkZ4Y0tTQXJYRzRnSUhSb1pXMWxYMk5zWVhOemFXTW9LU0FySUdkbmRHbDBiR1VvY0dGemRHVXdLRnhjUTI5dWMyVnVjM1Z6SUd4dmIzQWdjMk52Y21WY1hDa3BYRzVjYmx4dUl5QkVaV1pwYm1VZ2RHaGxJR1JoZEdGY2JtTmhkR1ZuYjNKcFpYTWdQQzBnWXloY1hGVndYRndzSUZ4Y1RtOWNYQ3dnWEZ4RWIzZHVYRndwWEc1MllXeDFaWE1nUEMwZ1l5Z3lNamdzSURrd09EUXNJRFUzTVRZNUtWeHVYRzRqSUVOaGJHTjFiR0YwWlNCd1pYSmpaVzUwWVdkbGMxeHVjR1Z5WTJWdWRHRm5aWE1nUEMwZ2NtOTFibVFvS0haaGJIVmxjeUF2SUhOMWJTaDJZV3gxWlhNcEtTQXFJREV3TUN3Z01pbGNibHh1SXlCRGIyMWlhVzVsSUhaaGJIVmxjeUJoYm1RZ2NHVnlZMlZ1ZEdGblpYTWdabTl5SUd4aFltVnNjMXh1YkdGaVpXeHpJRHd0SUhCaGMzUmxLR05oZEdWbmIzSnBaWE1zSUZ4Y1hGeHVYRndzSUhaaGJIVmxjeXdnWEZ4Y1hHNG9YRndzSUhCbGNtTmxiblJoWjJWekxDQmNYQ1VwWEZ3c0lITmxjQ0E5SUZ4Y1hGd3BYRzVjYm1acGJHVk9ZVzFsSUR3dElHaGxjbVVvWm1sblJHbHlMQ0JjWEhCcFpXTm9ZWEowWDNWdWFXOXVURzl2Y0hOY1hDbGNibmRwWkhSb0lEd3RJSEJoYm1Wc1UybDZaU2d5S1NwdGJWUnZTVzVqYUZ4dWFHVnBaMmgwSUR3dElIQmhibVZzVTJsNlpTZ3lLU3B0YlZSdlNXNWphRnh1YzNabmJHbDBaU2h3WVhOMFpUQW9abWxzWlU1aGJXVXNJRnhjTG5OMloxeGNLU3dnZDJsa2RHZ2dQU0IzYVdSMGFDd2dhR1ZwWjJoMElEMW9aV2xuYUhRcFhHNXdhV1VvZG1Gc2RXVnpMQ0JjYmlBZ0lDQnNZV0psYkhNZ1BTQnNZV0psYkhNc0lGeHVJQ0FnSUdOdmJDQTlJR01vYzNSeWIyNW5YM0psWkN3Z2JtOWZaM0psZVN3Z2MzUnliMjVuWDJKc2RXVXBMQ0JjYmlBZ0lDQmpaWGdnUFNCbWIyNTBVMmw2WlUwdk1USXBYRzVrWlhZdWIyWm1LQ2xjYmx4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbmNvbW1vbkxvb3BEaXIgPC0gaGVyZShcXC4uL2RhdGEvbG9vcF9hbmFseXNpc1xcKVxuXG5kaWZmQ3V0b2ZmIDwtIDAuMlxuXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29tbW9uTG9vcERpciwgXFxsb29wU2NvcmVfY2hyb21vc2lnaHQudHN2XFwpKVxuXG5zY29yZS50YiA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEFubm9fc2ltcGxlICVpbiUgYyhcXFMtU1xcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIHNjb3JlX0RNU08sIHNjb3JlX2RUQUcpXG5cblxuIyMjIFAxLiBVVCB2cyBBSURcbnNjb3JlLnRiJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkoc2NvcmUudGIkc2NvcmVfRE1TTywgc2NvcmUudGIkc2NvcmVfZFRBRywgbiA9IDIwMClcbnNjb3JlLnRiIDwtIHNjb3JlLnRiICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxucDEgPC0gZ2dwbG90KHNjb3JlLnRiLCBhZXMoeCA9IHNjb3JlX0RNU08sIHkgPSBzY29yZV9kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArXG4gIGdlb21fcG9pbnQoKSArIFxuICBzY2FsZV9jb2xvcl92aXJpZGlzKCkgK1xuICB4bGltKC0wLjUsIDEpICsgeWxpbSgtMC41LCAxKSArXG4gIGNvb3JkX2ZpeGVkKCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDAsIGNvbCA9IFxcZ3JleTUwXFwsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IC1kaWZmQ3V0b2ZmLCBjb2wgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgY29sID0gXFxncmV5XFwsIGxpbmV0eXBlID0gXFxkb3R0ZWRcXCkgK1xuICB0aGVtZV9jbGFzc2ljKCkgKyBnZ3RpdGxlKHBhc3RlMChcXENvbnNlbnN1cyBsb29wIHNjb3JlXFwpKVxuXG5cbiMgRGVmaW5lIHRoZSBkYXRhXG5jYXRlZ29yaWVzIDwtIGMoXFxVcFxcLCBcXE5vXFwsIFxcRG93blxcKVxudmFsdWVzIDwtIGMoMjI4LCA5MDg0LCA1NzE2OSlcblxuIyBDYWxjdWxhdGUgcGVyY2VudGFnZXNcbnBlcmNlbnRhZ2VzIDwtIHJvdW5kKCh2YWx1ZXMgLyBzdW0odmFsdWVzKSkgKiAxMDAsIDIpXG5cbiMgQ29tYmluZSB2YWx1ZXMgYW5kIHBlcmNlbnRhZ2VzIGZvciBsYWJlbHNcbmxhYmVscyA8LSBwYXN0ZShjYXRlZ29yaWVzLCBcXFxcblxcLCB2YWx1ZXMsIFxcXFxuKFxcLCBwZXJjZW50YWdlcywgXFwlKVxcLCBzZXAgPSBcXFxcKVxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgXFxwaWVjaGFydF91bmlvbkxvb3BzXFwpXG53aWR0aCA8LSBwYW5lbFNpemUoMikqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMikqbW1Ub0luY2hcbnN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksIHdpZHRoID0gd2lkdGgsIGhlaWdodCA9aGVpZ2h0KVxucGllKHZhbHVlcywgXG4gICAgbGFiZWxzID0gbGFiZWxzLCBcbiAgICBjb2wgPSBjKHN0cm9uZ19yZWQsIG5vX2dyZXksIHN0cm9uZ19ibHVlKSwgXG4gICAgY2V4ID0gZm9udFNpemVNLzEyKVxuZGV2Lm9mZigpXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5cbmRpZmZDdXRvZmYgPC0gMC4yXG5cbmRhdGEgPC0gZnJlYWQoaGVyZShjb21tb25Mb29wRGlyLCBcXGxvb3BTY29yZV9jaHJvbW9zaWdodC50c3ZcXCkpXG5cbnNjb3JlLnRiIDwtIGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ub19zaW1wbGUgJWluJSBjKFxcUy1TXFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChpZCwgc2NvcmVfRE1TTywgc2NvcmVfZFRBRylcblxuXG4jIyMgUDEuIFVUIHZzIEFJRFxuc2NvcmUudGIkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eShzY29yZS50YiRzY29yZV9ETVNPLCBzY29yZS50YiRzY29yZV9kVEFHLCBuID0gMjAwKVxuc2NvcmUudGIgPC0gc2NvcmUudGIgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5wMSA8LSBnZ3Bsb3Qoc2NvcmUudGIsIGFlcyh4ID0gc2NvcmVfRE1TTywgeSA9IHNjb3JlX2RUQUcsIGNvbG9yID0gZGVuc2l0eSkpICtcbiAgZ2VvbV9wb2ludCgpICsgXG4gIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArXG4gIHhsaW0oLTAuNSwgMSkgKyB5bGltKC0wLjUsIDEpICtcbiAgY29vcmRfZml4ZWQoKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCwgY29sID0gXFxncmV5NTBcXCwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gLWRpZmZDdXRvZmYsIGNvbCA9IFxcZ3JleVxcLCBsaW5ldHlwZSA9IFxcZG90dGVkXFwpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBjb2wgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUocGFzdGUwKFxcQ29uc2Vuc3VzIGxvb3Agc2NvcmVcXCkpXG5cblxuIyBEZWZpbmUgdGhlIGRhdGFcbmNhdGVnb3JpZXMgPC0gYyhcXFVwXFwsIFxcTm9cXCwgXFxEb3duXFwpXG52YWx1ZXMgPC0gYygyMjgsIDkwODQsIDU3MTY5KVxuXG4jIENhbGN1bGF0ZSBwZXJjZW50YWdlc1xucGVyY2VudGFnZXMgPC0gcm91bmQoKHZhbHVlcyAvIHN1bSh2YWx1ZXMpKSAqIDEwMCwgMilcblxuIyBDb21iaW5lIHZhbHVlcyBhbmQgcGVyY2VudGFnZXMgZm9yIGxhYmVsc1xubGFiZWxzIDwtIHBhc3RlKGNhdGVnb3JpZXMsIFxcXFxuXFwsIHZhbHVlcywgXFxcXG4oXFwsIHBlcmNlbnRhZ2VzLCBcXCUpXFwsIHNlcCA9IFxcXFwpXG5cbmZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBcXHBpZWNoYXJ0X3VuaW9uTG9vcHNcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSgyKSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgyKSptbVRvSW5jaFxuc3ZnbGl0ZShwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSwgd2lkdGggPSB3aWR0aCwgaGVpZ2h0ID1oZWlnaHQpXG5waWUodmFsdWVzLCBcbiAgICBsYWJlbHMgPSBsYWJlbHMsIFxuICAgIGNvbCA9IGMoc3Ryb25nX3JlZCwgbm9fZ3JleSwgc3Ryb25nX2JsdWUpLCBcbiAgICBjZXggPSBmb250U2l6ZU0vMTIpXG5kZXYub2ZmKClcblxuYGBgXG5gYGAifQ== -->

```r
```r
commonLoopDir <- here(\../data/loop_analysis\)

diffCutoff <- 0.2

data <- fread(here(commonLoopDir, \loopScore_chromosight.tsv\))

score.tb <- data %>% dplyr::filter(Anno_simple %in% c(\S-S\)) %>%
  dplyr::select(id, score_DMSO, score_dTAG)


### P1. UT vs AID
score.tb$density <- get_density(score.tb$score_DMSO, score.tb$score_dTAG, n = 200)
score.tb <- score.tb %>% dplyr::arrange(density)
p1 <- ggplot(score.tb, aes(x = score_DMSO, y = score_dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\))


# Define the data
categories <- c(\Up\, \No\, \Down\)
values <- c(228, 9084, 57169)

# Calculate percentages
percentages <- round((values / sum(values)) * 100, 2)

# Combine values and percentages for labels
labels <- paste(categories, \\n\, values, \\n(\, percentages, \%)\, sep = \\)

fileName <- here(figDir, \piechart_unionLoops\)
width <- panelSize(2)*mmToInch
height <- panelSize(2)*mmToInch
svglite(paste0(fileName, \.svg\), width = width, height =height)
pie(values, 
    labels = labels, 
    col = c(strong_red, no_grey, strong_blue), 
    cex = fontSizeM/12)
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZMjl0Ylc5dVRHOXZjRVJwY2lBOExTQm9aWEpsS0Z3aUxpNHZaR0YwWVM5c2IyOXdYMkZ1WVd4NWMybHpYQ0lwWEc1Y2JtUnBabVpEZFhSdlptWWdQQzBnTUM0eVhHNWNibVJoZEdFZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjIxdGIyNU1iMjl3UkdseUxDQmNJbXh2YjNCVFkyOXlaVjlqYUhKdmJXOXphV2RvZEM1MGMzWmNJaWtwWEc1Y2JuTmpiM0psTG5SaUlEd3RJR1JoZEdFZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1FXNXViMTl6YVcxd2JHVWdKV2x1SlNCaktGd2lVQzFRWENJc0lGd2lVQzFGWENJc0lGd2lSUzFGWENJcEtTQWxQaVZjYmlBZ1pIQnNlWEk2T25ObGJHVmpkQ2hwWkN3Z2IyOWxYMFJOVTA4c0lHOXZaVjlrVkVGSEtTQWxQaVZjYmlBZ1pIQnNlWEk2T21acGJIUmxjaWdoYVhNdWJtRW9iMjlsWDBSTlUwOHBMQ0FoYVhNdWJtRW9iMjlsWDJSVVFVY3BLVnh1WEc1Y2JpTWpJeUJRTVM0Z1ZWUWdkbk1nUVVsRVhHNXpZMjl5WlM1MFlpUmtaVzV6YVhSNUlEd3RJR2RsZEY5a1pXNXphWFI1S0hOamIzSmxMblJpSkc5dlpWOUVUVk5QTENCelkyOXlaUzUwWWlSdmIyVmZaRlJCUnl3Z2JpQTlJREl3TUNsY2JuTmpiM0psTG5SaUlEd3RJSE5qYjNKbExuUmlJQ1UrSlNCa2NHeDVjam82WVhKeVlXNW5aU2hrWlc1emFYUjVLVnh1Y0RFZ1BDMGdaMmR3Ykc5MEtITmpiM0psTG5SaUxDQmhaWE1vZUNBOUlHOXZaVjlFVFZOUExDQjVJRDBnYjI5bFgyUlVRVWNzSUdOdmJHOXlJRDBnWkdWdWMybDBlU2twSUN0Y2JpQWdaMlZ2YlY5d2IybHVkQ2dwSUNzZ1hHNGdJSE5qWVd4bFgyTnZiRzl5WDNacGNtbGthWE1vS1NBclhHNGdJR052YjNKa1gyWnBlR1ZrS0NrZ0sxeHVJQ0FnSUhoc2FXMG9MVEF1TlN3Z05Ta2dLeUI1YkdsdEtDMHdMalVzSURVcElDdGNibHh1SUNCblpXOXRYMkZpYkdsdVpTaHpiRzl3WlNBOUlERXNJR2x1ZEdWeVkyVndkQ0E5SURBc0lHTnZiQ0E5SUZ3aVozSmxlVFV3WENJc0lHeHBibVYwZVhCbElEMGdYQ0prWVhOb1pXUmNJaWtnSzF4dUlDQm5aVzl0WDJoc2FXNWxLSGxwYm5SbGNtTmxjSFFnUFNBd0xDQmhiSEJvWVNBOUlEQXVOU3dnWTI5c2IzSWdQU0JjSW1keVpYbGNJaWtnSzF4dUlDQm5aVzl0WDNac2FXNWxLSGhwYm5SbGNtTmxjSFFnUFNBd0xDQmhiSEJvWVNBOUlEQXVOU3dnWTI5c2IzSWdQU0JjSW1keVpYbGNJaWtnSzF4dUlDQm5aVzl0WDJGaWJHbHVaU2h6Ykc5d1pTQTlJREVzSUdsdWRHVnlZMlZ3ZENBOUlDMWthV1ptUTNWMGIyWm1MQ0JqYjJ3Z1BTQmNJbWR5WlhsY0lpd2diR2x1WlhSNWNHVWdQU0JjSW1SdmRIUmxaRndpS1NBclhHNGdJR2RsYjIxZllXSnNhVzVsS0hOc2IzQmxJRDBnTVN3Z2FXNTBaWEpqWlhCMElEMGdaR2xtWmtOMWRHOW1aaXdnWTI5c0lEMGdYQ0puY21WNVhDSXNJR3hwYm1WMGVYQmxJRDBnWENKa2IzUjBaV1JjSWlrZ0sxeHVJQ0IwYUdWdFpWOWpiR0Z6YzJsaktDa2dLeUJuWjNScGRHeGxLSEJoYzNSbE1DaGNJa052Ym5ObGJuTjFjeUJzYjI5d0lITmpiM0psWENJcEtWeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5cbmRpZmZDdXRvZmYgPC0gMC4yXG5cbmRhdGEgPC0gZnJlYWQoaGVyZShjb21tb25Mb29wRGlyLCBcXGxvb3BTY29yZV9jaHJvbW9zaWdodC50c3ZcXCkpXG5cbnNjb3JlLnRiIDwtIGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ub19zaW1wbGUgJWluJSBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChpZCwgb29lX0RNU08sIG9vZV9kVEFHKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEob29lX0RNU08pLCAhaXMubmEob29lX2RUQUcpKVxuXG5cbiMjIyBQMS4gVVQgdnMgQUlEXG5zY29yZS50YiRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHNjb3JlLnRiJG9vZV9ETVNPLCBzY29yZS50YiRvb2VfZFRBRywgbiA9IDIwMClcbnNjb3JlLnRiIDwtIHNjb3JlLnRiICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxucDEgPC0gZ2dwbG90KHNjb3JlLnRiLCBhZXMoeCA9IG9vZV9ETVNPLCB5ID0gb29lX2RUQUcsIGNvbG9yID0gZGVuc2l0eSkpICtcbiAgZ2VvbV9wb2ludCgpICsgXG4gIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArXG4gIGNvb3JkX2ZpeGVkKCkgK1xuICAgIHhsaW0oLTAuNSwgNSkgKyB5bGltKC0wLjUsIDUpICtcblxuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDAsIGNvbCA9IFxcZ3JleTUwXFwsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IC1kaWZmQ3V0b2ZmLCBjb2wgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgY29sID0gXFxncmV5XFwsIGxpbmV0eXBlID0gXFxkb3R0ZWRcXCkgK1xuICB0aGVtZV9jbGFzc2ljKCkgKyBnZ3RpdGxlKHBhc3RlMChcXENvbnNlbnN1cyBsb29wIHNjb3JlXFwpKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
commonLoopDir <- here(\../data/loop_analysis\)

diffCutoff <- 0.2

data <- fread(here(commonLoopDir, \loopScore_chromosight.tsv\))

score.tb <- data %>% dplyr::filter(Anno_simple %in% c(\P-P\, \P-E\, \E-E\)) %>%
  dplyr::select(id, ooe_DMSO, ooe_dTAG) %>%
  dplyr::filter(!is.na(ooe_DMSO), !is.na(ooe_dTAG))


### P1. UT vs AID
score.tb$density <- get_density(score.tb$ooe_DMSO, score.tb$ooe_dTAG, n = 200)
score.tb <- score.tb %>% dplyr::arrange(density)
p1 <- ggplot(score.tb, aes(x = ooe_DMSO, y = ooe_dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  coord_fixed() +
    xlim(-0.5, 5) + ylim(-0.5, 5) +

  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\))



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVkyOXRiVzl1VEc5dmNFUnBjaUE4TFNCb1pYSmxLRnhjTGk0dlpHRjBZUzlzYjI5d1gyRnVZV3g1YzJselhGd3BYRzVjYm1ScFptWkRkWFJ2Wm1ZZ1BDMGdNQzR5WEc1Y2JtUmhkR0VnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjF0YjI1TWIyOXdSR2x5TENCY1hHeHZiM0JUWTI5eVpWOWphSEp2Ylc5emFXZG9kQzUwYzNaY1hDa3BYRzVjYm5OamIzSmxMblJpSUR3dElHUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvUVc1dWIxOXphVzF3YkdVZ0pXbHVKU0JqS0Z4Y1VDMVFYRndzSUZ4Y1VDMUZYRndzSUZ4Y1JTMUZYRndwS1NBbFBpVmNiaUFnWkhCc2VYSTZPbk5sYkdWamRDaHBaQ3dnYjI5bFgwUk5VMDhzSUc5dlpWOWtWRUZIS1NBbFBpVmNiaUFnWkhCc2VYSTZPbVpwYkhSbGNpZ2hhWE11Ym1Fb2IyOWxYMFJOVTA4cExDQWhhWE11Ym1Fb2IyOWxYMlJVUVVjcEtWeHVYRzVjYmlNakl5QlFNUzRnVlZRZ2RuTWdRVWxFWEc1elkyOXlaUzUwWWlSa1pXNXphWFI1SUR3dElHZGxkRjlrWlc1emFYUjVLSE5qYjNKbExuUmlKRzl2WlY5RVRWTlBMQ0J6WTI5eVpTNTBZaVJ2YjJWZlpGUkJSeXdnYmlBOUlESXdNQ2xjYm5OamIzSmxMblJpSUR3dElITmpiM0psTG5SaUlDVStKU0JrY0d4NWNqbzZZWEp5WVc1blpTaGtaVzV6YVhSNUtWeHVjREVnUEMwZ1oyZHdiRzkwS0hOamIzSmxMblJpTENCaFpYTW9lQ0E5SUc5dlpWOUVUVk5QTENCNUlEMGdiMjlsWDJSVVFVY3NJR052Ykc5eUlEMGdaR1Z1YzJsMGVTa3BJQ3RjYmlBZ1oyVnZiVjl3YjJsdWRDZ3BJQ3NnWEc0Z0lITmpZV3hsWDJOdmJHOXlYM1pwY21sa2FYTW9LU0FyWEc0Z0lHTnZiM0prWDJacGVHVmtLQ2tnSzF4dUlDQWdJSGhzYVcwb0xUQXVOU3dnTlNrZ0t5QjViR2x0S0Mwd0xqVXNJRFVwSUN0Y2JseHVJQ0JuWlc5dFgyRmliR2x1WlNoemJHOXdaU0E5SURFc0lHbHVkR1Z5WTJWd2RDQTlJREFzSUdOdmJDQTlJRnhjWjNKbGVUVXdYRndzSUd4cGJtVjBlWEJsSUQwZ1hGeGtZWE5vWldSY1hDa2dLMXh1SUNCblpXOXRYMmhzYVc1bEtIbHBiblJsY21ObGNIUWdQU0F3TENCaGJIQm9ZU0E5SURBdU5Td2dZMjlzYjNJZ1BTQmNYR2R5WlhsY1hDa2dLMXh1SUNCblpXOXRYM1pzYVc1bEtIaHBiblJsY21ObGNIUWdQU0F3TENCaGJIQm9ZU0E5SURBdU5Td2dZMjlzYjNJZ1BTQmNYR2R5WlhsY1hDa2dLMXh1SUNCblpXOXRYMkZpYkdsdVpTaHpiRzl3WlNBOUlERXNJR2x1ZEdWeVkyVndkQ0E5SUMxa2FXWm1RM1YwYjJabUxDQmpiMndnUFNCY1hHZHlaWGxjWEN3Z2JHbHVaWFI1Y0dVZ1BTQmNYR1J2ZEhSbFpGeGNLU0FyWEc0Z0lHZGxiMjFmWVdKc2FXNWxLSE5zYjNCbElEMGdNU3dnYVc1MFpYSmpaWEIwSUQwZ1pHbG1aa04xZEc5bVppd2dZMjlzSUQwZ1hGeG5jbVY1WEZ3c0lHeHBibVYwZVhCbElEMGdYRnhrYjNSMFpXUmNYQ2tnSzF4dUlDQjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0t5Qm5aM1JwZEd4bEtIQmhjM1JsTUNoY1hFTnZibk5sYm5OMWN5QnNiMjl3SUhOamIzSmxYRndwS1Z4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbmNvbW1vbkxvb3BEaXIgPC0gaGVyZShcXC4uL2RhdGEvbG9vcF9hbmFseXNpc1xcKVxuXG5kaWZmQ3V0b2ZmIDwtIDAuMlxuXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29tbW9uTG9vcERpciwgXFxsb29wU2NvcmVfY2hyb21vc2lnaHQudHN2XFwpKVxuXG5zY29yZS50YiA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEFubm9fc2ltcGxlICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9vZV9ETVNPLCBvb2VfZFRBRykgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKG9vZV9ETVNPKSwgIWlzLm5hKG9vZV9kVEFHKSlcblxuXG4jIyMgUDEuIFVUIHZzIEFJRFxuc2NvcmUudGIkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eShzY29yZS50YiRvb2VfRE1TTywgc2NvcmUudGIkb29lX2RUQUcsIG4gPSAyMDApXG5zY29yZS50YiA8LSBzY29yZS50YiAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbnAxIDwtIGdncGxvdChzY29yZS50YiwgYWVzKHggPSBvb2VfRE1TTywgeSA9IG9vZV9kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArXG4gIGdlb21fcG9pbnQoKSArIFxuICBzY2FsZV9jb2xvcl92aXJpZGlzKCkgK1xuICBjb29yZF9maXhlZCgpICtcbiAgICB4bGltKC0wLjUsIDUpICsgeWxpbSgtMC41LCA1KSArXG5cbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwLCBjb2wgPSBcXGdyZXk1MFxcLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCwgYWxwaGEgPSAwLjUsIGNvbG9yID0gXFxncmV5XFwpICtcbiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gMCwgYWxwaGEgPSAwLjUsIGNvbG9yID0gXFxncmV5XFwpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAtZGlmZkN1dG9mZiwgY29sID0gXFxncmV5XFwsIGxpbmV0eXBlID0gXFxkb3R0ZWRcXCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IGRpZmZDdXRvZmYsIGNvbCA9IFxcZ3JleVxcLCBsaW5ldHlwZSA9IFxcZG90dGVkXFwpICtcbiAgdGhlbWVfY2xhc3NpYygpICsgZ2d0aXRsZShwYXN0ZTAoXFxDb25zZW5zdXMgbG9vcCBzY29yZVxcKSlcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuY29tbW9uTG9vcERpciA8LSBoZXJlKFxcLi4vZGF0YS9sb29wX2FuYWx5c2lzXFwpXG5cbmRpZmZDdXRvZmYgPC0gMC4yXG5cbmRhdGEgPC0gZnJlYWQoaGVyZShjb21tb25Mb29wRGlyLCBcXGxvb3BTY29yZV9jaHJvbW9zaWdodC50c3ZcXCkpXG5cbnNjb3JlLnRiIDwtIGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ub19zaW1wbGUgJWluJSBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChpZCwgb29lX0RNU08sIG9vZV9kVEFHKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEob29lX0RNU08pLCAhaXMubmEob29lX2RUQUcpKVxuXG5cbiMjIyBQMS4gVVQgdnMgQUlEXG5zY29yZS50YiRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHNjb3JlLnRiJG9vZV9ETVNPLCBzY29yZS50YiRvb2VfZFRBRywgbiA9IDIwMClcbnNjb3JlLnRiIDwtIHNjb3JlLnRiICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxucDEgPC0gZ2dwbG90KHNjb3JlLnRiLCBhZXMoeCA9IG9vZV9ETVNPLCB5ID0gb29lX2RUQUcsIGNvbG9yID0gZGVuc2l0eSkpICtcbiAgZ2VvbV9wb2ludCgpICsgXG4gIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArXG4gIGNvb3JkX2ZpeGVkKCkgK1xuICAgIHhsaW0oLTAuNSwgNSkgKyB5bGltKC0wLjUsIDUpICtcblxuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDAsIGNvbCA9IFxcZ3JleTUwXFwsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IC1kaWZmQ3V0b2ZmLCBjb2wgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgY29sID0gXFxncmV5XFwsIGxpbmV0eXBlID0gXFxkb3R0ZWRcXCkgK1xuICB0aGVtZV9jbGFzc2ljKCkgKyBnZ3RpdGxlKHBhc3RlMChcXENvbnNlbnN1cyBsb29wIHNjb3JlXFwpKVxuYGBgXG5gYGAifQ== -->

```r
```r
commonLoopDir <- here(\../data/loop_analysis\)

diffCutoff <- 0.2

data <- fread(here(commonLoopDir, \loopScore_chromosight.tsv\))

score.tb <- data %>% dplyr::filter(Anno_simple %in% c(\P-P\, \P-E\, \E-E\)) %>%
  dplyr::select(id, ooe_DMSO, ooe_dTAG) %>%
  dplyr::filter(!is.na(ooe_DMSO), !is.na(ooe_dTAG))


### P1. UT vs AID
score.tb$density <- get_density(score.tb$ooe_DMSO, score.tb$ooe_dTAG, n = 200)
score.tb <- score.tb %>% dplyr::arrange(density)
p1 <- ggplot(score.tb, aes(x = ooe_DMSO, y = ooe_dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  coord_fixed() +
    xlim(-0.5, 5) + ylim(-0.5, 5) +

  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\))
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

--------------------------------------------------------------------------------
# ARCHIVE


<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHViR2xpY21GeWVTaGtjR3g1Y2lsY2JteHBZbkpoY25rb1oyZHdiRzkwTWlsY2JteHBZbkpoY25rb2RtbHlhV1JwY3lsY2JteHBZbkpoY25rb2NIVnljbklwWEc1Y2JpTWdlVzkxY2lCa1pXNXphWFI1SUdadVhHNW5aWFJmWkdWdWMybDBlU0E4TFNCbWRXNWpkR2x2YmloNExDQjVMQ0J1SUQwZ01UQXdLU0I3WEc0Z0lDTWc0b0NtSUhkb1lYUmxkbVZ5SUhsdmRTQmhiSEpsWVdSNUlHaGhkbVVnNG9DbVhHNTlYRzVjYmlNZ01Ta2diV0ZyWlNCaElHZGxibVZ5WVd3Z2NHeHZkSFJwYm1jZ1puVnVZM1JwYjI1Y2JuQnNiM1JmWTI5dGNHRnlaU0E4TFNCbWRXNWpkR2x2Ymloa1ppd2dlRjlqYjJ3c0lIbGZZMjlzTENCa2FXWm1RM1YwYjJabUlEMGdNQzR4TENCc2FXMGdQU0JqS0Mwd0xqVXNJREVwS1NCN1hHNGdJR1JtTWlBOExTQmtaaUFsUGlWY2JpQWdJQ0J6Wld4bFkzUW9ZV3hzWDI5bUtHTW9lRjlqYjJ3c0lIbGZZMjlzS1NrcElDVStKVnh1SUNBZ0lISmxibUZ0WlNoNElEMGdJU0Z6ZVcwb2VGOWpiMndwTENCNUlEMGdJU0Z6ZVcwb2VWOWpiMndwS1NBbFBpVmNiaUFnSUNCdGRYUmhkR1VvWkdWdWMybDBlU0E5SUdkbGRGOWtaVzV6YVhSNUtIZ3NJSGtzSUc0Z1BTQXhNREFwS1NBbFBpVmNiaUFnSUNCaGNuSmhibWRsS0dSbGJuTnBkSGtwWEc1Y2JpQWdaMmR3Ykc5MEtHUm1NaXdnWVdWektIZ2dQU0I0TENCNUlEMGdlU3dnWTI5c2IzSWdQU0JrWlc1emFYUjVLU2tnSzF4dUlDQWdJR2RsYjIxZmNHOXBiblFvS1NBclhHNGdJQ0FnYzJOaGJHVmZZMjlzYjNKZmRtbHlhV1JwY3lncElDdGNiaUFnSUNCNGJHbHRLR3hwYlNrZ0t5QjViR2x0S0d4cGJTa2dLMXh1SUNBZ0lHTnZiM0prWDJacGVHVmtLQ2tnSzF4dUlDQWdJR2RsYjIxZllXSnNhVzVsS0hOc2IzQmxJRDBnTVN3Z2FXNTBaWEpqWlhCMElEMGdNQ3dnWTI5c2IzSWdQU0JjSW1keVpYazFNRndpTENCc2FXNWxkSGx3WlNBOUlGd2laR0Z6YUdWa1hDSXBJQ3RjYmlBZ0lDQm5aVzl0WDJoc2FXNWxLSGxwYm5SbGNtTmxjSFFnUFNBd0xDQmhiSEJvWVNBOUlEQXVOU3dnWTI5c2IzSWdQU0JjSW1keVpYbGNJaWtnSzF4dUlDQWdJR2RsYjIxZmRteHBibVVvZUdsdWRHVnlZMlZ3ZENBOUlEQXNJR0ZzY0doaElEMGdNQzQxTENCamIyeHZjaUE5SUZ3aVozSmxlVndpS1NBclhHNGdJQ0FnWjJWdmJWOWhZbXhwYm1Vb2MyeHZjR1VnUFNBeExDQnBiblJsY21ObGNIUWdQU0F0WkdsbVprTjFkRzltWml3Z1kyOXNiM0lnUFNCY0ltZHlaWGxjSWl3Z2JHbHVaWFI1Y0dVZ1BTQmNJbVJ2ZEhSbFpGd2lLU0FyWEc0Z0lDQWdaMlZ2YlY5aFlteHBibVVvYzJ4dmNHVWdQU0F4TENCcGJuUmxjbU5sY0hRZ1BTQWdaR2xtWmtOMWRHOW1aaXdnWTI5c2IzSWdQU0JjSW1keVpYbGNJaXdnYkdsdVpYUjVjR1VnUFNCY0ltUnZkSFJsWkZ3aUtTQXJYRzRnSUNBZ2RHaGxiV1ZmWTJ4aGMzTnBZeWdwSUN0Y2JpQWdJQ0JuWjNScGRHeGxLSEJoYzNSbEtIaGZZMjlzTENCY0luWnpYQ0lzSUhsZlkyOXNLU2xjYm4xY2JseHVJeUF5S1NCa1pXWnBibVVnZEdobElIQmhhWEp6SUhsdmRTQmpZWEpsSUdGaWIzVjBYRzV3WVdseWN5QThMU0JzYVhOMEtGeHVJQ0JFVFZOUFgzWnpYMlJVUVVjZ1BTQmpLRndpYzJOdmNtVmZSRTFUVDF3aUxDQmNJbk5qYjNKbFgyUlVRVWRjSWlrc1hHNGdJRlZVWDNaelgwRkpSQ0FnSUNBZ1BTQmpLRndpYzJOdmNtVmZWVlJjSWl3Z0lDQmNJbk5qYjNKbFgwRkpSRndpS1Z4dUlDQWpJT0tBcGlCaFpHUWdiVzl5WlNEaWdLWmNiaWxjYmx4dUl5QXpLU0JpZFdsc1pDQmhJRzVoYldWa0lHeHBjM1FnYjJZZ1oyZHdiRzkwYzF4dWNHeHZkSE1nUEMwZ2JXRndLSEJoYVhKekxDQitJSEJzYjNSZlkyOXRjR0Z5WlNoa1lYUmhMQ0F1ZUZzeFhTd2dMbmhiTWwwc0lHUnBabVpEZFhSdlptWWdQU0JrYVdabVEzVjBiMlptS1NsY2JseHVJeUJ1YjNjZ2VXOTFJR05oYmlCd2NtbHVkQ0IwYUdWdElHRnNiRHBjYm5kaGJHc29jR3h2ZEhNc0lIQnlhVzUwS1Z4dUl5QnZjaUJoY25KaGJtZGxJSFJvWlcwZ2QybDBhQ0J3WVhSamFIZHZjbXNnTHlCbmNtbGtSWGgwY21Fc0lHVjBZeTVjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbmxpYnJhcnkoZHBseXIpXG5saWJyYXJ5KGdncGxvdDIpXG5saWJyYXJ5KHZpcmlkaXMpXG5saWJyYXJ5KHB1cnJyKVxuXG4jIHlvdXIgZGVuc2l0eSBmblxuZ2V0X2RlbnNpdHkgPC0gZnVuY3Rpb24oeCwgeSwgbiA9IDEwMCkge1xuICAjIOKApiB3aGF0ZXZlciB5b3UgYWxyZWFkeSBoYXZlIOKAplxufVxuXG4jIDEpIG1ha2UgYSBnZW5lcmFsIHBsb3R0aW5nIGZ1bmN0aW9uXG5wbG90X2NvbXBhcmUgPC0gZnVuY3Rpb24oZGYsIHhfY29sLCB5X2NvbCwgZGlmZkN1dG9mZiA9IDAuMSwgbGltID0gYygtMC41LCAxKSkge1xuICBkZjIgPC0gZGYgJT4lXG4gICAgc2VsZWN0KGFsbF9vZihjKHhfY29sLCB5X2NvbCkpKSAlPiVcbiAgICByZW5hbWUoeCA9ICEhc3ltKHhfY29sKSwgeSA9ICEhc3ltKHlfY29sKSkgJT4lXG4gICAgbXV0YXRlKGRlbnNpdHkgPSBnZXRfZGVuc2l0eSh4LCB5LCBuID0gMTAwKSkgJT4lXG4gICAgYXJyYW5nZShkZW5zaXR5KVxuXG4gIGdncGxvdChkZjIsIGFlcyh4ID0geCwgeSA9IHksIGNvbG9yID0gZGVuc2l0eSkpICtcbiAgICBnZW9tX3BvaW50KCkgK1xuICAgIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArXG4gICAgeGxpbShsaW0pICsgeWxpbShsaW0pICtcbiAgICBjb29yZF9maXhlZCgpICtcbiAgICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDAsIGNvbG9yID0gXFxncmV5NTBcXCwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gICAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCwgYWxwaGEgPSAwLjUsIGNvbG9yID0gXFxncmV5XFwpICtcbiAgICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICAgIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gLWRpZmZDdXRvZmYsIGNvbG9yID0gXFxncmV5XFwsIGxpbmV0eXBlID0gXFxkb3R0ZWRcXCkgK1xuICAgIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gIGRpZmZDdXRvZmYsIGNvbG9yID0gXFxncmV5XFwsIGxpbmV0eXBlID0gXFxkb3R0ZWRcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArXG4gICAgZ2d0aXRsZShwYXN0ZSh4X2NvbCwgXFx2c1xcLCB5X2NvbCkpXG59XG5cbiMgMikgZGVmaW5lIHRoZSBwYWlycyB5b3UgY2FyZSBhYm91dFxucGFpcnMgPC0gbGlzdChcbiAgRE1TT192c19kVEFHID0gYyhcXHNjb3JlX0RNU09cXCwgXFxzY29yZV9kVEFHXFwpLFxuICBVVF92c19BSUQgICAgID0gYyhcXHNjb3JlX1VUXFwsICAgXFxzY29yZV9BSURcXClcbiAgIyDigKYgYWRkIG1vcmUg4oCmXG4pXG5cbiMgMykgYnVpbGQgYSBuYW1lZCBsaXN0IG9mIGdncGxvdHNcbnBsb3RzIDwtIG1hcChwYWlycywgfiBwbG90X2NvbXBhcmUoZGF0YSwgLnhbMV0sIC54WzJdLCBkaWZmQ3V0b2ZmID0gZGlmZkN1dG9mZikpXG5cbiMgbm93IHlvdSBjYW4gcHJpbnQgdGhlbSBhbGw6XG53YWxrKHBsb3RzLCBwcmludClcbiMgb3IgYXJyYW5nZSB0aGVtIHdpdGggcGF0Y2h3b3JrIC8gZ3JpZEV4dHJhLCBldGMuXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
library(dplyr)
library(ggplot2)
library(viridis)
library(purrr)

# your density fn
get_density <- function(x, y, n = 100) {
  # … whatever you already have …
}

# 1) make a general plotting function
plot_compare <- function(df, x_col, y_col, diffCutoff = 0.1, lim = c(-0.5, 1)) {
  df2 <- df %>%
    select(all_of(c(x_col, y_col))) %>%
    rename(x = !!sym(x_col), y = !!sym(y_col)) %>%
    mutate(density = get_density(x, y, n = 100)) %>%
    arrange(density)

  ggplot(df2, aes(x = x, y = y, color = density)) +
    geom_point() +
    scale_color_viridis() +
    xlim(lim) + ylim(lim) +
    coord_fixed() +
    geom_abline(slope = 1, intercept = 0, color = \grey50\, linetype = \dashed\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
    geom_abline(slope = 1, intercept = -diffCutoff, color = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept =  diffCutoff, color = \grey\, linetype = \dotted\) +
    theme_classic() +
    ggtitle(paste(x_col, \vs\, y_col))
}

# 2) define the pairs you care about
pairs <- list(
  DMSO_vs_dTAG = c(\score_DMSO\, \score_dTAG\),
  UT_vs_AID     = c(\score_UT\,   \score_AID\)
  # … add more …
)

# 3) build a named list of ggplots
plots <- map(pairs, ~ plot_compare(data, .x[1], .x[2], diffCutoff = diffCutoff))

# now you can print them all:
walk(plots, print)
# or arrange them with patchwork / gridExtra, etc.



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJHbGljbUZ5ZVNoa2NHeDVjaWxjYm14cFluSmhjbmtvWjJkd2JHOTBNaWxjYm14cFluSmhjbmtvZG1seWFXUnBjeWxjYm14cFluSmhjbmtvY0hWeWNuSXBYRzVjYmlNZ2VXOTFjaUJrWlc1emFYUjVJR1p1WEc1blpYUmZaR1Z1YzJsMGVTQThMU0JtZFc1amRHbHZiaWg0TENCNUxDQnVJRDBnTVRBd0tTQjdYRzRnSUNNZzRvQ21JSGRvWVhSbGRtVnlJSGx2ZFNCaGJISmxZV1I1SUdoaGRtVWc0b0NtWEc1OVhHNWNiaU1nTVNrZ2JXRnJaU0JoSUdkbGJtVnlZV3dnY0d4dmRIUnBibWNnWm5WdVkzUnBiMjVjYm5Cc2IzUmZZMjl0Y0dGeVpTQThMU0JtZFc1amRHbHZiaWhrWml3Z2VGOWpiMndzSUhsZlkyOXNMQ0JrYVdabVEzVjBiMlptSUQwZ01DNHhMQ0JzYVcwZ1BTQmpLQzB3TGpVc0lERXBLU0I3WEc0Z0lHUm1NaUE4TFNCa1ppQWxQaVZjYmlBZ0lDQnpaV3hsWTNRb1lXeHNYMjltS0dNb2VGOWpiMndzSUhsZlkyOXNLU2twSUNVK0pWeHVJQ0FnSUhKbGJtRnRaU2g0SUQwZ0lTRnplVzBvZUY5amIyd3BMQ0I1SUQwZ0lTRnplVzBvZVY5amIyd3BLU0FsUGlWY2JpQWdJQ0J0ZFhSaGRHVW9aR1Z1YzJsMGVTQTlJR2RsZEY5a1pXNXphWFI1S0hnc0lIa3NJRzRnUFNBeE1EQXBLU0FsUGlWY2JpQWdJQ0JoY25KaGJtZGxLR1JsYm5OcGRIa3BYRzVjYmlBZ1oyZHdiRzkwS0dSbU1pd2dZV1Z6S0hnZ1BTQjRMQ0I1SUQwZ2VTd2dZMjlzYjNJZ1BTQmtaVzV6YVhSNUtTa2dLMXh1SUNBZ0lHZGxiMjFmY0c5cGJuUW9LU0FyWEc0Z0lDQWdjMk5oYkdWZlkyOXNiM0pmZG1seWFXUnBjeWdwSUN0Y2JpQWdJQ0I0YkdsdEtHeHBiU2tnS3lCNWJHbHRLR3hwYlNrZ0sxeHVJQ0FnSUdOdmIzSmtYMlpwZUdWa0tDa2dLMXh1SUNBZ0lHZGxiMjFmWVdKc2FXNWxLSE5zYjNCbElEMGdNU3dnYVc1MFpYSmpaWEIwSUQwZ01Dd2dZMjlzYjNJZ1BTQmNYR2R5WlhrMU1GeGNMQ0JzYVc1bGRIbHdaU0E5SUZ4Y1pHRnphR1ZrWEZ3cElDdGNiaUFnSUNCblpXOXRYMmhzYVc1bEtIbHBiblJsY21ObGNIUWdQU0F3TENCaGJIQm9ZU0E5SURBdU5Td2dZMjlzYjNJZ1BTQmNYR2R5WlhsY1hDa2dLMXh1SUNBZ0lHZGxiMjFmZG14cGJtVW9lR2x1ZEdWeVkyVndkQ0E5SURBc0lHRnNjR2hoSUQwZ01DNDFMQ0JqYjJ4dmNpQTlJRnhjWjNKbGVWeGNLU0FyWEc0Z0lDQWdaMlZ2YlY5aFlteHBibVVvYzJ4dmNHVWdQU0F4TENCcGJuUmxjbU5sY0hRZ1BTQXRaR2xtWmtOMWRHOW1aaXdnWTI5c2IzSWdQU0JjWEdkeVpYbGNYQ3dnYkdsdVpYUjVjR1VnUFNCY1hHUnZkSFJsWkZ4Y0tTQXJYRzRnSUNBZ1oyVnZiVjloWW14cGJtVW9jMnh2Y0dVZ1BTQXhMQ0JwYm5SbGNtTmxjSFFnUFNBZ1pHbG1aa04xZEc5bVppd2dZMjlzYjNJZ1BTQmNYR2R5WlhsY1hDd2diR2x1WlhSNWNHVWdQU0JjWEdSdmRIUmxaRnhjS1NBclhHNGdJQ0FnZEdobGJXVmZZMnhoYzNOcFl5Z3BJQ3RjYmlBZ0lDQm5aM1JwZEd4bEtIQmhjM1JsS0hoZlkyOXNMQ0JjWEhaelhGd3NJSGxmWTI5c0tTbGNibjFjYmx4dUl5QXlLU0JrWldacGJtVWdkR2hsSUhCaGFYSnpJSGx2ZFNCallYSmxJR0ZpYjNWMFhHNXdZV2x5Y3lBOExTQnNhWE4wS0Z4dUlDQkVUVk5QWDNaelgyUlVRVWNnUFNCaktGeGNjMk52Y21WZlJFMVRUMXhjTENCY1hITmpiM0psWDJSVVFVZGNYQ2tzWEc0Z0lGVlVYM1p6WDBGSlJDQWdJQ0FnUFNCaktGeGNjMk52Y21WZlZWUmNYQ3dnSUNCY1hITmpiM0psWDBGSlJGeGNLVnh1SUNBaklPS0FwaUJoWkdRZ2JXOXlaU0RpZ0taY2JpbGNibHh1SXlBektTQmlkV2xzWkNCaElHNWhiV1ZrSUd4cGMzUWdiMllnWjJkd2JHOTBjMXh1Y0d4dmRITWdQQzBnYldGd0tIQmhhWEp6TENCK0lIQnNiM1JmWTI5dGNHRnlaU2hrWVhSaExDQXVlRnN4WFN3Z0xuaGJNbDBzSUdScFptWkRkWFJ2Wm1ZZ1BTQmthV1ptUTNWMGIyWm1LU2xjYmx4dUl5QnViM2NnZVc5MUlHTmhiaUJ3Y21sdWRDQjBhR1Z0SUdGc2JEcGNibmRoYkdzb2NHeHZkSE1zSUhCeWFXNTBLVnh1SXlCdmNpQmhjbkpoYm1kbElIUm9aVzBnZDJsMGFDQndZWFJqYUhkdmNtc2dMeUJuY21sa1JYaDBjbUVzSUdWMFl5NWNibUJnWUZ4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG5gYGByXG5saWJyYXJ5KGRwbHlyKVxubGlicmFyeShnZ3Bsb3QyKVxubGlicmFyeSh2aXJpZGlzKVxubGlicmFyeShwdXJycilcblxuIyB5b3VyIGRlbnNpdHkgZm5cbmdldF9kZW5zaXR5IDwtIGZ1bmN0aW9uKHgsIHksIG4gPSAxMDApIHtcbiAgIyDigKYgd2hhdGV2ZXIgeW91IGFscmVhZHkgaGF2ZSDigKZcbn1cblxuIyAxKSBtYWtlIGEgZ2VuZXJhbCBwbG90dGluZyBmdW5jdGlvblxucGxvdF9jb21wYXJlIDwtIGZ1bmN0aW9uKGRmLCB4X2NvbCwgeV9jb2wsIGRpZmZDdXRvZmYgPSAwLjEsIGxpbSA9IGMoLTAuNSwgMSkpIHtcbiAgZGYyIDwtIGRmICU+JVxuICAgIHNlbGVjdChhbGxfb2YoYyh4X2NvbCwgeV9jb2wpKSkgJT4lXG4gICAgcmVuYW1lKHggPSAhIXN5bSh4X2NvbCksIHkgPSAhIXN5bSh5X2NvbCkpICU+JVxuICAgIG11dGF0ZShkZW5zaXR5ID0gZ2V0X2RlbnNpdHkoeCwgeSwgbiA9IDEwMCkpICU+JVxuICAgIGFycmFuZ2UoZGVuc2l0eSlcblxuICBnZ3Bsb3QoZGYyLCBhZXMoeCA9IHgsIHkgPSB5LCBjb2xvciA9IGRlbnNpdHkpKSArXG4gICAgZ2VvbV9wb2ludCgpICtcbiAgICBzY2FsZV9jb2xvcl92aXJpZGlzKCkgK1xuICAgIHhsaW0obGltKSArIHlsaW0obGltKSArXG4gICAgY29vcmRfZml4ZWQoKSArXG4gICAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwLCBjb2xvciA9IFxcZ3JleTUwXFwsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICAgIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gICAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gMCwgYWxwaGEgPSAwLjUsIGNvbG9yID0gXFxncmV5XFwpICtcbiAgICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IC1kaWZmQ3V0b2ZmLCBjb2xvciA9IFxcZ3JleVxcLCBsaW5ldHlwZSA9IFxcZG90dGVkXFwpICtcbiAgICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9ICBkaWZmQ3V0b2ZmLCBjb2xvciA9IFxcZ3JleVxcLCBsaW5ldHlwZSA9IFxcZG90dGVkXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgK1xuICAgIGdndGl0bGUocGFzdGUoeF9jb2wsIFxcdnNcXCwgeV9jb2wpKVxufVxuXG4jIDIpIGRlZmluZSB0aGUgcGFpcnMgeW91IGNhcmUgYWJvdXRcbnBhaXJzIDwtIGxpc3QoXG4gIERNU09fdnNfZFRBRyA9IGMoXFxzY29yZV9ETVNPXFwsIFxcc2NvcmVfZFRBR1xcKSxcbiAgVVRfdnNfQUlEICAgICA9IGMoXFxzY29yZV9VVFxcLCAgIFxcc2NvcmVfQUlEXFwpXG4gICMg4oCmIGFkZCBtb3JlIOKAplxuKVxuXG4jIDMpIGJ1aWxkIGEgbmFtZWQgbGlzdCBvZiBnZ3Bsb3RzXG5wbG90cyA8LSBtYXAocGFpcnMsIH4gcGxvdF9jb21wYXJlKGRhdGEsIC54WzFdLCAueFsyXSwgZGlmZkN1dG9mZiA9IGRpZmZDdXRvZmYpKVxuXG4jIG5vdyB5b3UgY2FuIHByaW50IHRoZW0gYWxsOlxud2FsayhwbG90cywgcHJpbnQpXG4jIG9yIGFycmFuZ2UgdGhlbSB3aXRoIHBhdGNod29yayAvIGdyaWRFeHRyYSwgZXRjLlxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubGlicmFyeShkcGx5cilcbmxpYnJhcnkoZ2dwbG90MilcbmxpYnJhcnkodmlyaWRpcylcbmxpYnJhcnkocHVycnIpXG5cbiMgeW91ciBkZW5zaXR5IGZuXG5nZXRfZGVuc2l0eSA8LSBmdW5jdGlvbih4LCB5LCBuID0gMTAwKSB7XG4gICMg4oCmIHdoYXRldmVyIHlvdSBhbHJlYWR5IGhhdmUg4oCmXG59XG5cbiMgMSkgbWFrZSBhIGdlbmVyYWwgcGxvdHRpbmcgZnVuY3Rpb25cbnBsb3RfY29tcGFyZSA8LSBmdW5jdGlvbihkZiwgeF9jb2wsIHlfY29sLCBkaWZmQ3V0b2ZmID0gMC4xLCBsaW0gPSBjKC0wLjUsIDEpKSB7XG4gIGRmMiA8LSBkZiAlPiVcbiAgICBzZWxlY3QoYWxsX29mKGMoeF9jb2wsIHlfY29sKSkpICU+JVxuICAgIHJlbmFtZSh4ID0gISFzeW0oeF9jb2wpLCB5ID0gISFzeW0oeV9jb2wpKSAlPiVcbiAgICBtdXRhdGUoZGVuc2l0eSA9IGdldF9kZW5zaXR5KHgsIHksIG4gPSAxMDApKSAlPiVcbiAgICBhcnJhbmdlKGRlbnNpdHkpXG5cbiAgZ2dwbG90KGRmMiwgYWVzKHggPSB4LCB5ID0geSwgY29sb3IgPSBkZW5zaXR5KSkgK1xuICAgIGdlb21fcG9pbnQoKSArXG4gICAgc2NhbGVfY29sb3JfdmlyaWRpcygpICtcbiAgICB4bGltKGxpbSkgKyB5bGltKGxpbSkgK1xuICAgIGNvb3JkX2ZpeGVkKCkgK1xuICAgIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCwgY29sb3IgPSBcXGdyZXk1MFxcLCBsaW5ldHlwZSA9IFxcZGFzaGVkXFwpICtcbiAgICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICAgIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gICAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAtZGlmZkN1dG9mZiwgY29sb3IgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gICAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAgZGlmZkN1dG9mZiwgY29sb3IgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICtcbiAgICBnZ3RpdGxlKHBhc3RlKHhfY29sLCBcXHZzXFwsIHlfY29sKSlcbn1cblxuIyAyKSBkZWZpbmUgdGhlIHBhaXJzIHlvdSBjYXJlIGFib3V0XG5wYWlycyA8LSBsaXN0KFxuICBETVNPX3ZzX2RUQUcgPSBjKFxcc2NvcmVfRE1TT1xcLCBcXHNjb3JlX2RUQUdcXCksXG4gIFVUX3ZzX0FJRCAgICAgPSBjKFxcc2NvcmVfVVRcXCwgICBcXHNjb3JlX0FJRFxcKVxuICAjIOKApiBhZGQgbW9yZSDigKZcbilcblxuIyAzKSBidWlsZCBhIG5hbWVkIGxpc3Qgb2YgZ2dwbG90c1xucGxvdHMgPC0gbWFwKHBhaXJzLCB+IHBsb3RfY29tcGFyZShkYXRhLCAueFsxXSwgLnhbMl0sIGRpZmZDdXRvZmYgPSBkaWZmQ3V0b2ZmKSlcblxuIyBub3cgeW91IGNhbiBwcmludCB0aGVtIGFsbDpcbndhbGsocGxvdHMsIHByaW50KVxuIyBvciBhcnJhbmdlIHRoZW0gd2l0aCBwYXRjaHdvcmsgLyBncmlkRXh0cmEsIGV0Yy5cbmBgYFxuYGBgIn0= -->

```r
```r
library(dplyr)
library(ggplot2)
library(viridis)
library(purrr)

# your density fn
get_density <- function(x, y, n = 100) {
  # … whatever you already have …
}

# 1) make a general plotting function
plot_compare <- function(df, x_col, y_col, diffCutoff = 0.1, lim = c(-0.5, 1)) {
  df2 <- df %>%
    select(all_of(c(x_col, y_col))) %>%
    rename(x = !!sym(x_col), y = !!sym(y_col)) %>%
    mutate(density = get_density(x, y, n = 100)) %>%
    arrange(density)

  ggplot(df2, aes(x = x, y = y, color = density)) +
    geom_point() +
    scale_color_viridis() +
    xlim(lim) + ylim(lim) +
    coord_fixed() +
    geom_abline(slope = 1, intercept = 0, color = \grey50\, linetype = \dashed\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
    geom_abline(slope = 1, intercept = -diffCutoff, color = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept =  diffCutoff, color = \grey\, linetype = \dotted\) +
    theme_classic() +
    ggtitle(paste(x_col, \vs\, y_col))
}

# 2) define the pairs you care about
pairs <- list(
  DMSO_vs_dTAG = c(\score_DMSO\, \score_dTAG\),
  UT_vs_AID     = c(\score_UT\,   \score_AID\)
  # … add more …
)

# 3) build a named list of ggplots
plots <- map(pairs, ~ plot_compare(data, .x[1], .x[2], diffCutoff = diffCutoff))

# now you can print them all:
walk(plots, print)
# or arrange them with patchwork / gridExtra, etc.
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuc2FtcGxlIDwtIFwiRzEuRE1TTy5NZXJnZWRcIlxuZm9yKHNhbXBsZSBpbiBjKFwiRzEuRE1TTy5NZXJnZWRcIiwgXCJHMS5kVEFHLk1lcmdlZFwiLCBcIkcxLkE0ODUuTWVyZ2VkXCIpKXtcbiAgdGVtcC4yNWtiIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXCJsb29wU2NvcmVfXCIsIHNhbXBsZSwgXCJfMjVrYi50c3ZcIikpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcIl9cIikpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgY2hyb20yLCBzdGFydDIsIGVuZDIsIGlkLCBvYnNlcnZlZCwgXCJPL0VcIilcbiAgY29sbmFtZXModGVtcC4yNWtiKSA8LSBjKFwiY2hyb20xXCIsIFwic3RhcnQxXCIsIFwiZW5kMVwiLCBcImNocm9tMlwiLCBcInN0YXJ0MlwiLCBcImVuZDJcIiwgXCJpZFwiLCBcIm9ic1wiLCBcIm9ic2V4cFwiKVxuICBcbiAgdGVtcC4xMGtiIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXCJsb29wU2NvcmVfXCIsIHNhbXBsZSwgXCJfMTBrYi50c3ZcIikpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcIl9cIikpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgY2hyb20yLCBzdGFydDIsIGVuZDIsIGlkLCBvYnNlcnZlZCwgXCJPL0VcIilcbiAgY29sbmFtZXModGVtcC4xMGtiKSA8LSBjKFwiY2hyb20xXCIsIFwic3RhcnQxXCIsIFwiZW5kMVwiLCBcImNocm9tMlwiLCBcInN0YXJ0MlwiLCBcImVuZDJcIiwgXCJpZFwiLCBcIm9ic1wiLCBcIm9ic2V4cFwiKVxuICBcbiAgdGVtcC41a2IgPC1mcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFwibG9vcFNjb3JlX1wiLCBzYW1wbGUsIFwiXzVrYi50c3ZcIikpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcIl9cIikpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgY2hyb20yLCBzdGFydDIsIGVuZDIsIGlkLCBvYnNlcnZlZCwgXCJPL0VcIilcbiAgY29sbmFtZXModGVtcC41a2IpIDwtIGMoXCJjaHJvbTFcIiwgXCJzdGFydDFcIiwgXCJlbmQxXCIsIFwiY2hyb20yXCIsIFwic3RhcnQyXCIsIFwiZW5kMlwiLCBcImlkXCIsIFwib2JzXCIsIFwib2JzZXhwXCIpXG4gIFxuICB0ZW1wIDwtIGJpbmRfcm93cyh0ZW1wLjI1a2IsIHRlbXAuMTBrYiwgdGVtcC41a2IpXG4gIGZ3cml0ZSh0ZW1wLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFwibG9vcFNjb3JlX1wiLCBzYW1wbGUsIFwiLnRzdlwiKSksIHNlcCA9IFwiXFx0XCIpXG59XG5cblxudGVtcC5ETVNPIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImxvb3BTY29yZV9HMS5ETVNPLk1lcmdlZC50c3ZcIikpICU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBvYnMsIG9ic2V4cClcbmNvbG5hbWVzKHRlbXAuRE1TTykgPC0gYyhcImlkXCIsIFwib2JzX0RNU09cIiwgXCJvYnNleHBfRE1TT1wiKVxudGVtcC5kVEFHIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImxvb3BTY29yZV9HMS5kVEFHLk1lcmdlZC50c3ZcIikpICU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBvYnMsIG9ic2V4cClcbmNvbG5hbWVzKHRlbXAuZFRBRykgPC0gYyhcImlkXCIsIFwib2JzX2RUQUdcIiwgXCJvYnNleHBfZFRBR1wiKVxudGVtcC5BNDg1IDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImxvb3BTY29yZV9HMS5BNDg1Lk1lcmdlZC50c3ZcIikpICU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBvYnMsIG9ic2V4cClcbmNvbG5hbWVzKHRlbXAuQTQ4NSkgPC0gYyhcImlkXCIsIFwib2JzX0E0ODVcIiwgXCJvYnNleHBfQTQ4NVwiKVxuXG5sb29wc19vZSA8LSBmdWxsX2pvaW4oZnVsbF9qb2luKHRlbXAuRE1TTywgdGVtcC5kVEFHLCBieSA9IFwiaWRcIiksXG4gICAgICAgICAgdGVtcC5BNDg1LCBieSA9IFwiaWRcIikgJT4lXG4gIGRwbHlyOjptdXRhdGUob2VGQ19kVEFHX0RNU08gPSBpZl9lbHNlKG9ic2V4cF9ETVNPID09IDAsIE5BLCBvYnNleHBfZFRBRy9vYnNleHBfRE1TTyksXG4gICAgICAgICAgICAgICAgb2VGQ19BNDg1X0RNU08gPSBpZl9lbHNlKG9ic2V4cF9ETVNPID09IDAsIE5BLCBvYnNleHBfQTQ4NS9vYnNleHBfRE1TTykpXG5cbmZ3cml0ZShsb29wc19vZSwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcImxvb3BTY29yZV9jb25zX29ic2V4cC50c3ZcIikpLCBzZXAgPSBcIlxcdFwiKVxuYGBgIn0= -->\n\n```r\nsample <- \\G1.DMSO.Merged\\\nfor(sample in c(\\G1.DMSO.Merged\\, \\G1.dTAG.Merged\\, \\G1.A485.Merged\\)){\n  temp.25kb <- fread(here(consensusDir, paste0(\\loopScore_\\, sample, \\_25kb.tsv\\))) %>%\n    dplyr::mutate(binSize = end1 - start1,\n                  id = paste(chrom1, binSize, start1, start2, sep = \\_\\)) %>%\n    dplyr::filter(id %in% loops$id) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \\O/E\\)\n  colnames(temp.25kb) <- c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\, \\id\\, \\obs\\, \\obsexp\\)\n  \n  temp.10kb <- fread(here(consensusDir, paste0(\\loopScore_\\, sample, \\_10kb.tsv\\))) %>%\n    dplyr::mutate(binSize = end1 - start1,\n                  id = paste(chrom1, binSize, start1, start2, sep = \\_\\)) %>%\n    dplyr::filter(id %in% loops$id) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \\O/E\\)\n  colnames(temp.10kb) <- c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\, \\id\\, \\obs\\, \\obsexp\\)\n  \n  temp.5kb <-fread(here(consensusDir, paste0(\\loopScore_\\, sample, \\_5kb.tsv\\))) %>%\n    dplyr::mutate(binSize = end1 - start1,\n                  id = paste(chrom1, binSize, start1, start2, sep = \\_\\)) %>%\n    dplyr::filter(id %in% loops$id) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \\O/E\\)\n  colnames(temp.5kb) <- c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\, \\id\\, \\obs\\, \\obsexp\\)\n  \n  temp <- bind_rows(temp.25kb, temp.10kb, temp.5kb)\n  fwrite(temp, here(consensusDir, paste0(\\loopScore_\\, sample, \\.tsv\\)), sep = \\\\t\\)\n}\n\n\ntemp.DMSO <- fread(here(consensusDir, \\loopScore_G1.DMSO.Merged.tsv\\)) %>%\n  dplyr::select(id, obs, obsexp)\ncolnames(temp.DMSO) <- c(\\id\\, \\obs_DMSO\\, \\obsexp_DMSO\\)\ntemp.dTAG <- fread(here(consensusDir, \\loopScore_G1.dTAG.Merged.tsv\\)) %>%\n  dplyr::select(id, obs, obsexp)\ncolnames(temp.dTAG) <- c(\\id\\, \\obs_dTAG\\, \\obsexp_dTAG\\)\ntemp.A485 <- fread(here(consensusDir, \\loopScore_G1.A485.Merged.tsv\\)) %>%\n  dplyr::select(id, obs, obsexp)\ncolnames(temp.A485) <- c(\\id\\, \\obs_A485\\, \\obsexp_A485\\)\n\nloops_oe <- full_join(full_join(temp.DMSO, temp.dTAG, by = \\id\\),\n          temp.A485, by = \\id\\) %>%\n  dplyr::mutate(oeFC_dTAG_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_dTAG/obsexp_DMSO),\n                oeFC_A485_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_A485/obsexp_DMSO))\n\nfwrite(loops_oe, here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\)), sep = \\\\t\\)\n```\n\n<!-- rnb-source-end -->\n"} -->
sample <- \G1.DMSO.Merged\
for(sample in c(\G1.DMSO.Merged\, \G1.dTAG.Merged\, \G1.A485.Merged\)){
  temp.25kb <- fread(here(consensusDir, paste0(\loopScore_\, sample, \_25kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.25kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp.10kb <- fread(here(consensusDir, paste0(\loopScore_\, sample, \_10kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.10kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp.5kb <-fread(here(consensusDir, paste0(\loopScore_\, sample, \_5kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.5kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp <- bind_rows(temp.25kb, temp.10kb, temp.5kb)
  fwrite(temp, here(consensusDir, paste0(\loopScore_\, sample, \.tsv\)), sep = \\t\)
}


temp.DMSO <- fread(here(consensusDir, \loopScore_G1.DMSO.Merged.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.DMSO) <- c(\id\, \obs_DMSO\, \obsexp_DMSO\)
temp.dTAG <- fread(here(consensusDir, \loopScore_G1.dTAG.Merged.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.dTAG) <- c(\id\, \obs_dTAG\, \obsexp_dTAG\)
temp.A485 <- fread(here(consensusDir, \loopScore_G1.A485.Merged.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.A485) <- c(\id\, \obs_A485\, \obsexp_A485\)

loops_oe <- full_join(full_join(temp.DMSO, temp.dTAG, by = \id\),
          temp.A485, by = \id\) %>%
  dplyr::mutate(oeFC_dTAG_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_dTAG/obsexp_DMSO),
                oeFC_A485_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_A485/obsexp_DMSO))

fwrite(loops_oe, here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\)), sep = \\t\)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuc2FtcGxlIDwtIFxcRzEuRE1TTy5NZXJnZWRcXFxuZm9yKHNhbXBsZSBpbiBjKFxcRzEuRE1TTy5NZXJnZWRcXCwgXFxHMS5kVEFHLk1lcmdlZFxcLCBcXEcxLkE0ODUuTWVyZ2VkXFwpKXtcbiAgdGVtcC4yNWtiIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIHNhbXBsZSwgXFxfMjVrYi50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcXF9cXCkpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgY2hyb20yLCBzdGFydDIsIGVuZDIsIGlkLCBvYnNlcnZlZCwgXFxPL0VcXClcbiAgY29sbmFtZXModGVtcC4yNWtiKSA8LSBjKFxcY2hyb20xXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocm9tMlxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXCwgXFxpZFxcLCBcXG9ic1xcLCBcXG9ic2V4cFxcKVxuICBcbiAgdGVtcC4xMGtiIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIHNhbXBsZSwgXFxfMTBrYi50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcXF9cXCkpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgY2hyb20yLCBzdGFydDIsIGVuZDIsIGlkLCBvYnNlcnZlZCwgXFxPL0VcXClcbiAgY29sbmFtZXModGVtcC4xMGtiKSA8LSBjKFxcY2hyb20xXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocm9tMlxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXCwgXFxpZFxcLCBcXG9ic1xcLCBcXG9ic2V4cFxcKVxuICBcbiAgdGVtcC41a2IgPC1mcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBzYW1wbGUsIFxcXzVrYi50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcXF9cXCkpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgY2hyb20yLCBzdGFydDIsIGVuZDIsIGlkLCBvYnNlcnZlZCwgXFxPL0VcXClcbiAgY29sbmFtZXModGVtcC41a2IpIDwtIGMoXFxjaHJvbTFcXCwgXFxzdGFydDFcXCwgXFxlbmQxXFwsIFxcY2hyb20yXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcLCBcXGlkXFwsIFxcb2JzXFwsIFxcb2JzZXhwXFwpXG4gIFxuICB0ZW1wIDwtIGJpbmRfcm93cyh0ZW1wLjI1a2IsIHRlbXAuMTBrYiwgdGVtcC41a2IpXG4gIGZ3cml0ZSh0ZW1wLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBzYW1wbGUsIFxcLnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG59XG5cblxudGVtcC5ETVNPIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGxvb3BTY29yZV9HMS5ETVNPLk1lcmdlZC50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBvYnMsIG9ic2V4cClcbmNvbG5hbWVzKHRlbXAuRE1TTykgPC0gYyhcXGlkXFwsIFxcb2JzX0RNU09cXCwgXFxvYnNleHBfRE1TT1xcKVxudGVtcC5kVEFHIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGxvb3BTY29yZV9HMS5kVEFHLk1lcmdlZC50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBvYnMsIG9ic2V4cClcbmNvbG5hbWVzKHRlbXAuZFRBRykgPC0gYyhcXGlkXFwsIFxcb2JzX2RUQUdcXCwgXFxvYnNleHBfZFRBR1xcKVxudGVtcC5BNDg1IDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGxvb3BTY29yZV9HMS5BNDg1Lk1lcmdlZC50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBvYnMsIG9ic2V4cClcbmNvbG5hbWVzKHRlbXAuQTQ4NSkgPC0gYyhcXGlkXFwsIFxcb2JzX0E0ODVcXCwgXFxvYnNleHBfQTQ4NVxcKVxuXG5sb29wc19vZSA8LSBmdWxsX2pvaW4oZnVsbF9qb2luKHRlbXAuRE1TTywgdGVtcC5kVEFHLCBieSA9IFxcaWRcXCksXG4gICAgICAgICAgdGVtcC5BNDg1LCBieSA9IFxcaWRcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUob2VGQ19kVEFHX0RNU08gPSBpZl9lbHNlKG9ic2V4cF9ETVNPID09IDAsIE5BLCBvYnNleHBfZFRBRy9vYnNleHBfRE1TTyksXG4gICAgICAgICAgICAgICAgb2VGQ19BNDg1X0RNU08gPSBpZl9lbHNlKG9ic2V4cF9ETVNPID09IDAsIE5BLCBvYnNleHBfQTQ4NS9vYnNleHBfRE1TTykpXG5cbmZ3cml0ZShsb29wc19vZSwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9jb25zX29ic2V4cC50c3ZcXCkpLCBzZXAgPSBcXFxcdFxcKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\nsample <- \\G1.DMSO.Merged\\\nfor(sample in c(\\G1.DMSO.Merged\\, \\G1.dTAG.Merged\\, \\G1.A485.Merged\\)){\n  temp.25kb <- fread(here(consensusDir, paste0(\\loopScore_\\, sample, \\_25kb.tsv\\))) %>%\n    dplyr::mutate(binSize = end1 - start1,\n                  id = paste(chrom1, binSize, start1, start2, sep = \\_\\)) %>%\n    dplyr::filter(id %in% loops$id) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \\O/E\\)\n  colnames(temp.25kb) <- c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\, \\id\\, \\obs\\, \\obsexp\\)\n  \n  temp.10kb <- fread(here(consensusDir, paste0(\\loopScore_\\, sample, \\_10kb.tsv\\))) %>%\n    dplyr::mutate(binSize = end1 - start1,\n                  id = paste(chrom1, binSize, start1, start2, sep = \\_\\)) %>%\n    dplyr::filter(id %in% loops$id) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \\O/E\\)\n  colnames(temp.10kb) <- c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\, \\id\\, \\obs\\, \\obsexp\\)\n  \n  temp.5kb <-fread(here(consensusDir, paste0(\\loopScore_\\, sample, \\_5kb.tsv\\))) %>%\n    dplyr::mutate(binSize = end1 - start1,\n                  id = paste(chrom1, binSize, start1, start2, sep = \\_\\)) %>%\n    dplyr::filter(id %in% loops$id) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \\O/E\\)\n  colnames(temp.5kb) <- c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\, \\id\\, \\obs\\, \\obsexp\\)\n  \n  temp <- bind_rows(temp.25kb, temp.10kb, temp.5kb)\n  fwrite(temp, here(consensusDir, paste0(\\loopScore_\\, sample, \\.tsv\\)), sep = \\\\t\\)\n}\n\n\ntemp.DMSO <- fread(here(consensusDir, \\loopScore_G1.DMSO.Merged.tsv\\)) %>%\n  dplyr::select(id, obs, obsexp)\ncolnames(temp.DMSO) <- c(\\id\\, \\obs_DMSO\\, \\obsexp_DMSO\\)\ntemp.dTAG <- fread(here(consensusDir, \\loopScore_G1.dTAG.Merged.tsv\\)) %>%\n  dplyr::select(id, obs, obsexp)\ncolnames(temp.dTAG) <- c(\\id\\, \\obs_dTAG\\, \\obsexp_dTAG\\)\ntemp.A485 <- fread(here(consensusDir, \\loopScore_G1.A485.Merged.tsv\\)) %>%\n  dplyr::select(id, obs, obsexp)\ncolnames(temp.A485) <- c(\\id\\, \\obs_A485\\, \\obsexp_A485\\)\n\nloops_oe <- full_join(full_join(temp.DMSO, temp.dTAG, by = \\id\\),\n          temp.A485, by = \\id\\) %>%\n  dplyr::mutate(oeFC_dTAG_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_dTAG/obsexp_DMSO),\n                oeFC_A485_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_A485/obsexp_DMSO))\n\nfwrite(loops_oe, here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\)), sep = \\\\t\\)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuc2FtcGxlIDwtIFxcRzEuRE1TTy5NZXJnZWRcXFxuZm9yKHNhbXBsZSBpbiBjKFxcRzEuRE1TTy5NZXJnZWRcXCwgXFxHMS5kVEFHLk1lcmdlZFxcLCBcXEcxLkE0ODUuTWVyZ2VkXFwpKXtcbiAgdGVtcC4yNWtiIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIHNhbXBsZSwgXFxfMjVrYi50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcXF9cXCkpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgY2hyb20yLCBzdGFydDIsIGVuZDIsIGlkLCBvYnNlcnZlZCwgXFxPL0VcXClcbiAgY29sbmFtZXModGVtcC4yNWtiKSA8LSBjKFxcY2hyb20xXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocm9tMlxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXCwgXFxpZFxcLCBcXG9ic1xcLCBcXG9ic2V4cFxcKVxuICBcbiAgdGVtcC4xMGtiIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIHNhbXBsZSwgXFxfMTBrYi50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcXF9cXCkpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgY2hyb20yLCBzdGFydDIsIGVuZDIsIGlkLCBvYnNlcnZlZCwgXFxPL0VcXClcbiAgY29sbmFtZXModGVtcC4xMGtiKSA8LSBjKFxcY2hyb20xXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocm9tMlxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXCwgXFxpZFxcLCBcXG9ic1xcLCBcXG9ic2V4cFxcKVxuICBcbiAgdGVtcC41a2IgPC1mcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBzYW1wbGUsIFxcXzVrYi50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcXF9cXCkpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgY2hyb20yLCBzdGFydDIsIGVuZDIsIGlkLCBvYnNlcnZlZCwgXFxPL0VcXClcbiAgY29sbmFtZXModGVtcC41a2IpIDwtIGMoXFxjaHJvbTFcXCwgXFxzdGFydDFcXCwgXFxlbmQxXFwsIFxcY2hyb20yXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcLCBcXGlkXFwsIFxcb2JzXFwsIFxcb2JzZXhwXFwpXG4gIFxuICB0ZW1wIDwtIGJpbmRfcm93cyh0ZW1wLjI1a2IsIHRlbXAuMTBrYiwgdGVtcC41a2IpXG4gIGZ3cml0ZSh0ZW1wLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBzYW1wbGUsIFxcLnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG59XG5cblxudGVtcC5ETVNPIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGxvb3BTY29yZV9HMS5ETVNPLk1lcmdlZC50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBvYnMsIG9ic2V4cClcbmNvbG5hbWVzKHRlbXAuRE1TTykgPC0gYyhcXGlkXFwsIFxcb2JzX0RNU09cXCwgXFxvYnNleHBfRE1TT1xcKVxudGVtcC5kVEFHIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGxvb3BTY29yZV9HMS5kVEFHLk1lcmdlZC50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBvYnMsIG9ic2V4cClcbmNvbG5hbWVzKHRlbXAuZFRBRykgPC0gYyhcXGlkXFwsIFxcb2JzX2RUQUdcXCwgXFxvYnNleHBfZFRBR1xcKVxudGVtcC5BNDg1IDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGxvb3BTY29yZV9HMS5BNDg1Lk1lcmdlZC50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBvYnMsIG9ic2V4cClcbmNvbG5hbWVzKHRlbXAuQTQ4NSkgPC0gYyhcXGlkXFwsIFxcb2JzX0E0ODVcXCwgXFxvYnNleHBfQTQ4NVxcKVxuXG5sb29wc19vZSA8LSBmdWxsX2pvaW4oZnVsbF9qb2luKHRlbXAuRE1TTywgdGVtcC5kVEFHLCBieSA9IFxcaWRcXCksXG4gICAgICAgICAgdGVtcC5BNDg1LCBieSA9IFxcaWRcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUob2VGQ19kVEFHX0RNU08gPSBpZl9lbHNlKG9ic2V4cF9ETVNPID09IDAsIE5BLCBvYnNleHBfZFRBRy9vYnNleHBfRE1TTyksXG4gICAgICAgICAgICAgICAgb2VGQ19BNDg1X0RNU08gPSBpZl9lbHNlKG9ic2V4cF9ETVNPID09IDAsIE5BLCBvYnNleHBfQTQ4NS9vYnNleHBfRE1TTykpXG5cbmZ3cml0ZShsb29wc19vZSwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9jb25zX29ic2V4cC50c3ZcXCkpLCBzZXAgPSBcXFxcdFxcKVxuYGBgXG5gYGAifQ== -->

```r
```r
sample <- \G1.DMSO.Merged\
for(sample in c(\G1.DMSO.Merged\, \G1.dTAG.Merged\, \G1.A485.Merged\)){
  temp.25kb <- fread(here(consensusDir, paste0(\loopScore_\, sample, \_25kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.25kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp.10kb <- fread(here(consensusDir, paste0(\loopScore_\, sample, \_10kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.10kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp.5kb <-fread(here(consensusDir, paste0(\loopScore_\, sample, \_5kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.5kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp <- bind_rows(temp.25kb, temp.10kb, temp.5kb)
  fwrite(temp, here(consensusDir, paste0(\loopScore_\, sample, \.tsv\)), sep = \\t\)
}


temp.DMSO <- fread(here(consensusDir, \loopScore_G1.DMSO.Merged.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.DMSO) <- c(\id\, \obs_DMSO\, \obsexp_DMSO\)
temp.dTAG <- fread(here(consensusDir, \loopScore_G1.dTAG.Merged.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.dTAG) <- c(\id\, \obs_dTAG\, \obsexp_dTAG\)
temp.A485 <- fread(here(consensusDir, \loopScore_G1.A485.Merged.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.A485) <- c(\id\, \obs_A485\, \obsexp_A485\)

loops_oe <- full_join(full_join(temp.DMSO, temp.dTAG, by = \id\),
          temp.A485, by = \id\) %>%
  dplyr::mutate(oeFC_dTAG_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_dTAG/obsexp_DMSO),
                oeFC_A485_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_A485/obsexp_DMSO))

fwrite(loops_oe, here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\)), sep = \\t\)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \"chromo_cons_score.tsv\"))\n\ntemp <- fread(here(consensusDir, \"chromo_cons_score_async.tsv\")) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\"id\")) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \"grey\") +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -1, y = 0.5, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n\npng(here(figDir, paste0(\"consensus_score_scatterplot_pu100pz100_G1vsAsync.png\")), res = 600, units = \"in\", width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \"h\", ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\"consensus_score_scatterplot_pu100pz100_G1vsAsync.svg\")), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \"h\", ncol = 3))\ndev.off()\n\n\n```"} -->\n\n```r\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\ntemp <- fread(here(consensusDir, \\chromo_cons_score_async.tsv\\)) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\\id\\)) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -1, y = 0.5, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\npng(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync.png\\)), res = 600, units = \\in\\, width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync.svg\\)), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
diffCutoff = 0.2
data <- fread(here(consensusDir, \chromo_cons_score.tsv\))

temp <- fread(here(consensusDir, \chromo_cons_score_async.tsv\)) %>%
  dplyr::select(id, UT, AID)

score.tb <- data %>% dplyr::full_join(temp, by = c(\id\)) %>%
  dplyr::mutate(diff_G1 = dTAG - DMSO,
                  diff_async = AID - UT)


### P1. UT vs AID
score.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$UT, score.tb$AID)
p1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P1. DMSO vs dTAG
score.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$dTAG)
p2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


### P3. DMSO vs A485
score.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$A485)
p3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P3. DMSO vs UT
score.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$UT)
p4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


### P3. dTAG vs AID
score.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$dTAG, score.tb$AID)
p5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P3. diff
score.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$diff_G1, score.tb$diff_async)
p6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-1, 0.5) + ylim(-1, 0.5) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \grey\) +
  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -1, y = 0.5, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


png(here(figDir, paste0(\consensus_score_scatterplot_pu100pz100_G1vsAsync.png\)), res = 600, units = \in\, width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = \h\, ncol = 3))
dev.off()
svglite(here(figDir, paste0(\consensus_score_scatterplot_pu100pz100_G1vsAsync.svg\)), width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = \h\, ncol = 3))
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\ntemp <- fread(here(consensusDir, \\chromo_cons_score_async.tsv\\)) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\\id\\)) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -1, y = 0.5, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\npng(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync.png\\)), res = 600, units = \\in\\, width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync.svg\\)), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\n\n\n```\n```"} -->\n\n```r\n```r\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\ntemp <- fread(here(consensusDir, \\chromo_cons_score_async.tsv\\)) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\\id\\)) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -1, y = 0.5, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\npng(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync.png\\)), res = 600, units = \\in\\, width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync.svg\\)), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\ntemp <- fread(here(consensusDir, \\chromo_cons_score_async.tsv\\)) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\\id\\)) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -1, y = 0.5, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\npng(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync.png\\)), res = 600, units = \\in\\, width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync.svg\\)), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\n\n\n```\n```"} -->

```r
```r
diffCutoff = 0.2
data <- fread(here(consensusDir, \chromo_cons_score.tsv\))

temp <- fread(here(consensusDir, \chromo_cons_score_async.tsv\)) %>%
  dplyr::select(id, UT, AID)

score.tb <- data %>% dplyr::full_join(temp, by = c(\id\)) %>%
  dplyr::mutate(diff_G1 = dTAG - DMSO,
                  diff_async = AID - UT)


### P1. UT vs AID
score.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$UT, score.tb$AID)
p1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P1. DMSO vs dTAG
score.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$dTAG)
p2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


### P3. DMSO vs A485
score.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$A485)
p3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P3. DMSO vs UT
score.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$UT)
p4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


### P3. dTAG vs AID
score.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$dTAG, score.tb$AID)
p5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P3. diff
score.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$diff_G1, score.tb$diff_async)
p6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-1, 0.5) + ylim(-1, 0.5) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \grey\) +
  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -1, y = 0.5, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


png(here(figDir, paste0(\consensus_score_scatterplot_pu100pz100_G1vsAsync.png\)), res = 600, units = \in\, width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = \h\, ncol = 3))
dev.off()
svglite(here(figDir, paste0(\consensus_score_scatterplot_pu100pz100_G1vsAsync.svg\)), width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = \h\, ncol = 3))
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ntemp <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe.bedpe\")) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \"_\"))\nregID <- temp$id\n\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \"chromo_cons_score.tsv\"))\n\ntemp <- fread(here(consensusDir, \"chromo_cons_score_async.tsv\")) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\"id\")) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT) %>%\n  dplyr::filter(id %in% regID)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \"grey\") +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \"grey\") +\n    theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -1, y = 0.5, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n\npng(here(figDir, paste0(\"consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.png\")), res = 600, units = \"in\", width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \"h\", ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\"consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.svg\")), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \"h\", ncol = 3))\ndev.off()\n\n\n########## Saving Async and G1 specific regulatory loop\ndiffCutoff <- 0.2\ntemp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async >= -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\"), sep = \"\\t\", col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async < -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\"), sep = \"\\t\", col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async >= -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\"), sep = \"\\t\", col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async < -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\"), sep = \"\\t\", col.names = FALSE)\n```"} -->\n\n```r\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nregID <- temp$id\n\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\ntemp <- fread(here(consensusDir, \\chromo_cons_score_async.tsv\\)) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\\id\\)) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT) %>%\n  dplyr::filter(id %in% regID)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n    theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -1, y = 0.5, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\npng(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.png\\)), res = 600, units = \\in\\, width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.svg\\)), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\n\n\n########## Saving Async and G1 specific regulatory loop\ndiffCutoff <- 0.2\ntemp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async >= -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async < -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async >= -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async < -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n```\n\n<!-- rnb-source-end -->\n"} -->
temp <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\)) %>%
  dplyr::mutate(res = V3 - V2,
                id = paste(V1, res, V2, V5, sep = \_\))
regID <- temp$id

diffCutoff = 0.2
data <- fread(here(consensusDir, \chromo_cons_score.tsv\))

temp <- fread(here(consensusDir, \chromo_cons_score_async.tsv\)) %>%
  dplyr::select(id, UT, AID)

score.tb <- data %>% dplyr::full_join(temp, by = c(\id\)) %>%
  dplyr::mutate(diff_G1 = dTAG - DMSO,
                  diff_async = AID - UT) %>%
  dplyr::filter(id %in% regID)


### P1. UT vs AID
score.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$UT, score.tb$AID)
p1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P1. DMSO vs dTAG
score.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$dTAG)
p2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


### P3. DMSO vs A485
score.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$A485)
p3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P3. DMSO vs UT
score.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$UT)
p4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


### P3. dTAG vs AID
score.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$dTAG, score.tb$AID)
p5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P3. diff
score.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$diff_G1, score.tb$diff_async)
p6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-1, 0.5) + ylim(-1, 0.5) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \grey\) +
  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \grey\) +
    theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -1, y = 0.5, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


png(here(figDir, paste0(\consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.png\)), res = 600, units = \in\, width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = \h\, ncol = 3))
dev.off()
svglite(here(figDir, paste0(\consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.svg\)), width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = \h\, ncol = 3))
dev.off()


########## Saving Async and G1 specific regulatory loop
diffCutoff <- 0.2
temp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async >= -diffCutoff) %>%
  dplyr::select(seq(1, 7))
fwrite(temp, here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\), sep = \\t\, col.names = FALSE)

temp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async < -diffCutoff) %>%
  dplyr::select(seq(1, 7))
fwrite(temp, here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\), sep = \\t\, col.names = FALSE)

temp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async >= -diffCutoff) %>%
  dplyr::select(seq(1, 7))
fwrite(temp, here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\), sep = \\t\, col.names = FALSE)

temp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async < -diffCutoff) %>%
  dplyr::select(seq(1, 7))
fwrite(temp, here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\), sep = \\t\, col.names = FALSE)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nregID <- temp$id\n\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\ntemp <- fread(here(consensusDir, \\chromo_cons_score_async.tsv\\)) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\\id\\)) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT) %>%\n  dplyr::filter(id %in% regID)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n    theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -1, y = 0.5, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\npng(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.png\\)), res = 600, units = \\in\\, width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.svg\\)), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\n\n\n########## Saving Async and G1 specific regulatory loop\ndiffCutoff <- 0.2\ntemp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async >= -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async < -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async >= -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async < -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n```\n```"} -->\n\n```r\n```r\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nregID <- temp$id\n\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\ntemp <- fread(here(consensusDir, \\chromo_cons_score_async.tsv\\)) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\\id\\)) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT) %>%\n  dplyr::filter(id %in% regID)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n    theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -1, y = 0.5, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\npng(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.png\\)), res = 600, units = \\in\\, width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.svg\\)), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\n\n\n########## Saving Async and G1 specific regulatory loop\ndiffCutoff <- 0.2\ntemp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async >= -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async < -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async >= -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async < -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nregID <- temp$id\n\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\ntemp <- fread(here(consensusDir, \\chromo_cons_score_async.tsv\\)) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\\id\\)) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT) %>%\n  dplyr::filter(id %in% regID)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n    theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -1, y = 0.5, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\npng(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.png\\)), res = 600, units = \\in\\, width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.svg\\)), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\n\n\n########## Saving Async and G1 specific regulatory loop\ndiffCutoff <- 0.2\ntemp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async >= -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async < -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async >= -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async < -diffCutoff) %>%\n  dplyr::select(seq(1, 7))\nfwrite(temp, here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n```\n```"} -->

```r
```r
temp <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\)) %>%
  dplyr::mutate(res = V3 - V2,
                id = paste(V1, res, V2, V5, sep = \_\))
regID <- temp$id

diffCutoff = 0.2
data <- fread(here(consensusDir, \chromo_cons_score.tsv\))

temp <- fread(here(consensusDir, \chromo_cons_score_async.tsv\)) %>%
  dplyr::select(id, UT, AID)

score.tb <- data %>% dplyr::full_join(temp, by = c(\id\)) %>%
  dplyr::mutate(diff_G1 = dTAG - DMSO,
                  diff_async = AID - UT) %>%
  dplyr::filter(id %in% regID)


### P1. UT vs AID
score.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$UT, score.tb$AID)
p1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P1. DMSO vs dTAG
score.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$dTAG)
p2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


### P3. DMSO vs A485
score.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$A485)
p3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P3. DMSO vs UT
score.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$UT)
p4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


### P3. dTAG vs AID
score.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$dTAG, score.tb$AID)
p5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P3. diff
score.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$diff_G1, score.tb$diff_async)
p6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-1, 0.5) + ylim(-1, 0.5) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \grey\) +
  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \grey\) +
    theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -1, y = 0.5, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


png(here(figDir, paste0(\consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.png\)), res = 600, units = \in\, width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = \h\, ncol = 3))
dev.off()
svglite(here(figDir, paste0(\consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.svg\)), width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = \h\, ncol = 3))
dev.off()


########## Saving Async and G1 specific regulatory loop
diffCutoff <- 0.2
temp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async >= -diffCutoff) %>%
  dplyr::select(seq(1, 7))
fwrite(temp, here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\), sep = \\t\, col.names = FALSE)

temp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async < -diffCutoff) %>%
  dplyr::select(seq(1, 7))
fwrite(temp, here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\), sep = \\t\, col.names = FALSE)

temp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async >= -diffCutoff) %>%
  dplyr::select(seq(1, 7))
fwrite(temp, here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\), sep = \\t\, col.names = FALSE)

temp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async < -diffCutoff) %>%
  dplyr::select(seq(1, 7))
fwrite(temp, here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\), sep = \\t\, col.names = FALSE)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



#### Comparing G1 vs Async for consensus loops
##### All loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ntemp <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_structure.bedpe\")) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \"_\"))\nregID <- temp$id\n\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \"chromo_cons_score.tsv\"))\n\ntemp <- fread(here(consensusDir, \"chromo_cons_score_async.tsv\")) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\"id\")) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT) %>%\n  dplyr::filter(id %in% regID)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \"grey\") +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \"grey\") +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \"grey\") +\n  theme_classic() + ggtitle(paste0(\"Consensus loop score\")) +\n  annotate(\"text\", x = -1, y = 0.5, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n\npng(here(figDir, paste0(\"consensus_score_scatterplot_pu100pz100_G1vsAsync_str.png\")), res = 600, units = \"in\", width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \"h\", ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\"consensus_score_scatterplot_pu100pz100_G1vsAsync_str.svg\")), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \"h\", ncol = 3))\ndev.off()\n\n\n```"} -->\n\n```r\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nregID <- temp$id\n\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\ntemp <- fread(here(consensusDir, \\chromo_cons_score_async.tsv\\)) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\\id\\)) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT) %>%\n  dplyr::filter(id %in% regID)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -1, y = 0.5, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\npng(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_str.png\\)), res = 600, units = \\in\\, width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_str.svg\\)), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
temp <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure.bedpe\)) %>%
  dplyr::mutate(res = V3 - V2,
                id = paste(V1, res, V2, V5, sep = \_\))
regID <- temp$id

diffCutoff = 0.2
data <- fread(here(consensusDir, \chromo_cons_score.tsv\))

temp <- fread(here(consensusDir, \chromo_cons_score_async.tsv\)) %>%
  dplyr::select(id, UT, AID)

score.tb <- data %>% dplyr::full_join(temp, by = c(\id\)) %>%
  dplyr::mutate(diff_G1 = dTAG - DMSO,
                  diff_async = AID - UT) %>%
  dplyr::filter(id %in% regID)


### P1. UT vs AID
score.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$UT, score.tb$AID)
p1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P1. DMSO vs dTAG
score.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$dTAG)
p2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


### P3. DMSO vs A485
score.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$A485)
p3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P3. DMSO vs UT
score.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$UT)
p4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


### P3. dTAG vs AID
score.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$dTAG, score.tb$AID)
p5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P3. diff
score.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$diff_G1, score.tb$diff_async)
p6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-1, 0.5) + ylim(-1, 0.5) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \grey\) +
  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \grey\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -1, y = 0.5, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


png(here(figDir, paste0(\consensus_score_scatterplot_pu100pz100_G1vsAsync_str.png\)), res = 600, units = \in\, width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = \h\, ncol = 3))
dev.off()
svglite(here(figDir, paste0(\consensus_score_scatterplot_pu100pz100_G1vsAsync_str.svg\)), width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = \h\, ncol = 3))
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nregID <- temp$id\n\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\ntemp <- fread(here(consensusDir, \\chromo_cons_score_async.tsv\\)) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\\id\\)) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT) %>%\n  dplyr::filter(id %in% regID)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -1, y = 0.5, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\npng(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_str.png\\)), res = 600, units = \\in\\, width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_str.svg\\)), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\n\n\n```\n```"} -->\n\n```r\n```r\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nregID <- temp$id\n\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\ntemp <- fread(here(consensusDir, \\chromo_cons_score_async.tsv\\)) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\\id\\)) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT) %>%\n  dplyr::filter(id %in% regID)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -1, y = 0.5, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\npng(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_str.png\\)), res = 600, units = \\in\\, width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_str.svg\\)), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nregID <- temp$id\n\ndiffCutoff = 0.2\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\ntemp <- fread(here(consensusDir, \\chromo_cons_score_async.tsv\\)) %>%\n  dplyr::select(id, UT, AID)\n\nscore.tb <- data %>% dplyr::full_join(temp, by = c(\\id\\)) %>%\n  dplyr::mutate(diff_G1 = dTAG - DMSO,\n                  diff_async = AID - UT) %>%\n  dplyr::filter(id %in% regID)\n\n\n### P1. UT vs AID\nscore.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$UT, score.tb$AID)\np1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P1. DMSO vs dTAG\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$dTAG)\np2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. DMSO vs A485\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$A485)\np3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. DMSO vs UT\nscore.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$DMSO, score.tb$UT)\np4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\n### P3. dTAG vs AID\nscore.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$dTAG, score.tb$AID)\np5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n### P3. diff\nscore.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)\nscore.tb <- score.tb %>% dplyr::arrange(density)\ncorrelation <- cor(score.tb$diff_G1, score.tb$diff_async)\np6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +\n  geom_point() + \n  scale_color_viridis() +\n  xlim(-1, 0.5) + ylim(-1, 0.5) +\n  coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \\grey\\) +\n  theme_classic() + ggtitle(paste0(\\Consensus loop score\\)) +\n  annotate(\\text\\, x = -1, y = 0.5, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\)\n\n\npng(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_str.png\\)), res = 600, units = \\in\\, width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\nsvglite(here(figDir, paste0(\\consensus_score_scatterplot_pu100pz100_G1vsAsync_str.svg\\)), width = 5*2.5, height = 2.5*2.5)\nprint(cowplot::plot_grid(p1, p2, p3, \n                         p4, p5, p6, align = \\h\\, ncol = 3))\ndev.off()\n\n\n```\n```"} -->

```r
```r
temp <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure.bedpe\)) %>%
  dplyr::mutate(res = V3 - V2,
                id = paste(V1, res, V2, V5, sep = \_\))
regID <- temp$id

diffCutoff = 0.2
data <- fread(here(consensusDir, \chromo_cons_score.tsv\))

temp <- fread(here(consensusDir, \chromo_cons_score_async.tsv\)) %>%
  dplyr::select(id, UT, AID)

score.tb <- data %>% dplyr::full_join(temp, by = c(\id\)) %>%
  dplyr::mutate(diff_G1 = dTAG - DMSO,
                  diff_async = AID - UT) %>%
  dplyr::filter(id %in% regID)


### P1. UT vs AID
score.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$UT, score.tb$AID)
p1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P1. DMSO vs dTAG
score.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$dTAG)
p2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


### P3. DMSO vs A485
score.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$A485)
p3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P3. DMSO vs UT
score.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$UT)
p4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


### P3. dTAG vs AID
score.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$dTAG, score.tb$AID)
p5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

### P3. diff
score.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$diff_G1, score.tb$diff_async)
p6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-1, 0.5) + ylim(-1, 0.5) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = \grey\) +
  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = \grey\) +
  theme_classic() + ggtitle(paste0(\Consensus loop score\)) +
  annotate(\text\, x = -1, y = 0.5, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)


png(here(figDir, paste0(\consensus_score_scatterplot_pu100pz100_G1vsAsync_str.png\)), res = 600, units = \in\, width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = \h\, ncol = 3))
dev.off()
svglite(here(figDir, paste0(\consensus_score_scatterplot_pu100pz100_G1vsAsync_str.svg\)), width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = \h\, ncol = 3))
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### reg loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBJbXBvcnRpbmcgbG9vcHMuIEZvciBtYWtlIGNvbXBhcmlzb24gZWFzaWVyLCAyNSBrYlxuYmluU2l6ZSA9IDI1KjEwMDBcbnRlbXAgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiVGppYW5fY2hyb21vc2lnaHRfbG9vcC5iZWRwZVwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2VudGVyMSA9IDAuNSooVjIgKyBWMyksXG4gICAgICAgICAgICAgICAgY2VudGVyMiA9IDAuNSooVjUgKyBWNiksXG4gICAgICAgICAgICAgICAgc3RhcnQxID0gY2VudGVyMSAtIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIGVuZDEgPSBjZW50ZXIxICsgMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgc3RhcnQyID0gY2VudGVyMiAtIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIGVuZDIgPSBjZW50ZXIyICsgMC41KmJpblNpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBzdGFydDEsIGVuZDEsIFY0LCBzdGFydDIsIGVuZDIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFwiVjFcIiwgXCJWMlwiLCBcIlYzXCIsIFwiVjRcIiwgXCJWNVwiLCBcIlY2XCIpXG5sb29wLmFzeW5jIDwtIGltcG9ydEJlZHBlKHRlbXApXG5cblxuYmluU2l6ZSA9IDI1KjEwMDBcbnRlbXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnMuYmVkcGVcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKGNlbnRlcjEgPSAwLjUqKFYyICsgVjMpLFxuICAgICAgICAgICAgICAgIGNlbnRlcjIgPSAwLjUqKFY1ICsgVjYpLFxuICAgICAgICAgICAgICAgIHN0YXJ0MSA9IGNlbnRlcjEgLSAwLjUqYmluU2l6ZSxcbiAgICAgICAgICAgICAgICBlbmQxID0gY2VudGVyMSArIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIHN0YXJ0MiA9IGNlbnRlcjIgLSAwLjUqYmluU2l6ZSxcbiAgICAgICAgICAgICAgICBlbmQyID0gY2VudGVyMiArIDAuNSpiaW5TaXplKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWMSwgc3RhcnQxLCBlbmQxLCBWNCwgc3RhcnQyLCBlbmQyKVxuY29sbmFtZXModGVtcCkgPC0gYyhcIlYxXCIsIFwiVjJcIiwgXCJWM1wiLCBcIlY0XCIsIFwiVjVcIiwgXCJWNlwiKVxubG9vcC5HMSA8LSBpbXBvcnRCZWRwZSh0ZW1wKVxuXG5cbiMgQ2hlY2sgb3ZlcmxhcFxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMobG9vcC5hc3luYywgbG9vcC5HMSlcblxuXG5uLmFzeW5jIDwtIG5yb3coYXNfdGliYmxlKGxvb3AuYXN5bmMpKVxubi5HMSA8LSBucm93KGFzX3RpYmJsZShsb29wLkcxKSlcbm4uYXN5bmMub3ZlcmxhcCA8LSBsZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhvdmVybGFwKSkpXG5uLkcxLm92ZXJsYXAgPC0gbGVuZ3RoKHVuaXF1ZShzdWJqZWN0SGl0cyhvdmVybGFwKSkpXG5cbnBsb3QoZXVsZXIoYyhcIkFzeW5jXCIgPSBuLmFzeW5jIC0gbi5hc3luYy5vdmVybGFwLFxuICAgICAgICAgICAgIFwiQXN5bmMmRzFcIiA9IG4uYXN5bmMub3ZlcmxhcCxcbiAgICAgICAgICAgICBcIkcxXCIgPSAxKSksIHF1YW50aXRpZXMgPSBUUlVFKVxuXG5cbnBsb3QoZXVsZXIoYyhcIkFzeW5jXCIgPTEsXG4gICAgICAgICAgICAgXCJBc3luYyZHMVwiID0gbi5HMS5vdmVybGFwLFxuICAgICAgICAgICAgIFwiRzFcIiA9IG4uRzEgLSBuLkcxLm92ZXJsYXApKSwgcXVhbnRpdGllcyA9IFRSVUUpXG5cblxuXG5cbiMgSW1wb3J0aW5nIGxvb3BzLiBGb3IgbWFrZSBjb21wYXJpc29uIGVhc2llciwgMjUga2JcbmJpblNpemUgPSAyNSoxMDAwXG50ZW1wLnBwIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcIlRqaWFuX2Nocm9tb3NpZ2h0X2xvb3BfUC1QLmJlZHBlXCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjZW50ZXIxID0gMC41KihWMiArIFYzKSxcbiAgICAgICAgICAgICAgICBjZW50ZXIyID0gMC41KihWNSArIFY2KSxcbiAgICAgICAgICAgICAgICBzdGFydDEgPSBjZW50ZXIxIC0gMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgZW5kMSA9IGNlbnRlcjEgKyAwLjUqYmluU2l6ZSxcbiAgICAgICAgICAgICAgICBzdGFydDIgPSBjZW50ZXIyIC0gMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgZW5kMiA9IGNlbnRlcjIgKyAwLjUqYmluU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIHN0YXJ0MSwgZW5kMSwgVjQsIHN0YXJ0MiwgZW5kMilcbmNvbG5hbWVzKHRlbXAucHApIDwtIGMoXCJWMVwiLCBcIlYyXCIsIFwiVjNcIiwgXCJWNFwiLCBcIlY1XCIsIFwiVjZcIilcbmJpblNpemUgPSAyNSoxMDAwXG50ZW1wLmVwIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcIlRqaWFuX2Nocm9tb3NpZ2h0X2xvb3BfRS1QLmJlZHBlXCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjZW50ZXIxID0gMC41KihWMiArIFYzKSxcbiAgICAgICAgICAgICAgICBjZW50ZXIyID0gMC41KihWNSArIFY2KSxcbiAgICAgICAgICAgICAgICBzdGFydDEgPSBjZW50ZXIxIC0gMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgZW5kMSA9IGNlbnRlcjEgKyAwLjUqYmluU2l6ZSxcbiAgICAgICAgICAgICAgICBzdGFydDIgPSBjZW50ZXIyIC0gMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgZW5kMiA9IGNlbnRlcjIgKyAwLjUqYmluU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIHN0YXJ0MSwgZW5kMSwgVjQsIHN0YXJ0MiwgZW5kMilcbmNvbG5hbWVzKHRlbXAuZXApIDwtIGMoXCJWMVwiLCBcIlYyXCIsIFwiVjNcIiwgXCJWNFwiLCBcIlY1XCIsIFwiVjZcIilcbnRlbXAgPC0gYmluZF9yb3dzKHRlbXAucHAsIHRlbXAuZXApXG5sb29wLmFzeW5jIDwtIGltcG9ydEJlZHBlKHRlbXApXG5cblxuYmluU2l6ZSA9IDI1KjEwMDBcbnRlbXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZS5iZWRwZVwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2VudGVyMSA9IDAuNSooVjIgKyBWMyksXG4gICAgICAgICAgICAgICAgY2VudGVyMiA9IDAuNSooVjUgKyBWNiksXG4gICAgICAgICAgICAgICAgc3RhcnQxID0gY2VudGVyMSAtIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIGVuZDEgPSBjZW50ZXIxICsgMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgc3RhcnQyID0gY2VudGVyMiAtIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIGVuZDIgPSBjZW50ZXIyICsgMC41KmJpblNpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBzdGFydDEsIGVuZDEsIFY0LCBzdGFydDIsIGVuZDIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFwiVjFcIiwgXCJWMlwiLCBcIlYzXCIsIFwiVjRcIiwgXCJWNVwiLCBcIlY2XCIpXG5sb29wLkcxIDwtIGltcG9ydEJlZHBlKHRlbXApXG5cblxuIyBDaGVjayBvdmVybGFwXG5vdmVybGFwIDwtIGZpbmRPdmVybGFwcyhsb29wLmFzeW5jLCBsb29wLkcxKVxuXG5cbm4uYXN5bmMgPC0gbnJvdyhhc190aWJibGUobG9vcC5hc3luYykpXG5uLkcxIDwtIG5yb3coYXNfdGliYmxlKGxvb3AuRzEpKVxubi5hc3luYy5vdmVybGFwIDwtIGxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKG92ZXJsYXApKSlcbm4uRzEub3ZlcmxhcCA8LSBsZW5ndGgodW5pcXVlKHN1YmplY3RIaXRzKG92ZXJsYXApKSlcblxucGxvdChldWxlcihjKFwiQXN5bmNcIiA9IG4uYXN5bmMgLSBuLmFzeW5jLm92ZXJsYXAsXG4gICAgICAgICAgICAgXCJBc3luYyZHMVwiID0gbi5hc3luYy5vdmVybGFwLFxuICAgICAgICAgICAgIFwiRzFcIiA9IDEpKSwgcXVhbnRpdGllcyA9IFRSVUUpXG5cblxucGxvdChldWxlcihjKFwiQXN5bmNcIiA9MC4xLFxuICAgICAgICAgICAgIFwiQXN5bmMmRzFcIiA9IG4uRzEub3ZlcmxhcCxcbiAgICAgICAgICAgICBcIkcxXCIgPSBuLkcxIC0gbi5HMS5vdmVybGFwKSksIHF1YW50aXRpZXMgPSBUUlVFKVxuXG5gYGAifQ== -->\n\n```r\n# Importing loops. For make comparison easier, 25 kb\nbinSize = 25*1000\ntemp <- fread(here(refDir, \\Tjian_chromosight_loop.bedpe\\)) %>%\n  dplyr::mutate(center1 = 0.5*(V2 + V3),\n                center2 = 0.5*(V5 + V6),\n                start1 = center1 - 0.5*binSize,\n                end1 = center1 + 0.5*binSize,\n                start2 = center2 - 0.5*binSize,\n                end2 = center2 + 0.5*binSize) %>%\n  dplyr::select(V1, start1, end1, V4, start2, end2)\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloop.async <- importBedpe(temp)\n\n\nbinSize = 25*1000\ntemp <- fread(here(consensusDir, \\chromo_cons.bedpe\\)) %>%\n  dplyr::mutate(center1 = 0.5*(V2 + V3),\n                center2 = 0.5*(V5 + V6),\n                start1 = center1 - 0.5*binSize,\n                end1 = center1 + 0.5*binSize,\n                start2 = center2 - 0.5*binSize,\n                end2 = center2 + 0.5*binSize) %>%\n  dplyr::select(V1, start1, end1, V4, start2, end2)\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloop.G1 <- importBedpe(temp)\n\n\n# Check overlap\noverlap <- findOverlaps(loop.async, loop.G1)\n\n\nn.async <- nrow(as_tibble(loop.async))\nn.G1 <- nrow(as_tibble(loop.G1))\nn.async.overlap <- length(unique(queryHits(overlap)))\nn.G1.overlap <- length(unique(subjectHits(overlap)))\n\nplot(euler(c(\\Async\\ = n.async - n.async.overlap,\n             \\Async&G1\\ = n.async.overlap,\n             \\G1\\ = 1)), quantities = TRUE)\n\n\nplot(euler(c(\\Async\\ =1,\n             \\Async&G1\\ = n.G1.overlap,\n             \\G1\\ = n.G1 - n.G1.overlap)), quantities = TRUE)\n\n\n\n\n# Importing loops. For make comparison easier, 25 kb\nbinSize = 25*1000\ntemp.pp <- fread(here(refDir, \\Tjian_chromosight_loop_P-P.bedpe\\)) %>%\n  dplyr::mutate(center1 = 0.5*(V2 + V3),\n                center2 = 0.5*(V5 + V6),\n                start1 = center1 - 0.5*binSize,\n                end1 = center1 + 0.5*binSize,\n                start2 = center2 - 0.5*binSize,\n                end2 = center2 + 0.5*binSize) %>%\n  dplyr::select(V1, start1, end1, V4, start2, end2)\ncolnames(temp.pp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nbinSize = 25*1000\ntemp.ep <- fread(here(refDir, \\Tjian_chromosight_loop_E-P.bedpe\\)) %>%\n  dplyr::mutate(center1 = 0.5*(V2 + V3),\n                center2 = 0.5*(V5 + V6),\n                start1 = center1 - 0.5*binSize,\n                end1 = center1 + 0.5*binSize,\n                start2 = center2 - 0.5*binSize,\n                end2 = center2 + 0.5*binSize) %>%\n  dplyr::select(V1, start1, end1, V4, start2, end2)\ncolnames(temp.ep) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\ntemp <- bind_rows(temp.pp, temp.ep)\nloop.async <- importBedpe(temp)\n\n\nbinSize = 25*1000\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\)) %>%\n  dplyr::mutate(center1 = 0.5*(V2 + V3),\n                center2 = 0.5*(V5 + V6),\n                start1 = center1 - 0.5*binSize,\n                end1 = center1 + 0.5*binSize,\n                start2 = center2 - 0.5*binSize,\n                end2 = center2 + 0.5*binSize) %>%\n  dplyr::select(V1, start1, end1, V4, start2, end2)\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloop.G1 <- importBedpe(temp)\n\n\n# Check overlap\noverlap <- findOverlaps(loop.async, loop.G1)\n\n\nn.async <- nrow(as_tibble(loop.async))\nn.G1 <- nrow(as_tibble(loop.G1))\nn.async.overlap <- length(unique(queryHits(overlap)))\nn.G1.overlap <- length(unique(subjectHits(overlap)))\n\nplot(euler(c(\\Async\\ = n.async - n.async.overlap,\n             \\Async&G1\\ = n.async.overlap,\n             \\G1\\ = 1)), quantities = TRUE)\n\n\nplot(euler(c(\\Async\\ =0.1,\n             \\Async&G1\\ = n.G1.overlap,\n             \\G1\\ = n.G1 - n.G1.overlap)), quantities = TRUE)\n\n```\n\n<!-- rnb-source-end -->\n"} -->
# Importing loops. For make comparison easier, 25 kb
binSize = 25*1000
temp <- fread(here(refDir, \Tjian_chromosight_loop.bedpe\)) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
loop.async <- importBedpe(temp)


binSize = 25*1000
temp <- fread(here(consensusDir, \chromo_cons.bedpe\)) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
loop.G1 <- importBedpe(temp)


# Check overlap
overlap <- findOverlaps(loop.async, loop.G1)


n.async <- nrow(as_tibble(loop.async))
n.G1 <- nrow(as_tibble(loop.G1))
n.async.overlap <- length(unique(queryHits(overlap)))
n.G1.overlap <- length(unique(subjectHits(overlap)))

plot(euler(c(\Async\ = n.async - n.async.overlap,
             \Async&G1\ = n.async.overlap,
             \G1\ = 1)), quantities = TRUE)


plot(euler(c(\Async\ =1,
             \Async&G1\ = n.G1.overlap,
             \G1\ = n.G1 - n.G1.overlap)), quantities = TRUE)




# Importing loops. For make comparison easier, 25 kb
binSize = 25*1000
temp.pp <- fread(here(refDir, \Tjian_chromosight_loop_P-P.bedpe\)) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp.pp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
binSize = 25*1000
temp.ep <- fread(here(refDir, \Tjian_chromosight_loop_E-P.bedpe\)) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp.ep) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
temp <- bind_rows(temp.pp, temp.ep)
loop.async <- importBedpe(temp)


binSize = 25*1000
temp <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\)) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
loop.G1 <- importBedpe(temp)


# Check overlap
overlap <- findOverlaps(loop.async, loop.G1)


n.async <- nrow(as_tibble(loop.async))
n.G1 <- nrow(as_tibble(loop.G1))
n.async.overlap <- length(unique(queryHits(overlap)))
n.G1.overlap <- length(unique(subjectHits(overlap)))

plot(euler(c(\Async\ = n.async - n.async.overlap,
             \Async&G1\ = n.async.overlap,
             \G1\ = 1)), quantities = TRUE)


plot(euler(c(\Async\ =0.1,
             \Async&G1\ = n.G1.overlap,
             \G1\ = n.G1 - n.G1.overlap)), quantities = TRUE)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBJbXBvcnRpbmcgbG9vcHMuIEZvciBtYWtlIGNvbXBhcmlzb24gZWFzaWVyLCAyNSBrYlxuYmluU2l6ZSA9IDI1KjEwMDBcbnRlbXAgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcVGppYW5fY2hyb21vc2lnaHRfbG9vcC5iZWRwZVxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2VudGVyMSA9IDAuNSooVjIgKyBWMyksXG4gICAgICAgICAgICAgICAgY2VudGVyMiA9IDAuNSooVjUgKyBWNiksXG4gICAgICAgICAgICAgICAgc3RhcnQxID0gY2VudGVyMSAtIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIGVuZDEgPSBjZW50ZXIxICsgMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgc3RhcnQyID0gY2VudGVyMiAtIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIGVuZDIgPSBjZW50ZXIyICsgMC41KmJpblNpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBzdGFydDEsIGVuZDEsIFY0LCBzdGFydDIsIGVuZDIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcVjFcXCwgXFxWMlxcLCBcXFYzXFwsIFxcVjRcXCwgXFxWNVxcLCBcXFY2XFwpXG5sb29wLmFzeW5jIDwtIGltcG9ydEJlZHBlKHRlbXApXG5cblxuYmluU2l6ZSA9IDI1KjEwMDBcbnRlbXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnMuYmVkcGVcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGNlbnRlcjEgPSAwLjUqKFYyICsgVjMpLFxuICAgICAgICAgICAgICAgIGNlbnRlcjIgPSAwLjUqKFY1ICsgVjYpLFxuICAgICAgICAgICAgICAgIHN0YXJ0MSA9IGNlbnRlcjEgLSAwLjUqYmluU2l6ZSxcbiAgICAgICAgICAgICAgICBlbmQxID0gY2VudGVyMSArIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIHN0YXJ0MiA9IGNlbnRlcjIgLSAwLjUqYmluU2l6ZSxcbiAgICAgICAgICAgICAgICBlbmQyID0gY2VudGVyMiArIDAuNSpiaW5TaXplKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWMSwgc3RhcnQxLCBlbmQxLCBWNCwgc3RhcnQyLCBlbmQyKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXFYxXFwsIFxcVjJcXCwgXFxWM1xcLCBcXFY0XFwsIFxcVjVcXCwgXFxWNlxcKVxubG9vcC5HMSA8LSBpbXBvcnRCZWRwZSh0ZW1wKVxuXG5cbiMgQ2hlY2sgb3ZlcmxhcFxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMobG9vcC5hc3luYywgbG9vcC5HMSlcblxuXG5uLmFzeW5jIDwtIG5yb3coYXNfdGliYmxlKGxvb3AuYXN5bmMpKVxubi5HMSA8LSBucm93KGFzX3RpYmJsZShsb29wLkcxKSlcbm4uYXN5bmMub3ZlcmxhcCA8LSBsZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhvdmVybGFwKSkpXG5uLkcxLm92ZXJsYXAgPC0gbGVuZ3RoKHVuaXF1ZShzdWJqZWN0SGl0cyhvdmVybGFwKSkpXG5cbnBsb3QoZXVsZXIoYyhcXEFzeW5jXFwgPSBuLmFzeW5jIC0gbi5hc3luYy5vdmVybGFwLFxuICAgICAgICAgICAgIFxcQXN5bmMmRzFcXCA9IG4uYXN5bmMub3ZlcmxhcCxcbiAgICAgICAgICAgICBcXEcxXFwgPSAxKSksIHF1YW50aXRpZXMgPSBUUlVFKVxuXG5cbnBsb3QoZXVsZXIoYyhcXEFzeW5jXFwgPTEsXG4gICAgICAgICAgICAgXFxBc3luYyZHMVxcID0gbi5HMS5vdmVybGFwLFxuICAgICAgICAgICAgIFxcRzFcXCA9IG4uRzEgLSBuLkcxLm92ZXJsYXApKSwgcXVhbnRpdGllcyA9IFRSVUUpXG5cblxuXG5cbiMgSW1wb3J0aW5nIGxvb3BzLiBGb3IgbWFrZSBjb21wYXJpc29uIGVhc2llciwgMjUga2JcbmJpblNpemUgPSAyNSoxMDAwXG50ZW1wLnBwIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXFRqaWFuX2Nocm9tb3NpZ2h0X2xvb3BfUC1QLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjZW50ZXIxID0gMC41KihWMiArIFYzKSxcbiAgICAgICAgICAgICAgICBjZW50ZXIyID0gMC41KihWNSArIFY2KSxcbiAgICAgICAgICAgICAgICBzdGFydDEgPSBjZW50ZXIxIC0gMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgZW5kMSA9IGNlbnRlcjEgKyAwLjUqYmluU2l6ZSxcbiAgICAgICAgICAgICAgICBzdGFydDIgPSBjZW50ZXIyIC0gMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgZW5kMiA9IGNlbnRlcjIgKyAwLjUqYmluU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIHN0YXJ0MSwgZW5kMSwgVjQsIHN0YXJ0MiwgZW5kMilcbmNvbG5hbWVzKHRlbXAucHApIDwtIGMoXFxWMVxcLCBcXFYyXFwsIFxcVjNcXCwgXFxWNFxcLCBcXFY1XFwsIFxcVjZcXClcbmJpblNpemUgPSAyNSoxMDAwXG50ZW1wLmVwIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXFRqaWFuX2Nocm9tb3NpZ2h0X2xvb3BfRS1QLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjZW50ZXIxID0gMC41KihWMiArIFYzKSxcbiAgICAgICAgICAgICAgICBjZW50ZXIyID0gMC41KihWNSArIFY2KSxcbiAgICAgICAgICAgICAgICBzdGFydDEgPSBjZW50ZXIxIC0gMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgZW5kMSA9IGNlbnRlcjEgKyAwLjUqYmluU2l6ZSxcbiAgICAgICAgICAgICAgICBzdGFydDIgPSBjZW50ZXIyIC0gMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgZW5kMiA9IGNlbnRlcjIgKyAwLjUqYmluU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIHN0YXJ0MSwgZW5kMSwgVjQsIHN0YXJ0MiwgZW5kMilcbmNvbG5hbWVzKHRlbXAuZXApIDwtIGMoXFxWMVxcLCBcXFYyXFwsIFxcVjNcXCwgXFxWNFxcLCBcXFY1XFwsIFxcVjZcXClcbnRlbXAgPC0gYmluZF9yb3dzKHRlbXAucHAsIHRlbXAuZXApXG5sb29wLmFzeW5jIDwtIGltcG9ydEJlZHBlKHRlbXApXG5cblxuYmluU2l6ZSA9IDI1KjEwMDBcbnRlbXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZS5iZWRwZVxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2VudGVyMSA9IDAuNSooVjIgKyBWMyksXG4gICAgICAgICAgICAgICAgY2VudGVyMiA9IDAuNSooVjUgKyBWNiksXG4gICAgICAgICAgICAgICAgc3RhcnQxID0gY2VudGVyMSAtIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIGVuZDEgPSBjZW50ZXIxICsgMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgc3RhcnQyID0gY2VudGVyMiAtIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIGVuZDIgPSBjZW50ZXIyICsgMC41KmJpblNpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBzdGFydDEsIGVuZDEsIFY0LCBzdGFydDIsIGVuZDIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcVjFcXCwgXFxWMlxcLCBcXFYzXFwsIFxcVjRcXCwgXFxWNVxcLCBcXFY2XFwpXG5sb29wLkcxIDwtIGltcG9ydEJlZHBlKHRlbXApXG5cblxuIyBDaGVjayBvdmVybGFwXG5vdmVybGFwIDwtIGZpbmRPdmVybGFwcyhsb29wLmFzeW5jLCBsb29wLkcxKVxuXG5cbm4uYXN5bmMgPC0gbnJvdyhhc190aWJibGUobG9vcC5hc3luYykpXG5uLkcxIDwtIG5yb3coYXNfdGliYmxlKGxvb3AuRzEpKVxubi5hc3luYy5vdmVybGFwIDwtIGxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKG92ZXJsYXApKSlcbm4uRzEub3ZlcmxhcCA8LSBsZW5ndGgodW5pcXVlKHN1YmplY3RIaXRzKG92ZXJsYXApKSlcblxucGxvdChldWxlcihjKFxcQXN5bmNcXCA9IG4uYXN5bmMgLSBuLmFzeW5jLm92ZXJsYXAsXG4gICAgICAgICAgICAgXFxBc3luYyZHMVxcID0gbi5hc3luYy5vdmVybGFwLFxuICAgICAgICAgICAgIFxcRzFcXCA9IDEpKSwgcXVhbnRpdGllcyA9IFRSVUUpXG5cblxucGxvdChldWxlcihjKFxcQXN5bmNcXCA9MC4xLFxuICAgICAgICAgICAgIFxcQXN5bmMmRzFcXCA9IG4uRzEub3ZlcmxhcCxcbiAgICAgICAgICAgICBcXEcxXFwgPSBuLkcxIC0gbi5HMS5vdmVybGFwKSksIHF1YW50aXRpZXMgPSBUUlVFKVxuXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\n# Importing loops. For make comparison easier, 25 kb\nbinSize = 25*1000\ntemp <- fread(here(refDir, \\Tjian_chromosight_loop.bedpe\\)) %>%\n  dplyr::mutate(center1 = 0.5*(V2 + V3),\n                center2 = 0.5*(V5 + V6),\n                start1 = center1 - 0.5*binSize,\n                end1 = center1 + 0.5*binSize,\n                start2 = center2 - 0.5*binSize,\n                end2 = center2 + 0.5*binSize) %>%\n  dplyr::select(V1, start1, end1, V4, start2, end2)\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloop.async <- importBedpe(temp)\n\n\nbinSize = 25*1000\ntemp <- fread(here(consensusDir, \\chromo_cons.bedpe\\)) %>%\n  dplyr::mutate(center1 = 0.5*(V2 + V3),\n                center2 = 0.5*(V5 + V6),\n                start1 = center1 - 0.5*binSize,\n                end1 = center1 + 0.5*binSize,\n                start2 = center2 - 0.5*binSize,\n                end2 = center2 + 0.5*binSize) %>%\n  dplyr::select(V1, start1, end1, V4, start2, end2)\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloop.G1 <- importBedpe(temp)\n\n\n# Check overlap\noverlap <- findOverlaps(loop.async, loop.G1)\n\n\nn.async <- nrow(as_tibble(loop.async))\nn.G1 <- nrow(as_tibble(loop.G1))\nn.async.overlap <- length(unique(queryHits(overlap)))\nn.G1.overlap <- length(unique(subjectHits(overlap)))\n\nplot(euler(c(\\Async\\ = n.async - n.async.overlap,\n             \\Async&G1\\ = n.async.overlap,\n             \\G1\\ = 1)), quantities = TRUE)\n\n\nplot(euler(c(\\Async\\ =1,\n             \\Async&G1\\ = n.G1.overlap,\n             \\G1\\ = n.G1 - n.G1.overlap)), quantities = TRUE)\n\n\n\n\n# Importing loops. For make comparison easier, 25 kb\nbinSize = 25*1000\ntemp.pp <- fread(here(refDir, \\Tjian_chromosight_loop_P-P.bedpe\\)) %>%\n  dplyr::mutate(center1 = 0.5*(V2 + V3),\n                center2 = 0.5*(V5 + V6),\n                start1 = center1 - 0.5*binSize,\n                end1 = center1 + 0.5*binSize,\n                start2 = center2 - 0.5*binSize,\n                end2 = center2 + 0.5*binSize) %>%\n  dplyr::select(V1, start1, end1, V4, start2, end2)\ncolnames(temp.pp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nbinSize = 25*1000\ntemp.ep <- fread(here(refDir, \\Tjian_chromosight_loop_E-P.bedpe\\)) %>%\n  dplyr::mutate(center1 = 0.5*(V2 + V3),\n                center2 = 0.5*(V5 + V6),\n                start1 = center1 - 0.5*binSize,\n                end1 = center1 + 0.5*binSize,\n                start2 = center2 - 0.5*binSize,\n                end2 = center2 + 0.5*binSize) %>%\n  dplyr::select(V1, start1, end1, V4, start2, end2)\ncolnames(temp.ep) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\ntemp <- bind_rows(temp.pp, temp.ep)\nloop.async <- importBedpe(temp)\n\n\nbinSize = 25*1000\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\)) %>%\n  dplyr::mutate(center1 = 0.5*(V2 + V3),\n                center2 = 0.5*(V5 + V6),\n                start1 = center1 - 0.5*binSize,\n                end1 = center1 + 0.5*binSize,\n                start2 = center2 - 0.5*binSize,\n                end2 = center2 + 0.5*binSize) %>%\n  dplyr::select(V1, start1, end1, V4, start2, end2)\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloop.G1 <- importBedpe(temp)\n\n\n# Check overlap\noverlap <- findOverlaps(loop.async, loop.G1)\n\n\nn.async <- nrow(as_tibble(loop.async))\nn.G1 <- nrow(as_tibble(loop.G1))\nn.async.overlap <- length(unique(queryHits(overlap)))\nn.G1.overlap <- length(unique(subjectHits(overlap)))\n\nplot(euler(c(\\Async\\ = n.async - n.async.overlap,\n             \\Async&G1\\ = n.async.overlap,\n             \\G1\\ = 1)), quantities = TRUE)\n\n\nplot(euler(c(\\Async\\ =0.1,\n             \\Async&G1\\ = n.G1.overlap,\n             \\G1\\ = n.G1 - n.G1.overlap)), quantities = TRUE)\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBJbXBvcnRpbmcgbG9vcHMuIEZvciBtYWtlIGNvbXBhcmlzb24gZWFzaWVyLCAyNSBrYlxuYmluU2l6ZSA9IDI1KjEwMDBcbnRlbXAgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcVGppYW5fY2hyb21vc2lnaHRfbG9vcC5iZWRwZVxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2VudGVyMSA9IDAuNSooVjIgKyBWMyksXG4gICAgICAgICAgICAgICAgY2VudGVyMiA9IDAuNSooVjUgKyBWNiksXG4gICAgICAgICAgICAgICAgc3RhcnQxID0gY2VudGVyMSAtIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIGVuZDEgPSBjZW50ZXIxICsgMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgc3RhcnQyID0gY2VudGVyMiAtIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIGVuZDIgPSBjZW50ZXIyICsgMC41KmJpblNpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBzdGFydDEsIGVuZDEsIFY0LCBzdGFydDIsIGVuZDIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcVjFcXCwgXFxWMlxcLCBcXFYzXFwsIFxcVjRcXCwgXFxWNVxcLCBcXFY2XFwpXG5sb29wLmFzeW5jIDwtIGltcG9ydEJlZHBlKHRlbXApXG5cblxuYmluU2l6ZSA9IDI1KjEwMDBcbnRlbXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnMuYmVkcGVcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGNlbnRlcjEgPSAwLjUqKFYyICsgVjMpLFxuICAgICAgICAgICAgICAgIGNlbnRlcjIgPSAwLjUqKFY1ICsgVjYpLFxuICAgICAgICAgICAgICAgIHN0YXJ0MSA9IGNlbnRlcjEgLSAwLjUqYmluU2l6ZSxcbiAgICAgICAgICAgICAgICBlbmQxID0gY2VudGVyMSArIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIHN0YXJ0MiA9IGNlbnRlcjIgLSAwLjUqYmluU2l6ZSxcbiAgICAgICAgICAgICAgICBlbmQyID0gY2VudGVyMiArIDAuNSpiaW5TaXplKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWMSwgc3RhcnQxLCBlbmQxLCBWNCwgc3RhcnQyLCBlbmQyKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXFYxXFwsIFxcVjJcXCwgXFxWM1xcLCBcXFY0XFwsIFxcVjVcXCwgXFxWNlxcKVxubG9vcC5HMSA8LSBpbXBvcnRCZWRwZSh0ZW1wKVxuXG5cbiMgQ2hlY2sgb3ZlcmxhcFxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMobG9vcC5hc3luYywgbG9vcC5HMSlcblxuXG5uLmFzeW5jIDwtIG5yb3coYXNfdGliYmxlKGxvb3AuYXN5bmMpKVxubi5HMSA8LSBucm93KGFzX3RpYmJsZShsb29wLkcxKSlcbm4uYXN5bmMub3ZlcmxhcCA8LSBsZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhvdmVybGFwKSkpXG5uLkcxLm92ZXJsYXAgPC0gbGVuZ3RoKHVuaXF1ZShzdWJqZWN0SGl0cyhvdmVybGFwKSkpXG5cbnBsb3QoZXVsZXIoYyhcXEFzeW5jXFwgPSBuLmFzeW5jIC0gbi5hc3luYy5vdmVybGFwLFxuICAgICAgICAgICAgIFxcQXN5bmMmRzFcXCA9IG4uYXN5bmMub3ZlcmxhcCxcbiAgICAgICAgICAgICBcXEcxXFwgPSAxKSksIHF1YW50aXRpZXMgPSBUUlVFKVxuXG5cbnBsb3QoZXVsZXIoYyhcXEFzeW5jXFwgPTEsXG4gICAgICAgICAgICAgXFxBc3luYyZHMVxcID0gbi5HMS5vdmVybGFwLFxuICAgICAgICAgICAgIFxcRzFcXCA9IG4uRzEgLSBuLkcxLm92ZXJsYXApKSwgcXVhbnRpdGllcyA9IFRSVUUpXG5cblxuXG5cbiMgSW1wb3J0aW5nIGxvb3BzLiBGb3IgbWFrZSBjb21wYXJpc29uIGVhc2llciwgMjUga2JcbmJpblNpemUgPSAyNSoxMDAwXG50ZW1wLnBwIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXFRqaWFuX2Nocm9tb3NpZ2h0X2xvb3BfUC1QLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjZW50ZXIxID0gMC41KihWMiArIFYzKSxcbiAgICAgICAgICAgICAgICBjZW50ZXIyID0gMC41KihWNSArIFY2KSxcbiAgICAgICAgICAgICAgICBzdGFydDEgPSBjZW50ZXIxIC0gMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgZW5kMSA9IGNlbnRlcjEgKyAwLjUqYmluU2l6ZSxcbiAgICAgICAgICAgICAgICBzdGFydDIgPSBjZW50ZXIyIC0gMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgZW5kMiA9IGNlbnRlcjIgKyAwLjUqYmluU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIHN0YXJ0MSwgZW5kMSwgVjQsIHN0YXJ0MiwgZW5kMilcbmNvbG5hbWVzKHRlbXAucHApIDwtIGMoXFxWMVxcLCBcXFYyXFwsIFxcVjNcXCwgXFxWNFxcLCBcXFY1XFwsIFxcVjZcXClcbmJpblNpemUgPSAyNSoxMDAwXG50ZW1wLmVwIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXFRqaWFuX2Nocm9tb3NpZ2h0X2xvb3BfRS1QLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjZW50ZXIxID0gMC41KihWMiArIFYzKSxcbiAgICAgICAgICAgICAgICBjZW50ZXIyID0gMC41KihWNSArIFY2KSxcbiAgICAgICAgICAgICAgICBzdGFydDEgPSBjZW50ZXIxIC0gMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgZW5kMSA9IGNlbnRlcjEgKyAwLjUqYmluU2l6ZSxcbiAgICAgICAgICAgICAgICBzdGFydDIgPSBjZW50ZXIyIC0gMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgZW5kMiA9IGNlbnRlcjIgKyAwLjUqYmluU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIHN0YXJ0MSwgZW5kMSwgVjQsIHN0YXJ0MiwgZW5kMilcbmNvbG5hbWVzKHRlbXAuZXApIDwtIGMoXFxWMVxcLCBcXFYyXFwsIFxcVjNcXCwgXFxWNFxcLCBcXFY1XFwsIFxcVjZcXClcbnRlbXAgPC0gYmluZF9yb3dzKHRlbXAucHAsIHRlbXAuZXApXG5sb29wLmFzeW5jIDwtIGltcG9ydEJlZHBlKHRlbXApXG5cblxuYmluU2l6ZSA9IDI1KjEwMDBcbnRlbXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZS5iZWRwZVxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2VudGVyMSA9IDAuNSooVjIgKyBWMyksXG4gICAgICAgICAgICAgICAgY2VudGVyMiA9IDAuNSooVjUgKyBWNiksXG4gICAgICAgICAgICAgICAgc3RhcnQxID0gY2VudGVyMSAtIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIGVuZDEgPSBjZW50ZXIxICsgMC41KmJpblNpemUsXG4gICAgICAgICAgICAgICAgc3RhcnQyID0gY2VudGVyMiAtIDAuNSpiaW5TaXplLFxuICAgICAgICAgICAgICAgIGVuZDIgPSBjZW50ZXIyICsgMC41KmJpblNpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBzdGFydDEsIGVuZDEsIFY0LCBzdGFydDIsIGVuZDIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcVjFcXCwgXFxWMlxcLCBcXFYzXFwsIFxcVjRcXCwgXFxWNVxcLCBcXFY2XFwpXG5sb29wLkcxIDwtIGltcG9ydEJlZHBlKHRlbXApXG5cblxuIyBDaGVjayBvdmVybGFwXG5vdmVybGFwIDwtIGZpbmRPdmVybGFwcyhsb29wLmFzeW5jLCBsb29wLkcxKVxuXG5cbm4uYXN5bmMgPC0gbnJvdyhhc190aWJibGUobG9vcC5hc3luYykpXG5uLkcxIDwtIG5yb3coYXNfdGliYmxlKGxvb3AuRzEpKVxubi5hc3luYy5vdmVybGFwIDwtIGxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKG92ZXJsYXApKSlcbm4uRzEub3ZlcmxhcCA8LSBsZW5ndGgodW5pcXVlKHN1YmplY3RIaXRzKG92ZXJsYXApKSlcblxucGxvdChldWxlcihjKFxcQXN5bmNcXCA9IG4uYXN5bmMgLSBuLmFzeW5jLm92ZXJsYXAsXG4gICAgICAgICAgICAgXFxBc3luYyZHMVxcID0gbi5hc3luYy5vdmVybGFwLFxuICAgICAgICAgICAgIFxcRzFcXCA9IDEpKSwgcXVhbnRpdGllcyA9IFRSVUUpXG5cblxucGxvdChldWxlcihjKFxcQXN5bmNcXCA9MC4xLFxuICAgICAgICAgICAgIFxcQXN5bmMmRzFcXCA9IG4uRzEub3ZlcmxhcCxcbiAgICAgICAgICAgICBcXEcxXFwgPSBuLkcxIC0gbi5HMS5vdmVybGFwKSksIHF1YW50aXRpZXMgPSBUUlVFKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
# Importing loops. For make comparison easier, 25 kb
binSize = 25*1000
temp <- fread(here(refDir, \Tjian_chromosight_loop.bedpe\)) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
loop.async <- importBedpe(temp)


binSize = 25*1000
temp <- fread(here(consensusDir, \chromo_cons.bedpe\)) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
loop.G1 <- importBedpe(temp)


# Check overlap
overlap <- findOverlaps(loop.async, loop.G1)


n.async <- nrow(as_tibble(loop.async))
n.G1 <- nrow(as_tibble(loop.G1))
n.async.overlap <- length(unique(queryHits(overlap)))
n.G1.overlap <- length(unique(subjectHits(overlap)))

plot(euler(c(\Async\ = n.async - n.async.overlap,
             \Async&G1\ = n.async.overlap,
             \G1\ = 1)), quantities = TRUE)


plot(euler(c(\Async\ =1,
             \Async&G1\ = n.G1.overlap,
             \G1\ = n.G1 - n.G1.overlap)), quantities = TRUE)




# Importing loops. For make comparison easier, 25 kb
binSize = 25*1000
temp.pp <- fread(here(refDir, \Tjian_chromosight_loop_P-P.bedpe\)) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp.pp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
binSize = 25*1000
temp.ep <- fread(here(refDir, \Tjian_chromosight_loop_E-P.bedpe\)) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp.ep) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
temp <- bind_rows(temp.pp, temp.ep)
loop.async <- importBedpe(temp)


binSize = 25*1000
temp <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\)) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
loop.G1 <- importBedpe(temp)


# Check overlap
overlap <- findOverlaps(loop.async, loop.G1)


n.async <- nrow(as_tibble(loop.async))
n.G1 <- nrow(as_tibble(loop.G1))
n.async.overlap <- length(unique(queryHits(overlap)))
n.G1.overlap <- length(unique(subjectHits(overlap)))

plot(euler(c(\Async\ = n.async - n.async.overlap,
             \Async&G1\ = n.async.overlap,
             \G1\ = 1)), quantities = TRUE)


plot(euler(c(\Async\ =0.1,
             \Async&G1\ = n.G1.overlap,
             \G1\ = n.G1 - n.G1.overlap)), quantities = TRUE)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### str loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlCSmJYQnZjblJwYm1jZ1EyaEpVQzFsZUc4Z2NHVmhhM05jYm5KbFprUnBjaUE4TFNCb1pYSmxLRndpTGk0dkxpNWNJaXdnWENKeVpXWmxjbVZ1WTJWY0lpbGNibkJsWVdzdVNETkxNamRoWXlBOExTQnBiWEJ2Y25SUVpXRnJLR2hsY21Vb2NtVm1SR2x5TENCY0lrZFRUVEkwTXpnME56WmZSVU10UkVjdE16UTFPQzFJTTBzeU4wRkRYMEZUV1U1Zk1TNXVZWEp5YjNkUVpXRnJMbUpsWkZ3aUtTbGNibkJsWVdzdVNETkxORzFsTXlBOExTQnBiWEJ2Y25SUVpXRnJLR2hsY21Vb2NtVm1SR2x5TENCY0lqTXpNalUxWDBnelN6UnRaVE5mTURRdE56UTFYMEp5ZFdObExUUmZjR1ZoYTNNdWJXVnlaMlZRWldGckxtSmxaRndpS1NsY2JuQmxZV3N1UTFSRFJpQThMU0JwYlhCdmNuUlFaV0ZyS0dobGNtVW9jbVZtUkdseUxDQmNJak16TWpRNFgwTlVRMFpmTURjdE56STVYMEp5ZFdObExUUmZjR1ZoYTNNdWJXVnlaMlZRWldGckxtSmxaRndpS1NsY2JuQmxZV3N1VWtGRU1qRWdQQzBnYVcxd2IzSjBVR1ZoYXlob1pYSmxLSEpsWmtScGNpd2dYQ0l6TXpJMU1GOVNRVVF5TVY5aFlqazVNbDlDY25WalpTMDBYM0JsWVd0ekxtMWxjbWRsVUdWaGF5NWlaV1JjSWlrcFhHNXdaV0ZyTGxkb2VYUmxMbE5GSUR3dElHbHRjRzl5ZEZCbFlXc29hR1Z5WlNoeVpXWkVhWElzSUZ3aWMzVndaWEpGYm1oaGJtTmxjbDlYYUhsMFpWOUZVME5mYlcweE1DNWlaV1JjSWlrcFhHNXdaV0ZyTGtSNWJHRnVMbE5GSUR3dElHbHRjRzl5ZEZCbFlXc29hR1Z5WlNoeVpXWkVhWElzSUZ3aWMzVndaWEpGYm1oaGJtTmxjbDlFZVd4aGJsOUZVME11WW1Wa1hDSXBLVnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbiMjIyMgSW1wb3J0aW5nIENoSVAtZXhvIHBlYWtzXG5yZWZEaXIgPC0gaGVyZShcXC4uLy4uXFwsIFxccmVmZXJlbmNlXFwpXG5wZWFrLkgzSzI3YWMgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFxHU00yNDM4NDc2X0VDLURHLTM0NTgtSDNLMjdBQ19BU1lOXzEubmFycm93UGVhay5iZWRcXCkpXG5wZWFrLkgzSzRtZTMgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFwzMzI1NV9IM0s0bWUzXzA0LTc0NV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcXCkpXG5wZWFrLkNUQ0YgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFwzMzI0OF9DVENGXzA3LTcyOV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcXCkpXG5wZWFrLlJBRDIxIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKVxucGVhay5XaHl0ZS5TRSA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXHN1cGVyRW5oYW5jZXJfV2h5dGVfRVNDX21tMTAuYmVkXFwpKVxucGVhay5EeWxhbi5TRSA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXHN1cGVyRW5oYW5jZXJfRHlsYW5fRVNDLmJlZFxcKSlcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
#### Importing ChIP-exo peaks
refDir <- here(\../..\, \reference\)
peak.H3K27ac <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
peak.H3K4me3 <- importPeak(here(refDir, \33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\))
peak.CTCF <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))
peak.RAD21 <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))
peak.Whyte.SE <- importPeak(here(refDir, \superEnhancer_Whyte_ESC_mm10.bed\))
peak.Dylan.SE <- importPeak(here(refDir, \superEnhancer_Dylan_ESC.bed\))



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeUJKYlhCdmNuUnBibWNnUTJoSlVDMWxlRzhnY0dWaGEzTmNibkpsWmtScGNpQThMU0JvWlhKbEtGeGNMaTR2TGk1Y1hDd2dYRnh5WldabGNtVnVZMlZjWENsY2JuQmxZV3N1U0ROTE1qZGhZeUE4TFNCcGJYQnZjblJRWldGcktHaGxjbVVvY21WbVJHbHlMQ0JjWEVkVFRUSTBNemcwTnpaZlJVTXRSRWN0TXpRMU9DMUlNMHN5TjBGRFgwRlRXVTVmTVM1dVlYSnliM2RRWldGckxtSmxaRnhjS1NsY2JuQmxZV3N1U0ROTE5HMWxNeUE4TFNCcGJYQnZjblJRWldGcktHaGxjbVVvY21WbVJHbHlMQ0JjWERNek1qVTFYMGd6U3pSdFpUTmZNRFF0TnpRMVgwSnlkV05sTFRSZmNHVmhhM011YldWeVoyVlFaV0ZyTG1KbFpGeGNLU2xjYm5CbFlXc3VRMVJEUmlBOExTQnBiWEJ2Y25SUVpXRnJLR2hsY21Vb2NtVm1SR2x5TENCY1hETXpNalE0WDBOVVEwWmZNRGN0TnpJNVgwSnlkV05sTFRSZmNHVmhhM011YldWeVoyVlFaV0ZyTG1KbFpGeGNLU2xjYm5CbFlXc3VVa0ZFTWpFZ1BDMGdhVzF3YjNKMFVHVmhheWhvWlhKbEtISmxaa1JwY2l3Z1hGd3pNekkxTUY5U1FVUXlNVjloWWprNU1sOUNjblZqWlMwMFgzQmxZV3R6TG0xbGNtZGxVR1ZoYXk1aVpXUmNYQ2twWEc1d1pXRnJMbGRvZVhSbExsTkZJRHd0SUdsdGNHOXlkRkJsWVdzb2FHVnlaU2h5WldaRWFYSXNJRnhjYzNWd1pYSkZibWhoYm1ObGNsOVhhSGwwWlY5RlUwTmZiVzB4TUM1aVpXUmNYQ2twWEc1d1pXRnJMa1I1YkdGdUxsTkZJRHd0SUdsdGNHOXlkRkJsWVdzb2FHVnlaU2h5WldaRWFYSXNJRnhjYzNWd1pYSkZibWhoYm1ObGNsOUVlV3hoYmw5RlUwTXVZbVZrWEZ3cEtWeHVZR0JnWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5gYGByXG4jIyMjIEltcG9ydGluZyBDaElQLWV4byBwZWFrc1xucmVmRGlyIDwtIGhlcmUoXFwuLi8uLlxcLCBcXHJlZmVyZW5jZVxcKVxucGVhay5IM0syN2FjIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcR1NNMjQzODQ3Nl9FQy1ERy0zNDU4LUgzSzI3QUNfQVNZTl8xLm5hcnJvd1BlYWsuYmVkXFwpKVxucGVhay5IM0s0bWUzIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcMzMyNTVfSDNLNG1lM18wNC03NDVfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKVxucGVhay5DVENGIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcMzMyNDhfQ1RDRl8wNy03MjlfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKVxucGVhay5SQUQyMSA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXDMzMjUwX1JBRDIxX2FiOTkyX0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLmJlZFxcKSlcbnBlYWsuV2h5dGUuU0UgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFxzdXBlckVuaGFuY2VyX1doeXRlX0VTQ19tbTEwLmJlZFxcKSlcbnBlYWsuRHlsYW4uU0UgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFxzdXBlckVuaGFuY2VyX0R5bGFuX0VTQy5iZWRcXCkpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyBJbXBvcnRpbmcgQ2hJUC1leG8gcGVha3NcbnJlZkRpciA8LSBoZXJlKFxcLi4vLi5cXCwgXFxyZWZlcmVuY2VcXClcbnBlYWsuSDNLMjdhYyA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXEdTTTI0Mzg0NzZfRUMtREctMzQ1OC1IM0syN0FDX0FTWU5fMS5uYXJyb3dQZWFrLmJlZFxcKSlcbnBlYWsuSDNLNG1lMyA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXDMzMjU1X0gzSzRtZTNfMDQtNzQ1X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLmJlZFxcKSlcbnBlYWsuQ1RDRiA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXDMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLmJlZFxcKSlcbnBlYWsuUkFEMjEgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFwzMzI1MF9SQUQyMV9hYjk5Ml9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcXCkpXG5wZWFrLldoeXRlLlNFIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcc3VwZXJFbmhhbmNlcl9XaHl0ZV9FU0NfbW0xMC5iZWRcXCkpXG5wZWFrLkR5bGFuLlNFIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcc3VwZXJFbmhhbmNlcl9EeWxhbl9FU0MuYmVkXFwpKVxuYGBgXG5gYGAifQ== -->

```r
```r
#### Importing ChIP-exo peaks
refDir <- here(\../..\, \reference\)
peak.H3K27ac <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
peak.H3K4me3 <- importPeak(here(refDir, \33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\))
peak.CTCF <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))
peak.RAD21 <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))
peak.Whyte.SE <- importPeak(here(refDir, \superEnhancer_Whyte_ESC_mm10.bed\))
peak.Dylan.SE <- importPeak(here(refDir, \superEnhancer_Dylan_ESC.bed\))
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Comparing loops called from Async

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuY3JlYXRlTG9vcEFubm90YXRpb24gPC0gZnVuY3Rpb24oYmVkcGUubG9vcC5hbm5vLCBuYW1lLCBmaWdEaXIsIG91dERpciwgY29sb3JMaXN0KXtcbiAgdGVtcCA9IGJlZHBlLmxvb3AuYW5ubyAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKHNhbXBsZSA9IG5hbWUpXG4gIFxuICBudW0gPSBucm93KHRlbXApXG4gIHA3ID0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gc2FtcGxlLCBmaWxsID0gQW5ubzIpKSArXG4gICAgZ2VvbV9iYXIoY29sb3IgPSBcImJsYWNrXCIpICtcbiAgICB0aGVtZV9idygpICtcbiAgICBsYWJzKHRpdGxlID0gcGFzdGUwKG51bSwgXCIgbG9vcHNcIiksXG4gICAgICAgICB4ID0gXCJcIiwgeSA9IFwiQ291bnRzXCIpICtcbiAgICBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gY29tbWFfZm9ybWF0KCkpICtcbiAgICB0aGVtZShwbG90LnRpdGxlID0gZWxlbWVudF90ZXh0KGhqdXN0ID0gMC41KSxcbiAgICAgICAgICBhc3BlY3QucmF0aW8gPSA1LFxuICAgICAgICAgIGxlZ2VuZC5wb3NpdGlvbiA9IFwicmlnaHRcIixcbiAgICAgICAgICBsZWdlbmQuZGlyZWN0aW9uICA9IFwidmVydGljYWxcIikgK1xuICAgIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGNvbG9yTGlzdClcbiAgXG4gIHdpZHRoID0gM1xuICBoZWlnaHQgPSA1XG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsXG4gICAgICAgICAgICAgICBwYXN0ZTAoXCJsb29wQ2xhc3NpZnlfXCIsIG5hbWUsIFwiLnN2Z1wiKSksXG4gICAgICAgICAgd2lkdGggPSB3aWR0aCwgaGVpZ2h0ID0gaGVpZ2h0KVxuICBwbG90KHA3KVxuICBpbnZpc2libGUoZGV2Lm9mZigpKVxuICBwbmcoaGVyZShmaWdEaXIsXG4gICAgICAgICAgIHBhc3RlMChcImxvb3BDbGFzc2lmeV9cIiwgbmFtZSwgXCIucG5nXCIpKSxcbiAgICAgIHdpZHRoID0gd2lkdGgsIGhlaWdodCA9IGhlaWdodCwgcmVzID0gNjAwLCB1bml0cyA9IFwiaW5cIilcbiAgcGxvdChwNylcbiAgaW52aXNpYmxlKGRldi5vZmYoKSlcbn1cblxuXG5hbm5vdGF0ZUxvb3BSZWxheGVkVFNTIDwtIGZ1bmN0aW9uKGJlZHBlLmFubm8pe1xuICB0ZW1wID0gYmVkcGUuYW5ubyAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKFxuICAgICAgQTEgPSBpZl9lbHNlKChBMV9IM0s0bWUzVFNTKSwgXCJQXCIsIFxuICAgICAgICAgICAgICAgICAgIGlmX2Vsc2UoKEExX0gzSzI3YWMpLCBcIkVcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmX2Vsc2UoKEExX0NUQ0Z8QTFfUkFEMjEpLCBcIlNcIiwgXCJYXCIpKSksXG4gICAgICBBMiA9IGlmX2Vsc2UoKEEyX0gzSzRtZTNUU1MpLCBcIlBcIiwgXG4gICAgICAgICAgICAgICAgICAgaWZfZWxzZSgoQTJfSDNLMjdhYyksIFwiRVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZfZWxzZSgoQTJfQ1RDRnxBMl9SQUQyMSksIFwiU1wiLCBcIlhcIikpKVxuICAgIClcbiAgdGVtcCA9IHRlbXAgJT4lIGRwbHlyOjpyb3d3aXNlKCkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShBbm5vID0gcGFzdGUwKEExLCBcIi1cIiwgQTIpLFxuICAgICAgICAgICAgICAgICAgQW5ubzIgPSBpZl9lbHNlKEFubm8gPT0gXCJFLVBcIiwgXCJQLUVcIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZfZWxzZShBbm5vID09IFwiUy1QXCIsIFwiUC1TXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZl9lbHNlKEFubm8gPT0gXCJYLVBcIiwgXCJQLVhcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZfZWxzZShBbm5vID09IFwiUy1FXCIsIFwiRS1TXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZfZWxzZShBbm5vID09IFwiWC1FXCIsIFwiRS1YXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZl9lbHNlKEFubm8gPT0gXCJYLVNcIiwgXCJTLVhcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgQW5ubykpKSkpKSxcbiAgICApXG4gIFxuICB0ZW1wJEFubm8yID0gZmFjdG9yKHRlbXAkQW5ubzIsIGxldmVsID0gYyhcIlgtWFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIlMtWFwiLCBcIlMtU1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIkUtWFwiLFwiRS1TXCIsXCJFLUVcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJQLUVcIixcIlAtWFwiLCBcIlAtU1wiLCBcIlAtUFwiKSlcbiAgXG4gICMgQ2hlY2tpbmcgdGhlIHByZWNlbnNlIG9mIHN1cGVyIGVuaGFuY2VyXG4gIHRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKEFubm9TRSA9IGlmZWxzZShBMV9XaHl0ZS5TRSB8IEEyX1doeXRlLlNFLCBcIlNFXCIsIFwiTk9cIikpXG4gIHRlbXAkQW5ub1NFIDwtIGZhY3Rvcih0ZW1wJEFubm9TRSwgbGV2ZWwgPSBjKFwiU0VcIiwgXCJOT1wiKSlcbiAgXG4gIHJldHVybih0ZW1wKVxufVxuXG5hbm5vdGF0ZUxvb3BQcm9tb3RlclRTUyA8LSBmdW5jdGlvbihiZWRwZS5hbm5vKXtcbiAgdGVtcCA9IGJlZHBlLmFubm8gJT4lIGRwbHlyOjpyb3d3aXNlKCkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShcbiAgICAgIEExID0gaWZfZWxzZSgoQTFfSDNLNG1lM1RTUyksIFwiUFwiLCBcIk5cIiksXG4gICAgICBBMiA9IGlmX2Vsc2UoKEEyX0gzSzRtZTNUU1MpLCBcIlBcIiwgXCJOXCIpXG4gICAgKVxuICB0ZW1wID0gdGVtcCAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKEFubm8gPSBwYXN0ZTAoQTEsIFwiLVwiLCBBMiksXG4gICAgICAgICAgICAgICAgICBBbm5vMiA9IGlmX2Vsc2UoQW5ubyA9PSBcIk4tUFwiLCBcIlAtTlwiLCBBbm5vKSlcbiAgXG4gIHRlbXAkQW5ubzIgPSBmYWN0b3IodGVtcCRBbm5vMiwgbGV2ZWwgPSBjKFwiTi1OXCIsIFwiUC1OXCIsIFwiUC1QXCIpKVxuICBcbiAgcmV0dXJuKHRlbXApXG59XG5cbmFubm90YXRlTG9vcEVuaGFuY2VyIDwtIGZ1bmN0aW9uKGJlZHBlLmFubm8pe1xuICB0ZW1wID0gYmVkcGUuYW5ubyAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKFxuICAgICAgQTEgPSBpZl9lbHNlKChBMV9IM0syN2FjKSwgXCJFXCIsIFwiTlwiKSxcbiAgICAgIEEyID0gaWZfZWxzZSgoQTJfSDNLMjdhYyksIFwiRVwiLCBcIk5cIilcbiAgICApXG4gIHRlbXAgPSB0ZW1wICU+JSBkcGx5cjo6cm93d2lzZSgpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoQW5ubyA9IHBhc3RlMChBMSwgXCItXCIsIEEyKSxcbiAgICAgICAgICAgICAgICAgIEFubm8yID0gaWZfZWxzZShBbm5vID09IFwiTi1FXCIsIFwiRS1OXCIsIEFubm8pKVxuICB0ZW1wJEFubm8yID0gZmFjdG9yKHRlbXAkQW5ubzIsIGxldmVsID0gYyhcIk4tTlwiLCBcIkUtTlwiLCBcIkUtRVwiKSlcbiAgXG4gIHJldHVybih0ZW1wKVxufVxuXG5hbm5vdGF0ZUxvb3BTdHJ1Y3R1cmUgPC0gZnVuY3Rpb24oYmVkcGUuYW5ubyl7XG4gIHRlbXAgPSBiZWRwZS5hbm5vICU+JSBkcGx5cjo6cm93d2lzZSgpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoXG4gICAgICBBMSA9IGlmX2Vsc2UoKEExX0NUQ0Z8QTFfUkFEMjEpLCBcIlNcIiwgXCJOXCIpLFxuICAgICAgQTIgPSBpZl9lbHNlKChBMl9DVENGfEEyX1JBRDIxKSwgXCJTXCIsIFwiTlwiKVxuICAgIClcbiAgdGVtcCA9IHRlbXAgJT4lIGRwbHlyOjpyb3d3aXNlKCkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShBbm5vID0gcGFzdGUwKEExLCBcIi1cIiwgQTIpLFxuICAgICAgICAgICAgICAgICAgQW5ubzIgPSBpZl9lbHNlKEFubm8gPT0gXCJOLVNcIiwgXCJTLU5cIiwgQW5ubykpXG4gIHRlbXAkQW5ubzIgPSBmYWN0b3IodGVtcCRBbm5vMiwgbGV2ZWwgPSBjKFwiTi1OXCIsIFwiUy1OXCIsIFwiUy1TXCIpKVxuICByZXR1cm4odGVtcClcbn1cblxuXG5hbm5vdGF0ZUFuY2hvclRTUyA8LSBmdW5jdGlvbihiZWRwZSl7XG4gIHRiLmxvb3AgPSBcbiAgICBzZXRPdmVybGFwQ29sdW1uKFwiV2h5dGUuU0VcIixcbiAgICAgICAgICAgICAgICAgICAgIHNldE92ZXJsYXBDb2x1bW4oXCJDVENGXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNldE92ZXJsYXBDb2x1bW4oXCJSQUQyMVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNldE92ZXJsYXBDb2x1bW4oXCJIM0syN2FjXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzZXRPdmVybGFwQ29sdW1uKFwiSDNLNG1lM1RTU1wiLCBiZWRwZSkpKSkpXG4gIHJldHVybih0Yi5sb29wKVxufVxuXG5zZXRPdmVybGFwQ29sdW1uIDwtIGZ1bmN0aW9uKHBlYWtOYW1lLCBsb29wKXtcbiAgdGIubG9vcCA9IGFzX3RpYmJsZShsb29wKVxuICBvdmVybGFwID0gcmV0dXJuT3ZlcmxhcEluZGV4TGl4dChnZXQocGFzdGUwKFwicGVhay5cIiwgcGVha05hbWUpKSwgdGIubG9vcClcbiAgdGIubG9vcFtbcGFzdGUwKFwiQTFfXCIsIHBlYWtOYW1lKV1dID0gRkFMU0VcbiAgdGIubG9vcFtbcGFzdGUwKFwiQTFfXCIsIHBlYWtOYW1lKV1dW292ZXJsYXBbWzFdXV0gPSBUUlVFXG4gIHRiLmxvb3BbW3Bhc3RlMChcIkEyX1wiLCBwZWFrTmFtZSldXSA9IEZBTFNFXG4gIHRiLmxvb3BbW3Bhc3RlMChcIkEyX1wiLCBwZWFrTmFtZSldXVtvdmVybGFwW1syXV1dID0gVFJVRVxuICByZXR1cm4odGIubG9vcClcbn1cblxucmV0dXJuT3ZlcmxhcEluZGV4TGl4dCA8LSBmdW5jdGlvbihwZWFrLCBsb29wKXtcbiAgYW5jaG9yMS50YiA9IGFzX3RpYmJsZShsb29wKSAlPiUgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSlcbiAgYW5jaG9yMSA9IG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShkYXRhLmZyYW1lKFxuICAgIGNociA9IGFuY2hvcjEudGIkY2hyb20xLFxuICAgIHN0YXJ0ID0gYW5jaG9yMS50YiRzdGFydDEsXG4gICAgZW5kID0gYW5jaG9yMS50YiRlbmQxXG4gICkpXG4gIFxuICBhbmNob3IyLnRiID0gYXNfdGliYmxlKGxvb3ApICU+JSBkcGx5cjo6c2VsZWN0KGNocm9tMiwgc3RhcnQyLCBlbmQyKVxuICBhbmNob3IyID0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGRhdGEuZnJhbWUoXG4gICAgY2hyID0gYW5jaG9yMi50YiRjaHJvbTIsXG4gICAgc3RhcnQgPSBhbmNob3IyLnRiJHN0YXJ0MixcbiAgICBlbmQgPSBhbmNob3IyLnRiJGVuZDJcbiAgKSlcbiAgXG4gIG92ZXJsYXAgPSBsaXN0KG92ZXJsYXAxID0gdW5pcXVlKHF1ZXJ5SGl0cyhmaW5kT3ZlcmxhcHMoYW5jaG9yMSwgcGVhaykpKSxcbiAgICAgICAgICAgICAgICAgb3ZlcmxhcDIgPSB1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyhhbmNob3IyLCBwZWFrKSkpKVxuICByZXR1cm4ob3ZlcmxhcClcbn1cblxuc2F2ZUFubm9Hcm91cEJlZHBlIDwtIGZ1bmN0aW9uKHRlbXAsIGFubm8ubGlzdCwgbmFtZSwgYW5ub05hbWUsIG91RGlyKXtcbiAgbG9vcCA9IHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBhbm5vLmxpc3QpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoYyhcImNocm9tMVwiLCBcInN0YXJ0MVwiLCBcImVuZDFcIiwgXCJjaHJvbTJcIiwgXCJzdGFydDJcIiwgXCJlbmQyXCIpKVxuICBmd3JpdGUobG9vcCwgaGVyZShvdXREaXIsIHBhc3RlMChuYW1lLCBcIl9cIiwgYW5ub05hbWUsIFwiLmJlZHBlXCIpKSwgc2VwID0gXCJcXHRcIiwgY29sLm5hbWVzID0gRkFMU0UpXG59XG5gYGAifQ== -->\n\n```r\ncreateLoopAnnotation <- function(bedpe.loop.anno, name, figDir, outDir, colorList){\n  temp = bedpe.loop.anno %>%\n    dplyr::mutate(sample = name)\n  \n  num = nrow(temp)\n  p7 = ggplot(temp, aes(x = sample, fill = Anno2)) +\n    geom_bar(color = \\black\\) +\n    theme_bw() +\n    labs(title = paste0(num, \\ loops\\),\n         x = \\\\, y = \\Counts\\) +\n    scale_y_continuous(labels = comma_format()) +\n    theme(plot.title = element_text(hjust = 0.5),\n          aspect.ratio = 5,\n          legend.position = \\right\\,\n          legend.direction  = \\vertical\\) +\n    scale_fill_manual(values = colorList)\n  \n  width = 3\n  height = 5\n  svglite(here(figDir,\n               paste0(\\loopClassify_\\, name, \\.svg\\)),\n          width = width, height = height)\n  plot(p7)\n  invisible(dev.off())\n  png(here(figDir,\n           paste0(\\loopClassify_\\, name, \\.png\\)),\n      width = width, height = height, res = 600, units = \\in\\)\n  plot(p7)\n  invisible(dev.off())\n}\n\n\nannotateLoopRelaxedTSS <- function(bedpe.anno){\n  temp = bedpe.anno %>% dplyr::rowwise() %>%\n    dplyr::mutate(\n      A1 = if_else((A1_H3K4me3TSS), \\P\\, \n                   if_else((A1_H3K27ac), \\E\\,\n                           if_else((A1_CTCF|A1_RAD21), \\S\\, \\X\\))),\n      A2 = if_else((A2_H3K4me3TSS), \\P\\, \n                   if_else((A2_H3K27ac), \\E\\,\n                           if_else((A2_CTCF|A2_RAD21), \\S\\, \\X\\)))\n    )\n  temp = temp %>% dplyr::rowwise() %>%\n    dplyr::mutate(Anno = paste0(A1, \\-\\, A2),\n                  Anno2 = if_else(Anno == \\E-P\\, \\P-E\\, \n                                  if_else(Anno == \\S-P\\, \\P-S\\,\n                                          if_else(Anno == \\X-P\\, \\P-X\\,\n                                                  if_else(Anno == \\S-E\\, \\E-S\\,\n                                                          if_else(Anno == \\X-E\\, \\E-X\\,\n                                                                  if_else(Anno == \\X-S\\, \\S-X\\,\n                                                                          Anno)))))),\n    )\n  \n  temp$Anno2 = factor(temp$Anno2, level = c(\\X-X\\,\n                                            \\S-X\\, \\S-S\\,\n                                            \\E-X\\,\\E-S\\,\\E-E\\,\n                                            \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\))\n  \n  # Checking the precense of super enhancer\n  temp <- temp %>% dplyr::rowwise() %>%\n    dplyr::mutate(AnnoSE = ifelse(A1_Whyte.SE | A2_Whyte.SE, \\SE\\, \\NO\\))\n  temp$AnnoSE <- factor(temp$AnnoSE, level = c(\\SE\\, \\NO\\))\n  \n  return(temp)\n}\n\nannotateLoopPromoterTSS <- function(bedpe.anno){\n  temp = bedpe.anno %>% dplyr::rowwise() %>%\n    dplyr::mutate(\n      A1 = if_else((A1_H3K4me3TSS), \\P\\, \\N\\),\n      A2 = if_else((A2_H3K4me3TSS), \\P\\, \\N\\)\n    )\n  temp = temp %>% dplyr::rowwise() %>%\n    dplyr::mutate(Anno = paste0(A1, \\-\\, A2),\n                  Anno2 = if_else(Anno == \\N-P\\, \\P-N\\, Anno))\n  \n  temp$Anno2 = factor(temp$Anno2, level = c(\\N-N\\, \\P-N\\, \\P-P\\))\n  \n  return(temp)\n}\n\nannotateLoopEnhancer <- function(bedpe.anno){\n  temp = bedpe.anno %>% dplyr::rowwise() %>%\n    dplyr::mutate(\n      A1 = if_else((A1_H3K27ac), \\E\\, \\N\\),\n      A2 = if_else((A2_H3K27ac), \\E\\, \\N\\)\n    )\n  temp = temp %>% dplyr::rowwise() %>%\n    dplyr::mutate(Anno = paste0(A1, \\-\\, A2),\n                  Anno2 = if_else(Anno == \\N-E\\, \\E-N\\, Anno))\n  temp$Anno2 = factor(temp$Anno2, level = c(\\N-N\\, \\E-N\\, \\E-E\\))\n  \n  return(temp)\n}\n\nannotateLoopStructure <- function(bedpe.anno){\n  temp = bedpe.anno %>% dplyr::rowwise() %>%\n    dplyr::mutate(\n      A1 = if_else((A1_CTCF|A1_RAD21), \\S\\, \\N\\),\n      A2 = if_else((A2_CTCF|A2_RAD21), \\S\\, \\N\\)\n    )\n  temp = temp %>% dplyr::rowwise() %>%\n    dplyr::mutate(Anno = paste0(A1, \\-\\, A2),\n                  Anno2 = if_else(Anno == \\N-S\\, \\S-N\\, Anno))\n  temp$Anno2 = factor(temp$Anno2, level = c(\\N-N\\, \\S-N\\, \\S-S\\))\n  return(temp)\n}\n\n\nannotateAnchorTSS <- function(bedpe){\n  tb.loop = \n    setOverlapColumn(\\Whyte.SE\\,\n                     setOverlapColumn(\\CTCF\\,\n                                      setOverlapColumn(\\RAD21\\,\n                                                       setOverlapColumn(\\H3K27ac\\,\n                                                                        setOverlapColumn(\\H3K4me3TSS\\, bedpe)))))\n  return(tb.loop)\n}\n\nsetOverlapColumn <- function(peakName, loop){\n  tb.loop = as_tibble(loop)\n  overlap = returnOverlapIndexLixt(get(paste0(\\peak.\\, peakName)), tb.loop)\n  tb.loop[[paste0(\\A1_\\, peakName)]] = FALSE\n  tb.loop[[paste0(\\A1_\\, peakName)]][overlap[[1]]] = TRUE\n  tb.loop[[paste0(\\A2_\\, peakName)]] = FALSE\n  tb.loop[[paste0(\\A2_\\, peakName)]][overlap[[2]]] = TRUE\n  return(tb.loop)\n}\n\nreturnOverlapIndexLixt <- function(peak, loop){\n  anchor1.tb = as_tibble(loop) %>% dplyr::select(chrom1, start1, end1)\n  anchor1 = makeGRangesFromDataFrame(data.frame(\n    chr = anchor1.tb$chrom1,\n    start = anchor1.tb$start1,\n    end = anchor1.tb$end1\n  ))\n  \n  anchor2.tb = as_tibble(loop) %>% dplyr::select(chrom2, start2, end2)\n  anchor2 = makeGRangesFromDataFrame(data.frame(\n    chr = anchor2.tb$chrom2,\n    start = anchor2.tb$start2,\n    end = anchor2.tb$end2\n  ))\n  \n  overlap = list(overlap1 = unique(queryHits(findOverlaps(anchor1, peak))),\n                 overlap2 = unique(queryHits(findOverlaps(anchor2, peak))))\n  return(overlap)\n}\n\nsaveAnnoGroupBedpe <- function(temp, anno.list, name, annoName, ouDir){\n  loop = temp %>% dplyr::filter(Anno2 %in% anno.list) %>%\n    dplyr::select(c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\))\n  fwrite(loop, here(outDir, paste0(name, \\_\\, annoName, \\.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n}\n```\n\n<!-- rnb-source-end -->\n"} -->
createLoopAnnotation <- function(bedpe.loop.anno, name, figDir, outDir, colorList){
  temp = bedpe.loop.anno %>%
    dplyr::mutate(sample = name)
  
  num = nrow(temp)
  p7 = ggplot(temp, aes(x = sample, fill = Anno2)) +
    geom_bar(color = \black\) +
    theme_bw() +
    labs(title = paste0(num, \ loops\),
         x = \\, y = \Counts\) +
    scale_y_continuous(labels = comma_format()) +
    theme(plot.title = element_text(hjust = 0.5),
          aspect.ratio = 5,
          legend.position = \right\,
          legend.direction  = \vertical\) +
    scale_fill_manual(values = colorList)
  
  width = 3
  height = 5
  svglite(here(figDir,
               paste0(\loopClassify_\, name, \.svg\)),
          width = width, height = height)
  plot(p7)
  invisible(dev.off())
  png(here(figDir,
           paste0(\loopClassify_\, name, \.png\)),
      width = width, height = height, res = 600, units = \in\)
  plot(p7)
  invisible(dev.off())
}


annotateLoopRelaxedTSS <- function(bedpe.anno){
  temp = bedpe.anno %>% dplyr::rowwise() %>%
    dplyr::mutate(
      A1 = if_else((A1_H3K4me3TSS), \P\, 
                   if_else((A1_H3K27ac), \E\,
                           if_else((A1_CTCF|A1_RAD21), \S\, \X\))),
      A2 = if_else((A2_H3K4me3TSS), \P\, 
                   if_else((A2_H3K27ac), \E\,
                           if_else((A2_CTCF|A2_RAD21), \S\, \X\)))
    )
  temp = temp %>% dplyr::rowwise() %>%
    dplyr::mutate(Anno = paste0(A1, \-\, A2),
                  Anno2 = if_else(Anno == \E-P\, \P-E\, 
                                  if_else(Anno == \S-P\, \P-S\,
                                          if_else(Anno == \X-P\, \P-X\,
                                                  if_else(Anno == \S-E\, \E-S\,
                                                          if_else(Anno == \X-E\, \E-X\,
                                                                  if_else(Anno == \X-S\, \S-X\,
                                                                          Anno)))))),
    )
  
  temp$Anno2 = factor(temp$Anno2, level = c(\X-X\,
                                            \S-X\, \S-S\,
                                            \E-X\,\E-S\,\E-E\,
                                            \P-E\,\P-X\, \P-S\, \P-P\))
  
  # Checking the precense of super enhancer
  temp <- temp %>% dplyr::rowwise() %>%
    dplyr::mutate(AnnoSE = ifelse(A1_Whyte.SE | A2_Whyte.SE, \SE\, \NO\))
  temp$AnnoSE <- factor(temp$AnnoSE, level = c(\SE\, \NO\))
  
  return(temp)
}

annotateLoopPromoterTSS <- function(bedpe.anno){
  temp = bedpe.anno %>% dplyr::rowwise() %>%
    dplyr::mutate(
      A1 = if_else((A1_H3K4me3TSS), \P\, \N\),
      A2 = if_else((A2_H3K4me3TSS), \P\, \N\)
    )
  temp = temp %>% dplyr::rowwise() %>%
    dplyr::mutate(Anno = paste0(A1, \-\, A2),
                  Anno2 = if_else(Anno == \N-P\, \P-N\, Anno))
  
  temp$Anno2 = factor(temp$Anno2, level = c(\N-N\, \P-N\, \P-P\))
  
  return(temp)
}

annotateLoopEnhancer <- function(bedpe.anno){
  temp = bedpe.anno %>% dplyr::rowwise() %>%
    dplyr::mutate(
      A1 = if_else((A1_H3K27ac), \E\, \N\),
      A2 = if_else((A2_H3K27ac), \E\, \N\)
    )
  temp = temp %>% dplyr::rowwise() %>%
    dplyr::mutate(Anno = paste0(A1, \-\, A2),
                  Anno2 = if_else(Anno == \N-E\, \E-N\, Anno))
  temp$Anno2 = factor(temp$Anno2, level = c(\N-N\, \E-N\, \E-E\))
  
  return(temp)
}

annotateLoopStructure <- function(bedpe.anno){
  temp = bedpe.anno %>% dplyr::rowwise() %>%
    dplyr::mutate(
      A1 = if_else((A1_CTCF|A1_RAD21), \S\, \N\),
      A2 = if_else((A2_CTCF|A2_RAD21), \S\, \N\)
    )
  temp = temp %>% dplyr::rowwise() %>%
    dplyr::mutate(Anno = paste0(A1, \-\, A2),
                  Anno2 = if_else(Anno == \N-S\, \S-N\, Anno))
  temp$Anno2 = factor(temp$Anno2, level = c(\N-N\, \S-N\, \S-S\))
  return(temp)
}


annotateAnchorTSS <- function(bedpe){
  tb.loop = 
    setOverlapColumn(\Whyte.SE\,
                     setOverlapColumn(\CTCF\,
                                      setOverlapColumn(\RAD21\,
                                                       setOverlapColumn(\H3K27ac\,
                                                                        setOverlapColumn(\H3K4me3TSS\, bedpe)))))
  return(tb.loop)
}

setOverlapColumn <- function(peakName, loop){
  tb.loop = as_tibble(loop)
  overlap = returnOverlapIndexLixt(get(paste0(\peak.\, peakName)), tb.loop)
  tb.loop[[paste0(\A1_\, peakName)]] = FALSE
  tb.loop[[paste0(\A1_\, peakName)]][overlap[[1]]] = TRUE
  tb.loop[[paste0(\A2_\, peakName)]] = FALSE
  tb.loop[[paste0(\A2_\, peakName)]][overlap[[2]]] = TRUE
  return(tb.loop)
}

returnOverlapIndexLixt <- function(peak, loop){
  anchor1.tb = as_tibble(loop) %>% dplyr::select(chrom1, start1, end1)
  anchor1 = makeGRangesFromDataFrame(data.frame(
    chr = anchor1.tb$chrom1,
    start = anchor1.tb$start1,
    end = anchor1.tb$end1
  ))
  
  anchor2.tb = as_tibble(loop) %>% dplyr::select(chrom2, start2, end2)
  anchor2 = makeGRangesFromDataFrame(data.frame(
    chr = anchor2.tb$chrom2,
    start = anchor2.tb$start2,
    end = anchor2.tb$end2
  ))
  
  overlap = list(overlap1 = unique(queryHits(findOverlaps(anchor1, peak))),
                 overlap2 = unique(queryHits(findOverlaps(anchor2, peak))))
  return(overlap)
}

saveAnnoGroupBedpe <- function(temp, anno.list, name, annoName, ouDir){
  loop = temp %>% dplyr::filter(Anno2 %in% anno.list) %>%
    dplyr::select(c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\))
  fwrite(loop, here(outDir, paste0(name, \_\, annoName, \.bedpe\)), sep = \\t\, col.names = FALSE)
}



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuY3JlYXRlTG9vcEFubm90YXRpb24gPC0gZnVuY3Rpb24oYmVkcGUubG9vcC5hbm5vLCBuYW1lLCBmaWdEaXIsIG91dERpciwgY29sb3JMaXN0KXtcbiAgdGVtcCA9IGJlZHBlLmxvb3AuYW5ubyAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKHNhbXBsZSA9IG5hbWUpXG4gIFxuICBudW0gPSBucm93KHRlbXApXG4gIHA3ID0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gc2FtcGxlLCBmaWxsID0gQW5ubzIpKSArXG4gICAgZ2VvbV9iYXIoY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9idygpICtcbiAgICBsYWJzKHRpdGxlID0gcGFzdGUwKG51bSwgXFwgbG9vcHNcXCksXG4gICAgICAgICB4ID0gXFxcXCwgeSA9IFxcQ291bnRzXFwpICtcbiAgICBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gY29tbWFfZm9ybWF0KCkpICtcbiAgICB0aGVtZShwbG90LnRpdGxlID0gZWxlbWVudF90ZXh0KGhqdXN0ID0gMC41KSxcbiAgICAgICAgICBhc3BlY3QucmF0aW8gPSA1LFxuICAgICAgICAgIGxlZ2VuZC5wb3NpdGlvbiA9IFxccmlnaHRcXCxcbiAgICAgICAgICBsZWdlbmQuZGlyZWN0aW9uICA9IFxcdmVydGljYWxcXCkgK1xuICAgIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGNvbG9yTGlzdClcbiAgXG4gIHdpZHRoID0gM1xuICBoZWlnaHQgPSA1XG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsXG4gICAgICAgICAgICAgICBwYXN0ZTAoXFxsb29wQ2xhc3NpZnlfXFwsIG5hbWUsIFxcLnN2Z1xcKSksXG4gICAgICAgICAgd2lkdGggPSB3aWR0aCwgaGVpZ2h0ID0gaGVpZ2h0KVxuICBwbG90KHA3KVxuICBpbnZpc2libGUoZGV2Lm9mZigpKVxuICBwbmcoaGVyZShmaWdEaXIsXG4gICAgICAgICAgIHBhc3RlMChcXGxvb3BDbGFzc2lmeV9cXCwgbmFtZSwgXFwucG5nXFwpKSxcbiAgICAgIHdpZHRoID0gd2lkdGgsIGhlaWdodCA9IGhlaWdodCwgcmVzID0gNjAwLCB1bml0cyA9IFxcaW5cXClcbiAgcGxvdChwNylcbiAgaW52aXNpYmxlKGRldi5vZmYoKSlcbn1cblxuXG5hbm5vdGF0ZUxvb3BSZWxheGVkVFNTIDwtIGZ1bmN0aW9uKGJlZHBlLmFubm8pe1xuICB0ZW1wID0gYmVkcGUuYW5ubyAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKFxuICAgICAgQTEgPSBpZl9lbHNlKChBMV9IM0s0bWUzVFNTKSwgXFxQXFwsIFxuICAgICAgICAgICAgICAgICAgIGlmX2Vsc2UoKEExX0gzSzI3YWMpLCBcXEVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmX2Vsc2UoKEExX0NUQ0Z8QTFfUkFEMjEpLCBcXFNcXCwgXFxYXFwpKSksXG4gICAgICBBMiA9IGlmX2Vsc2UoKEEyX0gzSzRtZTNUU1MpLCBcXFBcXCwgXG4gICAgICAgICAgICAgICAgICAgaWZfZWxzZSgoQTJfSDNLMjdhYyksIFxcRVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZfZWxzZSgoQTJfQ1RDRnxBMl9SQUQyMSksIFxcU1xcLCBcXFhcXCkpKVxuICAgIClcbiAgdGVtcCA9IHRlbXAgJT4lIGRwbHlyOjpyb3d3aXNlKCkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShBbm5vID0gcGFzdGUwKEExLCBcXC1cXCwgQTIpLFxuICAgICAgICAgICAgICAgICAgQW5ubzIgPSBpZl9lbHNlKEFubm8gPT0gXFxFLVBcXCwgXFxQLUVcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZfZWxzZShBbm5vID09IFxcUy1QXFwsIFxcUC1TXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZl9lbHNlKEFubm8gPT0gXFxYLVBcXCwgXFxQLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZfZWxzZShBbm5vID09IFxcUy1FXFwsIFxcRS1TXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZfZWxzZShBbm5vID09IFxcWC1FXFwsIFxcRS1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZl9lbHNlKEFubm8gPT0gXFxYLVNcXCwgXFxTLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgQW5ubykpKSkpKSxcbiAgICApXG4gIFxuICB0ZW1wJEFubm8yID0gZmFjdG9yKHRlbXAkQW5ubzIsIGxldmVsID0gYyhcXFgtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFMtWFxcLCBcXFMtU1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXEUtWFxcLFxcRS1TXFwsXFxFLUVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxQLUVcXCxcXFAtWFxcLCBcXFAtU1xcLCBcXFAtUFxcKSlcbiAgXG4gICMgQ2hlY2tpbmcgdGhlIHByZWNlbnNlIG9mIHN1cGVyIGVuaGFuY2VyXG4gIHRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKEFubm9TRSA9IGlmZWxzZShBMV9XaHl0ZS5TRSB8IEEyX1doeXRlLlNFLCBcXFNFXFwsIFxcTk9cXCkpXG4gIHRlbXAkQW5ub1NFIDwtIGZhY3Rvcih0ZW1wJEFubm9TRSwgbGV2ZWwgPSBjKFxcU0VcXCwgXFxOT1xcKSlcbiAgXG4gIHJldHVybih0ZW1wKVxufVxuXG5hbm5vdGF0ZUxvb3BQcm9tb3RlclRTUyA8LSBmdW5jdGlvbihiZWRwZS5hbm5vKXtcbiAgdGVtcCA9IGJlZHBlLmFubm8gJT4lIGRwbHlyOjpyb3d3aXNlKCkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShcbiAgICAgIEExID0gaWZfZWxzZSgoQTFfSDNLNG1lM1RTUyksIFxcUFxcLCBcXE5cXCksXG4gICAgICBBMiA9IGlmX2Vsc2UoKEEyX0gzSzRtZTNUU1MpLCBcXFBcXCwgXFxOXFwpXG4gICAgKVxuICB0ZW1wID0gdGVtcCAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKEFubm8gPSBwYXN0ZTAoQTEsIFxcLVxcLCBBMiksXG4gICAgICAgICAgICAgICAgICBBbm5vMiA9IGlmX2Vsc2UoQW5ubyA9PSBcXE4tUFxcLCBcXFAtTlxcLCBBbm5vKSlcbiAgXG4gIHRlbXAkQW5ubzIgPSBmYWN0b3IodGVtcCRBbm5vMiwgbGV2ZWwgPSBjKFxcTi1OXFwsIFxcUC1OXFwsIFxcUC1QXFwpKVxuICBcbiAgcmV0dXJuKHRlbXApXG59XG5cbmFubm90YXRlTG9vcEVuaGFuY2VyIDwtIGZ1bmN0aW9uKGJlZHBlLmFubm8pe1xuICB0ZW1wID0gYmVkcGUuYW5ubyAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKFxuICAgICAgQTEgPSBpZl9lbHNlKChBMV9IM0syN2FjKSwgXFxFXFwsIFxcTlxcKSxcbiAgICAgIEEyID0gaWZfZWxzZSgoQTJfSDNLMjdhYyksIFxcRVxcLCBcXE5cXClcbiAgICApXG4gIHRlbXAgPSB0ZW1wICU+JSBkcGx5cjo6cm93d2lzZSgpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoQW5ubyA9IHBhc3RlMChBMSwgXFwtXFwsIEEyKSxcbiAgICAgICAgICAgICAgICAgIEFubm8yID0gaWZfZWxzZShBbm5vID09IFxcTi1FXFwsIFxcRS1OXFwsIEFubm8pKVxuICB0ZW1wJEFubm8yID0gZmFjdG9yKHRlbXAkQW5ubzIsIGxldmVsID0gYyhcXE4tTlxcLCBcXEUtTlxcLCBcXEUtRVxcKSlcbiAgXG4gIHJldHVybih0ZW1wKVxufVxuXG5hbm5vdGF0ZUxvb3BTdHJ1Y3R1cmUgPC0gZnVuY3Rpb24oYmVkcGUuYW5ubyl7XG4gIHRlbXAgPSBiZWRwZS5hbm5vICU+JSBkcGx5cjo6cm93d2lzZSgpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoXG4gICAgICBBMSA9IGlmX2Vsc2UoKEExX0NUQ0Z8QTFfUkFEMjEpLCBcXFNcXCwgXFxOXFwpLFxuICAgICAgQTIgPSBpZl9lbHNlKChBMl9DVENGfEEyX1JBRDIxKSwgXFxTXFwsIFxcTlxcKVxuICAgIClcbiAgdGVtcCA9IHRlbXAgJT4lIGRwbHlyOjpyb3d3aXNlKCkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShBbm5vID0gcGFzdGUwKEExLCBcXC1cXCwgQTIpLFxuICAgICAgICAgICAgICAgICAgQW5ubzIgPSBpZl9lbHNlKEFubm8gPT0gXFxOLVNcXCwgXFxTLU5cXCwgQW5ubykpXG4gIHRlbXAkQW5ubzIgPSBmYWN0b3IodGVtcCRBbm5vMiwgbGV2ZWwgPSBjKFxcTi1OXFwsIFxcUy1OXFwsIFxcUy1TXFwpKVxuICByZXR1cm4odGVtcClcbn1cblxuXG5hbm5vdGF0ZUFuY2hvclRTUyA8LSBmdW5jdGlvbihiZWRwZSl7XG4gIHRiLmxvb3AgPSBcbiAgICBzZXRPdmVybGFwQ29sdW1uKFxcV2h5dGUuU0VcXCxcbiAgICAgICAgICAgICAgICAgICAgIHNldE92ZXJsYXBDb2x1bW4oXFxDVENGXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNldE92ZXJsYXBDb2x1bW4oXFxSQUQyMVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNldE92ZXJsYXBDb2x1bW4oXFxIM0syN2FjXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzZXRPdmVybGFwQ29sdW1uKFxcSDNLNG1lM1RTU1xcLCBiZWRwZSkpKSkpXG4gIHJldHVybih0Yi5sb29wKVxufVxuXG5zZXRPdmVybGFwQ29sdW1uIDwtIGZ1bmN0aW9uKHBlYWtOYW1lLCBsb29wKXtcbiAgdGIubG9vcCA9IGFzX3RpYmJsZShsb29wKVxuICBvdmVybGFwID0gcmV0dXJuT3ZlcmxhcEluZGV4TGl4dChnZXQocGFzdGUwKFxccGVhay5cXCwgcGVha05hbWUpKSwgdGIubG9vcClcbiAgdGIubG9vcFtbcGFzdGUwKFxcQTFfXFwsIHBlYWtOYW1lKV1dID0gRkFMU0VcbiAgdGIubG9vcFtbcGFzdGUwKFxcQTFfXFwsIHBlYWtOYW1lKV1dW292ZXJsYXBbWzFdXV0gPSBUUlVFXG4gIHRiLmxvb3BbW3Bhc3RlMChcXEEyX1xcLCBwZWFrTmFtZSldXSA9IEZBTFNFXG4gIHRiLmxvb3BbW3Bhc3RlMChcXEEyX1xcLCBwZWFrTmFtZSldXVtvdmVybGFwW1syXV1dID0gVFJVRVxuICByZXR1cm4odGIubG9vcClcbn1cblxucmV0dXJuT3ZlcmxhcEluZGV4TGl4dCA8LSBmdW5jdGlvbihwZWFrLCBsb29wKXtcbiAgYW5jaG9yMS50YiA9IGFzX3RpYmJsZShsb29wKSAlPiUgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSlcbiAgYW5jaG9yMSA9IG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShkYXRhLmZyYW1lKFxuICAgIGNociA9IGFuY2hvcjEudGIkY2hyb20xLFxuICAgIHN0YXJ0ID0gYW5jaG9yMS50YiRzdGFydDEsXG4gICAgZW5kID0gYW5jaG9yMS50YiRlbmQxXG4gICkpXG4gIFxuICBhbmNob3IyLnRiID0gYXNfdGliYmxlKGxvb3ApICU+JSBkcGx5cjo6c2VsZWN0KGNocm9tMiwgc3RhcnQyLCBlbmQyKVxuICBhbmNob3IyID0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGRhdGEuZnJhbWUoXG4gICAgY2hyID0gYW5jaG9yMi50YiRjaHJvbTIsXG4gICAgc3RhcnQgPSBhbmNob3IyLnRiJHN0YXJ0MixcbiAgICBlbmQgPSBhbmNob3IyLnRiJGVuZDJcbiAgKSlcbiAgXG4gIG92ZXJsYXAgPSBsaXN0KG92ZXJsYXAxID0gdW5pcXVlKHF1ZXJ5SGl0cyhmaW5kT3ZlcmxhcHMoYW5jaG9yMSwgcGVhaykpKSxcbiAgICAgICAgICAgICAgICAgb3ZlcmxhcDIgPSB1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyhhbmNob3IyLCBwZWFrKSkpKVxuICByZXR1cm4ob3ZlcmxhcClcbn1cblxuc2F2ZUFubm9Hcm91cEJlZHBlIDwtIGZ1bmN0aW9uKHRlbXAsIGFubm8ubGlzdCwgbmFtZSwgYW5ub05hbWUsIG91RGlyKXtcbiAgbG9vcCA9IHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBhbm5vLmxpc3QpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoYyhcXGNocm9tMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHJvbTJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwpKVxuICBmd3JpdGUobG9vcCwgaGVyZShvdXREaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgYW5ub05hbWUsIFxcLmJlZHBlXFwpKSwgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gRkFMU0UpXG59XG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\ncreateLoopAnnotation <- function(bedpe.loop.anno, name, figDir, outDir, colorList){\n  temp = bedpe.loop.anno %>%\n    dplyr::mutate(sample = name)\n  \n  num = nrow(temp)\n  p7 = ggplot(temp, aes(x = sample, fill = Anno2)) +\n    geom_bar(color = \\black\\) +\n    theme_bw() +\n    labs(title = paste0(num, \\ loops\\),\n         x = \\\\, y = \\Counts\\) +\n    scale_y_continuous(labels = comma_format()) +\n    theme(plot.title = element_text(hjust = 0.5),\n          aspect.ratio = 5,\n          legend.position = \\right\\,\n          legend.direction  = \\vertical\\) +\n    scale_fill_manual(values = colorList)\n  \n  width = 3\n  height = 5\n  svglite(here(figDir,\n               paste0(\\loopClassify_\\, name, \\.svg\\)),\n          width = width, height = height)\n  plot(p7)\n  invisible(dev.off())\n  png(here(figDir,\n           paste0(\\loopClassify_\\, name, \\.png\\)),\n      width = width, height = height, res = 600, units = \\in\\)\n  plot(p7)\n  invisible(dev.off())\n}\n\n\nannotateLoopRelaxedTSS <- function(bedpe.anno){\n  temp = bedpe.anno %>% dplyr::rowwise() %>%\n    dplyr::mutate(\n      A1 = if_else((A1_H3K4me3TSS), \\P\\, \n                   if_else((A1_H3K27ac), \\E\\,\n                           if_else((A1_CTCF|A1_RAD21), \\S\\, \\X\\))),\n      A2 = if_else((A2_H3K4me3TSS), \\P\\, \n                   if_else((A2_H3K27ac), \\E\\,\n                           if_else((A2_CTCF|A2_RAD21), \\S\\, \\X\\)))\n    )\n  temp = temp %>% dplyr::rowwise() %>%\n    dplyr::mutate(Anno = paste0(A1, \\-\\, A2),\n                  Anno2 = if_else(Anno == \\E-P\\, \\P-E\\, \n                                  if_else(Anno == \\S-P\\, \\P-S\\,\n                                          if_else(Anno == \\X-P\\, \\P-X\\,\n                                                  if_else(Anno == \\S-E\\, \\E-S\\,\n                                                          if_else(Anno == \\X-E\\, \\E-X\\,\n                                                                  if_else(Anno == \\X-S\\, \\S-X\\,\n                                                                          Anno)))))),\n    )\n  \n  temp$Anno2 = factor(temp$Anno2, level = c(\\X-X\\,\n                                            \\S-X\\, \\S-S\\,\n                                            \\E-X\\,\\E-S\\,\\E-E\\,\n                                            \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\))\n  \n  # Checking the precense of super enhancer\n  temp <- temp %>% dplyr::rowwise() %>%\n    dplyr::mutate(AnnoSE = ifelse(A1_Whyte.SE | A2_Whyte.SE, \\SE\\, \\NO\\))\n  temp$AnnoSE <- factor(temp$AnnoSE, level = c(\\SE\\, \\NO\\))\n  \n  return(temp)\n}\n\nannotateLoopPromoterTSS <- function(bedpe.anno){\n  temp = bedpe.anno %>% dplyr::rowwise() %>%\n    dplyr::mutate(\n      A1 = if_else((A1_H3K4me3TSS), \\P\\, \\N\\),\n      A2 = if_else((A2_H3K4me3TSS), \\P\\, \\N\\)\n    )\n  temp = temp %>% dplyr::rowwise() %>%\n    dplyr::mutate(Anno = paste0(A1, \\-\\, A2),\n                  Anno2 = if_else(Anno == \\N-P\\, \\P-N\\, Anno))\n  \n  temp$Anno2 = factor(temp$Anno2, level = c(\\N-N\\, \\P-N\\, \\P-P\\))\n  \n  return(temp)\n}\n\nannotateLoopEnhancer <- function(bedpe.anno){\n  temp = bedpe.anno %>% dplyr::rowwise() %>%\n    dplyr::mutate(\n      A1 = if_else((A1_H3K27ac), \\E\\, \\N\\),\n      A2 = if_else((A2_H3K27ac), \\E\\, \\N\\)\n    )\n  temp = temp %>% dplyr::rowwise() %>%\n    dplyr::mutate(Anno = paste0(A1, \\-\\, A2),\n                  Anno2 = if_else(Anno == \\N-E\\, \\E-N\\, Anno))\n  temp$Anno2 = factor(temp$Anno2, level = c(\\N-N\\, \\E-N\\, \\E-E\\))\n  \n  return(temp)\n}\n\nannotateLoopStructure <- function(bedpe.anno){\n  temp = bedpe.anno %>% dplyr::rowwise() %>%\n    dplyr::mutate(\n      A1 = if_else((A1_CTCF|A1_RAD21), \\S\\, \\N\\),\n      A2 = if_else((A2_CTCF|A2_RAD21), \\S\\, \\N\\)\n    )\n  temp = temp %>% dplyr::rowwise() %>%\n    dplyr::mutate(Anno = paste0(A1, \\-\\, A2),\n                  Anno2 = if_else(Anno == \\N-S\\, \\S-N\\, Anno))\n  temp$Anno2 = factor(temp$Anno2, level = c(\\N-N\\, \\S-N\\, \\S-S\\))\n  return(temp)\n}\n\n\nannotateAnchorTSS <- function(bedpe){\n  tb.loop = \n    setOverlapColumn(\\Whyte.SE\\,\n                     setOverlapColumn(\\CTCF\\,\n                                      setOverlapColumn(\\RAD21\\,\n                                                       setOverlapColumn(\\H3K27ac\\,\n                                                                        setOverlapColumn(\\H3K4me3TSS\\, bedpe)))))\n  return(tb.loop)\n}\n\nsetOverlapColumn <- function(peakName, loop){\n  tb.loop = as_tibble(loop)\n  overlap = returnOverlapIndexLixt(get(paste0(\\peak.\\, peakName)), tb.loop)\n  tb.loop[[paste0(\\A1_\\, peakName)]] = FALSE\n  tb.loop[[paste0(\\A1_\\, peakName)]][overlap[[1]]] = TRUE\n  tb.loop[[paste0(\\A2_\\, peakName)]] = FALSE\n  tb.loop[[paste0(\\A2_\\, peakName)]][overlap[[2]]] = TRUE\n  return(tb.loop)\n}\n\nreturnOverlapIndexLixt <- function(peak, loop){\n  anchor1.tb = as_tibble(loop) %>% dplyr::select(chrom1, start1, end1)\n  anchor1 = makeGRangesFromDataFrame(data.frame(\n    chr = anchor1.tb$chrom1,\n    start = anchor1.tb$start1,\n    end = anchor1.tb$end1\n  ))\n  \n  anchor2.tb = as_tibble(loop) %>% dplyr::select(chrom2, start2, end2)\n  anchor2 = makeGRangesFromDataFrame(data.frame(\n    chr = anchor2.tb$chrom2,\n    start = anchor2.tb$start2,\n    end = anchor2.tb$end2\n  ))\n  \n  overlap = list(overlap1 = unique(queryHits(findOverlaps(anchor1, peak))),\n                 overlap2 = unique(queryHits(findOverlaps(anchor2, peak))))\n  return(overlap)\n}\n\nsaveAnnoGroupBedpe <- function(temp, anno.list, name, annoName, ouDir){\n  loop = temp %>% dplyr::filter(Anno2 %in% anno.list) %>%\n    dplyr::select(c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\))\n  fwrite(loop, here(outDir, paste0(name, \\_\\, annoName, \\.bedpe\\)), sep = \\\\t\\, col.names = FALSE)\n}\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuY3JlYXRlTG9vcEFubm90YXRpb24gPC0gZnVuY3Rpb24oYmVkcGUubG9vcC5hbm5vLCBuYW1lLCBmaWdEaXIsIG91dERpciwgY29sb3JMaXN0KXtcbiAgdGVtcCA9IGJlZHBlLmxvb3AuYW5ubyAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKHNhbXBsZSA9IG5hbWUpXG4gIFxuICBudW0gPSBucm93KHRlbXApXG4gIHA3ID0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gc2FtcGxlLCBmaWxsID0gQW5ubzIpKSArXG4gICAgZ2VvbV9iYXIoY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9idygpICtcbiAgICBsYWJzKHRpdGxlID0gcGFzdGUwKG51bSwgXFwgbG9vcHNcXCksXG4gICAgICAgICB4ID0gXFxcXCwgeSA9IFxcQ291bnRzXFwpICtcbiAgICBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gY29tbWFfZm9ybWF0KCkpICtcbiAgICB0aGVtZShwbG90LnRpdGxlID0gZWxlbWVudF90ZXh0KGhqdXN0ID0gMC41KSxcbiAgICAgICAgICBhc3BlY3QucmF0aW8gPSA1LFxuICAgICAgICAgIGxlZ2VuZC5wb3NpdGlvbiA9IFxccmlnaHRcXCxcbiAgICAgICAgICBsZWdlbmQuZGlyZWN0aW9uICA9IFxcdmVydGljYWxcXCkgK1xuICAgIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGNvbG9yTGlzdClcbiAgXG4gIHdpZHRoID0gM1xuICBoZWlnaHQgPSA1XG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsXG4gICAgICAgICAgICAgICBwYXN0ZTAoXFxsb29wQ2xhc3NpZnlfXFwsIG5hbWUsIFxcLnN2Z1xcKSksXG4gICAgICAgICAgd2lkdGggPSB3aWR0aCwgaGVpZ2h0ID0gaGVpZ2h0KVxuICBwbG90KHA3KVxuICBpbnZpc2libGUoZGV2Lm9mZigpKVxuICBwbmcoaGVyZShmaWdEaXIsXG4gICAgICAgICAgIHBhc3RlMChcXGxvb3BDbGFzc2lmeV9cXCwgbmFtZSwgXFwucG5nXFwpKSxcbiAgICAgIHdpZHRoID0gd2lkdGgsIGhlaWdodCA9IGhlaWdodCwgcmVzID0gNjAwLCB1bml0cyA9IFxcaW5cXClcbiAgcGxvdChwNylcbiAgaW52aXNpYmxlKGRldi5vZmYoKSlcbn1cblxuXG5hbm5vdGF0ZUxvb3BSZWxheGVkVFNTIDwtIGZ1bmN0aW9uKGJlZHBlLmFubm8pe1xuICB0ZW1wID0gYmVkcGUuYW5ubyAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKFxuICAgICAgQTEgPSBpZl9lbHNlKChBMV9IM0s0bWUzVFNTKSwgXFxQXFwsIFxuICAgICAgICAgICAgICAgICAgIGlmX2Vsc2UoKEExX0gzSzI3YWMpLCBcXEVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmX2Vsc2UoKEExX0NUQ0Z8QTFfUkFEMjEpLCBcXFNcXCwgXFxYXFwpKSksXG4gICAgICBBMiA9IGlmX2Vsc2UoKEEyX0gzSzRtZTNUU1MpLCBcXFBcXCwgXG4gICAgICAgICAgICAgICAgICAgaWZfZWxzZSgoQTJfSDNLMjdhYyksIFxcRVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZfZWxzZSgoQTJfQ1RDRnxBMl9SQUQyMSksIFxcU1xcLCBcXFhcXCkpKVxuICAgIClcbiAgdGVtcCA9IHRlbXAgJT4lIGRwbHlyOjpyb3d3aXNlKCkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShBbm5vID0gcGFzdGUwKEExLCBcXC1cXCwgQTIpLFxuICAgICAgICAgICAgICAgICAgQW5ubzIgPSBpZl9lbHNlKEFubm8gPT0gXFxFLVBcXCwgXFxQLUVcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZfZWxzZShBbm5vID09IFxcUy1QXFwsIFxcUC1TXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZl9lbHNlKEFubm8gPT0gXFxYLVBcXCwgXFxQLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZfZWxzZShBbm5vID09IFxcUy1FXFwsIFxcRS1TXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZfZWxzZShBbm5vID09IFxcWC1FXFwsIFxcRS1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZl9lbHNlKEFubm8gPT0gXFxYLVNcXCwgXFxTLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgQW5ubykpKSkpKSxcbiAgICApXG4gIFxuICB0ZW1wJEFubm8yID0gZmFjdG9yKHRlbXAkQW5ubzIsIGxldmVsID0gYyhcXFgtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFMtWFxcLCBcXFMtU1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXEUtWFxcLFxcRS1TXFwsXFxFLUVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxQLUVcXCxcXFAtWFxcLCBcXFAtU1xcLCBcXFAtUFxcKSlcbiAgXG4gICMgQ2hlY2tpbmcgdGhlIHByZWNlbnNlIG9mIHN1cGVyIGVuaGFuY2VyXG4gIHRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKEFubm9TRSA9IGlmZWxzZShBMV9XaHl0ZS5TRSB8IEEyX1doeXRlLlNFLCBcXFNFXFwsIFxcTk9cXCkpXG4gIHRlbXAkQW5ub1NFIDwtIGZhY3Rvcih0ZW1wJEFubm9TRSwgbGV2ZWwgPSBjKFxcU0VcXCwgXFxOT1xcKSlcbiAgXG4gIHJldHVybih0ZW1wKVxufVxuXG5hbm5vdGF0ZUxvb3BQcm9tb3RlclRTUyA8LSBmdW5jdGlvbihiZWRwZS5hbm5vKXtcbiAgdGVtcCA9IGJlZHBlLmFubm8gJT4lIGRwbHlyOjpyb3d3aXNlKCkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShcbiAgICAgIEExID0gaWZfZWxzZSgoQTFfSDNLNG1lM1RTUyksIFxcUFxcLCBcXE5cXCksXG4gICAgICBBMiA9IGlmX2Vsc2UoKEEyX0gzSzRtZTNUU1MpLCBcXFBcXCwgXFxOXFwpXG4gICAgKVxuICB0ZW1wID0gdGVtcCAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKEFubm8gPSBwYXN0ZTAoQTEsIFxcLVxcLCBBMiksXG4gICAgICAgICAgICAgICAgICBBbm5vMiA9IGlmX2Vsc2UoQW5ubyA9PSBcXE4tUFxcLCBcXFAtTlxcLCBBbm5vKSlcbiAgXG4gIHRlbXAkQW5ubzIgPSBmYWN0b3IodGVtcCRBbm5vMiwgbGV2ZWwgPSBjKFxcTi1OXFwsIFxcUC1OXFwsIFxcUC1QXFwpKVxuICBcbiAgcmV0dXJuKHRlbXApXG59XG5cbmFubm90YXRlTG9vcEVuaGFuY2VyIDwtIGZ1bmN0aW9uKGJlZHBlLmFubm8pe1xuICB0ZW1wID0gYmVkcGUuYW5ubyAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKFxuICAgICAgQTEgPSBpZl9lbHNlKChBMV9IM0syN2FjKSwgXFxFXFwsIFxcTlxcKSxcbiAgICAgIEEyID0gaWZfZWxzZSgoQTJfSDNLMjdhYyksIFxcRVxcLCBcXE5cXClcbiAgICApXG4gIHRlbXAgPSB0ZW1wICU+JSBkcGx5cjo6cm93d2lzZSgpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoQW5ubyA9IHBhc3RlMChBMSwgXFwtXFwsIEEyKSxcbiAgICAgICAgICAgICAgICAgIEFubm8yID0gaWZfZWxzZShBbm5vID09IFxcTi1FXFwsIFxcRS1OXFwsIEFubm8pKVxuICB0ZW1wJEFubm8yID0gZmFjdG9yKHRlbXAkQW5ubzIsIGxldmVsID0gYyhcXE4tTlxcLCBcXEUtTlxcLCBcXEUtRVxcKSlcbiAgXG4gIHJldHVybih0ZW1wKVxufVxuXG5hbm5vdGF0ZUxvb3BTdHJ1Y3R1cmUgPC0gZnVuY3Rpb24oYmVkcGUuYW5ubyl7XG4gIHRlbXAgPSBiZWRwZS5hbm5vICU+JSBkcGx5cjo6cm93d2lzZSgpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoXG4gICAgICBBMSA9IGlmX2Vsc2UoKEExX0NUQ0Z8QTFfUkFEMjEpLCBcXFNcXCwgXFxOXFwpLFxuICAgICAgQTIgPSBpZl9lbHNlKChBMl9DVENGfEEyX1JBRDIxKSwgXFxTXFwsIFxcTlxcKVxuICAgIClcbiAgdGVtcCA9IHRlbXAgJT4lIGRwbHlyOjpyb3d3aXNlKCkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShBbm5vID0gcGFzdGUwKEExLCBcXC1cXCwgQTIpLFxuICAgICAgICAgICAgICAgICAgQW5ubzIgPSBpZl9lbHNlKEFubm8gPT0gXFxOLVNcXCwgXFxTLU5cXCwgQW5ubykpXG4gIHRlbXAkQW5ubzIgPSBmYWN0b3IodGVtcCRBbm5vMiwgbGV2ZWwgPSBjKFxcTi1OXFwsIFxcUy1OXFwsIFxcUy1TXFwpKVxuICByZXR1cm4odGVtcClcbn1cblxuXG5hbm5vdGF0ZUFuY2hvclRTUyA8LSBmdW5jdGlvbihiZWRwZSl7XG4gIHRiLmxvb3AgPSBcbiAgICBzZXRPdmVybGFwQ29sdW1uKFxcV2h5dGUuU0VcXCxcbiAgICAgICAgICAgICAgICAgICAgIHNldE92ZXJsYXBDb2x1bW4oXFxDVENGXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNldE92ZXJsYXBDb2x1bW4oXFxSQUQyMVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNldE92ZXJsYXBDb2x1bW4oXFxIM0syN2FjXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzZXRPdmVybGFwQ29sdW1uKFxcSDNLNG1lM1RTU1xcLCBiZWRwZSkpKSkpXG4gIHJldHVybih0Yi5sb29wKVxufVxuXG5zZXRPdmVybGFwQ29sdW1uIDwtIGZ1bmN0aW9uKHBlYWtOYW1lLCBsb29wKXtcbiAgdGIubG9vcCA9IGFzX3RpYmJsZShsb29wKVxuICBvdmVybGFwID0gcmV0dXJuT3ZlcmxhcEluZGV4TGl4dChnZXQocGFzdGUwKFxccGVhay5cXCwgcGVha05hbWUpKSwgdGIubG9vcClcbiAgdGIubG9vcFtbcGFzdGUwKFxcQTFfXFwsIHBlYWtOYW1lKV1dID0gRkFMU0VcbiAgdGIubG9vcFtbcGFzdGUwKFxcQTFfXFwsIHBlYWtOYW1lKV1dW292ZXJsYXBbWzFdXV0gPSBUUlVFXG4gIHRiLmxvb3BbW3Bhc3RlMChcXEEyX1xcLCBwZWFrTmFtZSldXSA9IEZBTFNFXG4gIHRiLmxvb3BbW3Bhc3RlMChcXEEyX1xcLCBwZWFrTmFtZSldXVtvdmVybGFwW1syXV1dID0gVFJVRVxuICByZXR1cm4odGIubG9vcClcbn1cblxucmV0dXJuT3ZlcmxhcEluZGV4TGl4dCA8LSBmdW5jdGlvbihwZWFrLCBsb29wKXtcbiAgYW5jaG9yMS50YiA9IGFzX3RpYmJsZShsb29wKSAlPiUgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSlcbiAgYW5jaG9yMSA9IG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShkYXRhLmZyYW1lKFxuICAgIGNociA9IGFuY2hvcjEudGIkY2hyb20xLFxuICAgIHN0YXJ0ID0gYW5jaG9yMS50YiRzdGFydDEsXG4gICAgZW5kID0gYW5jaG9yMS50YiRlbmQxXG4gICkpXG4gIFxuICBhbmNob3IyLnRiID0gYXNfdGliYmxlKGxvb3ApICU+JSBkcGx5cjo6c2VsZWN0KGNocm9tMiwgc3RhcnQyLCBlbmQyKVxuICBhbmNob3IyID0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGRhdGEuZnJhbWUoXG4gICAgY2hyID0gYW5jaG9yMi50YiRjaHJvbTIsXG4gICAgc3RhcnQgPSBhbmNob3IyLnRiJHN0YXJ0MixcbiAgICBlbmQgPSBhbmNob3IyLnRiJGVuZDJcbiAgKSlcbiAgXG4gIG92ZXJsYXAgPSBsaXN0KG92ZXJsYXAxID0gdW5pcXVlKHF1ZXJ5SGl0cyhmaW5kT3ZlcmxhcHMoYW5jaG9yMSwgcGVhaykpKSxcbiAgICAgICAgICAgICAgICAgb3ZlcmxhcDIgPSB1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyhhbmNob3IyLCBwZWFrKSkpKVxuICByZXR1cm4ob3ZlcmxhcClcbn1cblxuc2F2ZUFubm9Hcm91cEJlZHBlIDwtIGZ1bmN0aW9uKHRlbXAsIGFubm8ubGlzdCwgbmFtZSwgYW5ub05hbWUsIG91RGlyKXtcbiAgbG9vcCA9IHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBhbm5vLmxpc3QpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoYyhcXGNocm9tMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHJvbTJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwpKVxuICBmd3JpdGUobG9vcCwgaGVyZShvdXREaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgYW5ub05hbWUsIFxcLmJlZHBlXFwpKSwgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gRkFMU0UpXG59XG5gYGBcbmBgYCJ9 -->

```r
```r
createLoopAnnotation <- function(bedpe.loop.anno, name, figDir, outDir, colorList){
  temp = bedpe.loop.anno %>%
    dplyr::mutate(sample = name)
  
  num = nrow(temp)
  p7 = ggplot(temp, aes(x = sample, fill = Anno2)) +
    geom_bar(color = \black\) +
    theme_bw() +
    labs(title = paste0(num, \ loops\),
         x = \\, y = \Counts\) +
    scale_y_continuous(labels = comma_format()) +
    theme(plot.title = element_text(hjust = 0.5),
          aspect.ratio = 5,
          legend.position = \right\,
          legend.direction  = \vertical\) +
    scale_fill_manual(values = colorList)
  
  width = 3
  height = 5
  svglite(here(figDir,
               paste0(\loopClassify_\, name, \.svg\)),
          width = width, height = height)
  plot(p7)
  invisible(dev.off())
  png(here(figDir,
           paste0(\loopClassify_\, name, \.png\)),
      width = width, height = height, res = 600, units = \in\)
  plot(p7)
  invisible(dev.off())
}


annotateLoopRelaxedTSS <- function(bedpe.anno){
  temp = bedpe.anno %>% dplyr::rowwise() %>%
    dplyr::mutate(
      A1 = if_else((A1_H3K4me3TSS), \P\, 
                   if_else((A1_H3K27ac), \E\,
                           if_else((A1_CTCF|A1_RAD21), \S\, \X\))),
      A2 = if_else((A2_H3K4me3TSS), \P\, 
                   if_else((A2_H3K27ac), \E\,
                           if_else((A2_CTCF|A2_RAD21), \S\, \X\)))
    )
  temp = temp %>% dplyr::rowwise() %>%
    dplyr::mutate(Anno = paste0(A1, \-\, A2),
                  Anno2 = if_else(Anno == \E-P\, \P-E\, 
                                  if_else(Anno == \S-P\, \P-S\,
                                          if_else(Anno == \X-P\, \P-X\,
                                                  if_else(Anno == \S-E\, \E-S\,
                                                          if_else(Anno == \X-E\, \E-X\,
                                                                  if_else(Anno == \X-S\, \S-X\,
                                                                          Anno)))))),
    )
  
  temp$Anno2 = factor(temp$Anno2, level = c(\X-X\,
                                            \S-X\, \S-S\,
                                            \E-X\,\E-S\,\E-E\,
                                            \P-E\,\P-X\, \P-S\, \P-P\))
  
  # Checking the precense of super enhancer
  temp <- temp %>% dplyr::rowwise() %>%
    dplyr::mutate(AnnoSE = ifelse(A1_Whyte.SE | A2_Whyte.SE, \SE\, \NO\))
  temp$AnnoSE <- factor(temp$AnnoSE, level = c(\SE\, \NO\))
  
  return(temp)
}

annotateLoopPromoterTSS <- function(bedpe.anno){
  temp = bedpe.anno %>% dplyr::rowwise() %>%
    dplyr::mutate(
      A1 = if_else((A1_H3K4me3TSS), \P\, \N\),
      A2 = if_else((A2_H3K4me3TSS), \P\, \N\)
    )
  temp = temp %>% dplyr::rowwise() %>%
    dplyr::mutate(Anno = paste0(A1, \-\, A2),
                  Anno2 = if_else(Anno == \N-P\, \P-N\, Anno))
  
  temp$Anno2 = factor(temp$Anno2, level = c(\N-N\, \P-N\, \P-P\))
  
  return(temp)
}

annotateLoopEnhancer <- function(bedpe.anno){
  temp = bedpe.anno %>% dplyr::rowwise() %>%
    dplyr::mutate(
      A1 = if_else((A1_H3K27ac), \E\, \N\),
      A2 = if_else((A2_H3K27ac), \E\, \N\)
    )
  temp = temp %>% dplyr::rowwise() %>%
    dplyr::mutate(Anno = paste0(A1, \-\, A2),
                  Anno2 = if_else(Anno == \N-E\, \E-N\, Anno))
  temp$Anno2 = factor(temp$Anno2, level = c(\N-N\, \E-N\, \E-E\))
  
  return(temp)
}

annotateLoopStructure <- function(bedpe.anno){
  temp = bedpe.anno %>% dplyr::rowwise() %>%
    dplyr::mutate(
      A1 = if_else((A1_CTCF|A1_RAD21), \S\, \N\),
      A2 = if_else((A2_CTCF|A2_RAD21), \S\, \N\)
    )
  temp = temp %>% dplyr::rowwise() %>%
    dplyr::mutate(Anno = paste0(A1, \-\, A2),
                  Anno2 = if_else(Anno == \N-S\, \S-N\, Anno))
  temp$Anno2 = factor(temp$Anno2, level = c(\N-N\, \S-N\, \S-S\))
  return(temp)
}


annotateAnchorTSS <- function(bedpe){
  tb.loop = 
    setOverlapColumn(\Whyte.SE\,
                     setOverlapColumn(\CTCF\,
                                      setOverlapColumn(\RAD21\,
                                                       setOverlapColumn(\H3K27ac\,
                                                                        setOverlapColumn(\H3K4me3TSS\, bedpe)))))
  return(tb.loop)
}

setOverlapColumn <- function(peakName, loop){
  tb.loop = as_tibble(loop)
  overlap = returnOverlapIndexLixt(get(paste0(\peak.\, peakName)), tb.loop)
  tb.loop[[paste0(\A1_\, peakName)]] = FALSE
  tb.loop[[paste0(\A1_\, peakName)]][overlap[[1]]] = TRUE
  tb.loop[[paste0(\A2_\, peakName)]] = FALSE
  tb.loop[[paste0(\A2_\, peakName)]][overlap[[2]]] = TRUE
  return(tb.loop)
}

returnOverlapIndexLixt <- function(peak, loop){
  anchor1.tb = as_tibble(loop) %>% dplyr::select(chrom1, start1, end1)
  anchor1 = makeGRangesFromDataFrame(data.frame(
    chr = anchor1.tb$chrom1,
    start = anchor1.tb$start1,
    end = anchor1.tb$end1
  ))
  
  anchor2.tb = as_tibble(loop) %>% dplyr::select(chrom2, start2, end2)
  anchor2 = makeGRangesFromDataFrame(data.frame(
    chr = anchor2.tb$chrom2,
    start = anchor2.tb$start2,
    end = anchor2.tb$end2
  ))
  
  overlap = list(overlap1 = unique(queryHits(findOverlaps(anchor1, peak))),
                 overlap2 = unique(queryHits(findOverlaps(anchor2, peak))))
  return(overlap)
}

saveAnnoGroupBedpe <- function(temp, anno.list, name, annoName, ouDir){
  loop = temp %>% dplyr::filter(Anno2 %in% anno.list) %>%
    dplyr::select(c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\))
  fwrite(loop, here(outDir, paste0(name, \_\, annoName, \.bedpe\)), sep = \\t\, col.names = FALSE)
}
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



### [2.5] Consensus loop annotation

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuY29uc2Vuc3VzLmxvb3AudGIgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfc2NvcmUudHN2XCIpKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBGaWx0ZXJpbmcgSDNLNG1lMyBwZWFrcyB0aGF0IGhhcyBUU1MgbmVhcmJ5XG4jIFNpbmNlIHRoZSBmaW5lc3QgcmVzb2x1dGlvbiBpcyA1a2IsICstMi41a2Igd2lsbCBiZSB1c2VkIGFzIGEgY3V0b2ZmIGZvciBjaGVja2luZyBUU1MgcHJlc2VuY2VcbmZsYW5rU2l6ZSA8LSAyNTAwXG5nZW5lLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcIm1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFwiK1wiLCBWMiwgVjMpLFxuICAgICAgICAgICAgICAgIFRTU3N0YXJ0ID0gVFNTIC0gZmxhbmtTaXplLFxuICAgICAgICAgICAgICAgIFRTU2VuZCA9IFRTUyArIGZsYW5rU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTU3N0YXJ0LCBUU1NlbmQpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFwiY2hyXCIsIFwic3RhcnRcIiwgXCJlbmRcIilcblRTUzFrYi5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZS50YilcbnRlbXAgPC0gcGVhay5IM0s0bWUzW3VuaXF1ZShxdWVyeUhpdHMoZmluZE92ZXJsYXBzKHBlYWsuSDNLNG1lMywgVFNTMWtiLmdyKSkpXVxuZndyaXRlKGFzX3RpYmJsZSh0ZW1wKSwgaGVyZShyZWZEaXIsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBwYXN0ZTAoXCIzMzI1NV9IM0s0bWUzXzA0LTc0NV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5cIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBmbGFua1NpemUvMTAwMCwgXCJrYlRTUy5iZWRcIikpLCBzZXAgPSBcIlxcdFwiLCBjb2wubmFtZXMgPSBGQUxTRSlcbnBlYWsuSDNLNG1lM1RTUyA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBwYXN0ZTAoXCIzMzI1NV9IM0s0bWUzXzA0LTc0NV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5cIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBmbGFua1NpemUvMTAwMCwgXCJrYlRTUy5iZWRcIikpKVxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMgQW5ub3RhdGluZyB3aXRoIHN0cmljdCBwcmlvcml0eSAoUC1UU1MgPiBFID4gUylcbnRlbXAuYW5uby5UU1MgPC0gYW5ub3RhdGVBbmNob3JUU1MoY29uc2Vuc3VzLmxvb3AudGIpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGRpZmZfZFRBR19ETVNPID0gKGRUQUctRE1TTyksXG4gICAgZGlmZl9BNDg1X0RNU08gPSAoQTQ4NS1ETVNPKSlcblxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuY29uc2Vuc3VzLmxvb3AuYW5uby50YiA8LSBhbm5vdGF0ZUxvb3BSZWxheGVkVFNTKHRlbXAuYW5uby5UU1MpXG5md3JpdGUoY29uc2Vuc3VzLmxvb3AuYW5uby50YiwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcIi50c3ZcIikpLCBcbiAgICAgICBzZXAgPSBcIlxcdFwiLCBjb2wubmFtZXMgPSBUUlVFKVxuY3JlYXRlTG9vcEFubm90YXRpb24oY29uc2Vuc3VzLmxvb3AuYW5uby50YiwgbmFtZSwgZmlnRGlyLCBvdXREaXIsICBjb2xvckxpc3RMb29wKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIHVuaXF1ZShjb25zZW5zdXMubG9vcC5hbm5vLnRiJEFubm8yKSAsIG5hbWUsIFwiYWxsXCIsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnRiLCBjKFwiUC1QXCIsIFwiUC1FXCIsIFwiUC1TXCIsIFwiUC1YXCIsIFwiRS1FXCIsIFwiRS1TXCIsIFwiRS1YXCIpLCBuYW1lLCBcInJlZ3VsYXRvcnlcIiwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIGMoXCJTLVNcIiwgXCJTLVhcIiksIG5hbWUsIFwic3RydWN0dXJlXCIsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnRiLCBjKFwiWC1YXCIpLCBuYW1lLCBcIngteFwiLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby50YiwgYyhcIlAtUFwiLCBcIlAtRVwiLCBcIlAtU1wiLCBcIlAtWFwiKSwgbmFtZSwgXCJwLW5cIiwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIGMoXCJQLVBcIiwgXCJQLUVcIiwgXCJFLUVcIiksIG5hbWUsIFwicGUtcGVcIiwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIGMoXCJQLVBcIiwgXCJQLUVcIiksIG5hbWUsIFwicC1wZVwiLCBvdXREaXIpXG5cbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnRiLCBjKFwiUC1QXCIpLCBuYW1lLCBcInAtcFwiLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby50YiwgYyhcIlAtRVwiKSwgbmFtZSwgXCJwLWVcIiwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIGMoXCJQLVNcIiksIG5hbWUsIFwicC1zXCIsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnRiLCBjKFwiUC1YXCIpLCBuYW1lLCBcInAteFwiLCBvdXREaXIpXG5cbiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG4jIEFubm90YXRpbmcgd2l0aCBvbmUgbWFya2VyIChQcm9tb3Rlcilcbm5hbWUgPC0gXCJjaHJvbW9fY29uc19hbm5vUHJvbW90ZXJcIlxuY29uc2Vuc3VzLmxvb3AuYW5uby5wcm9tb3Rlci50YiA8LSBhbm5vdGF0ZUxvb3BQcm9tb3RlclRTUyh0ZW1wLmFubm8uVFNTKVxuZndyaXRlKGNvbnNlbnN1cy5sb29wLmFubm8ucHJvbW90ZXIudGIsIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXCIudHN2XCIpKSwgXG4gICAgICAgc2VwID0gXCJcXHRcIiwgY29sLm5hbWVzID0gVFJVRSlcbmNyZWF0ZUxvb3BBbm5vdGF0aW9uKGNvbnNlbnN1cy5sb29wLmFubm8ucHJvbW90ZXIudGIsIG5hbWUsIFxuICAgICAgICAgICAgICAgICAgICAgZmlnRGlyLCBvdXREaXIsICBjb2xvckxpc3RQcm9tb3RlcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnByb21vdGVyLnRiLCB1bmlxdWUoY29uc2Vuc3VzLmxvb3AuYW5uby5wcm9tb3Rlci50YiRBbm5vMikgLCBuYW1lLCBcImFsbFwiLCBvdXREaXIpICBcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnByb21vdGVyLnRiLCBjKFwiUC1QXCIpLCBuYW1lLCBcInAtcFwiLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby5wcm9tb3Rlci50YiwgYyhcIlAtTlwiKSwgbmFtZSwgXCJwLW5cIiwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8ucHJvbW90ZXIudGIsIGMoXCJOLU5cIiksIG5hbWUsIFwibi1uXCIsIG91dERpcilcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMgQW5ub3RhdGluZyB3aXRoIG9uZSBtYXJrZXIgKEVuaGFuY2VyKVxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9FbmhhbmNlclwiXG5jb25zZW5zdXMubG9vcC5hbm5vLmVuaGFuY2VyLnRiIDwtIGFubm90YXRlTG9vcEVuaGFuY2VyKHRlbXAuYW5uby5UU1MpXG5md3JpdGUoY29uc2Vuc3VzLmxvb3AuYW5uby5lbmhhbmNlci50YiwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcIi50c3ZcIikpLCBcbiAgICAgICBzZXAgPSBcIlxcdFwiLCBjb2wubmFtZXMgPSBUUlVFKVxuY3JlYXRlTG9vcEFubm90YXRpb24oY29uc2Vuc3VzLmxvb3AuYW5uby5lbmhhbmNlci50YiwgbmFtZSwgXG4gICAgICAgICAgICAgICAgICAgICBmaWdEaXIsIG91dERpciwgIGNvbG9yTGlzdEVuaGFuY2VyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8uZW5oYW5jZXIudGIsIHVuaXF1ZShjb25zZW5zdXMubG9vcC5hbm5vLmVuaGFuY2VyLnRiJEFubm8yKSAsIG5hbWUsIFwiYWxsXCIsIG91dERpcikgIFxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8uZW5oYW5jZXIudGIsIGMoXCJFLUVcIiksIG5hbWUsIFwiZS1lXCIsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLmVuaGFuY2VyLnRiLCBjKFwiRS1OXCIpLCBuYW1lLCBcImUtblwiLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby5lbmhhbmNlci50YiwgYyhcIk4tTlwiKSwgbmFtZSwgXCJuLW5cIiwgb3V0RGlyKVxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMgQW5ub3RhdGluZyB3aXRoIG9uZSBtYXJrZXIgKFN0cnVjdHVyZSlcbm5hbWUgPC0gXCJjaHJvbW9fY29uc19hbm5vU3RydWN0dXJlXCJcbmNvbnNlbnN1cy5sb29wLmFubm8uc3RydWN0dXJlLnRiIDwtIGFubm90YXRlTG9vcFN0cnVjdHVyZSh0ZW1wLmFubm8uVFNTKVxuZndyaXRlKGNvbnNlbnN1cy5sb29wLmFubm8uc3RydWN0dXJlLnRiLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiLnRzdlwiKSksIFxuICAgICAgIHNlcCA9IFwiXFx0XCIsIGNvbC5uYW1lcyA9IFRSVUUpXG5jcmVhdGVMb29wQW5ub3RhdGlvbihjb25zZW5zdXMubG9vcC5hbm5vLnN0cnVjdHVyZS50YiwgbmFtZSwgXG4gICAgICAgICAgICAgICAgICAgICBmaWdEaXIsIG91dERpciwgIGNvbG9yTGlzdFN0cnVjdHVyZSlcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnN0cnVjdHVyZS50YiwgdW5pcXVlKGNvbnNlbnN1cy5sb29wLmFubm8uc3RydWN0dXJlLnRiJEFubm8yKSAsIG5hbWUsIFwiYWxsXCIsIG91dERpcikgIFxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8uc3RydWN0dXJlLnRiLCBjKFwiUy1TXCIpLCBuYW1lLCBcInMtc1wiLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby5zdHJ1Y3R1cmUudGIsIGMoXCJTLU5cIiksIG5hbWUsIFwicy1uXCIsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnN0cnVjdHVyZS50YiwgYyhcIk4tTlwiKSwgbmFtZSwgXCJuLW5cIiwgb3V0RGlyKVxuYGBgIn0= -->\n\n```r\nconsensus.loop.tb <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\n################################################################################\n# Filtering H3K4me3 peaks that has TSS nearby\n# Since the finest resolution is 5kb, +-2.5kb will be used as a cutoff for checking TSS presence\nflankSize <- 2500\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend)\ncolnames(gene.tb) <- c(\\chr\\, \\start\\, \\end\\)\nTSS1kb.gr <- makeGRangesFromDataFrame(gene.tb)\ntemp <- peak.H3K4me3[unique(queryHits(findOverlaps(peak.H3K4me3, TSS1kb.gr)))]\nfwrite(as_tibble(temp), here(refDir, \n                             paste0(\\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.\\, \n                                    flankSize/1000, \\kbTSS.bed\\)), sep = \\\\t\\, col.names = FALSE)\npeak.H3K4me3TSS <- importPeak(here(refDir, paste0(\\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.\\, \n                                    flankSize/1000, \\kbTSS.bed\\)))\n################################################################################\n# Annotating with strict priority (P-TSS > E > S)\ntemp.anno.TSS <- annotateAnchorTSS(consensus.loop.tb) %>%\n  dplyr::mutate(\n    diff_dTAG_DMSO = (dTAG-DMSO),\n    diff_A485_DMSO = (A485-DMSO))\n\nname <- \\chromo_cons_annoHierarchy\\\nconsensus.loop.anno.tb <- annotateLoopRelaxedTSS(temp.anno.TSS)\nfwrite(consensus.loop.anno.tb, here(consensusDir, paste0(name, \\.tsv\\)), \n       sep = \\\\t\\, col.names = TRUE)\ncreateLoopAnnotation(consensus.loop.anno.tb, name, figDir, outDir,  colorListLoop)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, unique(consensus.loop.anno.tb$Anno2) , name, \\all\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\, \\E-E\\, \\E-S\\, \\E-X\\), name, \\regulatory\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\S-S\\, \\S-X\\), name, \\structure\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\X-X\\), name, \\x-x\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\), name, \\p-n\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-P\\, \\P-E\\, \\E-E\\), name, \\pe-pe\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-P\\, \\P-E\\), name, \\p-pe\\, outDir)\n\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-P\\), name, \\p-p\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-E\\), name, \\p-e\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-S\\), name, \\p-s\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-X\\), name, \\p-x\\, outDir)\n\n################################################################################\n# Annotating with one marker (Promoter)\nname <- \\chromo_cons_annoPromoter\\\nconsensus.loop.anno.promoter.tb <- annotateLoopPromoterTSS(temp.anno.TSS)\nfwrite(consensus.loop.anno.promoter.tb, here(consensusDir, paste0(name, \\.tsv\\)), \n       sep = \\\\t\\, col.names = TRUE)\ncreateLoopAnnotation(consensus.loop.anno.promoter.tb, name, \n                     figDir, outDir,  colorListPromoter)\nsaveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, unique(consensus.loop.anno.promoter.tb$Anno2) , name, \\all\\, outDir)  \nsaveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c(\\P-P\\), name, \\p-p\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c(\\P-N\\), name, \\p-n\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c(\\N-N\\), name, \\n-n\\, outDir)\n\n################################################################################\n# Annotating with one marker (Enhancer)\nname <- \\chromo_cons_annoEnhancer\\\nconsensus.loop.anno.enhancer.tb <- annotateLoopEnhancer(temp.anno.TSS)\nfwrite(consensus.loop.anno.enhancer.tb, here(consensusDir, paste0(name, \\.tsv\\)), \n       sep = \\\\t\\, col.names = TRUE)\ncreateLoopAnnotation(consensus.loop.anno.enhancer.tb, name, \n                     figDir, outDir,  colorListEnhancer)\nsaveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, unique(consensus.loop.anno.enhancer.tb$Anno2) , name, \\all\\, outDir)  \nsaveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c(\\E-E\\), name, \\e-e\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c(\\E-N\\), name, \\e-n\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c(\\N-N\\), name, \\n-n\\, outDir)\n################################################################################\n# Annotating with one marker (Structure)\nname <- \\chromo_cons_annoStructure\\\nconsensus.loop.anno.structure.tb <- annotateLoopStructure(temp.anno.TSS)\nfwrite(consensus.loop.anno.structure.tb, here(consensusDir, paste0(name, \\.tsv\\)), \n       sep = \\\\t\\, col.names = TRUE)\ncreateLoopAnnotation(consensus.loop.anno.structure.tb, name, \n                     figDir, outDir,  colorListStructure)\nsaveAnnoGroupBedpe(consensus.loop.anno.structure.tb, unique(consensus.loop.anno.structure.tb$Anno2) , name, \\all\\, outDir)  \nsaveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c(\\S-S\\), name, \\s-s\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c(\\S-N\\), name, \\s-n\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c(\\N-N\\), name, \\n-n\\, outDir)\n```\n\n<!-- rnb-source-end -->\n"} -->
consensus.loop.tb <- fread(here(consensusDir, \chromo_cons_score.tsv\))

################################################################################
# Filtering H3K4me3 peaks that has TSS nearby
# Since the finest resolution is 5kb, +-2.5kb will be used as a cutoff for checking TSS presence
flankSize <- 2500
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend)
colnames(gene.tb) <- c(\chr\, \start\, \end\)
TSS1kb.gr <- makeGRangesFromDataFrame(gene.tb)
temp <- peak.H3K4me3[unique(queryHits(findOverlaps(peak.H3K4me3, TSS1kb.gr)))]
fwrite(as_tibble(temp), here(refDir, 
                             paste0(\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.\, 
                                    flankSize/1000, \kbTSS.bed\)), sep = \\t\, col.names = FALSE)
peak.H3K4me3TSS <- importPeak(here(refDir, paste0(\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.\, 
                                    flankSize/1000, \kbTSS.bed\)))
################################################################################
# Annotating with strict priority (P-TSS > E > S)
temp.anno.TSS <- annotateAnchorTSS(consensus.loop.tb) %>%
  dplyr::mutate(
    diff_dTAG_DMSO = (dTAG-DMSO),
    diff_A485_DMSO = (A485-DMSO))

name <- \chromo_cons_annoHierarchy\
consensus.loop.anno.tb <- annotateLoopRelaxedTSS(temp.anno.TSS)
fwrite(consensus.loop.anno.tb, here(consensusDir, paste0(name, \.tsv\)), 
       sep = \\t\, col.names = TRUE)
createLoopAnnotation(consensus.loop.anno.tb, name, figDir, outDir,  colorListLoop)
saveAnnoGroupBedpe(consensus.loop.anno.tb, unique(consensus.loop.anno.tb$Anno2) , name, \all\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-P\, \P-E\, \P-S\, \P-X\, \E-E\, \E-S\, \E-X\), name, \regulatory\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\S-S\, \S-X\), name, \structure\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\X-X\), name, \x-x\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-P\, \P-E\, \P-S\, \P-X\), name, \p-n\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-P\, \P-E\, \E-E\), name, \pe-pe\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-P\, \P-E\), name, \p-pe\, outDir)

saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-P\), name, \p-p\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-E\), name, \p-e\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-S\), name, \p-s\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-X\), name, \p-x\, outDir)

################################################################################
# Annotating with one marker (Promoter)
name <- \chromo_cons_annoPromoter\
consensus.loop.anno.promoter.tb <- annotateLoopPromoterTSS(temp.anno.TSS)
fwrite(consensus.loop.anno.promoter.tb, here(consensusDir, paste0(name, \.tsv\)), 
       sep = \\t\, col.names = TRUE)
createLoopAnnotation(consensus.loop.anno.promoter.tb, name, 
                     figDir, outDir,  colorListPromoter)
saveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, unique(consensus.loop.anno.promoter.tb$Anno2) , name, \all\, outDir)  
saveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c(\P-P\), name, \p-p\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c(\P-N\), name, \p-n\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c(\N-N\), name, \n-n\, outDir)

################################################################################
# Annotating with one marker (Enhancer)
name <- \chromo_cons_annoEnhancer\
consensus.loop.anno.enhancer.tb <- annotateLoopEnhancer(temp.anno.TSS)
fwrite(consensus.loop.anno.enhancer.tb, here(consensusDir, paste0(name, \.tsv\)), 
       sep = \\t\, col.names = TRUE)
createLoopAnnotation(consensus.loop.anno.enhancer.tb, name, 
                     figDir, outDir,  colorListEnhancer)
saveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, unique(consensus.loop.anno.enhancer.tb$Anno2) , name, \all\, outDir)  
saveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c(\E-E\), name, \e-e\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c(\E-N\), name, \e-n\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c(\N-N\), name, \n-n\, outDir)
################################################################################
# Annotating with one marker (Structure)
name <- \chromo_cons_annoStructure\
consensus.loop.anno.structure.tb <- annotateLoopStructure(temp.anno.TSS)
fwrite(consensus.loop.anno.structure.tb, here(consensusDir, paste0(name, \.tsv\)), 
       sep = \\t\, col.names = TRUE)
createLoopAnnotation(consensus.loop.anno.structure.tb, name, 
                     figDir, outDir,  colorListStructure)
saveAnnoGroupBedpe(consensus.loop.anno.structure.tb, unique(consensus.loop.anno.structure.tb$Anno2) , name, \all\, outDir)  
saveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c(\S-S\), name, \s-s\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c(\S-N\), name, \s-n\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c(\N-N\), name, \n-n\, outDir)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuY29uc2Vuc3VzLmxvb3AudGIgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfc2NvcmUudHN2XFwpKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBGaWx0ZXJpbmcgSDNLNG1lMyBwZWFrcyB0aGF0IGhhcyBUU1MgbmVhcmJ5XG4jIFNpbmNlIHRoZSBmaW5lc3QgcmVzb2x1dGlvbiBpcyA1a2IsICstMi41a2Igd2lsbCBiZSB1c2VkIGFzIGEgY3V0b2ZmIGZvciBjaGVja2luZyBUU1MgcHJlc2VuY2VcbmZsYW5rU2l6ZSA8LSAyNTAwXG5nZW5lLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpLFxuICAgICAgICAgICAgICAgIFRTU3N0YXJ0ID0gVFNTIC0gZmxhbmtTaXplLFxuICAgICAgICAgICAgICAgIFRTU2VuZCA9IFRTUyArIGZsYW5rU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTU3N0YXJ0LCBUU1NlbmQpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcblRTUzFrYi5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZS50YilcbnRlbXAgPC0gcGVhay5IM0s0bWUzW3VuaXF1ZShxdWVyeUhpdHMoZmluZE92ZXJsYXBzKHBlYWsuSDNLNG1lMywgVFNTMWtiLmdyKSkpXVxuZndyaXRlKGFzX3RpYmJsZSh0ZW1wKSwgaGVyZShyZWZEaXIsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBwYXN0ZTAoXFwzMzI1NV9IM0s0bWUzXzA0LTc0NV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5cXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBmbGFua1NpemUvMTAwMCwgXFxrYlRTUy5iZWRcXCkpLCBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBGQUxTRSlcbnBlYWsuSDNLNG1lM1RTUyA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBwYXN0ZTAoXFwzMzI1NV9IM0s0bWUzXzA0LTc0NV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5cXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBmbGFua1NpemUvMTAwMCwgXFxrYlRTUy5iZWRcXCkpKVxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMgQW5ub3RhdGluZyB3aXRoIHN0cmljdCBwcmlvcml0eSAoUC1UU1MgPiBFID4gUylcbnRlbXAuYW5uby5UU1MgPC0gYW5ub3RhdGVBbmNob3JUU1MoY29uc2Vuc3VzLmxvb3AudGIpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGRpZmZfZFRBR19ETVNPID0gKGRUQUctRE1TTyksXG4gICAgZGlmZl9BNDg1X0RNU08gPSAoQTQ4NS1ETVNPKSlcblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuY29uc2Vuc3VzLmxvb3AuYW5uby50YiA8LSBhbm5vdGF0ZUxvb3BSZWxheGVkVFNTKHRlbXAuYW5uby5UU1MpXG5md3JpdGUoY29uc2Vuc3VzLmxvb3AuYW5uby50YiwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpLCBcbiAgICAgICBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBUUlVFKVxuY3JlYXRlTG9vcEFubm90YXRpb24oY29uc2Vuc3VzLmxvb3AuYW5uby50YiwgbmFtZSwgZmlnRGlyLCBvdXREaXIsICBjb2xvckxpc3RMb29wKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIHVuaXF1ZShjb25zZW5zdXMubG9vcC5hbm5vLnRiJEFubm8yKSAsIG5hbWUsIFxcYWxsXFwsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnRiLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcUC1TXFwsIFxcUC1YXFwsIFxcRS1FXFwsIFxcRS1TXFwsIFxcRS1YXFwpLCBuYW1lLCBcXHJlZ3VsYXRvcnlcXCwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIGMoXFxTLVNcXCwgXFxTLVhcXCksIG5hbWUsIFxcc3RydWN0dXJlXFwsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnRiLCBjKFxcWC1YXFwpLCBuYW1lLCBcXHgteFxcLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby50YiwgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcKSwgbmFtZSwgXFxwLW5cXCwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCksIG5hbWUsIFxccGUtcGVcXCwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIGMoXFxQLVBcXCwgXFxQLUVcXCksIG5hbWUsIFxccC1wZVxcLCBvdXREaXIpXG5cbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnRiLCBjKFxcUC1QXFwpLCBuYW1lLCBcXHAtcFxcLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby50YiwgYyhcXFAtRVxcKSwgbmFtZSwgXFxwLWVcXCwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIGMoXFxQLVNcXCksIG5hbWUsIFxccC1zXFwsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnRiLCBjKFxcUC1YXFwpLCBuYW1lLCBcXHAteFxcLCBvdXREaXIpXG5cbiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG4jIEFubm90YXRpbmcgd2l0aCBvbmUgbWFya2VyIChQcm9tb3Rlcilcbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vUHJvbW90ZXJcXFxuY29uc2Vuc3VzLmxvb3AuYW5uby5wcm9tb3Rlci50YiA8LSBhbm5vdGF0ZUxvb3BQcm9tb3RlclRTUyh0ZW1wLmFubm8uVFNTKVxuZndyaXRlKGNvbnNlbnN1cy5sb29wLmFubm8ucHJvbW90ZXIudGIsIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSwgXG4gICAgICAgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gVFJVRSlcbmNyZWF0ZUxvb3BBbm5vdGF0aW9uKGNvbnNlbnN1cy5sb29wLmFubm8ucHJvbW90ZXIudGIsIG5hbWUsIFxuICAgICAgICAgICAgICAgICAgICAgZmlnRGlyLCBvdXREaXIsICBjb2xvckxpc3RQcm9tb3RlcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnByb21vdGVyLnRiLCB1bmlxdWUoY29uc2Vuc3VzLmxvb3AuYW5uby5wcm9tb3Rlci50YiRBbm5vMikgLCBuYW1lLCBcXGFsbFxcLCBvdXREaXIpICBcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnByb21vdGVyLnRiLCBjKFxcUC1QXFwpLCBuYW1lLCBcXHAtcFxcLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby5wcm9tb3Rlci50YiwgYyhcXFAtTlxcKSwgbmFtZSwgXFxwLW5cXCwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8ucHJvbW90ZXIudGIsIGMoXFxOLU5cXCksIG5hbWUsIFxcbi1uXFwsIG91dERpcilcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMgQW5ub3RhdGluZyB3aXRoIG9uZSBtYXJrZXIgKEVuaGFuY2VyKVxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9FbmhhbmNlclxcXG5jb25zZW5zdXMubG9vcC5hbm5vLmVuaGFuY2VyLnRiIDwtIGFubm90YXRlTG9vcEVuaGFuY2VyKHRlbXAuYW5uby5UU1MpXG5md3JpdGUoY29uc2Vuc3VzLmxvb3AuYW5uby5lbmhhbmNlci50YiwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpLCBcbiAgICAgICBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBUUlVFKVxuY3JlYXRlTG9vcEFubm90YXRpb24oY29uc2Vuc3VzLmxvb3AuYW5uby5lbmhhbmNlci50YiwgbmFtZSwgXG4gICAgICAgICAgICAgICAgICAgICBmaWdEaXIsIG91dERpciwgIGNvbG9yTGlzdEVuaGFuY2VyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8uZW5oYW5jZXIudGIsIHVuaXF1ZShjb25zZW5zdXMubG9vcC5hbm5vLmVuaGFuY2VyLnRiJEFubm8yKSAsIG5hbWUsIFxcYWxsXFwsIG91dERpcikgIFxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8uZW5oYW5jZXIudGIsIGMoXFxFLUVcXCksIG5hbWUsIFxcZS1lXFwsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLmVuaGFuY2VyLnRiLCBjKFxcRS1OXFwpLCBuYW1lLCBcXGUtblxcLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby5lbmhhbmNlci50YiwgYyhcXE4tTlxcKSwgbmFtZSwgXFxuLW5cXCwgb3V0RGlyKVxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMgQW5ub3RhdGluZyB3aXRoIG9uZSBtYXJrZXIgKFN0cnVjdHVyZSlcbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vU3RydWN0dXJlXFxcbmNvbnNlbnN1cy5sb29wLmFubm8uc3RydWN0dXJlLnRiIDwtIGFubm90YXRlTG9vcFN0cnVjdHVyZSh0ZW1wLmFubm8uVFNTKVxuZndyaXRlKGNvbnNlbnN1cy5sb29wLmFubm8uc3RydWN0dXJlLnRiLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSksIFxuICAgICAgIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IFRSVUUpXG5jcmVhdGVMb29wQW5ub3RhdGlvbihjb25zZW5zdXMubG9vcC5hbm5vLnN0cnVjdHVyZS50YiwgbmFtZSwgXG4gICAgICAgICAgICAgICAgICAgICBmaWdEaXIsIG91dERpciwgIGNvbG9yTGlzdFN0cnVjdHVyZSlcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnN0cnVjdHVyZS50YiwgdW5pcXVlKGNvbnNlbnN1cy5sb29wLmFubm8uc3RydWN0dXJlLnRiJEFubm8yKSAsIG5hbWUsIFxcYWxsXFwsIG91dERpcikgIFxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8uc3RydWN0dXJlLnRiLCBjKFxcUy1TXFwpLCBuYW1lLCBcXHMtc1xcLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby5zdHJ1Y3R1cmUudGIsIGMoXFxTLU5cXCksIG5hbWUsIFxccy1uXFwsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnN0cnVjdHVyZS50YiwgYyhcXE4tTlxcKSwgbmFtZSwgXFxuLW5cXCwgb3V0RGlyKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\nconsensus.loop.tb <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\n################################################################################\n# Filtering H3K4me3 peaks that has TSS nearby\n# Since the finest resolution is 5kb, +-2.5kb will be used as a cutoff for checking TSS presence\nflankSize <- 2500\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend)\ncolnames(gene.tb) <- c(\\chr\\, \\start\\, \\end\\)\nTSS1kb.gr <- makeGRangesFromDataFrame(gene.tb)\ntemp <- peak.H3K4me3[unique(queryHits(findOverlaps(peak.H3K4me3, TSS1kb.gr)))]\nfwrite(as_tibble(temp), here(refDir, \n                             paste0(\\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.\\, \n                                    flankSize/1000, \\kbTSS.bed\\)), sep = \\\\t\\, col.names = FALSE)\npeak.H3K4me3TSS <- importPeak(here(refDir, paste0(\\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.\\, \n                                    flankSize/1000, \\kbTSS.bed\\)))\n################################################################################\n# Annotating with strict priority (P-TSS > E > S)\ntemp.anno.TSS <- annotateAnchorTSS(consensus.loop.tb) %>%\n  dplyr::mutate(\n    diff_dTAG_DMSO = (dTAG-DMSO),\n    diff_A485_DMSO = (A485-DMSO))\n\nname <- \\chromo_cons_annoHierarchy\\\nconsensus.loop.anno.tb <- annotateLoopRelaxedTSS(temp.anno.TSS)\nfwrite(consensus.loop.anno.tb, here(consensusDir, paste0(name, \\.tsv\\)), \n       sep = \\\\t\\, col.names = TRUE)\ncreateLoopAnnotation(consensus.loop.anno.tb, name, figDir, outDir,  colorListLoop)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, unique(consensus.loop.anno.tb$Anno2) , name, \\all\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\, \\E-E\\, \\E-S\\, \\E-X\\), name, \\regulatory\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\S-S\\, \\S-X\\), name, \\structure\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\X-X\\), name, \\x-x\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\), name, \\p-n\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-P\\, \\P-E\\, \\E-E\\), name, \\pe-pe\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-P\\, \\P-E\\), name, \\p-pe\\, outDir)\n\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-P\\), name, \\p-p\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-E\\), name, \\p-e\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-S\\), name, \\p-s\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.tb, c(\\P-X\\), name, \\p-x\\, outDir)\n\n################################################################################\n# Annotating with one marker (Promoter)\nname <- \\chromo_cons_annoPromoter\\\nconsensus.loop.anno.promoter.tb <- annotateLoopPromoterTSS(temp.anno.TSS)\nfwrite(consensus.loop.anno.promoter.tb, here(consensusDir, paste0(name, \\.tsv\\)), \n       sep = \\\\t\\, col.names = TRUE)\ncreateLoopAnnotation(consensus.loop.anno.promoter.tb, name, \n                     figDir, outDir,  colorListPromoter)\nsaveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, unique(consensus.loop.anno.promoter.tb$Anno2) , name, \\all\\, outDir)  \nsaveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c(\\P-P\\), name, \\p-p\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c(\\P-N\\), name, \\p-n\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c(\\N-N\\), name, \\n-n\\, outDir)\n\n################################################################################\n# Annotating with one marker (Enhancer)\nname <- \\chromo_cons_annoEnhancer\\\nconsensus.loop.anno.enhancer.tb <- annotateLoopEnhancer(temp.anno.TSS)\nfwrite(consensus.loop.anno.enhancer.tb, here(consensusDir, paste0(name, \\.tsv\\)), \n       sep = \\\\t\\, col.names = TRUE)\ncreateLoopAnnotation(consensus.loop.anno.enhancer.tb, name, \n                     figDir, outDir,  colorListEnhancer)\nsaveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, unique(consensus.loop.anno.enhancer.tb$Anno2) , name, \\all\\, outDir)  \nsaveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c(\\E-E\\), name, \\e-e\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c(\\E-N\\), name, \\e-n\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c(\\N-N\\), name, \\n-n\\, outDir)\n################################################################################\n# Annotating with one marker (Structure)\nname <- \\chromo_cons_annoStructure\\\nconsensus.loop.anno.structure.tb <- annotateLoopStructure(temp.anno.TSS)\nfwrite(consensus.loop.anno.structure.tb, here(consensusDir, paste0(name, \\.tsv\\)), \n       sep = \\\\t\\, col.names = TRUE)\ncreateLoopAnnotation(consensus.loop.anno.structure.tb, name, \n                     figDir, outDir,  colorListStructure)\nsaveAnnoGroupBedpe(consensus.loop.anno.structure.tb, unique(consensus.loop.anno.structure.tb$Anno2) , name, \\all\\, outDir)  \nsaveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c(\\S-S\\), name, \\s-s\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c(\\S-N\\), name, \\s-n\\, outDir)\nsaveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c(\\N-N\\), name, \\n-n\\, outDir)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuY29uc2Vuc3VzLmxvb3AudGIgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfc2NvcmUudHN2XFwpKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBGaWx0ZXJpbmcgSDNLNG1lMyBwZWFrcyB0aGF0IGhhcyBUU1MgbmVhcmJ5XG4jIFNpbmNlIHRoZSBmaW5lc3QgcmVzb2x1dGlvbiBpcyA1a2IsICstMi41a2Igd2lsbCBiZSB1c2VkIGFzIGEgY3V0b2ZmIGZvciBjaGVja2luZyBUU1MgcHJlc2VuY2VcbmZsYW5rU2l6ZSA8LSAyNTAwXG5nZW5lLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpLFxuICAgICAgICAgICAgICAgIFRTU3N0YXJ0ID0gVFNTIC0gZmxhbmtTaXplLFxuICAgICAgICAgICAgICAgIFRTU2VuZCA9IFRTUyArIGZsYW5rU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTU3N0YXJ0LCBUU1NlbmQpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcblRTUzFrYi5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZS50YilcbnRlbXAgPC0gcGVhay5IM0s0bWUzW3VuaXF1ZShxdWVyeUhpdHMoZmluZE92ZXJsYXBzKHBlYWsuSDNLNG1lMywgVFNTMWtiLmdyKSkpXVxuZndyaXRlKGFzX3RpYmJsZSh0ZW1wKSwgaGVyZShyZWZEaXIsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBwYXN0ZTAoXFwzMzI1NV9IM0s0bWUzXzA0LTc0NV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5cXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBmbGFua1NpemUvMTAwMCwgXFxrYlRTUy5iZWRcXCkpLCBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBGQUxTRSlcbnBlYWsuSDNLNG1lM1RTUyA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBwYXN0ZTAoXFwzMzI1NV9IM0s0bWUzXzA0LTc0NV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5cXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBmbGFua1NpemUvMTAwMCwgXFxrYlRTUy5iZWRcXCkpKVxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMgQW5ub3RhdGluZyB3aXRoIHN0cmljdCBwcmlvcml0eSAoUC1UU1MgPiBFID4gUylcbnRlbXAuYW5uby5UU1MgPC0gYW5ub3RhdGVBbmNob3JUU1MoY29uc2Vuc3VzLmxvb3AudGIpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGRpZmZfZFRBR19ETVNPID0gKGRUQUctRE1TTyksXG4gICAgZGlmZl9BNDg1X0RNU08gPSAoQTQ4NS1ETVNPKSlcblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuY29uc2Vuc3VzLmxvb3AuYW5uby50YiA8LSBhbm5vdGF0ZUxvb3BSZWxheGVkVFNTKHRlbXAuYW5uby5UU1MpXG5md3JpdGUoY29uc2Vuc3VzLmxvb3AuYW5uby50YiwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpLCBcbiAgICAgICBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBUUlVFKVxuY3JlYXRlTG9vcEFubm90YXRpb24oY29uc2Vuc3VzLmxvb3AuYW5uby50YiwgbmFtZSwgZmlnRGlyLCBvdXREaXIsICBjb2xvckxpc3RMb29wKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIHVuaXF1ZShjb25zZW5zdXMubG9vcC5hbm5vLnRiJEFubm8yKSAsIG5hbWUsIFxcYWxsXFwsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnRiLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcUC1TXFwsIFxcUC1YXFwsIFxcRS1FXFwsIFxcRS1TXFwsIFxcRS1YXFwpLCBuYW1lLCBcXHJlZ3VsYXRvcnlcXCwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIGMoXFxTLVNcXCwgXFxTLVhcXCksIG5hbWUsIFxcc3RydWN0dXJlXFwsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnRiLCBjKFxcWC1YXFwpLCBuYW1lLCBcXHgteFxcLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby50YiwgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcKSwgbmFtZSwgXFxwLW5cXCwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCksIG5hbWUsIFxccGUtcGVcXCwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIGMoXFxQLVBcXCwgXFxQLUVcXCksIG5hbWUsIFxccC1wZVxcLCBvdXREaXIpXG5cbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnRiLCBjKFxcUC1QXFwpLCBuYW1lLCBcXHAtcFxcLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby50YiwgYyhcXFAtRVxcKSwgbmFtZSwgXFxwLWVcXCwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8udGIsIGMoXFxQLVNcXCksIG5hbWUsIFxccC1zXFwsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnRiLCBjKFxcUC1YXFwpLCBuYW1lLCBcXHAteFxcLCBvdXREaXIpXG5cbiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG4jIEFubm90YXRpbmcgd2l0aCBvbmUgbWFya2VyIChQcm9tb3Rlcilcbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vUHJvbW90ZXJcXFxuY29uc2Vuc3VzLmxvb3AuYW5uby5wcm9tb3Rlci50YiA8LSBhbm5vdGF0ZUxvb3BQcm9tb3RlclRTUyh0ZW1wLmFubm8uVFNTKVxuZndyaXRlKGNvbnNlbnN1cy5sb29wLmFubm8ucHJvbW90ZXIudGIsIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSwgXG4gICAgICAgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gVFJVRSlcbmNyZWF0ZUxvb3BBbm5vdGF0aW9uKGNvbnNlbnN1cy5sb29wLmFubm8ucHJvbW90ZXIudGIsIG5hbWUsIFxuICAgICAgICAgICAgICAgICAgICAgZmlnRGlyLCBvdXREaXIsICBjb2xvckxpc3RQcm9tb3RlcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnByb21vdGVyLnRiLCB1bmlxdWUoY29uc2Vuc3VzLmxvb3AuYW5uby5wcm9tb3Rlci50YiRBbm5vMikgLCBuYW1lLCBcXGFsbFxcLCBvdXREaXIpICBcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnByb21vdGVyLnRiLCBjKFxcUC1QXFwpLCBuYW1lLCBcXHAtcFxcLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby5wcm9tb3Rlci50YiwgYyhcXFAtTlxcKSwgbmFtZSwgXFxwLW5cXCwgb3V0RGlyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8ucHJvbW90ZXIudGIsIGMoXFxOLU5cXCksIG5hbWUsIFxcbi1uXFwsIG91dERpcilcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMgQW5ub3RhdGluZyB3aXRoIG9uZSBtYXJrZXIgKEVuaGFuY2VyKVxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9FbmhhbmNlclxcXG5jb25zZW5zdXMubG9vcC5hbm5vLmVuaGFuY2VyLnRiIDwtIGFubm90YXRlTG9vcEVuaGFuY2VyKHRlbXAuYW5uby5UU1MpXG5md3JpdGUoY29uc2Vuc3VzLmxvb3AuYW5uby5lbmhhbmNlci50YiwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpLCBcbiAgICAgICBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBUUlVFKVxuY3JlYXRlTG9vcEFubm90YXRpb24oY29uc2Vuc3VzLmxvb3AuYW5uby5lbmhhbmNlci50YiwgbmFtZSwgXG4gICAgICAgICAgICAgICAgICAgICBmaWdEaXIsIG91dERpciwgIGNvbG9yTGlzdEVuaGFuY2VyKVxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8uZW5oYW5jZXIudGIsIHVuaXF1ZShjb25zZW5zdXMubG9vcC5hbm5vLmVuaGFuY2VyLnRiJEFubm8yKSAsIG5hbWUsIFxcYWxsXFwsIG91dERpcikgIFxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8uZW5oYW5jZXIudGIsIGMoXFxFLUVcXCksIG5hbWUsIFxcZS1lXFwsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLmVuaGFuY2VyLnRiLCBjKFxcRS1OXFwpLCBuYW1lLCBcXGUtblxcLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby5lbmhhbmNlci50YiwgYyhcXE4tTlxcKSwgbmFtZSwgXFxuLW5cXCwgb3V0RGlyKVxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMgQW5ub3RhdGluZyB3aXRoIG9uZSBtYXJrZXIgKFN0cnVjdHVyZSlcbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vU3RydWN0dXJlXFxcbmNvbnNlbnN1cy5sb29wLmFubm8uc3RydWN0dXJlLnRiIDwtIGFubm90YXRlTG9vcFN0cnVjdHVyZSh0ZW1wLmFubm8uVFNTKVxuZndyaXRlKGNvbnNlbnN1cy5sb29wLmFubm8uc3RydWN0dXJlLnRiLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSksIFxuICAgICAgIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IFRSVUUpXG5jcmVhdGVMb29wQW5ub3RhdGlvbihjb25zZW5zdXMubG9vcC5hbm5vLnN0cnVjdHVyZS50YiwgbmFtZSwgXG4gICAgICAgICAgICAgICAgICAgICBmaWdEaXIsIG91dERpciwgIGNvbG9yTGlzdFN0cnVjdHVyZSlcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnN0cnVjdHVyZS50YiwgdW5pcXVlKGNvbnNlbnN1cy5sb29wLmFubm8uc3RydWN0dXJlLnRiJEFubm8yKSAsIG5hbWUsIFxcYWxsXFwsIG91dERpcikgIFxuc2F2ZUFubm9Hcm91cEJlZHBlKGNvbnNlbnN1cy5sb29wLmFubm8uc3RydWN0dXJlLnRiLCBjKFxcUy1TXFwpLCBuYW1lLCBcXHMtc1xcLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUoY29uc2Vuc3VzLmxvb3AuYW5uby5zdHJ1Y3R1cmUudGIsIGMoXFxTLU5cXCksIG5hbWUsIFxccy1uXFwsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShjb25zZW5zdXMubG9vcC5hbm5vLnN0cnVjdHVyZS50YiwgYyhcXE4tTlxcKSwgbmFtZSwgXFxuLW5cXCwgb3V0RGlyKVxuYGBgXG5gYGAifQ== -->

```r
```r
consensus.loop.tb <- fread(here(consensusDir, \chromo_cons_score.tsv\))

################################################################################
# Filtering H3K4me3 peaks that has TSS nearby
# Since the finest resolution is 5kb, +-2.5kb will be used as a cutoff for checking TSS presence
flankSize <- 2500
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend)
colnames(gene.tb) <- c(\chr\, \start\, \end\)
TSS1kb.gr <- makeGRangesFromDataFrame(gene.tb)
temp <- peak.H3K4me3[unique(queryHits(findOverlaps(peak.H3K4me3, TSS1kb.gr)))]
fwrite(as_tibble(temp), here(refDir, 
                             paste0(\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.\, 
                                    flankSize/1000, \kbTSS.bed\)), sep = \\t\, col.names = FALSE)
peak.H3K4me3TSS <- importPeak(here(refDir, paste0(\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.\, 
                                    flankSize/1000, \kbTSS.bed\)))
################################################################################
# Annotating with strict priority (P-TSS > E > S)
temp.anno.TSS <- annotateAnchorTSS(consensus.loop.tb) %>%
  dplyr::mutate(
    diff_dTAG_DMSO = (dTAG-DMSO),
    diff_A485_DMSO = (A485-DMSO))

name <- \chromo_cons_annoHierarchy\
consensus.loop.anno.tb <- annotateLoopRelaxedTSS(temp.anno.TSS)
fwrite(consensus.loop.anno.tb, here(consensusDir, paste0(name, \.tsv\)), 
       sep = \\t\, col.names = TRUE)
createLoopAnnotation(consensus.loop.anno.tb, name, figDir, outDir,  colorListLoop)
saveAnnoGroupBedpe(consensus.loop.anno.tb, unique(consensus.loop.anno.tb$Anno2) , name, \all\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-P\, \P-E\, \P-S\, \P-X\, \E-E\, \E-S\, \E-X\), name, \regulatory\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\S-S\, \S-X\), name, \structure\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\X-X\), name, \x-x\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-P\, \P-E\, \P-S\, \P-X\), name, \p-n\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-P\, \P-E\, \E-E\), name, \pe-pe\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-P\, \P-E\), name, \p-pe\, outDir)

saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-P\), name, \p-p\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-E\), name, \p-e\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-S\), name, \p-s\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c(\P-X\), name, \p-x\, outDir)

################################################################################
# Annotating with one marker (Promoter)
name <- \chromo_cons_annoPromoter\
consensus.loop.anno.promoter.tb <- annotateLoopPromoterTSS(temp.anno.TSS)
fwrite(consensus.loop.anno.promoter.tb, here(consensusDir, paste0(name, \.tsv\)), 
       sep = \\t\, col.names = TRUE)
createLoopAnnotation(consensus.loop.anno.promoter.tb, name, 
                     figDir, outDir,  colorListPromoter)
saveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, unique(consensus.loop.anno.promoter.tb$Anno2) , name, \all\, outDir)  
saveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c(\P-P\), name, \p-p\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c(\P-N\), name, \p-n\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c(\N-N\), name, \n-n\, outDir)

################################################################################
# Annotating with one marker (Enhancer)
name <- \chromo_cons_annoEnhancer\
consensus.loop.anno.enhancer.tb <- annotateLoopEnhancer(temp.anno.TSS)
fwrite(consensus.loop.anno.enhancer.tb, here(consensusDir, paste0(name, \.tsv\)), 
       sep = \\t\, col.names = TRUE)
createLoopAnnotation(consensus.loop.anno.enhancer.tb, name, 
                     figDir, outDir,  colorListEnhancer)
saveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, unique(consensus.loop.anno.enhancer.tb$Anno2) , name, \all\, outDir)  
saveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c(\E-E\), name, \e-e\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c(\E-N\), name, \e-n\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c(\N-N\), name, \n-n\, outDir)
################################################################################
# Annotating with one marker (Structure)
name <- \chromo_cons_annoStructure\
consensus.loop.anno.structure.tb <- annotateLoopStructure(temp.anno.TSS)
fwrite(consensus.loop.anno.structure.tb, here(consensusDir, paste0(name, \.tsv\)), 
       sep = \\t\, col.names = TRUE)
createLoopAnnotation(consensus.loop.anno.structure.tb, name, 
                     figDir, outDir,  colorListStructure)
saveAnnoGroupBedpe(consensus.loop.anno.structure.tb, unique(consensus.loop.anno.structure.tb$Anno2) , name, \all\, outDir)  
saveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c(\S-S\), name, \s-s\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c(\S-N\), name, \s-n\, outDir)
saveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c(\N-N\), name, \n-n\, outDir)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Functions

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TmNiaU1nTWpBeU5DNHdPUzR4TUNCVGNHeHBkSFJwYm1jZ2NtVm5kV3hoZEc5eWVTQnNiMjl3SUdsdWRHOGdjSFZ5WlNCeVpXZDFiR0YwYjNKNUlHRnVaQ0J6ZEhKMVkzUjFjbVV0Y21Wc1lYUmxaQ0JzYjI5d2MxeHVibUZ0WlNBOExTQmNJbU5vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGNJbHh1WTI5dWMyVnVjM1Z6TG14dmIzQXVZVzV1Ynk1MFlpQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ3aUxuUnpkbHdpS1NrcFhHNXlaV2QxYkdGMGIzSjVMbXh2YjNBdVlXNXVieTUwWWlBOExTQmpiMjV6Wlc1emRYTXViRzl2Y0M1aGJtNXZMblJpSUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0VGdWJtOHlJQ1ZwYmlVZ1l5aGNJbEF0VUZ3aUxDQmNJbEF0UlZ3aUxDQmNJa1V0UlZ3aUtTbGNibHh1Y21WbmRXeGhkRzl5ZVM1c2IyOXdMbUZ1Ym04dWRHSWdQQzBnY21WbmRXeGhkRzl5ZVM1c2IyOXdMbUZ1Ym04dWRHSWdKVDRsSUhKdmQzZHBjMlVvS1NBbFBpVmNiaUFnWkhCc2VYSTZPbTExZEdGMFpTaGNiaUFnSUNCQmJtNXZNeUE5SUdsbVpXeHpaU2hCTVY5U1FVUXlNU0I4SUVFeFgwTlVRMFlnZkNCQk1sOVNRVVF5TVNCOElFRXlYMUpCUkRJeExDQndZWE4wWlRBb1hDSnpkSEpjSWlrc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdjR0Z6ZEdVd0tGd2ljbVZuWENJcEtWeHVJQ0FwWEc1Y2JseHVabmR5YVhSbEtISmxaM1ZzWVhSdmNua3ViRzl2Y0M1aGJtNXZMblJpTENCb1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRndpWDBGdWJtOHpMblJ6ZGx3aUtTa3NJRnh1SUNBZ0lDQWdJSE5sY0NBOUlGd2lYRngwWENJc0lHTnZiQzV1WVcxbGN5QTlJRlJTVlVVcFhHNWNibkpsWjNWc1lYUnZjbmt1Ykc5dmNDNWhibTV2TG5SaVgzSmxaeUE4TFNCeVpXZDFiR0YwYjNKNUxteHZiM0F1WVc1dWJ5NTBZaUFsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhCYm01dk15QTlQU0JjSW5KbFoxd2lLVnh1Y21WbmRXeGhkRzl5ZVM1c2IyOXdMbUZ1Ym04dWRHSmZjM1J5SUR3dElISmxaM1ZzWVhSdmNua3ViRzl2Y0M1aGJtNXZMblJpSUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0VGdWJtOHpJRDA5SUZ3aWMzUnlYQ0lwWEc1Y2JuTmhkbVZCYm01dlIzSnZkWEJDWldSd1pTaHlaV2QxYkdGMGIzSjVMbXh2YjNBdVlXNXVieTUwWWw5eVpXY3NJR01vWENKUUxWQmNJaXdnWENKUUxVVmNJaXdnWENKRkxVVmNJaWtzSUc1aGJXVXNJRndpY0dVdGNHVmZjbVZuWENJc0lHOTFkRVJwY2lsY2JuTmhkbVZCYm01dlIzSnZkWEJDWldSd1pTaHlaV2QxYkdGMGIzSjVMbXh2YjNBdVlXNXVieTUwWWw5emRISXNJR01vWENKUUxWQmNJaXdnWENKUUxVVmNJaXdnWENKRkxVVmNJaWtzSUc1aGJXVXNJRndpY0dVdGNHVmZjM1J5WENJc0lHOTFkRVJwY2lsY2JseHVZR0JnSW4wPSAtLT5cblxuYGBgclxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMgMjAyNC4wOS4xMCBTcGxpdHRpbmcgcmVndWxhdG9yeSBsb29wIGludG8gcHVyZSByZWd1bGF0b3J5IGFuZCBzdHJ1Y3R1cmUtcmVsYXRlZCBsb29wc1xubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuY29uc2Vuc3VzLmxvb3AuYW5uby50YiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5yZWd1bGF0b3J5Lmxvb3AuYW5uby50YiA8LSBjb25zZW5zdXMubG9vcC5hbm5vLnRiICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSlcblxucmVndWxhdG9yeS5sb29wLmFubm8udGIgPC0gcmVndWxhdG9yeS5sb29wLmFubm8udGIgJT4lIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBBbm5vMyA9IGlmZWxzZShBMV9SQUQyMSB8IEExX0NUQ0YgfCBBMl9SQUQyMSB8IEEyX1JBRDIxLCBwYXN0ZTAoXFxzdHJcXCksXG4gICAgICAgICAgICAgICAgICAgcGFzdGUwKFxccmVnXFwpKVxuICApXG5cblxuZndyaXRlKHJlZ3VsYXRvcnkubG9vcC5hbm5vLnRiLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX0Fubm8zLnRzdlxcKSksIFxuICAgICAgIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IFRSVUUpXG5cbnJlZ3VsYXRvcnkubG9vcC5hbm5vLnRiX3JlZyA8LSByZWd1bGF0b3J5Lmxvb3AuYW5uby50YiAlPiUgZHBseXI6OmZpbHRlcihBbm5vMyA9PSBcXHJlZ1xcKVxucmVndWxhdG9yeS5sb29wLmFubm8udGJfc3RyIDwtIHJlZ3VsYXRvcnkubG9vcC5hbm5vLnRiICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8zID09IFxcc3RyXFwpXG5cbnNhdmVBbm5vR3JvdXBCZWRwZShyZWd1bGF0b3J5Lmxvb3AuYW5uby50Yl9yZWcsIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCksIG5hbWUsIFxccGUtcGVfcmVnXFwsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShyZWd1bGF0b3J5Lmxvb3AuYW5uby50Yl9zdHIsIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCksIG5hbWUsIFxccGUtcGVfc3RyXFwsIG91dERpcilcblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
################################################################################
# 2024.09.10 Splitting regulatory loop into pure regulatory and structure-related loops
name <- \chromo_cons_annoHierarchy\
consensus.loop.anno.tb <- fread(here(consensusDir, paste0(name, \.tsv\)))
regulatory.loop.anno.tb <- consensus.loop.anno.tb %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\))

regulatory.loop.anno.tb <- regulatory.loop.anno.tb %>% rowwise() %>%
  dplyr::mutate(
    Anno3 = ifelse(A1_RAD21 | A1_CTCF | A2_RAD21 | A2_RAD21, paste0(\str\),
                   paste0(\reg\))
  )


fwrite(regulatory.loop.anno.tb, here(consensusDir, paste0(name, \_Anno3.tsv\)), 
       sep = \\t\, col.names = TRUE)

regulatory.loop.anno.tb_reg <- regulatory.loop.anno.tb %>% dplyr::filter(Anno3 == \reg\)
regulatory.loop.anno.tb_str <- regulatory.loop.anno.tb %>% dplyr::filter(Anno3 == \str\)

saveAnnoGroupBedpe(regulatory.loop.anno.tb_reg, c(\P-P\, \P-E\, \E-E\), name, \pe-pe_reg\, outDir)
saveAnnoGroupBedpe(regulatory.loop.anno.tb_str, c(\P-P\, \P-E\, \E-E\), name, \pe-pe_str\, outDir)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlOY2JpTWdNakF5TkM0d09TNHhNQ0JUY0d4cGRIUnBibWNnY21WbmRXeGhkRzl5ZVNCc2IyOXdJR2x1ZEc4Z2NIVnlaU0J5WldkMWJHRjBiM0o1SUdGdVpDQnpkSEoxWTNSMWNtVXRjbVZzWVhSbFpDQnNiMjl3YzF4dWJtRnRaU0E4TFNCY1hHTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsY1hGeHVZMjl1YzJWdWMzVnpMbXh2YjNBdVlXNXVieTUwWWlBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRnhjTG5SemRseGNLU2twWEc1eVpXZDFiR0YwYjNKNUxteHZiM0F1WVc1dWJ5NTBZaUE4TFNCamIyNXpaVzV6ZFhNdWJHOXZjQzVoYm01dkxuUmlJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRUZ1Ym04eUlDVnBiaVVnWXloY1hGQXRVRnhjTENCY1hGQXRSVnhjTENCY1hFVXRSVnhjS1NsY2JseHVjbVZuZFd4aGRHOXllUzVzYjI5d0xtRnVibTh1ZEdJZ1BDMGdjbVZuZFd4aGRHOXllUzVzYjI5d0xtRnVibTh1ZEdJZ0pUNGxJSEp2ZDNkcGMyVW9LU0FsUGlWY2JpQWdaSEJzZVhJNk9tMTFkR0YwWlNoY2JpQWdJQ0JCYm01dk15QTlJR2xtWld4elpTaEJNVjlTUVVReU1TQjhJRUV4WDBOVVEwWWdmQ0JCTWw5U1FVUXlNU0I4SUVFeVgxSkJSREl4TENCd1lYTjBaVEFvWEZ4emRISmNYQ2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2NHRnpkR1V3S0Z4Y2NtVm5YRndwS1Z4dUlDQXBYRzVjYmx4dVpuZHlhWFJsS0hKbFozVnNZWFJ2Y25rdWJHOXZjQzVoYm01dkxuUmlMQ0JvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGeGNYMEZ1Ym04ekxuUnpkbHhjS1Nrc0lGeHVJQ0FnSUNBZ0lITmxjQ0E5SUZ4Y1hGeDBYRndzSUdOdmJDNXVZVzFsY3lBOUlGUlNWVVVwWEc1Y2JuSmxaM1ZzWVhSdmNua3ViRzl2Y0M1aGJtNXZMblJpWDNKbFp5QThMU0J5WldkMWJHRjBiM0o1TG14dmIzQXVZVzV1Ynk1MFlpQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaEJibTV2TXlBOVBTQmNYSEpsWjF4Y0tWeHVjbVZuZFd4aGRHOXllUzVzYjI5d0xtRnVibTh1ZEdKZmMzUnlJRHd0SUhKbFozVnNZWFJ2Y25rdWJHOXZjQzVoYm01dkxuUmlJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRUZ1Ym04eklEMDlJRnhjYzNSeVhGd3BYRzVjYm5OaGRtVkJibTV2UjNKdmRYQkNaV1J3WlNoeVpXZDFiR0YwYjNKNUxteHZiM0F1WVc1dWJ5NTBZbDl5Wldjc0lHTW9YRnhRTFZCY1hDd2dYRnhRTFVWY1hDd2dYRnhGTFVWY1hDa3NJRzVoYldVc0lGeGNjR1V0Y0dWZmNtVm5YRndzSUc5MWRFUnBjaWxjYm5OaGRtVkJibTV2UjNKdmRYQkNaV1J3WlNoeVpXZDFiR0YwYjNKNUxteHZiM0F1WVc1dWJ5NTBZbDl6ZEhJc0lHTW9YRnhRTFZCY1hDd2dYRnhRTFVWY1hDd2dYRnhGTFVWY1hDa3NJRzVoYldVc0lGeGNjR1V0Y0dWZmMzUnlYRndzSUc5MWRFUnBjaWxjYmx4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG4jIDIwMjQuMDkuMTAgU3BsaXR0aW5nIHJlZ3VsYXRvcnkgbG9vcCBpbnRvIHB1cmUgcmVndWxhdG9yeSBhbmQgc3RydWN0dXJlLXJlbGF0ZWQgbG9vcHNcbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5XFxcbmNvbnNlbnN1cy5sb29wLmFubm8udGIgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpKVxucmVndWxhdG9yeS5sb29wLmFubm8udGIgPC0gY29uc2Vuc3VzLmxvb3AuYW5uby50YiAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCkpXG5cbnJlZ3VsYXRvcnkubG9vcC5hbm5vLnRiIDwtIHJlZ3VsYXRvcnkubG9vcC5hbm5vLnRiICU+JSByb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgQW5ubzMgPSBpZmVsc2UoQTFfUkFEMjEgfCBBMV9DVENGIHwgQTJfUkFEMjEgfCBBMl9SQUQyMSwgcGFzdGUwKFxcc3RyXFwpLFxuICAgICAgICAgICAgICAgICAgIHBhc3RlMChcXHJlZ1xcKSlcbiAgKVxuXG5cbmZ3cml0ZShyZWd1bGF0b3J5Lmxvb3AuYW5uby50YiwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9Bbm5vMy50c3ZcXCkpLCBcbiAgICAgICBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBUUlVFKVxuXG5yZWd1bGF0b3J5Lmxvb3AuYW5uby50Yl9yZWcgPC0gcmVndWxhdG9yeS5sb29wLmFubm8udGIgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzMgPT0gXFxyZWdcXClcbnJlZ3VsYXRvcnkubG9vcC5hbm5vLnRiX3N0ciA8LSByZWd1bGF0b3J5Lmxvb3AuYW5uby50YiAlPiUgZHBseXI6OmZpbHRlcihBbm5vMyA9PSBcXHN0clxcKVxuXG5zYXZlQW5ub0dyb3VwQmVkcGUocmVndWxhdG9yeS5sb29wLmFubm8udGJfcmVnLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCBuYW1lLCBcXHBlLXBlX3JlZ1xcLCBvdXREaXIpXG5zYXZlQW5ub0dyb3VwQmVkcGUocmVndWxhdG9yeS5sb29wLmFubm8udGJfc3RyLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCBuYW1lLCBcXHBlLXBlX3N0clxcLCBvdXREaXIpXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMgMjAyNC4wOS4xMCBTcGxpdHRpbmcgcmVndWxhdG9yeSBsb29wIGludG8gcHVyZSByZWd1bGF0b3J5IGFuZCBzdHJ1Y3R1cmUtcmVsYXRlZCBsb29wc1xubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuY29uc2Vuc3VzLmxvb3AuYW5uby50YiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5yZWd1bGF0b3J5Lmxvb3AuYW5uby50YiA8LSBjb25zZW5zdXMubG9vcC5hbm5vLnRiICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSlcblxucmVndWxhdG9yeS5sb29wLmFubm8udGIgPC0gcmVndWxhdG9yeS5sb29wLmFubm8udGIgJT4lIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBBbm5vMyA9IGlmZWxzZShBMV9SQUQyMSB8IEExX0NUQ0YgfCBBMl9SQUQyMSB8IEEyX1JBRDIxLCBwYXN0ZTAoXFxzdHJcXCksXG4gICAgICAgICAgICAgICAgICAgcGFzdGUwKFxccmVnXFwpKVxuICApXG5cblxuZndyaXRlKHJlZ3VsYXRvcnkubG9vcC5hbm5vLnRiLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX0Fubm8zLnRzdlxcKSksIFxuICAgICAgIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IFRSVUUpXG5cbnJlZ3VsYXRvcnkubG9vcC5hbm5vLnRiX3JlZyA8LSByZWd1bGF0b3J5Lmxvb3AuYW5uby50YiAlPiUgZHBseXI6OmZpbHRlcihBbm5vMyA9PSBcXHJlZ1xcKVxucmVndWxhdG9yeS5sb29wLmFubm8udGJfc3RyIDwtIHJlZ3VsYXRvcnkubG9vcC5hbm5vLnRiICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8zID09IFxcc3RyXFwpXG5cbnNhdmVBbm5vR3JvdXBCZWRwZShyZWd1bGF0b3J5Lmxvb3AuYW5uby50Yl9yZWcsIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCksIG5hbWUsIFxccGUtcGVfcmVnXFwsIG91dERpcilcbnNhdmVBbm5vR3JvdXBCZWRwZShyZWd1bGF0b3J5Lmxvb3AuYW5uby50Yl9zdHIsIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCksIG5hbWUsIFxccGUtcGVfc3RyXFwsIG91dERpcilcblxuYGBgXG5gYGAifQ== -->

```r
```r
################################################################################
# 2024.09.10 Splitting regulatory loop into pure regulatory and structure-related loops
name <- \chromo_cons_annoHierarchy\
consensus.loop.anno.tb <- fread(here(consensusDir, paste0(name, \.tsv\)))
regulatory.loop.anno.tb <- consensus.loop.anno.tb %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\))

regulatory.loop.anno.tb <- regulatory.loop.anno.tb %>% rowwise() %>%
  dplyr::mutate(
    Anno3 = ifelse(A1_RAD21 | A1_CTCF | A2_RAD21 | A2_RAD21, paste0(\str\),
                   paste0(\reg\))
  )


fwrite(regulatory.loop.anno.tb, here(consensusDir, paste0(name, \_Anno3.tsv\)), 
       sep = \\t\, col.names = TRUE)

regulatory.loop.anno.tb_reg <- regulatory.loop.anno.tb %>% dplyr::filter(Anno3 == \reg\)
regulatory.loop.anno.tb_str <- regulatory.loop.anno.tb %>% dplyr::filter(Anno3 == \str\)

saveAnnoGroupBedpe(regulatory.loop.anno.tb_reg, c(\P-P\, \P-E\, \E-E\), name, \pe-pe_reg\, outDir)
saveAnnoGroupBedpe(regulatory.loop.anno.tb_str, c(\P-P\, \P-E\, \E-E\), name, \pe-pe_str\, outDir)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Annotation

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ncreate_loop_dis_vs_score <- function(data, figDir, name, Anno2List){\n  data = data %>% dplyr::filter(Anno2 %in% Anno2List)\n  \n  ### barplot\n  temp <- data %>% dplyr::select(id, DMSO, dTAG, A485) %>%\n    pivot_longer(!id, names_to = \"treatment\", values_to = \"score\")\n  temp$treatment <- factor(temp$treatment, levels = c(\"DMSO\", \"dTAG\", \"A485\"))\n  \n  p3 <- ggplot(temp, aes(x = treatment, y = score)) +\n    geom_violin(aes(fill = treatment), show.legend = FALSE) +\n    scale_fill_manual(values = c(\"DMSO\" = \"grey\", \"dTAG\" = \"pink\", \"A485\" = \"skyblue\")) +\n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    ylim(-0.5, 1) +\n    geom_hline(yintercept = 0, linetype = \"dashed\", color = \"grey\") +\n    theme_classic() +\n    ggtitle(name) +\n    theme(plot.title = element_text(size = 4))\n  fileName <- paste0(\"score_barplot_\", name)\n  png(here(figDir, paste0(fileName, \".png\")), \n      res = 600, units = \"in\", width = 2, height = 4)\n  print(p3)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")), \n          width = 2, height = 4)\n  print(p3)\n  dev.off()\n  \n  ### Distance vs score\n  \n  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, dTAG, A485)\n\n  avg_scores <- temp %>%\n    group_by(distance) %>%\n    summarise(across(starts_with(\"DMSO\"):starts_with(\"A485\"), mean, na.rm = TRUE))\n\n  avg_scores_long <- avg_scores %>%\n    pivot_longer(cols = DMSO:A485, names_to = \"condition\", values_to = \"avg_score\")\n  avg_scores_long$condition <- factor(avg_scores_long$condition, levels = c(\"DMSO\", \"dTAG\", \"A485\"))\n  # Create the plot\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +\n    geom_smooth(show.legend = TRUE) + ylim(0, 0.5) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = c(\"DMSO\" = \"grey\", \"dTAG\" = \"pink\", \"A485\" = \"skyblue\")) +\n    scale_fill_manual(values = c(\"DMSO\" = \"grey80\", \"dTAG\" = \"pink\", \"A485\" = \"skyblue\")) +\n    labs(title = paste0(name),\n         x = \"Distance\",\n         y = \"Average Score\") +\n    theme(plot.title = element_text(size = 5))\n  fileName <- paste0(\"dist_vs_score_linePlot_\", name)\n  png(here(figDir, paste0(fileName, \".png\")),\n      res = 600, units = \"in\", width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")),\n      width = 4, height = 3)\n  print(p4)\n  dev.off()\n}\n\ncreate_loop_dis_vs_diffscore <- function(data, figDir, name, Anno2List){\n  data = data %>% dplyr::filter(Anno2 %in% Anno2List)\n  \n  \n  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, diff_A485_DMSO)\n  \n  avg_scores <- temp %>%\n    group_by(distance) %>%\n    summarise(across(1:2, mean, na.rm = TRUE))\n  \n  avg_scores_long <- avg_scores %>%\n    pivot_longer(cols = 2:3, names_to = \"condition\", values_to = \"avg_score\")\n  avg_scores_long$condition <- factor(avg_scores_long$condition, \n                                      levels = c(\"diff_dTAG_DMSO\", \"diff_A485_DMSO\"))\n  # Create the plot\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +\n    geom_smooth(show.legend = TRUE) + geom_hline(yintercept = 0) + ylim(-0.5, 0.1) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = c(\"diff_dTAG_DMSO\" = \"pink\", \"diff_A485_DMSO\" = \"skyblue\")) +\n    scale_fill_manual(values = c(\"diff_dTAG_DMSO\" = \"pink\", \"diff_A485_DMSO\" = \"skyblue\")) +\n    labs(title = paste0(name),\n         x = \"Distance\",\n         y = \"Average Diff Score\") +\n    theme(plot.title = element_text(size = 5))\n  fileName <- paste0(\"dist_vs_score_difflinePlot_\", name)\n  png(here(figDir, paste0(fileName, \".png\")),\n      res = 600, units = \"in\", width = 4.5, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")),\n          width = 4.5, height = 3)\n  print(p4)\n  dev.off()\n}\n\ncreate_loop_scatterplot <- function(data, figDir, name, Anno2List, diffCutoff){\n  data <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \"UP\", \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \"NO\", \"DOWN\")),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \"UP\", \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \"NO\", \"DOWN\"))) %>%\n    dplyr::filter(Anno2 %in% Anno2List)\n  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\"UP\", \"NO\", \"DOWN\"))\n  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\"UP\", \"NO\", \"DOWN\"))\n  \n  num.up <- (summary(data$updown_dTAG_DMSO))[\"UP\"]\n  num.no <- (summary(data$updown_dTAG_DMSO))[\"NO\"]\n  num.down <- (summary(data$updown_dTAG_DMSO))[\"DOWN\"]\n  num.all <- num.up + num.no + num.down\n  perc.up <- round(num.up / num.all * 100, 2)\n  perc.no <- round(num.no / num.all * 100, 2)\n  perc.down <- round(num.down / num.all * 100, 2)\n  \n  ### Scatterplot\n  data$density <- get_density(data$DMSO, data$dTAG, n = 100)\n  data <- data %>% dplyr::arrange(density)\n  correlation <- cor(data$DMSO, data$dTAG)\n  p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +\n    geom_point(size = 1,\n      alpha = 1,\n      stroke = 0) + \n    scale_color_viridis(option = \"D\", guide = guide_colorbar(\n                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n                          barheight = 15/5.08   # Adjust height of the color bar\n                        )) +\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    annotate(\"text\", x = -0.5, y = 1, label = paste0(\"UP: \", num.up, \" (\", perc.up, \"%)\"), \n             color = \"black\", hjust = 0, , size = 1,\n        family = fontType) +\n    annotate(\"text\", x = -0.5, y = 1-0.1, label = paste0(\"NO: \", num.no, \" (\", perc.no, \"%)\"), \n             color = \"black\", hjust = 0, , size = 1,\n        family = fontType) +\n    annotate(\"text\", x = -0.5, y = 1-0.2, label = paste0(\"DOWN: \", num.down, \" (\", perc.down, \"%)\"), \n             color = \"black\", hjust = 0, , size = 1,\n        family = fontType) +\n    theme_classic() +\n    #annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\") +\n    theme(\n      # legend.position = \"none\",\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \"#000000\"\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \"#000000\"\n      ),\n      axis.line = element_line(\n        color = \"#000000\",\n        size = lineThick*mmToLineUnit,\n        lineend = \"square\"\n      ),\n      axis.ticks = element_line(\n        color = \"#000000\",\n        size = lineThick*mmToLineUnit,\n        lineend = \"square\"\n      ),\n      panel.background = element_rect(fill = \"transparent\"),\n    ) +\n  xlab(\"Loop score\\nG1.DMSO\") +\n    ylab(\"Loop score\\nG1.dTAG\")\n  \n  \n  \n  num.up <- (summary(data$updown_A485_DMSO))[\"UP\"]\n  num.no <- (summary(data$updown_A485_DMSO))[\"NO\"]\n  num.down <- (summary(data$updown_A485_DMSO))[\"DOWN\"]\n  num.all <- num.up + num.no + num.down\n  perc.up <- round(num.up / num.all * 100, 2)\n  perc.no <- round(num.no / num.all * 100, 2)\n  perc.down <- round(num.down / num.all * 100, 2)\n  \n  data$density <- get_density(data$DMSO, data$A485, n = 100)\n  data <- data %>% dplyr::arrange(density)\n  correlation <- cor(data$DMSO, data$A485)\n  p2 <- ggplot(data, aes(x = DMSO, y = A485, color = density)) +\n    geom_point(size = 1,\n      alpha = 1,\n      stroke = 0) + \n    scale_color_viridis(option = \"D\", guide = guide_colorbar(\n                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n                          barheight = 15/5.08   # Adjust height of the color bar\n                        )) +\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\",\n      color = \"black\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\") +\n    annotate(\"text\", x = -0.5, y = 1, label = paste0(\"UP: \", num.up, \" (\", perc.up, \"%)\"), \n             color = \"black\", hjust = 0, size = 1,\n        family = fontType) +\n    annotate(\"text\", x = -0.5, y = 1-0.1, label = paste0(\"NO: \", num.no, \" (\", perc.no, \"%)\"), \n             color = \"black\", hjust = 0, size = 1,\n        family = fontType) +\n    annotate(\"text\", x = -0.5, y = 1-0.2, label = paste0(\"DOWN: \", num.down, \" (\", perc.down, \"%)\"), \n             color = \"black\", hjust = 0, size = 1,\n        family = fontType) +\n    theme_classic() + \n    # annotate(\"text\", x = -0.5, y = 1, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\") +\n    theme(\n      # legend.position = \"none\",\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \"#000000\"\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \"#000000\"\n      ),\n      axis.line = element_line(\n        color = \"#000000\",\n        size = lineThick*mmToLineUnit,\n        lineend = \"square\"\n      ),\n      axis.ticks = element_line(\n        color = \"#000000\",\n        size = lineThick*mmToLineUnit,\n        lineend = \"square\"\n      ),\n      panel.background = element_rect(fill = \"transparent\"),\n    ) +\n    xlab(\"Loop score\\nG1.DMSO\") +\n    ylab(\"Loop score\\nG1.A485\")\n\n    width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch  \n  \n  fileName <- here(figDir,paste0(\"scatterplot_\", name, \"_dTAG_vs_DMSO_\", diffCutoff))\n\n  svglite(paste0(fileName, \".svg\"), width = width, height =height)\n  print(p1)\n  dev.off()\n  png(paste0(fileName, \".png\"), width = width, height =height, res = 600, unit = \"in\")\n  print(p1)\n  dev.off()\n  \n    fileName <- here(figDir, paste0(\"scatterplot_\", name, \"_A485_vs_DMSO_\", diffCutoff))\n\n  svglite(paste0(fileName, \".svg\"), width = width, height =height)\n  print(p2)\n  dev.off()\n  png(paste0(fileName, \".png\"), width = width, height =height, res = 600, unit = \"in\")\n  print(p2)\n  dev.off()\n  \n  # \n  # \n  # \n  # png(here(figDir, paste0(fileName, \".png\")), res = 600, units = \"in\", width = 5*1.5, height = 2.5*1.5)\n  # print(cowplot::plot_grid(p1, p2, align = \"h\"))\n  # dev.off()\n  # \n  # svglite(here(figDir, paste0(fileName, \".svg\")), \n  #         width = 5*1.5, height = 2.5*1.5)\n  # print(cowplot::plot_grid(p1, p2, align = \"h\"))\n  # dev.off()\n}\n\nmake_diff_bedpe <- function(data, name, Anno2List, outDir, diffCutoff){\n  data <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \"UP\", \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \"NO\", \"DOWN\")),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \"UP\", \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \"NO\", \"DOWN\"))) %>%\n    dplyr::filter(Anno2 %in% Anno2List)\n  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\"UP\", \"NO\", \"DOWN\"))\n  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\"UP\", \"NO\", \"DOWN\"))\n  \n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \"UP\") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \"_dTAGvsDMSO_UP_diff\", diffCutoff, \".bedpe\")), \n         sep = \"\\t\", col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \"NO\") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \"_dTAGvsDMSO_NO_diff\", diffCutoff, \".bedpe\")), \n         sep = \"\\t\", col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \"DOWN\") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \"_dTAGvsDMSO_DOWN_diff\", diffCutoff, \".bedpe\")), \n         sep = \"\\t\", col.names = FALSE)\n  \n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \"UP\") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \"_A485vsDMSO_UP_diff\", diffCutoff, \".bedpe\")), \n         sep = \"\\t\", col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \"NO\") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \"_A485vsDMSO_NO_diff\", diffCutoff, \".bedpe\")), \n         sep = \"\\t\", col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \"DOWN\") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \"_A485vsDMSO_DOWN_diff\", diffCutoff, \".bedpe\")), \n         sep = \"\\t\", col.names = FALSE)\n}\n\ncreate_dist_vs_avgScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){\n  avg_scores_long <- data %>%\n    group_by(distance, Anno2) %>%\n    summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n    ungroup() \n  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + \n    geom_smooth(show.legend = TRUE, se = se)  +\n    ylim(0, 0.5) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = colorList) +\n    scale_fill_manual(values = colorList) +\n    labs(title = paste0(name),\n         x = \"Distance\",\n         y = \"Average Score\") +\n    theme(plot.title = element_text(size = 8))\n  \n  fileName <- paste0(\"dist_vs_score_linePlot_\", name)\n  png(here(figDir, paste0(fileName, \".png\")), \n      res = 600, units = \"in\", width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")), \n          width = 4, height = 3)\n  print(p4)\n  dev.off()\n} \n\ncreate_dist_vs_avgDiffScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){\n  avg_scores_long <- data %>%\n    group_by(distance, Anno2) %>%\n    summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n    ungroup() \n  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + \n    geom_hline(yintercept = 0) +\n    geom_smooth(show.legend = TRUE, se = se)  +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = colorList) +\n    scale_fill_manual(values = colorList) +\n    labs(title = paste0(name),\n         x = \"Distance\",\n         y = \"Average Diff Score\") +\n    theme(plot.title = element_text(size = 8)) \n  \n  fileName <- paste0(\"dist_vs_score_difflinePlot_\", name)\n  png(here(figDir, paste0(fileName, \".png\")), \n      res = 600, units = \"in\", width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")), \n          width = 4, height = 3)\n  print(p4)\n  dev.off()\n} \n\ncreate_score_barplot_perTreatment <- function(data, figDir, name, loopList, colorList){\n  data$Anno2 <- factor(data$Anno2, levels = loopList)\n  \n  p3 <- ggplot(data, aes(x = Anno2, y = score)) +\n    geom_violin(aes(fill = Anno2), show.legend = FALSE) +\n    scale_fill_manual(values = colorList) +\n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    ylim(-0.5, 1) +\n    geom_hline(yintercept = 0, linetype = \"dashed\", color = \"grey\") +\n    theme_classic() +\n    ggtitle(name) +\n    theme(plot.title = element_text(size = 4))\n  \n  fileName <- paste0(\"score_barPlot_\", name)\n  \n  png(here(figDir, paste0(fileName, \".png\")), \n      res = 600, units = \"in\", width = 2, height = 4)\n  print(p3)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")), \n          width = 2, height = 4)\n  print(p3)\n}\n\n\niterate_loop_functions <- function(data, figDir, groupName, annoList){\n  # create_loop_dis_vs_score(data, figDir, groupName, annoList)\n  # create_loop_dis_vs_diffscore(data, figDir, groupName, annoList)\n\n  create_loop_scatterplot(data, figDir, groupName, annoList, 0.2)\n  # create_loop_scatterplot(data, figDir, groupName, annoList, 0.1)\n  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.2)\n  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.1)\n}\n```"} -->\n\n```r\ncreate_loop_dis_vs_score <- function(data, figDir, name, Anno2List){\n  data = data %>% dplyr::filter(Anno2 %in% Anno2List)\n  \n  ### barplot\n  temp <- data %>% dplyr::select(id, DMSO, dTAG, A485) %>%\n    pivot_longer(!id, names_to = \\treatment\\, values_to = \\score\\)\n  temp$treatment <- factor(temp$treatment, levels = c(\\DMSO\\, \\dTAG\\, \\A485\\))\n  \n  p3 <- ggplot(temp, aes(x = treatment, y = score)) +\n    geom_violin(aes(fill = treatment), show.legend = FALSE) +\n    scale_fill_manual(values = c(\\DMSO\\ = \\grey\\, \\dTAG\\ = \\pink\\, \\A485\\ = \\skyblue\\)) +\n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    ylim(-0.5, 1) +\n    geom_hline(yintercept = 0, linetype = \\dashed\\, color = \\grey\\) +\n    theme_classic() +\n    ggtitle(name) +\n    theme(plot.title = element_text(size = 4))\n  fileName <- paste0(\\score_barplot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 2, height = 4)\n  print(p3)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 2, height = 4)\n  print(p3)\n  dev.off()\n  \n  ### Distance vs score\n  \n  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, dTAG, A485)\n\n  avg_scores <- temp %>%\n    group_by(distance) %>%\n    summarise(across(starts_with(\\DMSO\\):starts_with(\\A485\\), mean, na.rm = TRUE))\n\n  avg_scores_long <- avg_scores %>%\n    pivot_longer(cols = DMSO:A485, names_to = \\condition\\, values_to = \\avg_score\\)\n  avg_scores_long$condition <- factor(avg_scores_long$condition, levels = c(\\DMSO\\, \\dTAG\\, \\A485\\))\n  # Create the plot\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +\n    geom_smooth(show.legend = TRUE) + ylim(0, 0.5) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = c(\\DMSO\\ = \\grey\\, \\dTAG\\ = \\pink\\, \\A485\\ = \\skyblue\\)) +\n    scale_fill_manual(values = c(\\DMSO\\ = \\grey80\\, \\dTAG\\ = \\pink\\, \\A485\\ = \\skyblue\\)) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Score\\) +\n    theme(plot.title = element_text(size = 5))\n  fileName <- paste0(\\dist_vs_score_linePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)),\n      res = 600, units = \\in\\, width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),\n      width = 4, height = 3)\n  print(p4)\n  dev.off()\n}\n\ncreate_loop_dis_vs_diffscore <- function(data, figDir, name, Anno2List){\n  data = data %>% dplyr::filter(Anno2 %in% Anno2List)\n  \n  \n  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, diff_A485_DMSO)\n  \n  avg_scores <- temp %>%\n    group_by(distance) %>%\n    summarise(across(1:2, mean, na.rm = TRUE))\n  \n  avg_scores_long <- avg_scores %>%\n    pivot_longer(cols = 2:3, names_to = \\condition\\, values_to = \\avg_score\\)\n  avg_scores_long$condition <- factor(avg_scores_long$condition, \n                                      levels = c(\\diff_dTAG_DMSO\\, \\diff_A485_DMSO\\))\n  # Create the plot\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +\n    geom_smooth(show.legend = TRUE) + geom_hline(yintercept = 0) + ylim(-0.5, 0.1) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = c(\\diff_dTAG_DMSO\\ = \\pink\\, \\diff_A485_DMSO\\ = \\skyblue\\)) +\n    scale_fill_manual(values = c(\\diff_dTAG_DMSO\\ = \\pink\\, \\diff_A485_DMSO\\ = \\skyblue\\)) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Diff Score\\) +\n    theme(plot.title = element_text(size = 5))\n  fileName <- paste0(\\dist_vs_score_difflinePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)),\n      res = 600, units = \\in\\, width = 4.5, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),\n          width = 4.5, height = 3)\n  print(p4)\n  dev.off()\n}\n\ncreate_loop_scatterplot <- function(data, figDir, name, Anno2List, diffCutoff){\n  data <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\))) %>%\n    dplyr::filter(Anno2 %in% Anno2List)\n  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  num.up <- (summary(data$updown_dTAG_DMSO))[\\UP\\]\n  num.no <- (summary(data$updown_dTAG_DMSO))[\\NO\\]\n  num.down <- (summary(data$updown_dTAG_DMSO))[\\DOWN\\]\n  num.all <- num.up + num.no + num.down\n  perc.up <- round(num.up / num.all * 100, 2)\n  perc.no <- round(num.no / num.all * 100, 2)\n  perc.down <- round(num.down / num.all * 100, 2)\n  \n  ### Scatterplot\n  data$density <- get_density(data$DMSO, data$dTAG, n = 100)\n  data <- data %>% dplyr::arrange(density)\n  correlation <- cor(data$DMSO, data$dTAG)\n  p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +\n    geom_point(size = 1,\n      alpha = 1,\n      stroke = 0) + \n    scale_color_viridis(option = \\D\\, guide = guide_colorbar(\n                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n                          barheight = 15/5.08   # Adjust height of the color bar\n                        )) +\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n             color = \\black\\, hjust = 0, , size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n             color = \\black\\, hjust = 0, , size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n             color = \\black\\, hjust = 0, , size = 1,\n        family = fontType) +\n    theme_classic() +\n    #annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\) +\n    theme(\n      # legend.position = \\none\\,\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n    ) +\n  xlab(\\Loop score\\nG1.DMSO\\) +\n    ylab(\\Loop score\\nG1.dTAG\\)\n  \n  \n  \n  num.up <- (summary(data$updown_A485_DMSO))[\\UP\\]\n  num.no <- (summary(data$updown_A485_DMSO))[\\NO\\]\n  num.down <- (summary(data$updown_A485_DMSO))[\\DOWN\\]\n  num.all <- num.up + num.no + num.down\n  perc.up <- round(num.up / num.all * 100, 2)\n  perc.no <- round(num.no / num.all * 100, 2)\n  perc.down <- round(num.down / num.all * 100, 2)\n  \n  data$density <- get_density(data$DMSO, data$A485, n = 100)\n  data <- data %>% dplyr::arrange(density)\n  correlation <- cor(data$DMSO, data$A485)\n  p2 <- ggplot(data, aes(x = DMSO, y = A485, color = density)) +\n    geom_point(size = 1,\n      alpha = 1,\n      stroke = 0) + \n    scale_color_viridis(option = \\D\\, guide = guide_colorbar(\n                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n                          barheight = 15/5.08   # Adjust height of the color bar\n                        )) +\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n             color = \\black\\, hjust = 0, size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n             color = \\black\\, hjust = 0, size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n             color = \\black\\, hjust = 0, size = 1,\n        family = fontType) +\n    theme_classic() + \n    # annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\) +\n    theme(\n      # legend.position = \\none\\,\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n    ) +\n    xlab(\\Loop score\\nG1.DMSO\\) +\n    ylab(\\Loop score\\nG1.A485\\)\n\n    width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch  \n  \n  fileName <- here(figDir,paste0(\\scatterplot_\\, name, \\_dTAG_vs_DMSO_\\, diffCutoff))\n\n  svglite(paste0(fileName, \\.svg\\), width = width, height =height)\n  print(p1)\n  dev.off()\n  png(paste0(fileName, \\.png\\), width = width, height =height, res = 600, unit = \\in\\)\n  print(p1)\n  dev.off()\n  \n    fileName <- here(figDir, paste0(\\scatterplot_\\, name, \\_A485_vs_DMSO_\\, diffCutoff))\n\n  svglite(paste0(fileName, \\.svg\\), width = width, height =height)\n  print(p2)\n  dev.off()\n  png(paste0(fileName, \\.png\\), width = width, height =height, res = 600, unit = \\in\\)\n  print(p2)\n  dev.off()\n  \n  # \n  # \n  # \n  # png(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 5*1.5, height = 2.5*1.5)\n  # print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  # dev.off()\n  # \n  # svglite(here(figDir, paste0(fileName, \\.svg\\)), \n  #         width = 5*1.5, height = 2.5*1.5)\n  # print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  # dev.off()\n}\n\nmake_diff_bedpe <- function(data, name, Anno2List, outDir, diffCutoff){\n  data <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\))) %>%\n    dplyr::filter(Anno2 %in% Anno2List)\n  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \\UP\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_dTAGvsDMSO_UP_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \\NO\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_dTAGvsDMSO_NO_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \\DOWN\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_dTAGvsDMSO_DOWN_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  \n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \\UP\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_A485vsDMSO_UP_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \\NO\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_A485vsDMSO_NO_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \\DOWN\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_A485vsDMSO_DOWN_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n}\n\ncreate_dist_vs_avgScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){\n  avg_scores_long <- data %>%\n    group_by(distance, Anno2) %>%\n    summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n    ungroup() \n  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + \n    geom_smooth(show.legend = TRUE, se = se)  +\n    ylim(0, 0.5) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = colorList) +\n    scale_fill_manual(values = colorList) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Score\\) +\n    theme(plot.title = element_text(size = 8))\n  \n  fileName <- paste0(\\dist_vs_score_linePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 4, height = 3)\n  print(p4)\n  dev.off()\n} \n\ncreate_dist_vs_avgDiffScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){\n  avg_scores_long <- data %>%\n    group_by(distance, Anno2) %>%\n    summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n    ungroup() \n  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + \n    geom_hline(yintercept = 0) +\n    geom_smooth(show.legend = TRUE, se = se)  +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = colorList) +\n    scale_fill_manual(values = colorList) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Diff Score\\) +\n    theme(plot.title = element_text(size = 8)) \n  \n  fileName <- paste0(\\dist_vs_score_difflinePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 4, height = 3)\n  print(p4)\n  dev.off()\n} \n\ncreate_score_barplot_perTreatment <- function(data, figDir, name, loopList, colorList){\n  data$Anno2 <- factor(data$Anno2, levels = loopList)\n  \n  p3 <- ggplot(data, aes(x = Anno2, y = score)) +\n    geom_violin(aes(fill = Anno2), show.legend = FALSE) +\n    scale_fill_manual(values = colorList) +\n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    ylim(-0.5, 1) +\n    geom_hline(yintercept = 0, linetype = \\dashed\\, color = \\grey\\) +\n    theme_classic() +\n    ggtitle(name) +\n    theme(plot.title = element_text(size = 4))\n  \n  fileName <- paste0(\\score_barPlot_\\, name)\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 2, height = 4)\n  print(p3)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 2, height = 4)\n  print(p3)\n}\n\n\niterate_loop_functions <- function(data, figDir, groupName, annoList){\n  # create_loop_dis_vs_score(data, figDir, groupName, annoList)\n  # create_loop_dis_vs_diffscore(data, figDir, groupName, annoList)\n\n  create_loop_scatterplot(data, figDir, groupName, annoList, 0.2)\n  # create_loop_scatterplot(data, figDir, groupName, annoList, 0.1)\n  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.2)\n  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.1)\n}\n```\n\n<!-- rnb-source-end -->\n"} -->
create_loop_dis_vs_score <- function(data, figDir, name, Anno2List){
  data = data %>% dplyr::filter(Anno2 %in% Anno2List)
  
  ### barplot
  temp <- data %>% dplyr::select(id, DMSO, dTAG, A485) %>%
    pivot_longer(!id, names_to = \treatment\, values_to = \score\)
  temp$treatment <- factor(temp$treatment, levels = c(\DMSO\, \dTAG\, \A485\))
  
  p3 <- ggplot(temp, aes(x = treatment, y = score)) +
    geom_violin(aes(fill = treatment), show.legend = FALSE) +
    scale_fill_manual(values = c(\DMSO\ = \grey\, \dTAG\ = \pink\, \A485\ = \skyblue\)) +
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    ylim(-0.5, 1) +
    geom_hline(yintercept = 0, linetype = \dashed\, color = \grey\) +
    theme_classic() +
    ggtitle(name) +
    theme(plot.title = element_text(size = 4))
  fileName <- paste0(\score_barplot_\, name)
  png(here(figDir, paste0(fileName, \.png\)), 
      res = 600, units = \in\, width = 2, height = 4)
  print(p3)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 2, height = 4)
  print(p3)
  dev.off()
  
  ### Distance vs score
  
  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, dTAG, A485)

  avg_scores <- temp %>%
    group_by(distance) %>%
    summarise(across(starts_with(\DMSO\):starts_with(\A485\), mean, na.rm = TRUE))

  avg_scores_long <- avg_scores %>%
    pivot_longer(cols = DMSO:A485, names_to = \condition\, values_to = \avg_score\)
  avg_scores_long$condition <- factor(avg_scores_long$condition, levels = c(\DMSO\, \dTAG\, \A485\))
  # Create the plot
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +
    geom_smooth(show.legend = TRUE) + ylim(0, 0.5) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = c(\DMSO\ = \grey\, \dTAG\ = \pink\, \A485\ = \skyblue\)) +
    scale_fill_manual(values = c(\DMSO\ = \grey80\, \dTAG\ = \pink\, \A485\ = \skyblue\)) +
    labs(title = paste0(name),
         x = \Distance\,
         y = \Average Score\) +
    theme(plot.title = element_text(size = 5))
  fileName <- paste0(\dist_vs_score_linePlot_\, name)
  png(here(figDir, paste0(fileName, \.png\)),
      res = 600, units = \in\, width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),
      width = 4, height = 3)
  print(p4)
  dev.off()
}

create_loop_dis_vs_diffscore <- function(data, figDir, name, Anno2List){
  data = data %>% dplyr::filter(Anno2 %in% Anno2List)
  
  
  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, diff_A485_DMSO)
  
  avg_scores <- temp %>%
    group_by(distance) %>%
    summarise(across(1:2, mean, na.rm = TRUE))
  
  avg_scores_long <- avg_scores %>%
    pivot_longer(cols = 2:3, names_to = \condition\, values_to = \avg_score\)
  avg_scores_long$condition <- factor(avg_scores_long$condition, 
                                      levels = c(\diff_dTAG_DMSO\, \diff_A485_DMSO\))
  # Create the plot
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +
    geom_smooth(show.legend = TRUE) + geom_hline(yintercept = 0) + ylim(-0.5, 0.1) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = c(\diff_dTAG_DMSO\ = \pink\, \diff_A485_DMSO\ = \skyblue\)) +
    scale_fill_manual(values = c(\diff_dTAG_DMSO\ = \pink\, \diff_A485_DMSO\ = \skyblue\)) +
    labs(title = paste0(name),
         x = \Distance\,
         y = \Average Diff Score\) +
    theme(plot.title = element_text(size = 5))
  fileName <- paste0(\dist_vs_score_difflinePlot_\, name)
  png(here(figDir, paste0(fileName, \.png\)),
      res = 600, units = \in\, width = 4.5, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),
          width = 4.5, height = 3)
  print(p4)
  dev.off()
}

create_loop_scatterplot <- function(data, figDir, name, Anno2List, diffCutoff){
  data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\))) %>%
    dplyr::filter(Anno2 %in% Anno2List)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  
  num.up <- (summary(data$updown_dTAG_DMSO))[\UP\]
  num.no <- (summary(data$updown_dTAG_DMSO))[\NO\]
  num.down <- (summary(data$updown_dTAG_DMSO))[\DOWN\]
  num.all <- num.up + num.no + num.down
  perc.up <- round(num.up / num.all * 100, 2)
  perc.no <- round(num.no / num.all * 100, 2)
  perc.down <- round(num.down / num.all * 100, 2)
  
  ### Scatterplot
  data$density <- get_density(data$DMSO, data$dTAG, n = 100)
  data <- data %>% dplyr::arrange(density)
  correlation <- cor(data$DMSO, data$dTAG)
  p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +
    geom_point(size = 1,
      alpha = 1,
      stroke = 0) + 
    scale_color_viridis(option = \D\, guide = guide_colorbar(
                          barwidth = 1.5/5.08,  # Adjust width of the color bar
                          barheight = 15/5.08   # Adjust height of the color bar
                        )) +
    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    annotate(\text\, x = -0.5, y = 1, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
             color = \black\, hjust = 0, , size = 1,
        family = fontType) +
    annotate(\text\, x = -0.5, y = 1-0.1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
             color = \black\, hjust = 0, , size = 1,
        family = fontType) +
    annotate(\text\, x = -0.5, y = 1-0.2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
             color = \black\, hjust = 0, , size = 1,
        family = fontType) +
    theme_classic() +
    #annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\) +
    theme(
      # legend.position = \none\,
      plot.title = element_text(
        hjust = 0.5,
        size = fontSizeS,
        family = fontType
      ),
      axis.title = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.line = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
    ) +
  xlab(\Loop score\nG1.DMSO\) +
    ylab(\Loop score\nG1.dTAG\)
  
  
  
  num.up <- (summary(data$updown_A485_DMSO))[\UP\]
  num.no <- (summary(data$updown_A485_DMSO))[\NO\]
  num.down <- (summary(data$updown_A485_DMSO))[\DOWN\]
  num.all <- num.up + num.no + num.down
  perc.up <- round(num.up / num.all * 100, 2)
  perc.no <- round(num.no / num.all * 100, 2)
  perc.down <- round(num.down / num.all * 100, 2)
  
  data$density <- get_density(data$DMSO, data$A485, n = 100)
  data <- data %>% dplyr::arrange(density)
  correlation <- cor(data$DMSO, data$A485)
  p2 <- ggplot(data, aes(x = DMSO, y = A485, color = density)) +
    geom_point(size = 1,
      alpha = 1,
      stroke = 0) + 
    scale_color_viridis(option = \D\, guide = guide_colorbar(
                          barwidth = 1.5/5.08,  # Adjust width of the color bar
                          barheight = 15/5.08   # Adjust height of the color bar
                        )) +
    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    annotate(\text\, x = -0.5, y = 1, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
             color = \black\, hjust = 0, size = 1,
        family = fontType) +
    annotate(\text\, x = -0.5, y = 1-0.1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
             color = \black\, hjust = 0, size = 1,
        family = fontType) +
    annotate(\text\, x = -0.5, y = 1-0.2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
             color = \black\, hjust = 0, size = 1,
        family = fontType) +
    theme_classic() + 
    # annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\) +
    theme(
      # legend.position = \none\,
      plot.title = element_text(
        hjust = 0.5,
        size = fontSizeS,
        family = fontType
      ),
      axis.title = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.line = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
    ) +
    xlab(\Loop score\nG1.DMSO\) +
    ylab(\Loop score\nG1.A485\)

    width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.5)*mmToInch  
  
  fileName <- here(figDir,paste0(\scatterplot_\, name, \_dTAG_vs_DMSO_\, diffCutoff))

  svglite(paste0(fileName, \.svg\), width = width, height =height)
  print(p1)
  dev.off()
  png(paste0(fileName, \.png\), width = width, height =height, res = 600, unit = \in\)
  print(p1)
  dev.off()
  
    fileName <- here(figDir, paste0(\scatterplot_\, name, \_A485_vs_DMSO_\, diffCutoff))

  svglite(paste0(fileName, \.svg\), width = width, height =height)
  print(p2)
  dev.off()
  png(paste0(fileName, \.png\), width = width, height =height, res = 600, unit = \in\)
  print(p2)
  dev.off()
  
  # 
  # 
  # 
  # png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 5*1.5, height = 2.5*1.5)
  # print(cowplot::plot_grid(p1, p2, align = \h\))
  # dev.off()
  # 
  # svglite(here(figDir, paste0(fileName, \.svg\)), 
  #         width = 5*1.5, height = 2.5*1.5)
  # print(cowplot::plot_grid(p1, p2, align = \h\))
  # dev.off()
}

make_diff_bedpe <- function(data, name, Anno2List, outDir, diffCutoff){
  data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\))) %>%
    dplyr::filter(Anno2 %in% Anno2List)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \UP\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_dTAGvsDMSO_UP_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \NO\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_dTAGvsDMSO_NO_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \DOWN\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_dTAGvsDMSO_DOWN_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \UP\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_A485vsDMSO_UP_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \NO\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_A485vsDMSO_NO_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \DOWN\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_A485vsDMSO_DOWN_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
}

create_dist_vs_avgScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){
  avg_scores_long <- data %>%
    group_by(distance, Anno2) %>%
    summarise(avg_score = mean(score, na.rm = TRUE)) %>%
    ungroup() 
  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + 
    geom_smooth(show.legend = TRUE, se = se)  +
    ylim(0, 0.5) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = colorList) +
    scale_fill_manual(values = colorList) +
    labs(title = paste0(name),
         x = \Distance\,
         y = \Average Score\) +
    theme(plot.title = element_text(size = 8))
  
  fileName <- paste0(\dist_vs_score_linePlot_\, name)
  png(here(figDir, paste0(fileName, \.png\)), 
      res = 600, units = \in\, width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 4, height = 3)
  print(p4)
  dev.off()
} 

create_dist_vs_avgDiffScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){
  avg_scores_long <- data %>%
    group_by(distance, Anno2) %>%
    summarise(avg_score = mean(score, na.rm = TRUE)) %>%
    ungroup() 
  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + 
    geom_hline(yintercept = 0) +
    geom_smooth(show.legend = TRUE, se = se)  +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = colorList) +
    scale_fill_manual(values = colorList) +
    labs(title = paste0(name),
         x = \Distance\,
         y = \Average Diff Score\) +
    theme(plot.title = element_text(size = 8)) 
  
  fileName <- paste0(\dist_vs_score_difflinePlot_\, name)
  png(here(figDir, paste0(fileName, \.png\)), 
      res = 600, units = \in\, width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 4, height = 3)
  print(p4)
  dev.off()
} 

create_score_barplot_perTreatment <- function(data, figDir, name, loopList, colorList){
  data$Anno2 <- factor(data$Anno2, levels = loopList)
  
  p3 <- ggplot(data, aes(x = Anno2, y = score)) +
    geom_violin(aes(fill = Anno2), show.legend = FALSE) +
    scale_fill_manual(values = colorList) +
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    ylim(-0.5, 1) +
    geom_hline(yintercept = 0, linetype = \dashed\, color = \grey\) +
    theme_classic() +
    ggtitle(name) +
    theme(plot.title = element_text(size = 4))
  
  fileName <- paste0(\score_barPlot_\, name)
  
  png(here(figDir, paste0(fileName, \.png\)), 
      res = 600, units = \in\, width = 2, height = 4)
  print(p3)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 2, height = 4)
  print(p3)
}


iterate_loop_functions <- function(data, figDir, groupName, annoList){
  # create_loop_dis_vs_score(data, figDir, groupName, annoList)
  # create_loop_dis_vs_diffscore(data, figDir, groupName, annoList)

  create_loop_scatterplot(data, figDir, groupName, annoList, 0.2)
  # create_loop_scatterplot(data, figDir, groupName, annoList, 0.1)
  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.2)
  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.1)
}



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ncreate_loop_dis_vs_score <- function(data, figDir, name, Anno2List){\n  data = data %>% dplyr::filter(Anno2 %in% Anno2List)\n  \n  ### barplot\n  temp <- data %>% dplyr::select(id, DMSO, dTAG, A485) %>%\n    pivot_longer(!id, names_to = \\treatment\\, values_to = \\score\\)\n  temp$treatment <- factor(temp$treatment, levels = c(\\DMSO\\, \\dTAG\\, \\A485\\))\n  \n  p3 <- ggplot(temp, aes(x = treatment, y = score)) +\n    geom_violin(aes(fill = treatment), show.legend = FALSE) +\n    scale_fill_manual(values = c(\\DMSO\\ = \\grey\\, \\dTAG\\ = \\pink\\, \\A485\\ = \\skyblue\\)) +\n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    ylim(-0.5, 1) +\n    geom_hline(yintercept = 0, linetype = \\dashed\\, color = \\grey\\) +\n    theme_classic() +\n    ggtitle(name) +\n    theme(plot.title = element_text(size = 4))\n  fileName <- paste0(\\score_barplot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 2, height = 4)\n  print(p3)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 2, height = 4)\n  print(p3)\n  dev.off()\n  \n  ### Distance vs score\n  \n  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, dTAG, A485)\n\n  avg_scores <- temp %>%\n    group_by(distance) %>%\n    summarise(across(starts_with(\\DMSO\\):starts_with(\\A485\\), mean, na.rm = TRUE))\n\n  avg_scores_long <- avg_scores %>%\n    pivot_longer(cols = DMSO:A485, names_to = \\condition\\, values_to = \\avg_score\\)\n  avg_scores_long$condition <- factor(avg_scores_long$condition, levels = c(\\DMSO\\, \\dTAG\\, \\A485\\))\n  # Create the plot\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +\n    geom_smooth(show.legend = TRUE) + ylim(0, 0.5) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = c(\\DMSO\\ = \\grey\\, \\dTAG\\ = \\pink\\, \\A485\\ = \\skyblue\\)) +\n    scale_fill_manual(values = c(\\DMSO\\ = \\grey80\\, \\dTAG\\ = \\pink\\, \\A485\\ = \\skyblue\\)) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Score\\) +\n    theme(plot.title = element_text(size = 5))\n  fileName <- paste0(\\dist_vs_score_linePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)),\n      res = 600, units = \\in\\, width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),\n      width = 4, height = 3)\n  print(p4)\n  dev.off()\n}\n\ncreate_loop_dis_vs_diffscore <- function(data, figDir, name, Anno2List){\n  data = data %>% dplyr::filter(Anno2 %in% Anno2List)\n  \n  \n  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, diff_A485_DMSO)\n  \n  avg_scores <- temp %>%\n    group_by(distance) %>%\n    summarise(across(1:2, mean, na.rm = TRUE))\n  \n  avg_scores_long <- avg_scores %>%\n    pivot_longer(cols = 2:3, names_to = \\condition\\, values_to = \\avg_score\\)\n  avg_scores_long$condition <- factor(avg_scores_long$condition, \n                                      levels = c(\\diff_dTAG_DMSO\\, \\diff_A485_DMSO\\))\n  # Create the plot\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +\n    geom_smooth(show.legend = TRUE) + geom_hline(yintercept = 0) + ylim(-0.5, 0.1) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = c(\\diff_dTAG_DMSO\\ = \\pink\\, \\diff_A485_DMSO\\ = \\skyblue\\)) +\n    scale_fill_manual(values = c(\\diff_dTAG_DMSO\\ = \\pink\\, \\diff_A485_DMSO\\ = \\skyblue\\)) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Diff Score\\) +\n    theme(plot.title = element_text(size = 5))\n  fileName <- paste0(\\dist_vs_score_difflinePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)),\n      res = 600, units = \\in\\, width = 4.5, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),\n          width = 4.5, height = 3)\n  print(p4)\n  dev.off()\n}\n\ncreate_loop_scatterplot <- function(data, figDir, name, Anno2List, diffCutoff){\n  data <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\))) %>%\n    dplyr::filter(Anno2 %in% Anno2List)\n  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  num.up <- (summary(data$updown_dTAG_DMSO))[\\UP\\]\n  num.no <- (summary(data$updown_dTAG_DMSO))[\\NO\\]\n  num.down <- (summary(data$updown_dTAG_DMSO))[\\DOWN\\]\n  num.all <- num.up + num.no + num.down\n  perc.up <- round(num.up / num.all * 100, 2)\n  perc.no <- round(num.no / num.all * 100, 2)\n  perc.down <- round(num.down / num.all * 100, 2)\n  \n  ### Scatterplot\n  data$density <- get_density(data$DMSO, data$dTAG, n = 100)\n  data <- data %>% dplyr::arrange(density)\n  correlation <- cor(data$DMSO, data$dTAG)\n  p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +\n    geom_point(size = 1,\n      alpha = 1,\n      stroke = 0) + \n    scale_color_viridis(option = \\D\\, guide = guide_colorbar(\n                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n                          barheight = 15/5.08   # Adjust height of the color bar\n                        )) +\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n             color = \\black\\, hjust = 0, , size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n             color = \\black\\, hjust = 0, , size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n             color = \\black\\, hjust = 0, , size = 1,\n        family = fontType) +\n    theme_classic() +\n    #annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\) +\n    theme(\n      # legend.position = \\none\\,\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n    ) +\n  xlab(\\Loop score\\nG1.DMSO\\) +\n    ylab(\\Loop score\\nG1.dTAG\\)\n  \n  \n  \n  num.up <- (summary(data$updown_A485_DMSO))[\\UP\\]\n  num.no <- (summary(data$updown_A485_DMSO))[\\NO\\]\n  num.down <- (summary(data$updown_A485_DMSO))[\\DOWN\\]\n  num.all <- num.up + num.no + num.down\n  perc.up <- round(num.up / num.all * 100, 2)\n  perc.no <- round(num.no / num.all * 100, 2)\n  perc.down <- round(num.down / num.all * 100, 2)\n  \n  data$density <- get_density(data$DMSO, data$A485, n = 100)\n  data <- data %>% dplyr::arrange(density)\n  correlation <- cor(data$DMSO, data$A485)\n  p2 <- ggplot(data, aes(x = DMSO, y = A485, color = density)) +\n    geom_point(size = 1,\n      alpha = 1,\n      stroke = 0) + \n    scale_color_viridis(option = \\D\\, guide = guide_colorbar(\n                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n                          barheight = 15/5.08   # Adjust height of the color bar\n                        )) +\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n             color = \\black\\, hjust = 0, size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n             color = \\black\\, hjust = 0, size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n             color = \\black\\, hjust = 0, size = 1,\n        family = fontType) +\n    theme_classic() + \n    # annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\) +\n    theme(\n      # legend.position = \\none\\,\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n    ) +\n    xlab(\\Loop score\\nG1.DMSO\\) +\n    ylab(\\Loop score\\nG1.A485\\)\n\n    width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch  \n  \n  fileName <- here(figDir,paste0(\\scatterplot_\\, name, \\_dTAG_vs_DMSO_\\, diffCutoff))\n\n  svglite(paste0(fileName, \\.svg\\), width = width, height =height)\n  print(p1)\n  dev.off()\n  png(paste0(fileName, \\.png\\), width = width, height =height, res = 600, unit = \\in\\)\n  print(p1)\n  dev.off()\n  \n    fileName <- here(figDir, paste0(\\scatterplot_\\, name, \\_A485_vs_DMSO_\\, diffCutoff))\n\n  svglite(paste0(fileName, \\.svg\\), width = width, height =height)\n  print(p2)\n  dev.off()\n  png(paste0(fileName, \\.png\\), width = width, height =height, res = 600, unit = \\in\\)\n  print(p2)\n  dev.off()\n  \n  # \n  # \n  # \n  # png(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 5*1.5, height = 2.5*1.5)\n  # print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  # dev.off()\n  # \n  # svglite(here(figDir, paste0(fileName, \\.svg\\)), \n  #         width = 5*1.5, height = 2.5*1.5)\n  # print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  # dev.off()\n}\n\nmake_diff_bedpe <- function(data, name, Anno2List, outDir, diffCutoff){\n  data <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\))) %>%\n    dplyr::filter(Anno2 %in% Anno2List)\n  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \\UP\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_dTAGvsDMSO_UP_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \\NO\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_dTAGvsDMSO_NO_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \\DOWN\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_dTAGvsDMSO_DOWN_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  \n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \\UP\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_A485vsDMSO_UP_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \\NO\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_A485vsDMSO_NO_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \\DOWN\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_A485vsDMSO_DOWN_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n}\n\ncreate_dist_vs_avgScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){\n  avg_scores_long <- data %>%\n    group_by(distance, Anno2) %>%\n    summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n    ungroup() \n  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + \n    geom_smooth(show.legend = TRUE, se = se)  +\n    ylim(0, 0.5) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = colorList) +\n    scale_fill_manual(values = colorList) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Score\\) +\n    theme(plot.title = element_text(size = 8))\n  \n  fileName <- paste0(\\dist_vs_score_linePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 4, height = 3)\n  print(p4)\n  dev.off()\n} \n\ncreate_dist_vs_avgDiffScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){\n  avg_scores_long <- data %>%\n    group_by(distance, Anno2) %>%\n    summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n    ungroup() \n  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + \n    geom_hline(yintercept = 0) +\n    geom_smooth(show.legend = TRUE, se = se)  +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = colorList) +\n    scale_fill_manual(values = colorList) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Diff Score\\) +\n    theme(plot.title = element_text(size = 8)) \n  \n  fileName <- paste0(\\dist_vs_score_difflinePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 4, height = 3)\n  print(p4)\n  dev.off()\n} \n\ncreate_score_barplot_perTreatment <- function(data, figDir, name, loopList, colorList){\n  data$Anno2 <- factor(data$Anno2, levels = loopList)\n  \n  p3 <- ggplot(data, aes(x = Anno2, y = score)) +\n    geom_violin(aes(fill = Anno2), show.legend = FALSE) +\n    scale_fill_manual(values = colorList) +\n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    ylim(-0.5, 1) +\n    geom_hline(yintercept = 0, linetype = \\dashed\\, color = \\grey\\) +\n    theme_classic() +\n    ggtitle(name) +\n    theme(plot.title = element_text(size = 4))\n  \n  fileName <- paste0(\\score_barPlot_\\, name)\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 2, height = 4)\n  print(p3)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 2, height = 4)\n  print(p3)\n}\n\n\niterate_loop_functions <- function(data, figDir, groupName, annoList){\n  # create_loop_dis_vs_score(data, figDir, groupName, annoList)\n  # create_loop_dis_vs_diffscore(data, figDir, groupName, annoList)\n\n  create_loop_scatterplot(data, figDir, groupName, annoList, 0.2)\n  # create_loop_scatterplot(data, figDir, groupName, annoList, 0.1)\n  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.2)\n  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.1)\n}\n```\n```"} -->\n\n```r\n```r\ncreate_loop_dis_vs_score <- function(data, figDir, name, Anno2List){\n  data = data %>% dplyr::filter(Anno2 %in% Anno2List)\n  \n  ### barplot\n  temp <- data %>% dplyr::select(id, DMSO, dTAG, A485) %>%\n    pivot_longer(!id, names_to = \\treatment\\, values_to = \\score\\)\n  temp$treatment <- factor(temp$treatment, levels = c(\\DMSO\\, \\dTAG\\, \\A485\\))\n  \n  p3 <- ggplot(temp, aes(x = treatment, y = score)) +\n    geom_violin(aes(fill = treatment), show.legend = FALSE) +\n    scale_fill_manual(values = c(\\DMSO\\ = \\grey\\, \\dTAG\\ = \\pink\\, \\A485\\ = \\skyblue\\)) +\n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    ylim(-0.5, 1) +\n    geom_hline(yintercept = 0, linetype = \\dashed\\, color = \\grey\\) +\n    theme_classic() +\n    ggtitle(name) +\n    theme(plot.title = element_text(size = 4))\n  fileName <- paste0(\\score_barplot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 2, height = 4)\n  print(p3)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 2, height = 4)\n  print(p3)\n  dev.off()\n  \n  ### Distance vs score\n  \n  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, dTAG, A485)\n\n  avg_scores <- temp %>%\n    group_by(distance) %>%\n    summarise(across(starts_with(\\DMSO\\):starts_with(\\A485\\), mean, na.rm = TRUE))\n\n  avg_scores_long <- avg_scores %>%\n    pivot_longer(cols = DMSO:A485, names_to = \\condition\\, values_to = \\avg_score\\)\n  avg_scores_long$condition <- factor(avg_scores_long$condition, levels = c(\\DMSO\\, \\dTAG\\, \\A485\\))\n  # Create the plot\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +\n    geom_smooth(show.legend = TRUE) + ylim(0, 0.5) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = c(\\DMSO\\ = \\grey\\, \\dTAG\\ = \\pink\\, \\A485\\ = \\skyblue\\)) +\n    scale_fill_manual(values = c(\\DMSO\\ = \\grey80\\, \\dTAG\\ = \\pink\\, \\A485\\ = \\skyblue\\)) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Score\\) +\n    theme(plot.title = element_text(size = 5))\n  fileName <- paste0(\\dist_vs_score_linePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)),\n      res = 600, units = \\in\\, width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),\n      width = 4, height = 3)\n  print(p4)\n  dev.off()\n}\n\ncreate_loop_dis_vs_diffscore <- function(data, figDir, name, Anno2List){\n  data = data %>% dplyr::filter(Anno2 %in% Anno2List)\n  \n  \n  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, diff_A485_DMSO)\n  \n  avg_scores <- temp %>%\n    group_by(distance) %>%\n    summarise(across(1:2, mean, na.rm = TRUE))\n  \n  avg_scores_long <- avg_scores %>%\n    pivot_longer(cols = 2:3, names_to = \\condition\\, values_to = \\avg_score\\)\n  avg_scores_long$condition <- factor(avg_scores_long$condition, \n                                      levels = c(\\diff_dTAG_DMSO\\, \\diff_A485_DMSO\\))\n  # Create the plot\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +\n    geom_smooth(show.legend = TRUE) + geom_hline(yintercept = 0) + ylim(-0.5, 0.1) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = c(\\diff_dTAG_DMSO\\ = \\pink\\, \\diff_A485_DMSO\\ = \\skyblue\\)) +\n    scale_fill_manual(values = c(\\diff_dTAG_DMSO\\ = \\pink\\, \\diff_A485_DMSO\\ = \\skyblue\\)) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Diff Score\\) +\n    theme(plot.title = element_text(size = 5))\n  fileName <- paste0(\\dist_vs_score_difflinePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)),\n      res = 600, units = \\in\\, width = 4.5, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),\n          width = 4.5, height = 3)\n  print(p4)\n  dev.off()\n}\n\ncreate_loop_scatterplot <- function(data, figDir, name, Anno2List, diffCutoff){\n  data <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\))) %>%\n    dplyr::filter(Anno2 %in% Anno2List)\n  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  num.up <- (summary(data$updown_dTAG_DMSO))[\\UP\\]\n  num.no <- (summary(data$updown_dTAG_DMSO))[\\NO\\]\n  num.down <- (summary(data$updown_dTAG_DMSO))[\\DOWN\\]\n  num.all <- num.up + num.no + num.down\n  perc.up <- round(num.up / num.all * 100, 2)\n  perc.no <- round(num.no / num.all * 100, 2)\n  perc.down <- round(num.down / num.all * 100, 2)\n  \n  ### Scatterplot\n  data$density <- get_density(data$DMSO, data$dTAG, n = 100)\n  data <- data %>% dplyr::arrange(density)\n  correlation <- cor(data$DMSO, data$dTAG)\n  p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +\n    geom_point(size = 1,\n      alpha = 1,\n      stroke = 0) + \n    scale_color_viridis(option = \\D\\, guide = guide_colorbar(\n                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n                          barheight = 15/5.08   # Adjust height of the color bar\n                        )) +\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n             color = \\black\\, hjust = 0, , size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n             color = \\black\\, hjust = 0, , size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n             color = \\black\\, hjust = 0, , size = 1,\n        family = fontType) +\n    theme_classic() +\n    #annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\) +\n    theme(\n      # legend.position = \\none\\,\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n    ) +\n  xlab(\\Loop score\\nG1.DMSO\\) +\n    ylab(\\Loop score\\nG1.dTAG\\)\n  \n  \n  \n  num.up <- (summary(data$updown_A485_DMSO))[\\UP\\]\n  num.no <- (summary(data$updown_A485_DMSO))[\\NO\\]\n  num.down <- (summary(data$updown_A485_DMSO))[\\DOWN\\]\n  num.all <- num.up + num.no + num.down\n  perc.up <- round(num.up / num.all * 100, 2)\n  perc.no <- round(num.no / num.all * 100, 2)\n  perc.down <- round(num.down / num.all * 100, 2)\n  \n  data$density <- get_density(data$DMSO, data$A485, n = 100)\n  data <- data %>% dplyr::arrange(density)\n  correlation <- cor(data$DMSO, data$A485)\n  p2 <- ggplot(data, aes(x = DMSO, y = A485, color = density)) +\n    geom_point(size = 1,\n      alpha = 1,\n      stroke = 0) + \n    scale_color_viridis(option = \\D\\, guide = guide_colorbar(\n                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n                          barheight = 15/5.08   # Adjust height of the color bar\n                        )) +\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n             color = \\black\\, hjust = 0, size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n             color = \\black\\, hjust = 0, size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n             color = \\black\\, hjust = 0, size = 1,\n        family = fontType) +\n    theme_classic() + \n    # annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\) +\n    theme(\n      # legend.position = \\none\\,\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n    ) +\n    xlab(\\Loop score\\nG1.DMSO\\) +\n    ylab(\\Loop score\\nG1.A485\\)\n\n    width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch  \n  \n  fileName <- here(figDir,paste0(\\scatterplot_\\, name, \\_dTAG_vs_DMSO_\\, diffCutoff))\n\n  svglite(paste0(fileName, \\.svg\\), width = width, height =height)\n  print(p1)\n  dev.off()\n  png(paste0(fileName, \\.png\\), width = width, height =height, res = 600, unit = \\in\\)\n  print(p1)\n  dev.off()\n  \n    fileName <- here(figDir, paste0(\\scatterplot_\\, name, \\_A485_vs_DMSO_\\, diffCutoff))\n\n  svglite(paste0(fileName, \\.svg\\), width = width, height =height)\n  print(p2)\n  dev.off()\n  png(paste0(fileName, \\.png\\), width = width, height =height, res = 600, unit = \\in\\)\n  print(p2)\n  dev.off()\n  \n  # \n  # \n  # \n  # png(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 5*1.5, height = 2.5*1.5)\n  # print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  # dev.off()\n  # \n  # svglite(here(figDir, paste0(fileName, \\.svg\\)), \n  #         width = 5*1.5, height = 2.5*1.5)\n  # print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  # dev.off()\n}\n\nmake_diff_bedpe <- function(data, name, Anno2List, outDir, diffCutoff){\n  data <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\))) %>%\n    dplyr::filter(Anno2 %in% Anno2List)\n  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \\UP\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_dTAGvsDMSO_UP_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \\NO\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_dTAGvsDMSO_NO_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \\DOWN\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_dTAGvsDMSO_DOWN_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  \n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \\UP\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_A485vsDMSO_UP_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \\NO\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_A485vsDMSO_NO_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \\DOWN\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_A485vsDMSO_DOWN_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n}\n\ncreate_dist_vs_avgScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){\n  avg_scores_long <- data %>%\n    group_by(distance, Anno2) %>%\n    summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n    ungroup() \n  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + \n    geom_smooth(show.legend = TRUE, se = se)  +\n    ylim(0, 0.5) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = colorList) +\n    scale_fill_manual(values = colorList) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Score\\) +\n    theme(plot.title = element_text(size = 8))\n  \n  fileName <- paste0(\\dist_vs_score_linePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 4, height = 3)\n  print(p4)\n  dev.off()\n} \n\ncreate_dist_vs_avgDiffScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){\n  avg_scores_long <- data %>%\n    group_by(distance, Anno2) %>%\n    summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n    ungroup() \n  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + \n    geom_hline(yintercept = 0) +\n    geom_smooth(show.legend = TRUE, se = se)  +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = colorList) +\n    scale_fill_manual(values = colorList) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Diff Score\\) +\n    theme(plot.title = element_text(size = 8)) \n  \n  fileName <- paste0(\\dist_vs_score_difflinePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 4, height = 3)\n  print(p4)\n  dev.off()\n} \n\ncreate_score_barplot_perTreatment <- function(data, figDir, name, loopList, colorList){\n  data$Anno2 <- factor(data$Anno2, levels = loopList)\n  \n  p3 <- ggplot(data, aes(x = Anno2, y = score)) +\n    geom_violin(aes(fill = Anno2), show.legend = FALSE) +\n    scale_fill_manual(values = colorList) +\n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    ylim(-0.5, 1) +\n    geom_hline(yintercept = 0, linetype = \\dashed\\, color = \\grey\\) +\n    theme_classic() +\n    ggtitle(name) +\n    theme(plot.title = element_text(size = 4))\n  \n  fileName <- paste0(\\score_barPlot_\\, name)\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 2, height = 4)\n  print(p3)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 2, height = 4)\n  print(p3)\n}\n\n\niterate_loop_functions <- function(data, figDir, groupName, annoList){\n  # create_loop_dis_vs_score(data, figDir, groupName, annoList)\n  # create_loop_dis_vs_diffscore(data, figDir, groupName, annoList)\n\n  create_loop_scatterplot(data, figDir, groupName, annoList, 0.2)\n  # create_loop_scatterplot(data, figDir, groupName, annoList, 0.1)\n  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.2)\n  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.1)\n}\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ncreate_loop_dis_vs_score <- function(data, figDir, name, Anno2List){\n  data = data %>% dplyr::filter(Anno2 %in% Anno2List)\n  \n  ### barplot\n  temp <- data %>% dplyr::select(id, DMSO, dTAG, A485) %>%\n    pivot_longer(!id, names_to = \\treatment\\, values_to = \\score\\)\n  temp$treatment <- factor(temp$treatment, levels = c(\\DMSO\\, \\dTAG\\, \\A485\\))\n  \n  p3 <- ggplot(temp, aes(x = treatment, y = score)) +\n    geom_violin(aes(fill = treatment), show.legend = FALSE) +\n    scale_fill_manual(values = c(\\DMSO\\ = \\grey\\, \\dTAG\\ = \\pink\\, \\A485\\ = \\skyblue\\)) +\n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    ylim(-0.5, 1) +\n    geom_hline(yintercept = 0, linetype = \\dashed\\, color = \\grey\\) +\n    theme_classic() +\n    ggtitle(name) +\n    theme(plot.title = element_text(size = 4))\n  fileName <- paste0(\\score_barplot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 2, height = 4)\n  print(p3)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 2, height = 4)\n  print(p3)\n  dev.off()\n  \n  ### Distance vs score\n  \n  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, dTAG, A485)\n\n  avg_scores <- temp %>%\n    group_by(distance) %>%\n    summarise(across(starts_with(\\DMSO\\):starts_with(\\A485\\), mean, na.rm = TRUE))\n\n  avg_scores_long <- avg_scores %>%\n    pivot_longer(cols = DMSO:A485, names_to = \\condition\\, values_to = \\avg_score\\)\n  avg_scores_long$condition <- factor(avg_scores_long$condition, levels = c(\\DMSO\\, \\dTAG\\, \\A485\\))\n  # Create the plot\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +\n    geom_smooth(show.legend = TRUE) + ylim(0, 0.5) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = c(\\DMSO\\ = \\grey\\, \\dTAG\\ = \\pink\\, \\A485\\ = \\skyblue\\)) +\n    scale_fill_manual(values = c(\\DMSO\\ = \\grey80\\, \\dTAG\\ = \\pink\\, \\A485\\ = \\skyblue\\)) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Score\\) +\n    theme(plot.title = element_text(size = 5))\n  fileName <- paste0(\\dist_vs_score_linePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)),\n      res = 600, units = \\in\\, width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),\n      width = 4, height = 3)\n  print(p4)\n  dev.off()\n}\n\ncreate_loop_dis_vs_diffscore <- function(data, figDir, name, Anno2List){\n  data = data %>% dplyr::filter(Anno2 %in% Anno2List)\n  \n  \n  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, diff_A485_DMSO)\n  \n  avg_scores <- temp %>%\n    group_by(distance) %>%\n    summarise(across(1:2, mean, na.rm = TRUE))\n  \n  avg_scores_long <- avg_scores %>%\n    pivot_longer(cols = 2:3, names_to = \\condition\\, values_to = \\avg_score\\)\n  avg_scores_long$condition <- factor(avg_scores_long$condition, \n                                      levels = c(\\diff_dTAG_DMSO\\, \\diff_A485_DMSO\\))\n  # Create the plot\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +\n    geom_smooth(show.legend = TRUE) + geom_hline(yintercept = 0) + ylim(-0.5, 0.1) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = c(\\diff_dTAG_DMSO\\ = \\pink\\, \\diff_A485_DMSO\\ = \\skyblue\\)) +\n    scale_fill_manual(values = c(\\diff_dTAG_DMSO\\ = \\pink\\, \\diff_A485_DMSO\\ = \\skyblue\\)) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Diff Score\\) +\n    theme(plot.title = element_text(size = 5))\n  fileName <- paste0(\\dist_vs_score_difflinePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)),\n      res = 600, units = \\in\\, width = 4.5, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),\n          width = 4.5, height = 3)\n  print(p4)\n  dev.off()\n}\n\ncreate_loop_scatterplot <- function(data, figDir, name, Anno2List, diffCutoff){\n  data <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\))) %>%\n    dplyr::filter(Anno2 %in% Anno2List)\n  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  num.up <- (summary(data$updown_dTAG_DMSO))[\\UP\\]\n  num.no <- (summary(data$updown_dTAG_DMSO))[\\NO\\]\n  num.down <- (summary(data$updown_dTAG_DMSO))[\\DOWN\\]\n  num.all <- num.up + num.no + num.down\n  perc.up <- round(num.up / num.all * 100, 2)\n  perc.no <- round(num.no / num.all * 100, 2)\n  perc.down <- round(num.down / num.all * 100, 2)\n  \n  ### Scatterplot\n  data$density <- get_density(data$DMSO, data$dTAG, n = 100)\n  data <- data %>% dplyr::arrange(density)\n  correlation <- cor(data$DMSO, data$dTAG)\n  p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +\n    geom_point(size = 1,\n      alpha = 1,\n      stroke = 0) + \n    scale_color_viridis(option = \\D\\, guide = guide_colorbar(\n                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n                          barheight = 15/5.08   # Adjust height of the color bar\n                        )) +\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n             color = \\black\\, hjust = 0, , size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n             color = \\black\\, hjust = 0, , size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n             color = \\black\\, hjust = 0, , size = 1,\n        family = fontType) +\n    theme_classic() +\n    #annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\) +\n    theme(\n      # legend.position = \\none\\,\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n    ) +\n  xlab(\\Loop score\\nG1.DMSO\\) +\n    ylab(\\Loop score\\nG1.dTAG\\)\n  \n  \n  \n  num.up <- (summary(data$updown_A485_DMSO))[\\UP\\]\n  num.no <- (summary(data$updown_A485_DMSO))[\\NO\\]\n  num.down <- (summary(data$updown_A485_DMSO))[\\DOWN\\]\n  num.all <- num.up + num.no + num.down\n  perc.up <- round(num.up / num.all * 100, 2)\n  perc.no <- round(num.no / num.all * 100, 2)\n  perc.down <- round(num.down / num.all * 100, 2)\n  \n  data$density <- get_density(data$DMSO, data$A485, n = 100)\n  data <- data %>% dplyr::arrange(density)\n  correlation <- cor(data$DMSO, data$A485)\n  p2 <- ggplot(data, aes(x = DMSO, y = A485, color = density)) +\n    geom_point(size = 1,\n      alpha = 1,\n      stroke = 0) + \n    scale_color_viridis(option = \\D\\, guide = guide_colorbar(\n                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n                          barheight = 15/5.08   # Adjust height of the color bar\n                        )) +\n    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\,\n      color = \\black\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\) +\n    annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n             color = \\black\\, hjust = 0, size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n             color = \\black\\, hjust = 0, size = 1,\n        family = fontType) +\n    annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n             color = \\black\\, hjust = 0, size = 1,\n        family = fontType) +\n    theme_classic() + \n    # annotate(\\text\\, x = -0.5, y = 1, label = paste(\\r =\\, round(correlation, 2)), size = 5, color = \\black\\) +\n    theme(\n      # legend.position = \\none\\,\n      plot.title = element_text(\n        hjust = 0.5,\n        size = fontSizeS,\n        family = fontType\n      ),\n      axis.title = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS,\n        family = fontType,\n        color = \\#000000\\\n      ),\n      axis.line = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\,\n        size = lineThick*mmToLineUnit,\n        lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n    ) +\n    xlab(\\Loop score\\nG1.DMSO\\) +\n    ylab(\\Loop score\\nG1.A485\\)\n\n    width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.5)*mmToInch  \n  \n  fileName <- here(figDir,paste0(\\scatterplot_\\, name, \\_dTAG_vs_DMSO_\\, diffCutoff))\n\n  svglite(paste0(fileName, \\.svg\\), width = width, height =height)\n  print(p1)\n  dev.off()\n  png(paste0(fileName, \\.png\\), width = width, height =height, res = 600, unit = \\in\\)\n  print(p1)\n  dev.off()\n  \n    fileName <- here(figDir, paste0(\\scatterplot_\\, name, \\_A485_vs_DMSO_\\, diffCutoff))\n\n  svglite(paste0(fileName, \\.svg\\), width = width, height =height)\n  print(p2)\n  dev.off()\n  png(paste0(fileName, \\.png\\), width = width, height =height, res = 600, unit = \\in\\)\n  print(p2)\n  dev.off()\n  \n  # \n  # \n  # \n  # png(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 5*1.5, height = 2.5*1.5)\n  # print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  # dev.off()\n  # \n  # svglite(here(figDir, paste0(fileName, \\.svg\\)), \n  #         width = 5*1.5, height = 2.5*1.5)\n  # print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  # dev.off()\n}\n\nmake_diff_bedpe <- function(data, name, Anno2List, outDir, diffCutoff){\n  data <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\))) %>%\n    dplyr::filter(Anno2 %in% Anno2List)\n  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n  \n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \\UP\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_dTAGvsDMSO_UP_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \\NO\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_dTAGvsDMSO_NO_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \\DOWN\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_dTAGvsDMSO_DOWN_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  \n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \\UP\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_A485vsDMSO_UP_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \\NO\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_A485vsDMSO_NO_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \\DOWN\\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \\_A485vsDMSO_DOWN_diff\\, diffCutoff, \\.bedpe\\)), \n         sep = \\\\t\\, col.names = FALSE)\n}\n\ncreate_dist_vs_avgScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){\n  avg_scores_long <- data %>%\n    group_by(distance, Anno2) %>%\n    summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n    ungroup() \n  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + \n    geom_smooth(show.legend = TRUE, se = se)  +\n    ylim(0, 0.5) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = colorList) +\n    scale_fill_manual(values = colorList) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Score\\) +\n    theme(plot.title = element_text(size = 8))\n  \n  fileName <- paste0(\\dist_vs_score_linePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 4, height = 3)\n  print(p4)\n  dev.off()\n} \n\ncreate_dist_vs_avgDiffScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){\n  avg_scores_long <- data %>%\n    group_by(distance, Anno2) %>%\n    summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n    ungroup() \n  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + \n    geom_hline(yintercept = 0) +\n    geom_smooth(show.legend = TRUE, se = se)  +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = colorList) +\n    scale_fill_manual(values = colorList) +\n    labs(title = paste0(name),\n         x = \\Distance\\,\n         y = \\Average Diff Score\\) +\n    theme(plot.title = element_text(size = 8)) \n  \n  fileName <- paste0(\\dist_vs_score_difflinePlot_\\, name)\n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 4, height = 3)\n  print(p4)\n  dev.off()\n} \n\ncreate_score_barplot_perTreatment <- function(data, figDir, name, loopList, colorList){\n  data$Anno2 <- factor(data$Anno2, levels = loopList)\n  \n  p3 <- ggplot(data, aes(x = Anno2, y = score)) +\n    geom_violin(aes(fill = Anno2), show.legend = FALSE) +\n    scale_fill_manual(values = colorList) +\n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    ylim(-0.5, 1) +\n    geom_hline(yintercept = 0, linetype = \\dashed\\, color = \\grey\\) +\n    theme_classic() +\n    ggtitle(name) +\n    theme(plot.title = element_text(size = 4))\n  \n  fileName <- paste0(\\score_barPlot_\\, name)\n  \n  png(here(figDir, paste0(fileName, \\.png\\)), \n      res = 600, units = \\in\\, width = 2, height = 4)\n  print(p3)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 2, height = 4)\n  print(p3)\n}\n\n\niterate_loop_functions <- function(data, figDir, groupName, annoList){\n  # create_loop_dis_vs_score(data, figDir, groupName, annoList)\n  # create_loop_dis_vs_diffscore(data, figDir, groupName, annoList)\n\n  create_loop_scatterplot(data, figDir, groupName, annoList, 0.2)\n  # create_loop_scatterplot(data, figDir, groupName, annoList, 0.1)\n  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.2)\n  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.1)\n}\n```\n```"} -->

```r
```r
create_loop_dis_vs_score <- function(data, figDir, name, Anno2List){
  data = data %>% dplyr::filter(Anno2 %in% Anno2List)
  
  ### barplot
  temp <- data %>% dplyr::select(id, DMSO, dTAG, A485) %>%
    pivot_longer(!id, names_to = \treatment\, values_to = \score\)
  temp$treatment <- factor(temp$treatment, levels = c(\DMSO\, \dTAG\, \A485\))
  
  p3 <- ggplot(temp, aes(x = treatment, y = score)) +
    geom_violin(aes(fill = treatment), show.legend = FALSE) +
    scale_fill_manual(values = c(\DMSO\ = \grey\, \dTAG\ = \pink\, \A485\ = \skyblue\)) +
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    ylim(-0.5, 1) +
    geom_hline(yintercept = 0, linetype = \dashed\, color = \grey\) +
    theme_classic() +
    ggtitle(name) +
    theme(plot.title = element_text(size = 4))
  fileName <- paste0(\score_barplot_\, name)
  png(here(figDir, paste0(fileName, \.png\)), 
      res = 600, units = \in\, width = 2, height = 4)
  print(p3)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 2, height = 4)
  print(p3)
  dev.off()
  
  ### Distance vs score
  
  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, dTAG, A485)

  avg_scores <- temp %>%
    group_by(distance) %>%
    summarise(across(starts_with(\DMSO\):starts_with(\A485\), mean, na.rm = TRUE))

  avg_scores_long <- avg_scores %>%
    pivot_longer(cols = DMSO:A485, names_to = \condition\, values_to = \avg_score\)
  avg_scores_long$condition <- factor(avg_scores_long$condition, levels = c(\DMSO\, \dTAG\, \A485\))
  # Create the plot
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +
    geom_smooth(show.legend = TRUE) + ylim(0, 0.5) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = c(\DMSO\ = \grey\, \dTAG\ = \pink\, \A485\ = \skyblue\)) +
    scale_fill_manual(values = c(\DMSO\ = \grey80\, \dTAG\ = \pink\, \A485\ = \skyblue\)) +
    labs(title = paste0(name),
         x = \Distance\,
         y = \Average Score\) +
    theme(plot.title = element_text(size = 5))
  fileName <- paste0(\dist_vs_score_linePlot_\, name)
  png(here(figDir, paste0(fileName, \.png\)),
      res = 600, units = \in\, width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),
      width = 4, height = 3)
  print(p4)
  dev.off()
}

create_loop_dis_vs_diffscore <- function(data, figDir, name, Anno2List){
  data = data %>% dplyr::filter(Anno2 %in% Anno2List)
  
  
  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, diff_A485_DMSO)
  
  avg_scores <- temp %>%
    group_by(distance) %>%
    summarise(across(1:2, mean, na.rm = TRUE))
  
  avg_scores_long <- avg_scores %>%
    pivot_longer(cols = 2:3, names_to = \condition\, values_to = \avg_score\)
  avg_scores_long$condition <- factor(avg_scores_long$condition, 
                                      levels = c(\diff_dTAG_DMSO\, \diff_A485_DMSO\))
  # Create the plot
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +
    geom_smooth(show.legend = TRUE) + geom_hline(yintercept = 0) + ylim(-0.5, 0.1) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = c(\diff_dTAG_DMSO\ = \pink\, \diff_A485_DMSO\ = \skyblue\)) +
    scale_fill_manual(values = c(\diff_dTAG_DMSO\ = \pink\, \diff_A485_DMSO\ = \skyblue\)) +
    labs(title = paste0(name),
         x = \Distance\,
         y = \Average Diff Score\) +
    theme(plot.title = element_text(size = 5))
  fileName <- paste0(\dist_vs_score_difflinePlot_\, name)
  png(here(figDir, paste0(fileName, \.png\)),
      res = 600, units = \in\, width = 4.5, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),
          width = 4.5, height = 3)
  print(p4)
  dev.off()
}

create_loop_scatterplot <- function(data, figDir, name, Anno2List, diffCutoff){
  data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\))) %>%
    dplyr::filter(Anno2 %in% Anno2List)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  
  num.up <- (summary(data$updown_dTAG_DMSO))[\UP\]
  num.no <- (summary(data$updown_dTAG_DMSO))[\NO\]
  num.down <- (summary(data$updown_dTAG_DMSO))[\DOWN\]
  num.all <- num.up + num.no + num.down
  perc.up <- round(num.up / num.all * 100, 2)
  perc.no <- round(num.no / num.all * 100, 2)
  perc.down <- round(num.down / num.all * 100, 2)
  
  ### Scatterplot
  data$density <- get_density(data$DMSO, data$dTAG, n = 100)
  data <- data %>% dplyr::arrange(density)
  correlation <- cor(data$DMSO, data$dTAG)
  p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +
    geom_point(size = 1,
      alpha = 1,
      stroke = 0) + 
    scale_color_viridis(option = \D\, guide = guide_colorbar(
                          barwidth = 1.5/5.08,  # Adjust width of the color bar
                          barheight = 15/5.08   # Adjust height of the color bar
                        )) +
    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    annotate(\text\, x = -0.5, y = 1, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
             color = \black\, hjust = 0, , size = 1,
        family = fontType) +
    annotate(\text\, x = -0.5, y = 1-0.1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
             color = \black\, hjust = 0, , size = 1,
        family = fontType) +
    annotate(\text\, x = -0.5, y = 1-0.2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
             color = \black\, hjust = 0, , size = 1,
        family = fontType) +
    theme_classic() +
    #annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\) +
    theme(
      # legend.position = \none\,
      plot.title = element_text(
        hjust = 0.5,
        size = fontSizeS,
        family = fontType
      ),
      axis.title = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.line = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
    ) +
  xlab(\Loop score\nG1.DMSO\) +
    ylab(\Loop score\nG1.dTAG\)
  
  
  
  num.up <- (summary(data$updown_A485_DMSO))[\UP\]
  num.no <- (summary(data$updown_A485_DMSO))[\NO\]
  num.down <- (summary(data$updown_A485_DMSO))[\DOWN\]
  num.all <- num.up + num.no + num.down
  perc.up <- round(num.up / num.all * 100, 2)
  perc.no <- round(num.no / num.all * 100, 2)
  perc.down <- round(num.down / num.all * 100, 2)
  
  data$density <- get_density(data$DMSO, data$A485, n = 100)
  data <- data %>% dplyr::arrange(density)
  correlation <- cor(data$DMSO, data$A485)
  p2 <- ggplot(data, aes(x = DMSO, y = A485, color = density)) +
    geom_point(size = 1,
      alpha = 1,
      stroke = 0) + 
    scale_color_viridis(option = \D\, guide = guide_colorbar(
                          barwidth = 1.5/5.08,  # Adjust width of the color bar
                          barheight = 15/5.08   # Adjust height of the color bar
                        )) +
    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\,
      color = \black\,
      size = lineThick*mmToLineUnit,
      lineend = \square\) +
    annotate(\text\, x = -0.5, y = 1, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
             color = \black\, hjust = 0, size = 1,
        family = fontType) +
    annotate(\text\, x = -0.5, y = 1-0.1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
             color = \black\, hjust = 0, size = 1,
        family = fontType) +
    annotate(\text\, x = -0.5, y = 1-0.2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
             color = \black\, hjust = 0, size = 1,
        family = fontType) +
    theme_classic() + 
    # annotate(\text\, x = -0.5, y = 1, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\) +
    theme(
      # legend.position = \none\,
      plot.title = element_text(
        hjust = 0.5,
        size = fontSizeS,
        family = fontType
      ),
      axis.title = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS,
        family = fontType,
        color = \#000000\
      ),
      axis.line = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\,
        size = lineThick*mmToLineUnit,
        lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
    ) +
    xlab(\Loop score\nG1.DMSO\) +
    ylab(\Loop score\nG1.A485\)

    width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.5)*mmToInch  
  
  fileName <- here(figDir,paste0(\scatterplot_\, name, \_dTAG_vs_DMSO_\, diffCutoff))

  svglite(paste0(fileName, \.svg\), width = width, height =height)
  print(p1)
  dev.off()
  png(paste0(fileName, \.png\), width = width, height =height, res = 600, unit = \in\)
  print(p1)
  dev.off()
  
    fileName <- here(figDir, paste0(\scatterplot_\, name, \_A485_vs_DMSO_\, diffCutoff))

  svglite(paste0(fileName, \.svg\), width = width, height =height)
  print(p2)
  dev.off()
  png(paste0(fileName, \.png\), width = width, height =height, res = 600, unit = \in\)
  print(p2)
  dev.off()
  
  # 
  # 
  # 
  # png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 5*1.5, height = 2.5*1.5)
  # print(cowplot::plot_grid(p1, p2, align = \h\))
  # dev.off()
  # 
  # svglite(here(figDir, paste0(fileName, \.svg\)), 
  #         width = 5*1.5, height = 2.5*1.5)
  # print(cowplot::plot_grid(p1, p2, align = \h\))
  # dev.off()
}

make_diff_bedpe <- function(data, name, Anno2List, outDir, diffCutoff){
  data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\))) %>%
    dplyr::filter(Anno2 %in% Anno2List)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \UP\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_dTAGvsDMSO_UP_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \NO\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_dTAGvsDMSO_NO_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \DOWN\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_dTAGvsDMSO_DOWN_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \UP\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_A485vsDMSO_UP_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \NO\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_A485vsDMSO_NO_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \DOWN\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_A485vsDMSO_DOWN_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
}

create_dist_vs_avgScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){
  avg_scores_long <- data %>%
    group_by(distance, Anno2) %>%
    summarise(avg_score = mean(score, na.rm = TRUE)) %>%
    ungroup() 
  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + 
    geom_smooth(show.legend = TRUE, se = se)  +
    ylim(0, 0.5) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = colorList) +
    scale_fill_manual(values = colorList) +
    labs(title = paste0(name),
         x = \Distance\,
         y = \Average Score\) +
    theme(plot.title = element_text(size = 8))
  
  fileName <- paste0(\dist_vs_score_linePlot_\, name)
  png(here(figDir, paste0(fileName, \.png\)), 
      res = 600, units = \in\, width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 4, height = 3)
  print(p4)
  dev.off()
} 

create_dist_vs_avgDiffScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){
  avg_scores_long <- data %>%
    group_by(distance, Anno2) %>%
    summarise(avg_score = mean(score, na.rm = TRUE)) %>%
    ungroup() 
  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + 
    geom_hline(yintercept = 0) +
    geom_smooth(show.legend = TRUE, se = se)  +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = colorList) +
    scale_fill_manual(values = colorList) +
    labs(title = paste0(name),
         x = \Distance\,
         y = \Average Diff Score\) +
    theme(plot.title = element_text(size = 8)) 
  
  fileName <- paste0(\dist_vs_score_difflinePlot_\, name)
  png(here(figDir, paste0(fileName, \.png\)), 
      res = 600, units = \in\, width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 4, height = 3)
  print(p4)
  dev.off()
} 

create_score_barplot_perTreatment <- function(data, figDir, name, loopList, colorList){
  data$Anno2 <- factor(data$Anno2, levels = loopList)
  
  p3 <- ggplot(data, aes(x = Anno2, y = score)) +
    geom_violin(aes(fill = Anno2), show.legend = FALSE) +
    scale_fill_manual(values = colorList) +
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    ylim(-0.5, 1) +
    geom_hline(yintercept = 0, linetype = \dashed\, color = \grey\) +
    theme_classic() +
    ggtitle(name) +
    theme(plot.title = element_text(size = 4))
  
  fileName <- paste0(\score_barPlot_\, name)
  
  png(here(figDir, paste0(fileName, \.png\)), 
      res = 600, units = \in\, width = 2, height = 4)
  print(p3)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 2, height = 4)
  print(p3)
}


iterate_loop_functions <- function(data, figDir, groupName, annoList){
  # create_loop_dis_vs_score(data, figDir, groupName, annoList)
  # create_loop_dis_vs_diffscore(data, figDir, groupName, annoList)

  create_loop_scatterplot(data, figDir, groupName, annoList, 0.2)
  # create_loop_scatterplot(data, figDir, groupName, annoList, 0.1)
  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.2)
  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.1)
}
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### Pure-reg vs Str-reg

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5uYW1lIDwtIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVwiXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXCIudHN2XCIpKSlcblxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcIl9cIiwgXCJjbF9hbGxcIiksIHVuaXF1ZShkYXRhJEFubm8yKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXCJfXCIsIFwiY2xfc3RydWN0dXJlXCIpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgYyhcIlMtU1wiLCBcIlMtWFwiKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXCJfXCIsIFwicy1zXCIpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgYyhcIlMtU1wiKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXCJfXCIsIFwiY2xfcmVndWxhdG9yeVwiKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXCJQLVBcIiwgXCJQLUVcIiwgXCJQLVNcIiwgXCJQLVhcIiwgXCJFLUVcIiwgXCJFLVNcIiwgXCJFLVhcIikpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFwiX1wiLCBcImNsX3BlLXBlXCIpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgYyhcIlAtUFwiLCBcIlAtRVwiLCBcIkUtRVwiKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXCJfXCIsIFwicC1wZVwiKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXCJQLVBcIiwgXCJQLUVcIikpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFwiX1wiLCBcInAtcFwiKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXCJQLVBcIikpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFwiX1wiLCBcInAtZVwiKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXCJQLUVcIikpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFwiX1wiLCBcImUtZVwiKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXCJFLUVcIikpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFwiX1wiLCBcIngteFwiKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXCJYLVhcIikpXG4jIyMjIyMjIyMjI1xuIyBDcmVhdGluZyBkaWZmZXJlbnRpYWwgc2NhdHRlcnBsb3RcblZpZXcoZGF0YSlcblxuXG5cbiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG4jIENyZWF0aW5nIGZpZ3VyZXMgcGVyIGVhY2ggY29uZGl0aW9uXG5uYW1lIDwtIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVwiXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXCIudHN2XCIpKSlcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIERNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcImRpc3RhbmNlXCIsIFwic2NvcmVcIiwgXCJBbm5vMlwiKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFwiX0RNU09cIiksIGMoXCJYLVhcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJTLVhcIiwgXCJTLVNcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJFLVhcIixcIkUtU1wiLFwiRS1FXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiUC1FXCIsXCJQLVhcIiwgXCJQLVNcIiwgXCJQLVBcIiksIGNvbG9yTGlzdExvb3ApXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBkVEFHLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXCJkaXN0YW5jZVwiLCBcInNjb3JlXCIsIFwiQW5ubzJcIilcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcIl9kVEFHXCIpLCBjKFwiWC1YXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiUy1YXCIsIFwiUy1TXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiRS1YXCIsXCJFLVNcIixcIkUtRVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIlAtRVwiLFwiUC1YXCIsIFwiUC1TXCIsIFwiUC1QXCIpLCBjb2xvckxpc3RMb29wKVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBBNDg1LCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXCJkaXN0YW5jZVwiLCBcInNjb3JlXCIsIFwiQW5ubzJcIilcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcIl9BNDg1XCIpLCBjKFwiWC1YXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiUy1YXCIsIFwiUy1TXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiRS1YXCIsXCJFLVNcIixcIkUtRVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIlAtRVwiLFwiUC1YXCIsIFwiUC1TXCIsIFwiUC1QXCIpLCBjb2xvckxpc3RMb29wKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBDcmVhdGluZyBmaWd1cmVzIHBlciBlYWNoIGNvbmRpdGlvbiwgZGlmZmVyZW50aWFsXG5uYW1lIDwtIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVwiXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXCIudHN2XCIpKSlcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRpZmZfZFRBR19ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXCJkaXN0YW5jZVwiLCBcInNjb3JlXCIsIFwiQW5ubzJcIilcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXCJfZFRBR1wiKSwgYyhcIlgtWFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIlMtWFwiLCBcIlMtU1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIkUtWFwiLFwiRS1TXCIsXCJFLUVcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJQLUVcIixcIlAtWFwiLCBcIlAtU1wiLCBcIlAtUFwiKSwgY29sb3JMaXN0TG9vcClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXCJfZFRBR19TRVwiKSwgYyhcIlgtWFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIlMtWFwiLCBcIlMtU1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIkUtWFwiLFwiRS1TXCIsXCJFLUVcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJQLUVcIixcIlAtWFwiLCBcIlAtU1wiLCBcIlAtUFwiKSwgY29sb3JMaXN0TG9vcCwgc2UgPSBUUlVFKVxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiLnRzdlwiKSkpXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBkaWZmX0E0ODVfRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFwiZGlzdGFuY2VcIiwgXCJzY29yZVwiLCBcIkFubm8yXCIpXG5jcmVhdGVfZGlzdF92c19hdmdEaWZmU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFwiX0E0ODVcIiksIGMoXCJYLVhcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJTLVhcIiwgXCJTLVNcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJFLVhcIixcIkUtU1wiLFwiRS1FXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiUC1FXCIsXCJQLVhcIiwgXCJQLVNcIiwgXCJQLVBcIiksIGNvbG9yTGlzdExvb3ApXG5cbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXCJfQTQ4NV9TRVwiKSwgYyhcIlgtWFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIlMtWFwiLCBcIlMtU1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIkUtWFwiLFwiRS1TXCIsXCJFLUVcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJQLUVcIixcIlAtWFwiLCBcIlAtU1wiLCBcIlAtUFwiKSwgY29sb3JMaXN0TG9vcCwgc2UgPSBUUlVFKVxuYGBgIn0= -->\n\n```r\n\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\n\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\cl_all\\), unique(data$Anno2))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\cl_structure\\), \n                       c(\\S-S\\, \\S-X\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\s-s\\), \n                       c(\\S-S\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\cl_regulatory\\), \n                       c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\, \\E-E\\, \\E-S\\, \\E-X\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\cl_pe-pe\\), \n                       c(\\P-P\\, \\P-E\\, \\E-E\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\p-pe\\), \n                       c(\\P-P\\, \\P-E\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\p-p\\), \n                       c(\\P-P\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\p-e\\), \n                       c(\\P-E\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\e-e\\), \n                       c(\\E-E\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\x-x\\), \n                       c(\\X-X\\))\n###########\n# Creating differential scatterplot\nView(data)\n\n\n\n#######################\n# Creating figures per each condition\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ntemp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)\ncolnames(temp) <- c(\\distance\\, \\score\\, \\Anno2\\)\ncreate_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \\_DMSO\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop)\ntemp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)\ncolnames(temp) <- c(\\distance\\, \\score\\, \\Anno2\\)\ncreate_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \\_dTAG\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop)\n\ntemp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)\ncolnames(temp) <- c(\\distance\\, \\score\\, \\Anno2\\)\ncreate_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \\_A485\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop)\n\n#######################\n# Creating figures per each condition, differential\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ntemp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)\ncolnames(temp) <- c(\\distance\\, \\score\\, \\Anno2\\)\ncreate_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \\_dTAG\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop)\ncreate_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \\_dTAG_SE\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop, se = TRUE)\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ntemp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)\ncolnames(temp) <- c(\\distance\\, \\score\\, \\Anno2\\)\ncreate_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \\_A485\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop)\n\ncreate_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \\_A485_SE\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop, se = TRUE)\n```\n\n<!-- rnb-source-end -->\n"} -->

name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

iterate_loop_functions(data, figDir, paste0(name, \_\, \cl_all\), unique(data$Anno2))
iterate_loop_functions(data, figDir, paste0(name, \_\, \cl_structure\), 
                       c(\S-S\, \S-X\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \s-s\), 
                       c(\S-S\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \cl_regulatory\), 
                       c(\P-P\, \P-E\, \P-S\, \P-X\, \E-E\, \E-S\, \E-X\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \cl_pe-pe\), 
                       c(\P-P\, \P-E\, \E-E\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \p-pe\), 
                       c(\P-P\, \P-E\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \p-p\), 
                       c(\P-P\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \p-e\), 
                       c(\P-E\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \e-e\), 
                       c(\E-E\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \x-x\), 
                       c(\X-X\))
###########
# Creating differential scatterplot
View(data)



#######################
# Creating figures per each condition
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_DMSO\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_A485\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop)

#######################
# Creating figures per each condition, differential
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_dTAG_SE\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop, se = TRUE)
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_A485\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop)

create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_A485_SE\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop, se = TRUE)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcblxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxjbF9hbGxcXCksIHVuaXF1ZShkYXRhJEFubm8yKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxcY2xfc3RydWN0dXJlXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgYyhcXFMtU1xcLCBcXFMtWFxcKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxccy1zXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgYyhcXFMtU1xcKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxcY2xfcmVndWxhdG9yeVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCwgXFxFLUVcXCwgXFxFLVNcXCwgXFxFLVhcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXGNsX3BlLXBlXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxccC1wZVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXFxQLVBcXCwgXFxQLUVcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXHAtcFxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXFxQLVBcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXHAtZVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXFxQLUVcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXGUtZVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXFxFLUVcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXHgteFxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXFxYLVhcXCkpXG4jIyMjIyMjIyMjI1xuIyBDcmVhdGluZyBkaWZmZXJlbnRpYWwgc2NhdHRlcnBsb3RcblZpZXcoZGF0YSlcblxuXG5cbiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG4jIENyZWF0aW5nIGZpZ3VyZXMgcGVyIGVhY2ggY29uZGl0aW9uXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIERNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0RNU09cXCksIGMoXFxYLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxTLVhcXCwgXFxTLVNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxFLVhcXCxcXEUtU1xcLFxcRS1FXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcUC1FXFwsXFxQLVhcXCwgXFxQLVNcXCwgXFxQLVBcXCksIGNvbG9yTGlzdExvb3ApXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBkVEFHLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHXFwpLCBjKFxcWC1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcUy1YXFwsIFxcUy1TXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcRS1YXFwsXFxFLVNcXCxcXEUtRVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFAtRVxcLFxcUC1YXFwsIFxcUC1TXFwsIFxcUC1QXFwpLCBjb2xvckxpc3RMb29wKVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBBNDg1LCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9BNDg1XFwpLCBjKFxcWC1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcUy1YXFwsIFxcUy1TXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcRS1YXFwsXFxFLVNcXCxcXEUtRVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFAtRVxcLFxcUC1YXFwsIFxcUC1TXFwsIFxcUC1QXFwpLCBjb2xvckxpc3RMb29wKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBDcmVhdGluZyBmaWd1cmVzIHBlciBlYWNoIGNvbmRpdGlvbiwgZGlmZmVyZW50aWFsXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRpZmZfZFRBR19ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfZFRBR1xcKSwgYyhcXFgtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFMtWFxcLCBcXFMtU1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXEUtWFxcLFxcRS1TXFwsXFxFLUVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxQLUVcXCxcXFAtWFxcLCBcXFAtU1xcLCBcXFAtUFxcKSwgY29sb3JMaXN0TG9vcClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfZFRBR19TRVxcKSwgYyhcXFgtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFMtWFxcLCBcXFMtU1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXEUtWFxcLFxcRS1TXFwsXFxFLUVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxQLUVcXCxcXFAtWFxcLCBcXFAtU1xcLCBcXFAtUFxcKSwgY29sb3JMaXN0TG9vcCwgc2UgPSBUUlVFKVxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBkaWZmX0E0ODVfRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdEaWZmU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0E0ODVcXCksIGMoXFxYLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxTLVhcXCwgXFxTLVNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxFLVhcXCxcXEUtU1xcLFxcRS1FXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcUC1FXFwsXFxQLVhcXCwgXFxQLVNcXCwgXFxQLVBcXCksIGNvbG9yTGlzdExvb3ApXG5cbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NV9TRVxcKSwgYyhcXFgtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFMtWFxcLCBcXFMtU1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXEUtWFxcLFxcRS1TXFwsXFxFLUVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxQLUVcXCxcXFAtWFxcLCBcXFAtU1xcLCBcXFAtUFxcKSwgY29sb3JMaXN0TG9vcCwgc2UgPSBUUlVFKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\n\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\cl_all\\), unique(data$Anno2))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\cl_structure\\), \n                       c(\\S-S\\, \\S-X\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\s-s\\), \n                       c(\\S-S\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\cl_regulatory\\), \n                       c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\, \\E-E\\, \\E-S\\, \\E-X\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\cl_pe-pe\\), \n                       c(\\P-P\\, \\P-E\\, \\E-E\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\p-pe\\), \n                       c(\\P-P\\, \\P-E\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\p-p\\), \n                       c(\\P-P\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\p-e\\), \n                       c(\\P-E\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\e-e\\), \n                       c(\\E-E\\))\niterate_loop_functions(data, figDir, paste0(name, \\_\\, \\x-x\\), \n                       c(\\X-X\\))\n###########\n# Creating differential scatterplot\nView(data)\n\n\n\n#######################\n# Creating figures per each condition\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ntemp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)\ncolnames(temp) <- c(\\distance\\, \\score\\, \\Anno2\\)\ncreate_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \\_DMSO\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop)\ntemp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)\ncolnames(temp) <- c(\\distance\\, \\score\\, \\Anno2\\)\ncreate_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \\_dTAG\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop)\n\ntemp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)\ncolnames(temp) <- c(\\distance\\, \\score\\, \\Anno2\\)\ncreate_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \\_A485\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop)\n\n#######################\n# Creating figures per each condition, differential\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ntemp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)\ncolnames(temp) <- c(\\distance\\, \\score\\, \\Anno2\\)\ncreate_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \\_dTAG\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop)\ncreate_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \\_dTAG_SE\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop, se = TRUE)\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ntemp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)\ncolnames(temp) <- c(\\distance\\, \\score\\, \\Anno2\\)\ncreate_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \\_A485\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop)\n\ncreate_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \\_A485_SE\\), c(\\X-X\\,\n                                                                 \\S-X\\, \\S-S\\,\n                                                                 \\E-X\\,\\E-S\\,\\E-E\\,\n                                                                 \\P-E\\,\\P-X\\, \\P-S\\, \\P-P\\), colorListLoop, se = TRUE)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcblxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxjbF9hbGxcXCksIHVuaXF1ZShkYXRhJEFubm8yKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxcY2xfc3RydWN0dXJlXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgYyhcXFMtU1xcLCBcXFMtWFxcKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxccy1zXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgYyhcXFMtU1xcKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxcY2xfcmVndWxhdG9yeVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCwgXFxFLUVcXCwgXFxFLVNcXCwgXFxFLVhcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXGNsX3BlLXBlXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxccC1wZVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXFxQLVBcXCwgXFxQLUVcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXHAtcFxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXFxQLVBcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXHAtZVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXFxQLUVcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXGUtZVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXFxFLUVcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXHgteFxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgIGMoXFxYLVhcXCkpXG4jIyMjIyMjIyMjI1xuIyBDcmVhdGluZyBkaWZmZXJlbnRpYWwgc2NhdHRlcnBsb3RcblZpZXcoZGF0YSlcblxuXG5cbiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG4jIENyZWF0aW5nIGZpZ3VyZXMgcGVyIGVhY2ggY29uZGl0aW9uXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIERNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0RNU09cXCksIGMoXFxYLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxTLVhcXCwgXFxTLVNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxFLVhcXCxcXEUtU1xcLFxcRS1FXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcUC1FXFwsXFxQLVhcXCwgXFxQLVNcXCwgXFxQLVBcXCksIGNvbG9yTGlzdExvb3ApXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBkVEFHLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHXFwpLCBjKFxcWC1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcUy1YXFwsIFxcUy1TXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcRS1YXFwsXFxFLVNcXCxcXEUtRVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFAtRVxcLFxcUC1YXFwsIFxcUC1TXFwsIFxcUC1QXFwpLCBjb2xvckxpc3RMb29wKVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBBNDg1LCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9BNDg1XFwpLCBjKFxcWC1YXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcUy1YXFwsIFxcUy1TXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcRS1YXFwsXFxFLVNcXCxcXEUtRVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFAtRVxcLFxcUC1YXFwsIFxcUC1TXFwsIFxcUC1QXFwpLCBjb2xvckxpc3RMb29wKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBDcmVhdGluZyBmaWd1cmVzIHBlciBlYWNoIGNvbmRpdGlvbiwgZGlmZmVyZW50aWFsXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRpZmZfZFRBR19ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfZFRBR1xcKSwgYyhcXFgtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFMtWFxcLCBcXFMtU1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXEUtWFxcLFxcRS1TXFwsXFxFLUVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxQLUVcXCxcXFAtWFxcLCBcXFAtU1xcLCBcXFAtUFxcKSwgY29sb3JMaXN0TG9vcClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfZFRBR19TRVxcKSwgYyhcXFgtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFMtWFxcLCBcXFMtU1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXEUtWFxcLFxcRS1TXFwsXFxFLUVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxQLUVcXCxcXFAtWFxcLCBcXFAtU1xcLCBcXFAtUFxcKSwgY29sb3JMaXN0TG9vcCwgc2UgPSBUUlVFKVxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBkaWZmX0E0ODVfRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdEaWZmU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0E0ODVcXCksIGMoXFxYLVhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxTLVhcXCwgXFxTLVNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxFLVhcXCxcXEUtU1xcLFxcRS1FXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcUC1FXFwsXFxQLVhcXCwgXFxQLVNcXCwgXFxQLVBcXCksIGNvbG9yTGlzdExvb3ApXG5cbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NV9TRVxcKSwgYyhcXFgtWFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFMtWFxcLCBcXFMtU1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXEUtWFxcLFxcRS1TXFwsXFxFLUVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxQLUVcXCxcXFAtWFxcLCBcXFAtU1xcLCBcXFAtUFxcKSwgY29sb3JMaXN0TG9vcCwgc2UgPSBUUlVFKVxuYGBgXG5gYGAifQ== -->

```r
```r

name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

iterate_loop_functions(data, figDir, paste0(name, \_\, \cl_all\), unique(data$Anno2))
iterate_loop_functions(data, figDir, paste0(name, \_\, \cl_structure\), 
                       c(\S-S\, \S-X\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \s-s\), 
                       c(\S-S\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \cl_regulatory\), 
                       c(\P-P\, \P-E\, \P-S\, \P-X\, \E-E\, \E-S\, \E-X\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \cl_pe-pe\), 
                       c(\P-P\, \P-E\, \E-E\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \p-pe\), 
                       c(\P-P\, \P-E\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \p-p\), 
                       c(\P-P\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \p-e\), 
                       c(\P-E\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \e-e\), 
                       c(\E-E\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \x-x\), 
                       c(\X-X\))
###########
# Creating differential scatterplot
View(data)



#######################
# Creating figures per each condition
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_DMSO\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_A485\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop)

#######################
# Creating figures per each condition, differential
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_dTAG_SE\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop, se = TRUE)
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_A485\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop)

create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_A485_SE\), c(\X-X\,
                                                                 \S-X\, \S-S\,
                                                                 \E-X\,\E-S\,\E-E\,
                                                                 \P-E\,\P-X\, \P-S\, \P-P\), colorListLoop, se = TRUE)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



### [2.6] Comparing across samples for conesnsus loop
#### Functions

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiX0Fubm8zLnRzdlwiKSkpXG5kaWZmQ3V0b2ZmIDwtIDAuMlxuXG4jIFNwbGl0dGluZyBkYXRhXG5kYXRhLnJlZyA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8zID09IFwicmVnXCIpXG5kYXRhLnN0ciA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8zID09IFwic3RyXCIpXG5cbiMgVGFraW5nIGNvZGVzIGZyb20gcHJldmlvdXMgZnVuY3Rpb24gKHN0cilcbmRhdGEgPC0gZGF0YS5zdHJcbmRhdGEgPC0gZGF0YSAlPiVcbiAgZHBseXI6Om11dGF0ZSh1cGRvd25fZFRBR19ETVNPID0gaWZlbHNlKGRpZmZfZFRBR19ETVNPID4gZGlmZkN1dG9mZiwgXCJVUFwiLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcIk5PXCIsIFwiRE9XTlwiKSksXG4gICAgICAgICAgICAgICAgdXBkb3duX0E0ODVfRE1TTyA9IGlmZWxzZShkaWZmX0E0ODVfRE1TTyA+IGRpZmZDdXRvZmYsIFwiVVBcIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiAtZGlmZkN1dG9mZiwgXCJOT1wiLCBcIkRPV05cIikpKVxuZGF0YSR1cGRvd25fZFRBR19ETVNPIDwtIGZhY3RvcihkYXRhJHVwZG93bl9kVEFHX0RNU08sIGxldmVscyA9IGMoXCJVUFwiLCBcIk5PXCIsIFwiRE9XTlwiKSlcbmRhdGEkdXBkb3duX0E0ODVfRE1TTyA8LSBmYWN0b3IoZGF0YSR1cGRvd25fQTQ4NV9ETVNPLCBsZXZlbHMgPSBjKFwiVVBcIiwgXCJOT1wiLCBcIkRPV05cIikpXG5cbm51bS51cCA8LSAoc3VtbWFyeShkYXRhJHVwZG93bl9kVEFHX0RNU08pKVtcIlVQXCJdXG5udW0ubm8gPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXCJOT1wiXVxubnVtLmRvd24gPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXCJET1dOXCJdXG5udW0uYWxsIDwtIG51bS51cCArIG51bS5ubyArIG51bS5kb3duXG5wZXJjLnVwIDwtIHJvdW5kKG51bS51cCAvIG51bS5hbGwgKiAxMDAsIDIpXG5wZXJjLm5vIDwtIHJvdW5kKG51bS5ubyAvIG51bS5hbGwgKiAxMDAsIDIpXG5wZXJjLmRvd24gPC0gcm91bmQobnVtLmRvd24gLyBudW0uYWxsICogMTAwLCAyKVxuXG5kYXRhJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkoZGF0YSRETVNPLCBkYXRhJGRUQUcsIG4gPSAxMDApXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5wMSA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBETVNPLCB5ID0gZFRBRywgY29sb3IgPSBkZW5zaXR5KSkgK1xuICBnZW9tX3BvaW50KHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArXG4gIHhsaW0oLTAuNSwgMSkgKyB5bGltKC0wLjUsIDEpICsgY29vcmRfZml4ZWQoKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCwgY29sID0gXCJncmV5NTBcIiwgbGluZXR5cGUgPSBcImRhc2hlZFwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gLWRpZmZDdXRvZmYsIGNvbCA9IFwiZ3JleVwiLCBsaW5ldHlwZSA9IFwiZG90dGVkXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBjb2wgPSBcImdyZXlcIiwgbGluZXR5cGUgPSBcImRvdHRlZFwiKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFwiZ3JleVwiKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFwiZ3JleVwiKSArXG4gIGFubm90YXRlKFwidGV4dFwiLCB4ID0gLTAuNSwgeSA9IDEsIGxhYmVsID0gcGFzdGUwKFwiVVA6IFwiLCBudW0udXAsIFwiIChcIiwgcGVyYy51cCwgXCIlKVwiKSwgXG4gICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAzKSArXG4gIGFubm90YXRlKFwidGV4dFwiLCB4ID0gLTAuNSwgeSA9IDEtMC4xLCBsYWJlbCA9IHBhc3RlMChcIk5POiBcIiwgbnVtLm5vLCBcIiAoXCIsIHBlcmMubm8sIFwiJSlcIiksIFxuICAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IC0wLjUsIHkgPSAxLTAuMiwgbGFiZWwgPSBwYXN0ZTAoXCJET1dOOiBcIiwgbnVtLmRvd24sIFwiIChcIiwgcGVyYy5kb3duLCBcIiUpXCIpLCBcbiAgICAgICAgICAgY29sb3IgPSBcImJsYWNrXCIsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgdGhlbWVfY2xhc3NpYygpICsgZ2d0aXRsZShuYW1lKSArIHRoZW1lKHBsb3QudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDUpKVxuXG4jIFRha2luZyBjb2RlcyBmcm9tIHByZXZpb3VzIGZ1bmN0aW9uIChyZWcpXG5kYXRhIDwtIGRhdGEucmVnXG5kYXRhIDwtIGRhdGEgJT4lXG4gIGRwbHlyOjptdXRhdGUodXBkb3duX2RUQUdfRE1TTyA9IGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IGRpZmZDdXRvZmYsIFwiVVBcIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9kVEFHX0RNU08gPiAtZGlmZkN1dG9mZiwgXCJOT1wiLCBcIkRPV05cIikpLFxuICAgICAgICAgICAgICAgIHVwZG93bl9BNDg1X0RNU08gPSBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiBkaWZmQ3V0b2ZmLCBcIlVQXCIsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGRpZmZfQTQ4NV9ETVNPID4gLWRpZmZDdXRvZmYsIFwiTk9cIiwgXCJET1dOXCIpKSlcbmRhdGEkdXBkb3duX2RUQUdfRE1TTyA8LSBmYWN0b3IoZGF0YSR1cGRvd25fZFRBR19ETVNPLCBsZXZlbHMgPSBjKFwiVVBcIiwgXCJOT1wiLCBcIkRPV05cIikpXG5kYXRhJHVwZG93bl9BNDg1X0RNU08gPC0gZmFjdG9yKGRhdGEkdXBkb3duX0E0ODVfRE1TTywgbGV2ZWxzID0gYyhcIlVQXCIsIFwiTk9cIiwgXCJET1dOXCIpKVxuXG5udW0udXAgPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXCJVUFwiXVxubnVtLm5vIDwtIChzdW1tYXJ5KGRhdGEkdXBkb3duX2RUQUdfRE1TTykpW1wiTk9cIl1cbm51bS5kb3duIDwtIChzdW1tYXJ5KGRhdGEkdXBkb3duX2RUQUdfRE1TTykpW1wiRE9XTlwiXVxubnVtLmFsbCA8LSBudW0udXAgKyBudW0ubm8gKyBudW0uZG93blxucGVyYy51cCA8LSByb3VuZChudW0udXAgLyBudW0uYWxsICogMTAwLCAyKVxucGVyYy5ubyA8LSByb3VuZChudW0ubm8gLyBudW0uYWxsICogMTAwLCAyKVxucGVyYy5kb3duIDwtIHJvdW5kKG51bS5kb3duIC8gbnVtLmFsbCAqIDEwMCwgMilcblxuZGF0YSRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KGRhdGEkRE1TTywgZGF0YSRkVEFHLCBuID0gMTAwKVxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxucDIgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gRE1TTywgeSA9IGRUQUcsIGNvbG9yID0gZGVuc2l0eSkpICtcbiAgZ2VvbV9wb2ludChzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICBzY2FsZV9jb2xvcl92aXJpZGlzKCkgK1xuICB4bGltKC0wLjUsIDEpICsgeWxpbSgtMC41LCAxKSArIGNvb3JkX2ZpeGVkKCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDAsIGNvbCA9IFwiZ3JleTUwXCIsIGxpbmV0eXBlID0gXCJkYXNoZWRcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IC1kaWZmQ3V0b2ZmLCBjb2wgPSBcImdyZXlcIiwgbGluZXR5cGUgPSBcImRvdHRlZFwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgY29sID0gXCJncmV5XCIsIGxpbmV0eXBlID0gXCJkb3R0ZWRcIikgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcImdyZXlcIikgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcImdyZXlcIikgK1xuICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IC0wLjUsIHkgPSAxLCBsYWJlbCA9IHBhc3RlMChcIlVQOiBcIiwgbnVtLnVwLCBcIiAoXCIsIHBlcmMudXAsIFwiJSlcIiksIFxuICAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IC0wLjUsIHkgPSAxLTAuMSwgbGFiZWwgPSBwYXN0ZTAoXCJOTzogXCIsIG51bS5ubywgXCIgKFwiLCBwZXJjLm5vLCBcIiUpXCIpLCBcbiAgICAgICAgICAgY29sb3IgPSBcImJsYWNrXCIsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAtMC41LCB5ID0gMS0wLjIsIGxhYmVsID0gcGFzdGUwKFwiRE9XTjogXCIsIG51bS5kb3duLCBcIiAoXCIsIHBlcmMuZG93biwgXCIlKVwiKSwgXG4gICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAzKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUobmFtZSkgKyB0aGVtZShwbG90LnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA1KSkgIFxuICBcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwic2NhdHRlcnBsb3RfXCIsIG5hbWUsIFwiX1wiLCBkaWZmQ3V0b2ZmLCBcIl9wdXJlX3N0cl9yZWdcIilcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXRzID0gXCJpblwiLCB3aWR0aCA9IDUqMS41LCBoZWlnaHQgPSAyLjUqMS41KVxucHJpbnQoY293cGxvdDo6cGxvdF9ncmlkKHAxLCBwMiwgYWxpZ24gPSBcImhcIikpXG5kZXYub2ZmKClcblxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCBcbiAgICAgICAgd2lkdGggPSA1KjEuNSwgaGVpZ2h0ID0gMi41KjEuNSlcbnByaW50KGNvd3Bsb3Q6OnBsb3RfZ3JpZChwMSwgcDIsIGFsaWduID0gXCJoXCIpKVxuZGV2Lm9mZigpXG5gYGAifQ== -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\_Anno3.tsv\\)))\ndiffCutoff <- 0.2\n\n# Splitting data\ndata.reg <- data %>% dplyr::filter(Anno3 == \\reg\\)\ndata.str <- data %>% dplyr::filter(Anno3 == \\str\\)\n\n# Taking codes from previous function (str)\ndata <- data.str\ndata <- data %>%\n  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)))\ndata$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\ndata$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n\nnum.up <- (summary(data$updown_dTAG_DMSO))[\\UP\\]\nnum.no <- (summary(data$updown_dTAG_DMSO))[\\NO\\]\nnum.down <- (summary(data$updown_dTAG_DMSO))[\\DOWN\\]\nnum.all <- num.up + num.no + num.down\nperc.up <- round(num.up / num.all * 100, 2)\nperc.no <- round(num.no / num.all * 100, 2)\nperc.down <- round(num.down / num.all * 100, 2)\n\ndata$density <- get_density(data$DMSO, data$dTAG, n = 100)\ndata <- data %>% dplyr::arrange(density)\np1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point(show.legend = FALSE) + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))\n\n# Taking codes from previous function (reg)\ndata <- data.reg\ndata <- data %>%\n  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)))\ndata$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\ndata$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n\nnum.up <- (summary(data$updown_dTAG_DMSO))[\\UP\\]\nnum.no <- (summary(data$updown_dTAG_DMSO))[\\NO\\]\nnum.down <- (summary(data$updown_dTAG_DMSO))[\\DOWN\\]\nnum.all <- num.up + num.no + num.down\nperc.up <- round(num.up / num.all * 100, 2)\nperc.no <- round(num.no / num.all * 100, 2)\nperc.down <- round(num.down / num.all * 100, 2)\n\ndata$density <- get_density(data$DMSO, data$dTAG, n = 100)\ndata <- data %>% dplyr::arrange(density)\np2 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point(show.legend = FALSE) + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  \n  \n\nfileName <- paste0(\\scatterplot_\\, name, \\_\\, diffCutoff, \\_pure_str_reg\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 5*1.5, height = 2.5*1.5)\nprint(cowplot::plot_grid(p1, p2, align = \\h\\))\ndev.off()\n\nsvglite(here(figDir, paste0(fileName, \\.svg\\)), \n        width = 5*1.5, height = 2.5*1.5)\nprint(cowplot::plot_grid(p1, p2, align = \\h\\))\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \_Anno3.tsv\)))
diffCutoff <- 0.2

# Splitting data
data.reg <- data %>% dplyr::filter(Anno3 == \reg\)
data.str <- data %>% dplyr::filter(Anno3 == \str\)

# Taking codes from previous function (str)
data <- data.str
data <- data %>%
  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)))
data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))

num.up <- (summary(data$updown_dTAG_DMSO))[\UP\]
num.no <- (summary(data$updown_dTAG_DMSO))[\NO\]
num.down <- (summary(data$updown_dTAG_DMSO))[\DOWN\]
num.all <- num.up + num.no + num.down
perc.up <- round(num.up / num.all * 100, 2)
perc.no <- round(num.no / num.all * 100, 2)
perc.down <- round(num.down / num.all * 100, 2)

data$density <- get_density(data$DMSO, data$dTAG, n = 100)
data <- data %>% dplyr::arrange(density)
p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  annotate(\text\, x = -0.5, y = 1, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))

# Taking codes from previous function (reg)
data <- data.reg
data <- data %>%
  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)))
data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))

num.up <- (summary(data$updown_dTAG_DMSO))[\UP\]
num.no <- (summary(data$updown_dTAG_DMSO))[\NO\]
num.down <- (summary(data$updown_dTAG_DMSO))[\DOWN\]
num.all <- num.up + num.no + num.down
perc.up <- round(num.up / num.all * 100, 2)
perc.no <- round(num.no / num.all * 100, 2)
perc.down <- round(num.down / num.all * 100, 2)

data$density <- get_density(data$DMSO, data$dTAG, n = 100)
data <- data %>% dplyr::arrange(density)
p2 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  annotate(\text\, x = -0.5, y = 1, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  
  

fileName <- paste0(\scatterplot_\, name, \_\, diffCutoff, \_pure_str_reg\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 5*1.5, height = 2.5*1.5)
print(cowplot::plot_grid(p1, p2, align = \h\))
dev.off()

svglite(here(figDir, paste0(fileName, \.svg\)), 
        width = 5*1.5, height = 2.5*1.5)
print(cowplot::plot_grid(p1, p2, align = \h\))
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX0Fubm8zLnRzdlxcKSkpXG5kaWZmQ3V0b2ZmIDwtIDAuMlxuXG4jIFNwbGl0dGluZyBkYXRhXG5kYXRhLnJlZyA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8zID09IFxccmVnXFwpXG5kYXRhLnN0ciA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8zID09IFxcc3RyXFwpXG5cbiMgVGFraW5nIGNvZGVzIGZyb20gcHJldmlvdXMgZnVuY3Rpb24gKHN0cilcbmRhdGEgPC0gZGF0YS5zdHJcbmRhdGEgPC0gZGF0YSAlPiVcbiAgZHBseXI6Om11dGF0ZSh1cGRvd25fZFRBR19ETVNPID0gaWZlbHNlKGRpZmZfZFRBR19ETVNPID4gZGlmZkN1dG9mZiwgXFxVUFxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcXE5PXFwsIFxcRE9XTlxcKSksXG4gICAgICAgICAgICAgICAgdXBkb3duX0E0ODVfRE1TTyA9IGlmZWxzZShkaWZmX0E0ODVfRE1TTyA+IGRpZmZDdXRvZmYsIFxcVVBcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiAtZGlmZkN1dG9mZiwgXFxOT1xcLCBcXERPV05cXCkpKVxuZGF0YSR1cGRvd25fZFRBR19ETVNPIDwtIGZhY3RvcihkYXRhJHVwZG93bl9kVEFHX0RNU08sIGxldmVscyA9IGMoXFxVUFxcLCBcXE5PXFwsIFxcRE9XTlxcKSlcbmRhdGEkdXBkb3duX0E0ODVfRE1TTyA8LSBmYWN0b3IoZGF0YSR1cGRvd25fQTQ4NV9ETVNPLCBsZXZlbHMgPSBjKFxcVVBcXCwgXFxOT1xcLCBcXERPV05cXCkpXG5cbm51bS51cCA8LSAoc3VtbWFyeShkYXRhJHVwZG93bl9kVEFHX0RNU08pKVtcXFVQXFxdXG5udW0ubm8gPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXFxOT1xcXVxubnVtLmRvd24gPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXFxET1dOXFxdXG5udW0uYWxsIDwtIG51bS51cCArIG51bS5ubyArIG51bS5kb3duXG5wZXJjLnVwIDwtIHJvdW5kKG51bS51cCAvIG51bS5hbGwgKiAxMDAsIDIpXG5wZXJjLm5vIDwtIHJvdW5kKG51bS5ubyAvIG51bS5hbGwgKiAxMDAsIDIpXG5wZXJjLmRvd24gPC0gcm91bmQobnVtLmRvd24gLyBudW0uYWxsICogMTAwLCAyKVxuXG5kYXRhJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkoZGF0YSRETVNPLCBkYXRhJGRUQUcsIG4gPSAxMDApXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5wMSA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBETVNPLCB5ID0gZFRBRywgY29sb3IgPSBkZW5zaXR5KSkgK1xuICBnZW9tX3BvaW50KHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArXG4gIHhsaW0oLTAuNSwgMSkgKyB5bGltKC0wLjUsIDEpICsgY29vcmRfZml4ZWQoKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCwgY29sID0gXFxncmV5NTBcXCwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gLWRpZmZDdXRvZmYsIGNvbCA9IFxcZ3JleVxcLCBsaW5ldHlwZSA9IFxcZG90dGVkXFwpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBjb2wgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gLTAuNSwgeSA9IDEsIGxhYmVsID0gcGFzdGUwKFxcVVA6IFxcLCBudW0udXAsIFxcIChcXCwgcGVyYy51cCwgXFwlKVxcKSwgXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gLTAuNSwgeSA9IDEtMC4xLCBsYWJlbCA9IHBhc3RlMChcXE5POiBcXCwgbnVtLm5vLCBcXCAoXFwsIHBlcmMubm8sIFxcJSlcXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IC0wLjUsIHkgPSAxLTAuMiwgbGFiZWwgPSBwYXN0ZTAoXFxET1dOOiBcXCwgbnVtLmRvd24sIFxcIChcXCwgcGVyYy5kb3duLCBcXCUpXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgdGhlbWVfY2xhc3NpYygpICsgZ2d0aXRsZShuYW1lKSArIHRoZW1lKHBsb3QudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDUpKVxuXG4jIFRha2luZyBjb2RlcyBmcm9tIHByZXZpb3VzIGZ1bmN0aW9uIChyZWcpXG5kYXRhIDwtIGRhdGEucmVnXG5kYXRhIDwtIGRhdGEgJT4lXG4gIGRwbHlyOjptdXRhdGUodXBkb3duX2RUQUdfRE1TTyA9IGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IGRpZmZDdXRvZmYsIFxcVVBcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9kVEFHX0RNU08gPiAtZGlmZkN1dG9mZiwgXFxOT1xcLCBcXERPV05cXCkpLFxuICAgICAgICAgICAgICAgIHVwZG93bl9BNDg1X0RNU08gPSBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiBkaWZmQ3V0b2ZmLCBcXFVQXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGRpZmZfQTQ4NV9ETVNPID4gLWRpZmZDdXRvZmYsIFxcTk9cXCwgXFxET1dOXFwpKSlcbmRhdGEkdXBkb3duX2RUQUdfRE1TTyA8LSBmYWN0b3IoZGF0YSR1cGRvd25fZFRBR19ETVNPLCBsZXZlbHMgPSBjKFxcVVBcXCwgXFxOT1xcLCBcXERPV05cXCkpXG5kYXRhJHVwZG93bl9BNDg1X0RNU08gPC0gZmFjdG9yKGRhdGEkdXBkb3duX0E0ODVfRE1TTywgbGV2ZWxzID0gYyhcXFVQXFwsIFxcTk9cXCwgXFxET1dOXFwpKVxuXG5udW0udXAgPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXFxVUFxcXVxubnVtLm5vIDwtIChzdW1tYXJ5KGRhdGEkdXBkb3duX2RUQUdfRE1TTykpW1xcTk9cXF1cbm51bS5kb3duIDwtIChzdW1tYXJ5KGRhdGEkdXBkb3duX2RUQUdfRE1TTykpW1xcRE9XTlxcXVxubnVtLmFsbCA8LSBudW0udXAgKyBudW0ubm8gKyBudW0uZG93blxucGVyYy51cCA8LSByb3VuZChudW0udXAgLyBudW0uYWxsICogMTAwLCAyKVxucGVyYy5ubyA8LSByb3VuZChudW0ubm8gLyBudW0uYWxsICogMTAwLCAyKVxucGVyYy5kb3duIDwtIHJvdW5kKG51bS5kb3duIC8gbnVtLmFsbCAqIDEwMCwgMilcblxuZGF0YSRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KGRhdGEkRE1TTywgZGF0YSRkVEFHLCBuID0gMTAwKVxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxucDIgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gRE1TTywgeSA9IGRUQUcsIGNvbG9yID0gZGVuc2l0eSkpICtcbiAgZ2VvbV9wb2ludChzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICBzY2FsZV9jb2xvcl92aXJpZGlzKCkgK1xuICB4bGltKC0wLjUsIDEpICsgeWxpbSgtMC41LCAxKSArIGNvb3JkX2ZpeGVkKCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDAsIGNvbCA9IFxcZ3JleTUwXFwsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IC1kaWZmQ3V0b2ZmLCBjb2wgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgY29sID0gXFxncmV5XFwsIGxpbmV0eXBlID0gXFxkb3R0ZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IC0wLjUsIHkgPSAxLCBsYWJlbCA9IHBhc3RlMChcXFVQOiBcXCwgbnVtLnVwLCBcXCAoXFwsIHBlcmMudXAsIFxcJSlcXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IC0wLjUsIHkgPSAxLTAuMSwgbGFiZWwgPSBwYXN0ZTAoXFxOTzogXFwsIG51bS5ubywgXFwgKFxcLCBwZXJjLm5vLCBcXCUpXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAtMC41LCB5ID0gMS0wLjIsIGxhYmVsID0gcGFzdGUwKFxcRE9XTjogXFwsIG51bS5kb3duLCBcXCAoXFwsIHBlcmMuZG93biwgXFwlKVxcKSwgXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUobmFtZSkgKyB0aGVtZShwbG90LnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA1KSkgIFxuICBcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcc2NhdHRlcnBsb3RfXFwsIG5hbWUsIFxcX1xcLCBkaWZmQ3V0b2ZmLCBcXF9wdXJlX3N0cl9yZWdcXClcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXRzID0gXFxpblxcLCB3aWR0aCA9IDUqMS41LCBoZWlnaHQgPSAyLjUqMS41KVxucHJpbnQoY293cGxvdDo6cGxvdF9ncmlkKHAxLCBwMiwgYWxpZ24gPSBcXGhcXCkpXG5kZXYub2ZmKClcblxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCBcbiAgICAgICAgd2lkdGggPSA1KjEuNSwgaGVpZ2h0ID0gMi41KjEuNSlcbnByaW50KGNvd3Bsb3Q6OnBsb3RfZ3JpZChwMSwgcDIsIGFsaWduID0gXFxoXFwpKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\_Anno3.tsv\\)))\ndiffCutoff <- 0.2\n\n# Splitting data\ndata.reg <- data %>% dplyr::filter(Anno3 == \\reg\\)\ndata.str <- data %>% dplyr::filter(Anno3 == \\str\\)\n\n# Taking codes from previous function (str)\ndata <- data.str\ndata <- data %>%\n  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)))\ndata$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\ndata$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n\nnum.up <- (summary(data$updown_dTAG_DMSO))[\\UP\\]\nnum.no <- (summary(data$updown_dTAG_DMSO))[\\NO\\]\nnum.down <- (summary(data$updown_dTAG_DMSO))[\\DOWN\\]\nnum.all <- num.up + num.no + num.down\nperc.up <- round(num.up / num.all * 100, 2)\nperc.no <- round(num.no / num.all * 100, 2)\nperc.down <- round(num.down / num.all * 100, 2)\n\ndata$density <- get_density(data$DMSO, data$dTAG, n = 100)\ndata <- data %>% dplyr::arrange(density)\np1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point(show.legend = FALSE) + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))\n\n# Taking codes from previous function (reg)\ndata <- data.reg\ndata <- data %>%\n  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)))\ndata$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\ndata$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n\nnum.up <- (summary(data$updown_dTAG_DMSO))[\\UP\\]\nnum.no <- (summary(data$updown_dTAG_DMSO))[\\NO\\]\nnum.down <- (summary(data$updown_dTAG_DMSO))[\\DOWN\\]\nnum.all <- num.up + num.no + num.down\nperc.up <- round(num.up / num.all * 100, 2)\nperc.no <- round(num.no / num.all * 100, 2)\nperc.down <- round(num.down / num.all * 100, 2)\n\ndata$density <- get_density(data$DMSO, data$dTAG, n = 100)\ndata <- data %>% dplyr::arrange(density)\np2 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point(show.legend = FALSE) + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  \n  \n\nfileName <- paste0(\\scatterplot_\\, name, \\_\\, diffCutoff, \\_pure_str_reg\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 5*1.5, height = 2.5*1.5)\nprint(cowplot::plot_grid(p1, p2, align = \\h\\))\ndev.off()\n\nsvglite(here(figDir, paste0(fileName, \\.svg\\)), \n        width = 5*1.5, height = 2.5*1.5)\nprint(cowplot::plot_grid(p1, p2, align = \\h\\))\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX0Fubm8zLnRzdlxcKSkpXG5kaWZmQ3V0b2ZmIDwtIDAuMlxuXG4jIFNwbGl0dGluZyBkYXRhXG5kYXRhLnJlZyA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8zID09IFxccmVnXFwpXG5kYXRhLnN0ciA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8zID09IFxcc3RyXFwpXG5cbiMgVGFraW5nIGNvZGVzIGZyb20gcHJldmlvdXMgZnVuY3Rpb24gKHN0cilcbmRhdGEgPC0gZGF0YS5zdHJcbmRhdGEgPC0gZGF0YSAlPiVcbiAgZHBseXI6Om11dGF0ZSh1cGRvd25fZFRBR19ETVNPID0gaWZlbHNlKGRpZmZfZFRBR19ETVNPID4gZGlmZkN1dG9mZiwgXFxVUFxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcXE5PXFwsIFxcRE9XTlxcKSksXG4gICAgICAgICAgICAgICAgdXBkb3duX0E0ODVfRE1TTyA9IGlmZWxzZShkaWZmX0E0ODVfRE1TTyA+IGRpZmZDdXRvZmYsIFxcVVBcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiAtZGlmZkN1dG9mZiwgXFxOT1xcLCBcXERPV05cXCkpKVxuZGF0YSR1cGRvd25fZFRBR19ETVNPIDwtIGZhY3RvcihkYXRhJHVwZG93bl9kVEFHX0RNU08sIGxldmVscyA9IGMoXFxVUFxcLCBcXE5PXFwsIFxcRE9XTlxcKSlcbmRhdGEkdXBkb3duX0E0ODVfRE1TTyA8LSBmYWN0b3IoZGF0YSR1cGRvd25fQTQ4NV9ETVNPLCBsZXZlbHMgPSBjKFxcVVBcXCwgXFxOT1xcLCBcXERPV05cXCkpXG5cbm51bS51cCA8LSAoc3VtbWFyeShkYXRhJHVwZG93bl9kVEFHX0RNU08pKVtcXFVQXFxdXG5udW0ubm8gPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXFxOT1xcXVxubnVtLmRvd24gPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXFxET1dOXFxdXG5udW0uYWxsIDwtIG51bS51cCArIG51bS5ubyArIG51bS5kb3duXG5wZXJjLnVwIDwtIHJvdW5kKG51bS51cCAvIG51bS5hbGwgKiAxMDAsIDIpXG5wZXJjLm5vIDwtIHJvdW5kKG51bS5ubyAvIG51bS5hbGwgKiAxMDAsIDIpXG5wZXJjLmRvd24gPC0gcm91bmQobnVtLmRvd24gLyBudW0uYWxsICogMTAwLCAyKVxuXG5kYXRhJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkoZGF0YSRETVNPLCBkYXRhJGRUQUcsIG4gPSAxMDApXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5wMSA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBETVNPLCB5ID0gZFRBRywgY29sb3IgPSBkZW5zaXR5KSkgK1xuICBnZW9tX3BvaW50KHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArXG4gIHhsaW0oLTAuNSwgMSkgKyB5bGltKC0wLjUsIDEpICsgY29vcmRfZml4ZWQoKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCwgY29sID0gXFxncmV5NTBcXCwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gLWRpZmZDdXRvZmYsIGNvbCA9IFxcZ3JleVxcLCBsaW5ldHlwZSA9IFxcZG90dGVkXFwpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBjb2wgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gLTAuNSwgeSA9IDEsIGxhYmVsID0gcGFzdGUwKFxcVVA6IFxcLCBudW0udXAsIFxcIChcXCwgcGVyYy51cCwgXFwlKVxcKSwgXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gLTAuNSwgeSA9IDEtMC4xLCBsYWJlbCA9IHBhc3RlMChcXE5POiBcXCwgbnVtLm5vLCBcXCAoXFwsIHBlcmMubm8sIFxcJSlcXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IC0wLjUsIHkgPSAxLTAuMiwgbGFiZWwgPSBwYXN0ZTAoXFxET1dOOiBcXCwgbnVtLmRvd24sIFxcIChcXCwgcGVyYy5kb3duLCBcXCUpXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgdGhlbWVfY2xhc3NpYygpICsgZ2d0aXRsZShuYW1lKSArIHRoZW1lKHBsb3QudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDUpKVxuXG4jIFRha2luZyBjb2RlcyBmcm9tIHByZXZpb3VzIGZ1bmN0aW9uIChyZWcpXG5kYXRhIDwtIGRhdGEucmVnXG5kYXRhIDwtIGRhdGEgJT4lXG4gIGRwbHlyOjptdXRhdGUodXBkb3duX2RUQUdfRE1TTyA9IGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IGRpZmZDdXRvZmYsIFxcVVBcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9kVEFHX0RNU08gPiAtZGlmZkN1dG9mZiwgXFxOT1xcLCBcXERPV05cXCkpLFxuICAgICAgICAgICAgICAgIHVwZG93bl9BNDg1X0RNU08gPSBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiBkaWZmQ3V0b2ZmLCBcXFVQXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGRpZmZfQTQ4NV9ETVNPID4gLWRpZmZDdXRvZmYsIFxcTk9cXCwgXFxET1dOXFwpKSlcbmRhdGEkdXBkb3duX2RUQUdfRE1TTyA8LSBmYWN0b3IoZGF0YSR1cGRvd25fZFRBR19ETVNPLCBsZXZlbHMgPSBjKFxcVVBcXCwgXFxOT1xcLCBcXERPV05cXCkpXG5kYXRhJHVwZG93bl9BNDg1X0RNU08gPC0gZmFjdG9yKGRhdGEkdXBkb3duX0E0ODVfRE1TTywgbGV2ZWxzID0gYyhcXFVQXFwsIFxcTk9cXCwgXFxET1dOXFwpKVxuXG5udW0udXAgPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXFxVUFxcXVxubnVtLm5vIDwtIChzdW1tYXJ5KGRhdGEkdXBkb3duX2RUQUdfRE1TTykpW1xcTk9cXF1cbm51bS5kb3duIDwtIChzdW1tYXJ5KGRhdGEkdXBkb3duX2RUQUdfRE1TTykpW1xcRE9XTlxcXVxubnVtLmFsbCA8LSBudW0udXAgKyBudW0ubm8gKyBudW0uZG93blxucGVyYy51cCA8LSByb3VuZChudW0udXAgLyBudW0uYWxsICogMTAwLCAyKVxucGVyYy5ubyA8LSByb3VuZChudW0ubm8gLyBudW0uYWxsICogMTAwLCAyKVxucGVyYy5kb3duIDwtIHJvdW5kKG51bS5kb3duIC8gbnVtLmFsbCAqIDEwMCwgMilcblxuZGF0YSRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KGRhdGEkRE1TTywgZGF0YSRkVEFHLCBuID0gMTAwKVxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxucDIgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gRE1TTywgeSA9IGRUQUcsIGNvbG9yID0gZGVuc2l0eSkpICtcbiAgZ2VvbV9wb2ludChzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICBzY2FsZV9jb2xvcl92aXJpZGlzKCkgK1xuICB4bGltKC0wLjUsIDEpICsgeWxpbSgtMC41LCAxKSArIGNvb3JkX2ZpeGVkKCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDAsIGNvbCA9IFxcZ3JleTUwXFwsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IC1kaWZmQ3V0b2ZmLCBjb2wgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgY29sID0gXFxncmV5XFwsIGxpbmV0eXBlID0gXFxkb3R0ZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IC0wLjUsIHkgPSAxLCBsYWJlbCA9IHBhc3RlMChcXFVQOiBcXCwgbnVtLnVwLCBcXCAoXFwsIHBlcmMudXAsIFxcJSlcXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IC0wLjUsIHkgPSAxLTAuMSwgbGFiZWwgPSBwYXN0ZTAoXFxOTzogXFwsIG51bS5ubywgXFwgKFxcLCBwZXJjLm5vLCBcXCUpXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAtMC41LCB5ID0gMS0wLjIsIGxhYmVsID0gcGFzdGUwKFxcRE9XTjogXFwsIG51bS5kb3duLCBcXCAoXFwsIHBlcmMuZG93biwgXFwlKVxcKSwgXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUobmFtZSkgKyB0aGVtZShwbG90LnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA1KSkgIFxuICBcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcc2NhdHRlcnBsb3RfXFwsIG5hbWUsIFxcX1xcLCBkaWZmQ3V0b2ZmLCBcXF9wdXJlX3N0cl9yZWdcXClcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXRzID0gXFxpblxcLCB3aWR0aCA9IDUqMS41LCBoZWlnaHQgPSAyLjUqMS41KVxucHJpbnQoY293cGxvdDo6cGxvdF9ncmlkKHAxLCBwMiwgYWxpZ24gPSBcXGhcXCkpXG5kZXYub2ZmKClcblxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCBcbiAgICAgICAgd2lkdGggPSA1KjEuNSwgaGVpZ2h0ID0gMi41KjEuNSlcbnByaW50KGNvd3Bsb3Q6OnBsb3RfZ3JpZChwMSwgcDIsIGFsaWduID0gXFxoXFwpKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \_Anno3.tsv\)))
diffCutoff <- 0.2

# Splitting data
data.reg <- data %>% dplyr::filter(Anno3 == \reg\)
data.str <- data %>% dplyr::filter(Anno3 == \str\)

# Taking codes from previous function (str)
data <- data.str
data <- data %>%
  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)))
data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))

num.up <- (summary(data$updown_dTAG_DMSO))[\UP\]
num.no <- (summary(data$updown_dTAG_DMSO))[\NO\]
num.down <- (summary(data$updown_dTAG_DMSO))[\DOWN\]
num.all <- num.up + num.no + num.down
perc.up <- round(num.up / num.all * 100, 2)
perc.no <- round(num.no / num.all * 100, 2)
perc.down <- round(num.down / num.all * 100, 2)

data$density <- get_density(data$DMSO, data$dTAG, n = 100)
data <- data %>% dplyr::arrange(density)
p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  annotate(\text\, x = -0.5, y = 1, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))

# Taking codes from previous function (reg)
data <- data.reg
data <- data %>%
  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)))
data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))

num.up <- (summary(data$updown_dTAG_DMSO))[\UP\]
num.no <- (summary(data$updown_dTAG_DMSO))[\NO\]
num.down <- (summary(data$updown_dTAG_DMSO))[\DOWN\]
num.all <- num.up + num.no + num.down
perc.up <- round(num.up / num.all * 100, 2)
perc.no <- round(num.no / num.all * 100, 2)
perc.down <- round(num.down / num.all * 100, 2)

data$density <- get_density(data$DMSO, data$dTAG, n = 100)
data <- data %>% dplyr::arrange(density)
p2 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  annotate(\text\, x = -0.5, y = 1, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  
  

fileName <- paste0(\scatterplot_\, name, \_\, diffCutoff, \_pure_str_reg\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 5*1.5, height = 2.5*1.5)
print(cowplot::plot_grid(p1, p2, align = \h\))
dev.off()

svglite(here(figDir, paste0(fileName, \.svg\)), 
        width = 5*1.5, height = 2.5*1.5)
print(cowplot::plot_grid(p1, p2, align = \h\))
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Relaxed annotation

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiX0Fubm8zLnRzdlwiKSkpXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShzaXplID0gc3RhcnQyIC0gc3RhcnQxKVxuXG5kYXRhX3VuZGVyNTBrYiA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcIlAtUFwiLCBcIlAtRVwiLCBcIkUtRVwiKSwgc2l6ZSA8IDUwKjEwMDAsIEFubm8zID09IFwicmVnXCIpXG5kYXRhX3VuZGVyMjAwa2IgPC0gZGF0YSAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXCJQLVBcIiwgXCJQLUVcIiwgXCJFLUVcIiksIHNpemUgPj0gNTAqMTAwMCwgc2l6ZSA8IDIwMCoxMDAwLCBBbm5vMyA9PSBcInJlZ1wiKVxuZGF0YV9vdmVyMjAwa2IgPC0gZGF0YSAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXCJQLVBcIiwgXCJQLUVcIiwgXCJFLUVcIiksIHNpemUgPj0gMjAwKjEwMDAsIEFubm8zID09IFwicmVnXCIpXG5cbiMjIyMjIyMjXG5cbmRhdGEgPC0gZGF0YV91bmRlcjUwa2JcblxuZGlmZkN1dG9mZiA8LSAwLjJcbmRhdGEgPC0gZGF0YSAlPiVcbiAgZHBseXI6Om11dGF0ZSh1cGRvd25fZFRBR19ETVNPID0gaWZlbHNlKGRpZmZfZFRBR19ETVNPID4gZGlmZkN1dG9mZiwgXCJVUFwiLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcIk5PXCIsIFwiRE9XTlwiKSksXG4gICAgICAgICAgICAgICAgdXBkb3duX0E0ODVfRE1TTyA9IGlmZWxzZShkaWZmX0E0ODVfRE1TTyA+IGRpZmZDdXRvZmYsIFwiVVBcIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiAtZGlmZkN1dG9mZiwgXCJOT1wiLCBcIkRPV05cIikpKVxuZGF0YSR1cGRvd25fZFRBR19ETVNPIDwtIGZhY3RvcihkYXRhJHVwZG93bl9kVEFHX0RNU08sIGxldmVscyA9IGMoXCJVUFwiLCBcIk5PXCIsIFwiRE9XTlwiKSlcbmRhdGEkdXBkb3duX0E0ODVfRE1TTyA8LSBmYWN0b3IoZGF0YSR1cGRvd25fQTQ4NV9ETVNPLCBsZXZlbHMgPSBjKFwiVVBcIiwgXCJOT1wiLCBcIkRPV05cIikpXG5cbiMjIyNcbm51bS51cCA8LSAoc3VtbWFyeShkYXRhJHVwZG93bl9kVEFHX0RNU08pKVtcIlVQXCJdXG5udW0ubm8gPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXCJOT1wiXVxubnVtLmRvd24gPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXCJET1dOXCJdXG5udW0uYWxsIDwtIG51bS51cCArIG51bS5ubyArIG51bS5kb3duXG5wZXJjLnVwIDwtIHJvdW5kKG51bS51cCAvIG51bS5hbGwgKiAxMDAsIDIpXG5wZXJjLm5vIDwtIHJvdW5kKG51bS5ubyAvIG51bS5hbGwgKiAxMDAsIDIpXG5wZXJjLmRvd24gPC0gcm91bmQobnVtLmRvd24gLyBudW0uYWxsICogMTAwLCAyKVxuXG5kYXRhJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkoZGF0YSRETVNPLCBkYXRhJGRUQUcsIG4gPSAxMDApXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5wMSA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBETVNPLCB5ID0gZFRBRywgY29sb3IgPSBkZW5zaXR5KSkgK1xuICBnZW9tX3BvaW50KHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArXG4gIHhsaW0oLTAuNSwgMSkgKyB5bGltKC0wLjUsIDEpICsgY29vcmRfZml4ZWQoKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCwgY29sID0gXCJncmV5NTBcIiwgbGluZXR5cGUgPSBcImRhc2hlZFwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gLWRpZmZDdXRvZmYsIGNvbCA9IFwiZ3JleVwiLCBsaW5ldHlwZSA9IFwiZG90dGVkXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBjb2wgPSBcImdyZXlcIiwgbGluZXR5cGUgPSBcImRvdHRlZFwiKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFwiZ3JleVwiKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFwiZ3JleVwiKSArXG4gIGFubm90YXRlKFwidGV4dFwiLCB4ID0gLTAuNSwgeSA9IDEsIGxhYmVsID0gcGFzdGUwKFwiVVA6IFwiLCBudW0udXAsIFwiIChcIiwgcGVyYy51cCwgXCIlKVwiKSwgXG4gICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAzKSArXG4gIGFubm90YXRlKFwidGV4dFwiLCB4ID0gLTAuNSwgeSA9IDEtMC4xLCBsYWJlbCA9IHBhc3RlMChcIk5POiBcIiwgbnVtLm5vLCBcIiAoXCIsIHBlcmMubm8sIFwiJSlcIiksIFxuICAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IC0wLjUsIHkgPSAxLTAuMiwgbGFiZWwgPSBwYXN0ZTAoXCJET1dOOiBcIiwgbnVtLmRvd24sIFwiIChcIiwgcGVyYy5kb3duLCBcIiUpXCIpLCBcbiAgICAgICAgICAgY29sb3IgPSBcImJsYWNrXCIsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgdGhlbWVfY2xhc3NpYygpICsgZ2d0aXRsZShuYW1lKSArIHRoZW1lKHBsb3QudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDUpKSAgXG4gIFxuXG4jIyMjXG5udW0udXAgPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fQTQ4NV9ETVNPKSlbXCJVUFwiXVxubnVtLm5vIDwtIChzdW1tYXJ5KGRhdGEkdXBkb3duX0E0ODVfRE1TTykpW1wiTk9cIl1cbm51bS5kb3duIDwtIChzdW1tYXJ5KGRhdGEkdXBkb3duX0E0ODVfRE1TTykpW1wiRE9XTlwiXVxubnVtLmFsbCA8LSBudW0udXAgKyBudW0ubm8gKyBudW0uZG93blxucGVyYy51cCA8LSByb3VuZChudW0udXAgLyBudW0uYWxsICogMTAwLCAyKVxucGVyYy5ubyA8LSByb3VuZChudW0ubm8gLyBudW0uYWxsICogMTAwLCAyKVxucGVyYy5kb3duIDwtIHJvdW5kKG51bS5kb3duIC8gbnVtLmFsbCAqIDEwMCwgMilcblxuZGF0YSRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KGRhdGEkRE1TTywgZGF0YSRBNDg1LCBuID0gMTAwKVxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxucDIgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gRE1TTywgeSA9IEE0ODUsIGNvbG9yID0gZGVuc2l0eSkpICtcbiAgZ2VvbV9wb2ludChzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICBzY2FsZV9jb2xvcl92aXJpZGlzKCkgK1xuICB4bGltKC0wLjUsIDEpICsgeWxpbSgtMC41LCAxKSArIGNvb3JkX2ZpeGVkKCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDAsIGNvbCA9IFwiZ3JleTUwXCIsIGxpbmV0eXBlID0gXCJkYXNoZWRcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IC1kaWZmQ3V0b2ZmLCBjb2wgPSBcImdyZXlcIiwgbGluZXR5cGUgPSBcImRvdHRlZFwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgY29sID0gXCJncmV5XCIsIGxpbmV0eXBlID0gXCJkb3R0ZWRcIikgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcImdyZXlcIikgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcImdyZXlcIikgK1xuICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IC0wLjUsIHkgPSAxLCBsYWJlbCA9IHBhc3RlMChcIlVQOiBcIiwgbnVtLnVwLCBcIiAoXCIsIHBlcmMudXAsIFwiJSlcIiksIFxuICAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IC0wLjUsIHkgPSAxLTAuMSwgbGFiZWwgPSBwYXN0ZTAoXCJOTzogXCIsIG51bS5ubywgXCIgKFwiLCBwZXJjLm5vLCBcIiUpXCIpLCBcbiAgICAgICAgICAgY29sb3IgPSBcImJsYWNrXCIsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAtMC41LCB5ID0gMS0wLjIsIGxhYmVsID0gcGFzdGUwKFwiRE9XTjogXCIsIG51bS5kb3duLCBcIiAoXCIsIHBlcmMuZG93biwgXCIlKVwiKSwgXG4gICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAzKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUobmFtZSkgKyB0aGVtZShwbG90LnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA1KSkgIFxuICBcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwic2NhdHRlcnBsb3RfXCIsIG5hbWUsIFwiX1wiLCBkaWZmQ3V0b2ZmLCBcIl9yZWd1bmRlcjUwa2JfcHVyZVwiKVxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdHMgPSBcImluXCIsIHdpZHRoID0gNSoxLjUsIGhlaWdodCA9IDIuNSoxLjUpXG5wcmludChjb3dwbG90OjpwbG90X2dyaWQocDEsIHAyLCBhbGlnbiA9IFwiaFwiKSlcbmRldi5vZmYoKVxuXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksIFxuICAgICAgICB3aWR0aCA9IDUqMS41LCBoZWlnaHQgPSAyLjUqMS41KVxucHJpbnQoY293cGxvdDo6cGxvdF9ncmlkKHAxLCBwMiwgYWxpZ24gPSBcImhcIikpXG5kZXYub2ZmKClcblxuYGBgIn0= -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\_Anno3.tsv\\)))\n\ndata <- data %>% dplyr::mutate(size = start2 - start1)\n\ndata_under50kb <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\), size < 50*1000, Anno3 == \\reg\\)\ndata_under200kb <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\), size >= 50*1000, size < 200*1000, Anno3 == \\reg\\)\ndata_over200kb <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\), size >= 200*1000, Anno3 == \\reg\\)\n\n########\n\ndata <- data_under50kb\n\ndiffCutoff <- 0.2\ndata <- data %>%\n  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)))\ndata$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\ndata$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n\n####\nnum.up <- (summary(data$updown_dTAG_DMSO))[\\UP\\]\nnum.no <- (summary(data$updown_dTAG_DMSO))[\\NO\\]\nnum.down <- (summary(data$updown_dTAG_DMSO))[\\DOWN\\]\nnum.all <- num.up + num.no + num.down\nperc.up <- round(num.up / num.all * 100, 2)\nperc.no <- round(num.no / num.all * 100, 2)\nperc.down <- round(num.down / num.all * 100, 2)\n\ndata$density <- get_density(data$DMSO, data$dTAG, n = 100)\ndata <- data %>% dplyr::arrange(density)\np1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point(show.legend = FALSE) + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  \n  \n\n####\nnum.up <- (summary(data$updown_A485_DMSO))[\\UP\\]\nnum.no <- (summary(data$updown_A485_DMSO))[\\NO\\]\nnum.down <- (summary(data$updown_A485_DMSO))[\\DOWN\\]\nnum.all <- num.up + num.no + num.down\nperc.up <- round(num.up / num.all * 100, 2)\nperc.no <- round(num.no / num.all * 100, 2)\nperc.down <- round(num.down / num.all * 100, 2)\n\ndata$density <- get_density(data$DMSO, data$A485, n = 100)\ndata <- data %>% dplyr::arrange(density)\np2 <- ggplot(data, aes(x = DMSO, y = A485, color = density)) +\n  geom_point(show.legend = FALSE) + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  \n  \n\nfileName <- paste0(\\scatterplot_\\, name, \\_\\, diffCutoff, \\_regunder50kb_pure\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 5*1.5, height = 2.5*1.5)\nprint(cowplot::plot_grid(p1, p2, align = \\h\\))\ndev.off()\n\nsvglite(here(figDir, paste0(fileName, \\.svg\\)), \n        width = 5*1.5, height = 2.5*1.5)\nprint(cowplot::plot_grid(p1, p2, align = \\h\\))\ndev.off()\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \_Anno3.tsv\)))

data <- data %>% dplyr::mutate(size = start2 - start1)

data_under50kb <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\), size < 50*1000, Anno3 == \reg\)
data_under200kb <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\), size >= 50*1000, size < 200*1000, Anno3 == \reg\)
data_over200kb <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\), size >= 200*1000, Anno3 == \reg\)

########

data <- data_under50kb

diffCutoff <- 0.2
data <- data %>%
  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)))
data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))

####
num.up <- (summary(data$updown_dTAG_DMSO))[\UP\]
num.no <- (summary(data$updown_dTAG_DMSO))[\NO\]
num.down <- (summary(data$updown_dTAG_DMSO))[\DOWN\]
num.all <- num.up + num.no + num.down
perc.up <- round(num.up / num.all * 100, 2)
perc.no <- round(num.no / num.all * 100, 2)
perc.down <- round(num.down / num.all * 100, 2)

data$density <- get_density(data$DMSO, data$dTAG, n = 100)
data <- data %>% dplyr::arrange(density)
p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  annotate(\text\, x = -0.5, y = 1, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  
  

####
num.up <- (summary(data$updown_A485_DMSO))[\UP\]
num.no <- (summary(data$updown_A485_DMSO))[\NO\]
num.down <- (summary(data$updown_A485_DMSO))[\DOWN\]
num.all <- num.up + num.no + num.down
perc.up <- round(num.up / num.all * 100, 2)
perc.no <- round(num.no / num.all * 100, 2)
perc.down <- round(num.down / num.all * 100, 2)

data$density <- get_density(data$DMSO, data$A485, n = 100)
data <- data %>% dplyr::arrange(density)
p2 <- ggplot(data, aes(x = DMSO, y = A485, color = density)) +
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  annotate(\text\, x = -0.5, y = 1, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  
  

fileName <- paste0(\scatterplot_\, name, \_\, diffCutoff, \_regunder50kb_pure\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 5*1.5, height = 2.5*1.5)
print(cowplot::plot_grid(p1, p2, align = \h\))
dev.off()

svglite(here(figDir, paste0(fileName, \.svg\)), 
        width = 5*1.5, height = 2.5*1.5)
print(cowplot::plot_grid(p1, p2, align = \h\))
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX0Fubm8zLnRzdlxcKSkpXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShzaXplID0gc3RhcnQyIC0gc3RhcnQxKVxuXG5kYXRhX3VuZGVyNTBrYiA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSwgc2l6ZSA8IDUwKjEwMDAsIEFubm8zID09IFxccmVnXFwpXG5kYXRhX3VuZGVyMjAwa2IgPC0gZGF0YSAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCksIHNpemUgPj0gNTAqMTAwMCwgc2l6ZSA8IDIwMCoxMDAwLCBBbm5vMyA9PSBcXHJlZ1xcKVxuZGF0YV9vdmVyMjAwa2IgPC0gZGF0YSAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCksIHNpemUgPj0gMjAwKjEwMDAsIEFubm8zID09IFxccmVnXFwpXG5cbiMjIyMjIyMjXG5cbmRhdGEgPC0gZGF0YV91bmRlcjUwa2JcblxuZGlmZkN1dG9mZiA8LSAwLjJcbmRhdGEgPC0gZGF0YSAlPiVcbiAgZHBseXI6Om11dGF0ZSh1cGRvd25fZFRBR19ETVNPID0gaWZlbHNlKGRpZmZfZFRBR19ETVNPID4gZGlmZkN1dG9mZiwgXFxVUFxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcXE5PXFwsIFxcRE9XTlxcKSksXG4gICAgICAgICAgICAgICAgdXBkb3duX0E0ODVfRE1TTyA9IGlmZWxzZShkaWZmX0E0ODVfRE1TTyA+IGRpZmZDdXRvZmYsIFxcVVBcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiAtZGlmZkN1dG9mZiwgXFxOT1xcLCBcXERPV05cXCkpKVxuZGF0YSR1cGRvd25fZFRBR19ETVNPIDwtIGZhY3RvcihkYXRhJHVwZG93bl9kVEFHX0RNU08sIGxldmVscyA9IGMoXFxVUFxcLCBcXE5PXFwsIFxcRE9XTlxcKSlcbmRhdGEkdXBkb3duX0E0ODVfRE1TTyA8LSBmYWN0b3IoZGF0YSR1cGRvd25fQTQ4NV9ETVNPLCBsZXZlbHMgPSBjKFxcVVBcXCwgXFxOT1xcLCBcXERPV05cXCkpXG5cbiMjIyNcbm51bS51cCA8LSAoc3VtbWFyeShkYXRhJHVwZG93bl9kVEFHX0RNU08pKVtcXFVQXFxdXG5udW0ubm8gPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXFxOT1xcXVxubnVtLmRvd24gPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXFxET1dOXFxdXG5udW0uYWxsIDwtIG51bS51cCArIG51bS5ubyArIG51bS5kb3duXG5wZXJjLnVwIDwtIHJvdW5kKG51bS51cCAvIG51bS5hbGwgKiAxMDAsIDIpXG5wZXJjLm5vIDwtIHJvdW5kKG51bS5ubyAvIG51bS5hbGwgKiAxMDAsIDIpXG5wZXJjLmRvd24gPC0gcm91bmQobnVtLmRvd24gLyBudW0uYWxsICogMTAwLCAyKVxuXG5kYXRhJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkoZGF0YSRETVNPLCBkYXRhJGRUQUcsIG4gPSAxMDApXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5wMSA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBETVNPLCB5ID0gZFRBRywgY29sb3IgPSBkZW5zaXR5KSkgK1xuICBnZW9tX3BvaW50KHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArXG4gIHhsaW0oLTAuNSwgMSkgKyB5bGltKC0wLjUsIDEpICsgY29vcmRfZml4ZWQoKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCwgY29sID0gXFxncmV5NTBcXCwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gLWRpZmZDdXRvZmYsIGNvbCA9IFxcZ3JleVxcLCBsaW5ldHlwZSA9IFxcZG90dGVkXFwpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBjb2wgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gLTAuNSwgeSA9IDEsIGxhYmVsID0gcGFzdGUwKFxcVVA6IFxcLCBudW0udXAsIFxcIChcXCwgcGVyYy51cCwgXFwlKVxcKSwgXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gLTAuNSwgeSA9IDEtMC4xLCBsYWJlbCA9IHBhc3RlMChcXE5POiBcXCwgbnVtLm5vLCBcXCAoXFwsIHBlcmMubm8sIFxcJSlcXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IC0wLjUsIHkgPSAxLTAuMiwgbGFiZWwgPSBwYXN0ZTAoXFxET1dOOiBcXCwgbnVtLmRvd24sIFxcIChcXCwgcGVyYy5kb3duLCBcXCUpXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgdGhlbWVfY2xhc3NpYygpICsgZ2d0aXRsZShuYW1lKSArIHRoZW1lKHBsb3QudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDUpKSAgXG4gIFxuXG4jIyMjXG5udW0udXAgPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fQTQ4NV9ETVNPKSlbXFxVUFxcXVxubnVtLm5vIDwtIChzdW1tYXJ5KGRhdGEkdXBkb3duX0E0ODVfRE1TTykpW1xcTk9cXF1cbm51bS5kb3duIDwtIChzdW1tYXJ5KGRhdGEkdXBkb3duX0E0ODVfRE1TTykpW1xcRE9XTlxcXVxubnVtLmFsbCA8LSBudW0udXAgKyBudW0ubm8gKyBudW0uZG93blxucGVyYy51cCA8LSByb3VuZChudW0udXAgLyBudW0uYWxsICogMTAwLCAyKVxucGVyYy5ubyA8LSByb3VuZChudW0ubm8gLyBudW0uYWxsICogMTAwLCAyKVxucGVyYy5kb3duIDwtIHJvdW5kKG51bS5kb3duIC8gbnVtLmFsbCAqIDEwMCwgMilcblxuZGF0YSRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KGRhdGEkRE1TTywgZGF0YSRBNDg1LCBuID0gMTAwKVxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxucDIgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gRE1TTywgeSA9IEE0ODUsIGNvbG9yID0gZGVuc2l0eSkpICtcbiAgZ2VvbV9wb2ludChzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICBzY2FsZV9jb2xvcl92aXJpZGlzKCkgK1xuICB4bGltKC0wLjUsIDEpICsgeWxpbSgtMC41LCAxKSArIGNvb3JkX2ZpeGVkKCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDAsIGNvbCA9IFxcZ3JleTUwXFwsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IC1kaWZmQ3V0b2ZmLCBjb2wgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgY29sID0gXFxncmV5XFwsIGxpbmV0eXBlID0gXFxkb3R0ZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IC0wLjUsIHkgPSAxLCBsYWJlbCA9IHBhc3RlMChcXFVQOiBcXCwgbnVtLnVwLCBcXCAoXFwsIHBlcmMudXAsIFxcJSlcXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IC0wLjUsIHkgPSAxLTAuMSwgbGFiZWwgPSBwYXN0ZTAoXFxOTzogXFwsIG51bS5ubywgXFwgKFxcLCBwZXJjLm5vLCBcXCUpXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAtMC41LCB5ID0gMS0wLjIsIGxhYmVsID0gcGFzdGUwKFxcRE9XTjogXFwsIG51bS5kb3duLCBcXCAoXFwsIHBlcmMuZG93biwgXFwlKVxcKSwgXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUobmFtZSkgKyB0aGVtZShwbG90LnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA1KSkgIFxuICBcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcc2NhdHRlcnBsb3RfXFwsIG5hbWUsIFxcX1xcLCBkaWZmQ3V0b2ZmLCBcXF9yZWd1bmRlcjUwa2JfcHVyZVxcKVxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gNSoxLjUsIGhlaWdodCA9IDIuNSoxLjUpXG5wcmludChjb3dwbG90OjpwbG90X2dyaWQocDEsIHAyLCBhbGlnbiA9IFxcaFxcKSlcbmRldi5vZmYoKVxuXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksIFxuICAgICAgICB3aWR0aCA9IDUqMS41LCBoZWlnaHQgPSAyLjUqMS41KVxucHJpbnQoY293cGxvdDo6cGxvdF9ncmlkKHAxLCBwMiwgYWxpZ24gPSBcXGhcXCkpXG5kZXYub2ZmKClcblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\_Anno3.tsv\\)))\n\ndata <- data %>% dplyr::mutate(size = start2 - start1)\n\ndata_under50kb <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\), size < 50*1000, Anno3 == \\reg\\)\ndata_under200kb <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\), size >= 50*1000, size < 200*1000, Anno3 == \\reg\\)\ndata_over200kb <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\), size >= 200*1000, Anno3 == \\reg\\)\n\n########\n\ndata <- data_under50kb\n\ndiffCutoff <- 0.2\ndata <- data %>%\n  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)))\ndata$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\ndata$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\n\n####\nnum.up <- (summary(data$updown_dTAG_DMSO))[\\UP\\]\nnum.no <- (summary(data$updown_dTAG_DMSO))[\\NO\\]\nnum.down <- (summary(data$updown_dTAG_DMSO))[\\DOWN\\]\nnum.all <- num.up + num.no + num.down\nperc.up <- round(num.up / num.all * 100, 2)\nperc.no <- round(num.no / num.all * 100, 2)\nperc.down <- round(num.down / num.all * 100, 2)\n\ndata$density <- get_density(data$DMSO, data$dTAG, n = 100)\ndata <- data %>% dplyr::arrange(density)\np1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +\n  geom_point(show.legend = FALSE) + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  \n  \n\n####\nnum.up <- (summary(data$updown_A485_DMSO))[\\UP\\]\nnum.no <- (summary(data$updown_A485_DMSO))[\\NO\\]\nnum.down <- (summary(data$updown_A485_DMSO))[\\DOWN\\]\nnum.all <- num.up + num.no + num.down\nperc.up <- round(num.up / num.all * 100, 2)\nperc.no <- round(num.no / num.all * 100, 2)\nperc.down <- round(num.down / num.all * 100, 2)\n\ndata$density <- get_density(data$DMSO, data$A485, n = 100)\ndata <- data %>% dplyr::arrange(density)\np2 <- ggplot(data, aes(x = DMSO, y = A485, color = density)) +\n  geom_point(show.legend = FALSE) + \n  scale_color_viridis() +\n  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +\n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  annotate(\\text\\, x = -0.5, y = 1, label = paste0(\\UP: \\, num.up, \\ (\\, perc.up, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.1, label = paste0(\\NO: \\, num.no, \\ (\\, perc.no, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  annotate(\\text\\, x = -0.5, y = 1-0.2, label = paste0(\\DOWN: \\, num.down, \\ (\\, perc.down, \\%)\\), \n           color = \\black\\, hjust = 0, size = 3) +\n  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  \n  \n\nfileName <- paste0(\\scatterplot_\\, name, \\_\\, diffCutoff, \\_regunder50kb_pure\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 5*1.5, height = 2.5*1.5)\nprint(cowplot::plot_grid(p1, p2, align = \\h\\))\ndev.off()\n\nsvglite(here(figDir, paste0(fileName, \\.svg\\)), \n        width = 5*1.5, height = 2.5*1.5)\nprint(cowplot::plot_grid(p1, p2, align = \\h\\))\ndev.off()\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX0Fubm8zLnRzdlxcKSkpXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShzaXplID0gc3RhcnQyIC0gc3RhcnQxKVxuXG5kYXRhX3VuZGVyNTBrYiA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSwgc2l6ZSA8IDUwKjEwMDAsIEFubm8zID09IFxccmVnXFwpXG5kYXRhX3VuZGVyMjAwa2IgPC0gZGF0YSAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCksIHNpemUgPj0gNTAqMTAwMCwgc2l6ZSA8IDIwMCoxMDAwLCBBbm5vMyA9PSBcXHJlZ1xcKVxuZGF0YV9vdmVyMjAwa2IgPC0gZGF0YSAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCksIHNpemUgPj0gMjAwKjEwMDAsIEFubm8zID09IFxccmVnXFwpXG5cbiMjIyMjIyMjXG5cbmRhdGEgPC0gZGF0YV91bmRlcjUwa2JcblxuZGlmZkN1dG9mZiA8LSAwLjJcbmRhdGEgPC0gZGF0YSAlPiVcbiAgZHBseXI6Om11dGF0ZSh1cGRvd25fZFRBR19ETVNPID0gaWZlbHNlKGRpZmZfZFRBR19ETVNPID4gZGlmZkN1dG9mZiwgXFxVUFxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcXE5PXFwsIFxcRE9XTlxcKSksXG4gICAgICAgICAgICAgICAgdXBkb3duX0E0ODVfRE1TTyA9IGlmZWxzZShkaWZmX0E0ODVfRE1TTyA+IGRpZmZDdXRvZmYsIFxcVVBcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiAtZGlmZkN1dG9mZiwgXFxOT1xcLCBcXERPV05cXCkpKVxuZGF0YSR1cGRvd25fZFRBR19ETVNPIDwtIGZhY3RvcihkYXRhJHVwZG93bl9kVEFHX0RNU08sIGxldmVscyA9IGMoXFxVUFxcLCBcXE5PXFwsIFxcRE9XTlxcKSlcbmRhdGEkdXBkb3duX0E0ODVfRE1TTyA8LSBmYWN0b3IoZGF0YSR1cGRvd25fQTQ4NV9ETVNPLCBsZXZlbHMgPSBjKFxcVVBcXCwgXFxOT1xcLCBcXERPV05cXCkpXG5cbiMjIyNcbm51bS51cCA8LSAoc3VtbWFyeShkYXRhJHVwZG93bl9kVEFHX0RNU08pKVtcXFVQXFxdXG5udW0ubm8gPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXFxOT1xcXVxubnVtLmRvd24gPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fZFRBR19ETVNPKSlbXFxET1dOXFxdXG5udW0uYWxsIDwtIG51bS51cCArIG51bS5ubyArIG51bS5kb3duXG5wZXJjLnVwIDwtIHJvdW5kKG51bS51cCAvIG51bS5hbGwgKiAxMDAsIDIpXG5wZXJjLm5vIDwtIHJvdW5kKG51bS5ubyAvIG51bS5hbGwgKiAxMDAsIDIpXG5wZXJjLmRvd24gPC0gcm91bmQobnVtLmRvd24gLyBudW0uYWxsICogMTAwLCAyKVxuXG5kYXRhJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkoZGF0YSRETVNPLCBkYXRhJGRUQUcsIG4gPSAxMDApXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5wMSA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBETVNPLCB5ID0gZFRBRywgY29sb3IgPSBkZW5zaXR5KSkgK1xuICBnZW9tX3BvaW50KHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArXG4gIHhsaW0oLTAuNSwgMSkgKyB5bGltKC0wLjUsIDEpICsgY29vcmRfZml4ZWQoKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCwgY29sID0gXFxncmV5NTBcXCwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gLWRpZmZDdXRvZmYsIGNvbCA9IFxcZ3JleVxcLCBsaW5ldHlwZSA9IFxcZG90dGVkXFwpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBjb2wgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gLTAuNSwgeSA9IDEsIGxhYmVsID0gcGFzdGUwKFxcVVA6IFxcLCBudW0udXAsIFxcIChcXCwgcGVyYy51cCwgXFwlKVxcKSwgXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gLTAuNSwgeSA9IDEtMC4xLCBsYWJlbCA9IHBhc3RlMChcXE5POiBcXCwgbnVtLm5vLCBcXCAoXFwsIHBlcmMubm8sIFxcJSlcXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IC0wLjUsIHkgPSAxLTAuMiwgbGFiZWwgPSBwYXN0ZTAoXFxET1dOOiBcXCwgbnVtLmRvd24sIFxcIChcXCwgcGVyYy5kb3duLCBcXCUpXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgdGhlbWVfY2xhc3NpYygpICsgZ2d0aXRsZShuYW1lKSArIHRoZW1lKHBsb3QudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDUpKSAgXG4gIFxuXG4jIyMjXG5udW0udXAgPC0gKHN1bW1hcnkoZGF0YSR1cGRvd25fQTQ4NV9ETVNPKSlbXFxVUFxcXVxubnVtLm5vIDwtIChzdW1tYXJ5KGRhdGEkdXBkb3duX0E0ODVfRE1TTykpW1xcTk9cXF1cbm51bS5kb3duIDwtIChzdW1tYXJ5KGRhdGEkdXBkb3duX0E0ODVfRE1TTykpW1xcRE9XTlxcXVxubnVtLmFsbCA8LSBudW0udXAgKyBudW0ubm8gKyBudW0uZG93blxucGVyYy51cCA8LSByb3VuZChudW0udXAgLyBudW0uYWxsICogMTAwLCAyKVxucGVyYy5ubyA8LSByb3VuZChudW0ubm8gLyBudW0uYWxsICogMTAwLCAyKVxucGVyYy5kb3duIDwtIHJvdW5kKG51bS5kb3duIC8gbnVtLmFsbCAqIDEwMCwgMilcblxuZGF0YSRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KGRhdGEkRE1TTywgZGF0YSRBNDg1LCBuID0gMTAwKVxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxucDIgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gRE1TTywgeSA9IEE0ODUsIGNvbG9yID0gZGVuc2l0eSkpICtcbiAgZ2VvbV9wb2ludChzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICBzY2FsZV9jb2xvcl92aXJpZGlzKCkgK1xuICB4bGltKC0wLjUsIDEpICsgeWxpbSgtMC41LCAxKSArIGNvb3JkX2ZpeGVkKCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDAsIGNvbCA9IFxcZ3JleTUwXFwsIGxpbmV0eXBlID0gXFxkYXNoZWRcXCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IC1kaWZmQ3V0b2ZmLCBjb2wgPSBcXGdyZXlcXCwgbGluZXR5cGUgPSBcXGRvdHRlZFxcKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgY29sID0gXFxncmV5XFwsIGxpbmV0eXBlID0gXFxkb3R0ZWRcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IC0wLjUsIHkgPSAxLCBsYWJlbCA9IHBhc3RlMChcXFVQOiBcXCwgbnVtLnVwLCBcXCAoXFwsIHBlcmMudXAsIFxcJSlcXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IC0wLjUsIHkgPSAxLTAuMSwgbGFiZWwgPSBwYXN0ZTAoXFxOTzogXFwsIG51bS5ubywgXFwgKFxcLCBwZXJjLm5vLCBcXCUpXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAtMC41LCB5ID0gMS0wLjIsIGxhYmVsID0gcGFzdGUwKFxcRE9XTjogXFwsIG51bS5kb3duLCBcXCAoXFwsIHBlcmMuZG93biwgXFwlKVxcKSwgXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUobmFtZSkgKyB0aGVtZShwbG90LnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA1KSkgIFxuICBcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcc2NhdHRlcnBsb3RfXFwsIG5hbWUsIFxcX1xcLCBkaWZmQ3V0b2ZmLCBcXF9yZWd1bmRlcjUwa2JfcHVyZVxcKVxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gNSoxLjUsIGhlaWdodCA9IDIuNSoxLjUpXG5wcmludChjb3dwbG90OjpwbG90X2dyaWQocDEsIHAyLCBhbGlnbiA9IFxcaFxcKSlcbmRldi5vZmYoKVxuXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksIFxuICAgICAgICB3aWR0aCA9IDUqMS41LCBoZWlnaHQgPSAyLjUqMS41KVxucHJpbnQoY293cGxvdDo6cGxvdF9ncmlkKHAxLCBwMiwgYWxpZ24gPSBcXGhcXCkpXG5kZXYub2ZmKClcblxuYGBgXG5gYGAifQ== -->

```r
```r
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \_Anno3.tsv\)))

data <- data %>% dplyr::mutate(size = start2 - start1)

data_under50kb <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\), size < 50*1000, Anno3 == \reg\)
data_under200kb <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\), size >= 50*1000, size < 200*1000, Anno3 == \reg\)
data_over200kb <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\), size >= 200*1000, Anno3 == \reg\)

########

data <- data_under50kb

diffCutoff <- 0.2
data <- data %>%
  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)))
data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))

####
num.up <- (summary(data$updown_dTAG_DMSO))[\UP\]
num.no <- (summary(data$updown_dTAG_DMSO))[\NO\]
num.down <- (summary(data$updown_dTAG_DMSO))[\DOWN\]
num.all <- num.up + num.no + num.down
perc.up <- round(num.up / num.all * 100, 2)
perc.no <- round(num.no / num.all * 100, 2)
perc.down <- round(num.down / num.all * 100, 2)

data$density <- get_density(data$DMSO, data$dTAG, n = 100)
data <- data %>% dplyr::arrange(density)
p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  annotate(\text\, x = -0.5, y = 1, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  
  

####
num.up <- (summary(data$updown_A485_DMSO))[\UP\]
num.no <- (summary(data$updown_A485_DMSO))[\NO\]
num.down <- (summary(data$updown_A485_DMSO))[\DOWN\]
num.all <- num.up + num.no + num.down
perc.up <- round(num.up / num.all * 100, 2)
perc.no <- round(num.no / num.all * 100, 2)
perc.down <- round(num.down / num.all * 100, 2)

data$density <- get_density(data$DMSO, data$A485, n = 100)
data <- data %>% dplyr::arrange(density)
p2 <- ggplot(data, aes(x = DMSO, y = A485, color = density)) +
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  annotate(\text\, x = -0.5, y = 1, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  annotate(\text\, x = -0.5, y = 1-0.2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
           color = \black\, hjust = 0, size = 3) +
  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  
  

fileName <- paste0(\scatterplot_\, name, \_\, diffCutoff, \_regunder50kb_pure\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 5*1.5, height = 2.5*1.5)
print(cowplot::plot_grid(p1, p2, align = \h\))
dev.off()

svglite(here(figDir, paste0(fileName, \.svg\)), 
        width = 5*1.5, height = 2.5*1.5)
print(cowplot::plot_grid(p1, p2, align = \h\))
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### Pure-reg vs str-reg

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVYRzV1WVcxbElEd3RJRndpWTJoeWIyMXZYMk52Ym5OZllXNXViMUJ5YjIxdmRHVnlYQ0pjYm1SaGRHRWdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY0lpNTBjM1pjSWlrcEtWeHVhWFJsY21GMFpWOXNiMjl3WDJaMWJtTjBhVzl1Y3loa1lYUmhMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY0lsOWNJaXdnWENKaGJHeGNJaWtzSUhWdWFYRjFaU2hrWVhSaEpFRnVibTh5S1NsY2JtbDBaWEpoZEdWZmJHOXZjRjltZFc1amRHbHZibk1vWkdGMFlTd2dabWxuUkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWENKZlhDSXNJRndpY0Mxd1hDSXBMQ0JqS0Z3aVVDMVFYQ0lwS1Z4dWFYUmxjbUYwWlY5c2IyOXdYMloxYm1OMGFXOXVjeWhrWVhSaExDQm1hV2RFYVhJc0lIQmhjM1JsTUNodVlXMWxMQ0JjSWw5Y0lpd2dYQ0p3TFc1Y0lpa3NJR01vWENKUUxVNWNJaWtwWEc1cGRHVnlZWFJsWDJ4dmIzQmZablZ1WTNScGIyNXpLR1JoZEdFc0lHWnBaMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRndpWDF3aUxDQmNJbTR0Ymx3aUtTd2dZeWhjSWs0dFRsd2lLU2xjYmx4dVkyOXNiM0pNYVhOMElEd3RJR052Ykc5eVRHbHpkRkJ5YjIxdmRHVnlYRzVzYjI5d1RHbHpkQ0E4TFNCaktGd2lUaTFPWENJc0lGd2lVQzFPWENJc0lGd2lVQzFRWENJcFhHNWNiblJsYlhBZ1BDMGdaR0YwWVNBbFBpVWdaSEJzZVhJNk9tMTFkR0YwWlNoa2FYTjBZVzVqWlNBOUlITjBZWEowTWlBdElITjBZWEowTVNrZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1pHbHpkR0Z1WTJVc0lFUk5VMDhzSUVGdWJtOHlLVnh1WTI5c2JtRnRaWE1vZEdWdGNDa2dQQzBnWXloY0ltUnBjM1JoYm1ObFhDSXNJRndpYzJOdmNtVmNJaXdnWENKQmJtNXZNbHdpS1Z4dVkzSmxZWFJsWDJScGMzUmZkbk5mWVhablUyTnZjbVZmY0dWeVZISmxZWFJ0Wlc1MEtIUmxiWEFzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lYMFJOVTA5Y0lpa3NJRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUd4dmIzQk1hWE4wTENCamIyeHZja3hwYzNRc0lITmxJRDBnVkZKVlJTbGNibU55WldGMFpWOXpZMjl5WlY5aVlYSndiRzkwWDNCbGNsUnlaV0YwYldWdWRDaDBaVzF3TENCbWFXZEVhWElzSUhCaGMzUmxNQ2h1WVcxbExDQmNJbDlFVFZOUFhDSXBMQ0JjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JHOXZjRXhwYzNRc0lHTnZiRzl5VEdsemRDbGNiblJsYlhBZ1BDMGdaR0YwWVNBbFBpVWdaSEJzZVhJNk9tMTFkR0YwWlNoa2FYTjBZVzVqWlNBOUlITjBZWEowTWlBdElITjBZWEowTVNrZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1pHbHpkR0Z1WTJVc0lHUlVRVWNzSUVGdWJtOHlLVnh1WTI5c2JtRnRaWE1vZEdWdGNDa2dQQzBnWXloY0ltUnBjM1JoYm1ObFhDSXNJRndpYzJOdmNtVmNJaXdnWENKQmJtNXZNbHdpS1Z4dVkzSmxZWFJsWDJScGMzUmZkbk5mWVhablUyTnZjbVZmY0dWeVZISmxZWFJ0Wlc1MEtIUmxiWEFzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lYMlJVUVVkY0lpa3NJRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUd4dmIzQk1hWE4wTENCamIyeHZja3hwYzNRc0lITmxJRDBnVkZKVlJTbGNibHh1WTNKbFlYUmxYM05qYjNKbFgySmhjbkJzYjNSZmNHVnlWSEpsWVhSdFpXNTBLSFJsYlhBc0lHWnBaMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRndpWDJSVVFVZGNJaWtzSUZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnNiMjl3VEdsemRDd2dZMjlzYjNKTWFYTjBLVnh1ZEdWdGNDQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZiWFYwWVhSbEtHUnBjM1JoYm1ObElEMGdjM1JoY25ReUlDMGdjM1JoY25ReEtTQWxQaVVnWkhCc2VYSTZPbk5sYkdWamRDaGthWE4wWVc1alpTd2dRVFE0TlN3Z1FXNXVieklwWEc1amIyeHVZVzFsY3loMFpXMXdLU0E4TFNCaktGd2laR2x6ZEdGdVkyVmNJaXdnWENKelkyOXlaVndpTENCY0lrRnVibTh5WENJcFhHNWpjbVZoZEdWZlpHbHpkRjkyYzE5aGRtZFRZMjl5WlY5d1pYSlVjbVZoZEcxbGJuUW9kR1Z0Y0N3Z1ptbG5SR2x5TENCd1lYTjBaVEFvYm1GdFpTd2dYQ0pmUVRRNE5Wd2lLU3dnWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JHOXZjRXhwYzNRc0lHTnZiRzl5VEdsemRDd2djMlVnUFNCVVVsVkZLVnh1WTNKbFlYUmxYM05qYjNKbFgySmhjbkJzYjNSZmNHVnlWSEpsWVhSdFpXNTBLSFJsYlhBc0lHWnBaMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRndpWDBFME9EVmNJaWtzSUZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnNiMjl3VEdsemRDd2dZMjlzYjNKTWFYTjBLVnh1WEc1MFpXMXdJRHd0SUdSaGRHRWdKVDRsSUdSd2JIbHlPanB0ZFhSaGRHVW9aR2x6ZEdGdVkyVWdQU0J6ZEdGeWRESWdMU0J6ZEdGeWRERXBJQ1UrSlNCa2NHeDVjam82YzJWc1pXTjBLR1JwYzNSaGJtTmxMQ0JrYVdabVgyUlVRVWRmUkUxVFR5d2dRVzV1YnpJcFhHNWpiMnh1WVcxbGN5aDBaVzF3S1NBOExTQmpLRndpWkdsemRHRnVZMlZjSWl3Z1hDSnpZMjl5WlZ3aUxDQmNJa0Z1Ym04eVhDSXBYRzVqY21WaGRHVmZaR2x6ZEY5MmMxOWhkbWRFYVdabVUyTnZjbVZmY0dWeVZISmxZWFJ0Wlc1MEtIUmxiWEFzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lYMlJVUVVkY0lpa3NJRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUd4dmIzQk1hWE4wTENCamIyeHZja3hwYzNRc0lITmxJRDBnVkZKVlJTbGNibHh1ZEdWdGNDQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZiWFYwWVhSbEtHUnBjM1JoYm1ObElEMGdjM1JoY25ReUlDMGdjM1JoY25ReEtTQWxQaVVnWkhCc2VYSTZPbk5sYkdWamRDaGthWE4wWVc1alpTd2daR2xtWmw5Qk5EZzFYMFJOVTA4c0lFRnVibTh5S1Z4dVkyOXNibUZ0WlhNb2RHVnRjQ2tnUEMwZ1l5aGNJbVJwYzNSaGJtTmxYQ0lzSUZ3aWMyTnZjbVZjSWl3Z1hDSkJibTV2TWx3aUtWeHVZM0psWVhSbFgyUnBjM1JmZG5OZllYWm5SR2xtWmxOamIzSmxYM0JsY2xSeVpXRjBiV1Z1ZENoMFpXMXdMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY0lsOUJORGcxWENJcExDQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JzYjI5d1RHbHpkQ3dnWTI5c2IzSk1hWE4wTENCelpTQTlJRlJTVlVVcFhHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub1Byb21vdGVyXFxcbmRhdGEgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpKVxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxhbGxcXCksIHVuaXF1ZShkYXRhJEFubm8yKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxccC1wXFwpLCBjKFxcUC1QXFwpKVxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxwLW5cXCksIGMoXFxQLU5cXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXG4tblxcKSwgYyhcXE4tTlxcKSlcblxuY29sb3JMaXN0IDwtIGNvbG9yTGlzdFByb21vdGVyXG5sb29wTGlzdCA8LSBjKFxcTi1OXFwsIFxcUC1OXFwsIFxcUC1QXFwpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIERNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0RNU09cXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9ETVNPXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRUQUcsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcblxuY3JlYXRlX3Njb3JlX2JhcnBsb3RfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0KVxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgQTQ4NSwgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdCwgc2UgPSBUUlVFKVxuY3JlYXRlX3Njb3JlX2JhcnBsb3RfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0E0ODVcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0KVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBkaWZmX2RUQUdfRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdEaWZmU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgZGlmZl9BNDg1X0RNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnRGlmZlNjb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9BNDg1XFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0LCBzZSA9IFRSVUUpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->

name <- \chromo_cons_annoPromoter\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
iterate_loop_functions(data, figDir, paste0(name, \_\, \all\), unique(data$Anno2))
iterate_loop_functions(data, figDir, paste0(name, \_\, \p-p\), c(\P-P\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \p-n\), c(\P-N\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \n-n\), c(\N-N\))

colorList <- colorListPromoter
loopList <- c(\N-N\, \P-N\, \P-P\)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_DMSO\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_DMSO\), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                     loopList, colorList, se = TRUE)

create_score_barplot_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                      loopList, colorList)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                     loopList, colorList, se = TRUE)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                     loopList, colorList, se = TRUE)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVhHNXVZVzFsSUR3dElGeGNZMmh5YjIxdlgyTnZibk5mWVc1dWIxQnliMjF2ZEdWeVhGeGNibVJoZEdFZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lIQmhjM1JsTUNodVlXMWxMQ0JjWEM1MGMzWmNYQ2twS1Z4dWFYUmxjbUYwWlY5c2IyOXdYMloxYm1OMGFXOXVjeWhrWVhSaExDQm1hV2RFYVhJc0lIQmhjM1JsTUNodVlXMWxMQ0JjWEY5Y1hDd2dYRnhoYkd4Y1hDa3NJSFZ1YVhGMVpTaGtZWFJoSkVGdWJtOHlLU2xjYm1sMFpYSmhkR1ZmYkc5dmNGOW1kVzVqZEdsdmJuTW9aR0YwWVN3Z1ptbG5SR2x5TENCd1lYTjBaVEFvYm1GdFpTd2dYRnhmWEZ3c0lGeGNjQzF3WEZ3cExDQmpLRnhjVUMxUVhGd3BLVnh1YVhSbGNtRjBaVjlzYjI5d1gyWjFibU4wYVc5dWN5aGtZWFJoTENCbWFXZEVhWElzSUhCaGMzUmxNQ2h1WVcxbExDQmNYRjljWEN3Z1hGeHdMVzVjWENrc0lHTW9YRnhRTFU1Y1hDa3BYRzVwZEdWeVlYUmxYMnh2YjNCZlpuVnVZM1JwYjI1ektHUmhkR0VzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGeGNYMXhjTENCY1hHNHRibHhjS1N3Z1l5aGNYRTR0VGx4Y0tTbGNibHh1WTI5c2IzSk1hWE4wSUR3dElHTnZiRzl5VEdsemRGQnliMjF2ZEdWeVhHNXNiMjl3VEdsemRDQThMU0JqS0Z4Y1RpMU9YRndzSUZ4Y1VDMU9YRndzSUZ4Y1VDMVFYRndwWEc1Y2JuUmxiWEFnUEMwZ1pHRjBZU0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hrYVhOMFlXNWpaU0E5SUhOMFlYSjBNaUF0SUhOMFlYSjBNU2tnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWkdsemRHRnVZMlVzSUVSTlUwOHNJRUZ1Ym04eUtWeHVZMjlzYm1GdFpYTW9kR1Z0Y0NrZ1BDMGdZeWhjWEdScGMzUmhibU5sWEZ3c0lGeGNjMk52Y21WY1hDd2dYRnhCYm01dk1seGNLVnh1WTNKbFlYUmxYMlJwYzNSZmRuTmZZWFpuVTJOdmNtVmZjR1Z5VkhKbFlYUnRaVzUwS0hSbGJYQXNJR1pwWjBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gwUk5VMDljWENrc0lGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3h2YjNCTWFYTjBMQ0JqYjJ4dmNreHBjM1FzSUhObElEMGdWRkpWUlNsY2JtTnlaV0YwWlY5elkyOXlaVjlpWVhKd2JHOTBYM0JsY2xSeVpXRjBiV1Z1ZENoMFpXMXdMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY1hGOUVUVk5QWEZ3cExDQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYkc5dmNFeHBjM1FzSUdOdmJHOXlUR2x6ZENsY2JuUmxiWEFnUEMwZ1pHRjBZU0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hrYVhOMFlXNWpaU0E5SUhOMFlYSjBNaUF0SUhOMFlYSjBNU2tnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWkdsemRHRnVZMlVzSUdSVVFVY3NJRUZ1Ym04eUtWeHVZMjlzYm1GdFpYTW9kR1Z0Y0NrZ1BDMGdZeWhjWEdScGMzUmhibU5sWEZ3c0lGeGNjMk52Y21WY1hDd2dYRnhCYm01dk1seGNLVnh1WTNKbFlYUmxYMlJwYzNSZmRuTmZZWFpuVTJOdmNtVmZjR1Z5VkhKbFlYUnRaVzUwS0hSbGJYQXNJR1pwWjBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gyUlVRVWRjWENrc0lGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3h2YjNCTWFYTjBMQ0JqYjJ4dmNreHBjM1FzSUhObElEMGdWRkpWUlNsY2JseHVZM0psWVhSbFgzTmpiM0psWDJKaGNuQnNiM1JmY0dWeVZISmxZWFJ0Wlc1MEtIUmxiWEFzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGeGNYMlJVUVVkY1hDa3NJRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCc2IyOXdUR2x6ZEN3Z1kyOXNiM0pNYVhOMEtWeHVkR1Z0Y0NBOExTQmtZWFJoSUNVK0pTQmtjR3g1Y2pvNmJYVjBZWFJsS0dScGMzUmhibU5sSUQwZ2MzUmhjblF5SUMwZ2MzUmhjblF4S1NBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoa2FYTjBZVzVqWlN3Z1FUUTROU3dnUVc1dWJ6SXBYRzVqYjJ4dVlXMWxjeWgwWlcxd0tTQThMU0JqS0Z4Y1pHbHpkR0Z1WTJWY1hDd2dYRnh6WTI5eVpWeGNMQ0JjWEVGdWJtOHlYRndwWEc1amNtVmhkR1ZmWkdsemRGOTJjMTloZG1kVFkyOXlaVjl3WlhKVWNtVmhkRzFsYm5Rb2RHVnRjQ3dnWm1sblJHbHlMQ0J3WVhOMFpUQW9ibUZ0WlN3Z1hGeGZRVFE0TlZ4Y0tTd2dYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYkc5dmNFeHBjM1FzSUdOdmJHOXlUR2x6ZEN3Z2MyVWdQU0JVVWxWRktWeHVZM0psWVhSbFgzTmpiM0psWDJKaGNuQnNiM1JmY0dWeVZISmxZWFJ0Wlc1MEtIUmxiWEFzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGeGNYMEUwT0RWY1hDa3NJRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCc2IyOXdUR2x6ZEN3Z1kyOXNiM0pNYVhOMEtWeHVYRzUwWlcxd0lEd3RJR1JoZEdFZ0pUNGxJR1J3YkhseU9qcHRkWFJoZEdVb1pHbHpkR0Z1WTJVZ1BTQnpkR0Z5ZERJZ0xTQnpkR0Z5ZERFcElDVStKU0JrY0d4NWNqbzZjMlZzWldOMEtHUnBjM1JoYm1ObExDQmthV1ptWDJSVVFVZGZSRTFUVHl3Z1FXNXVieklwWEc1amIyeHVZVzFsY3loMFpXMXdLU0E4TFNCaktGeGNaR2x6ZEdGdVkyVmNYQ3dnWEZ4elkyOXlaVnhjTENCY1hFRnVibTh5WEZ3cFhHNWpjbVZoZEdWZlpHbHpkRjkyYzE5aGRtZEVhV1ptVTJOdmNtVmZjR1Z5VkhKbFlYUnRaVzUwS0hSbGJYQXNJR1pwWjBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gyUlVRVWRjWENrc0lGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3h2YjNCTWFYTjBMQ0JqYjJ4dmNreHBjM1FzSUhObElEMGdWRkpWUlNsY2JseHVkR1Z0Y0NBOExTQmtZWFJoSUNVK0pTQmtjR3g1Y2pvNmJYVjBZWFJsS0dScGMzUmhibU5sSUQwZ2MzUmhjblF5SUMwZ2MzUmhjblF4S1NBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoa2FYTjBZVzVqWlN3Z1pHbG1abDlCTkRnMVgwUk5VMDhzSUVGdWJtOHlLVnh1WTI5c2JtRnRaWE1vZEdWdGNDa2dQQzBnWXloY1hHUnBjM1JoYm1ObFhGd3NJRnhjYzJOdmNtVmNYQ3dnWEZ4QmJtNXZNbHhjS1Z4dVkzSmxZWFJsWDJScGMzUmZkbk5mWVhablJHbG1abE5qYjNKbFgzQmxjbFJ5WldGMGJXVnVkQ2gwWlcxd0xDQm1hV2RFYVhJc0lIQmhjM1JsTUNodVlXMWxMQ0JjWEY5Qk5EZzFYRndwTENCY2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnNiMjl3VEdsemRDd2dZMjlzYjNKTWFYTjBMQ0J6WlNBOUlGUlNWVVVwWEc1Z1lHQmNibUJnWUNKOSAtLT5cblxuYGBgclxuYGBgclxuXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub1Byb21vdGVyXFxcbmRhdGEgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpKVxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxhbGxcXCksIHVuaXF1ZShkYXRhJEFubm8yKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxccC1wXFwpLCBjKFxcUC1QXFwpKVxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxwLW5cXCksIGMoXFxQLU5cXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXG4tblxcKSwgYyhcXE4tTlxcKSlcblxuY29sb3JMaXN0IDwtIGNvbG9yTGlzdFByb21vdGVyXG5sb29wTGlzdCA8LSBjKFxcTi1OXFwsIFxcUC1OXFwsIFxcUC1QXFwpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIERNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0RNU09cXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9ETVNPXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRUQUcsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcblxuY3JlYXRlX3Njb3JlX2JhcnBsb3RfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0KVxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgQTQ4NSwgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdCwgc2UgPSBUUlVFKVxuY3JlYXRlX3Njb3JlX2JhcnBsb3RfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0E0ODVcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0KVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBkaWZmX2RUQUdfRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdEaWZmU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgZGlmZl9BNDg1X0RNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnRGlmZlNjb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9BNDg1XFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0LCBzZSA9IFRSVUUpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub1Byb21vdGVyXFxcbmRhdGEgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpKVxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxhbGxcXCksIHVuaXF1ZShkYXRhJEFubm8yKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxccC1wXFwpLCBjKFxcUC1QXFwpKVxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxwLW5cXCksIGMoXFxQLU5cXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXG4tblxcKSwgYyhcXE4tTlxcKSlcblxuY29sb3JMaXN0IDwtIGNvbG9yTGlzdFByb21vdGVyXG5sb29wTGlzdCA8LSBjKFxcTi1OXFwsIFxcUC1OXFwsIFxcUC1QXFwpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIERNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0RNU09cXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9ETVNPXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRUQUcsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcblxuY3JlYXRlX3Njb3JlX2JhcnBsb3RfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0KVxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgQTQ4NSwgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdCwgc2UgPSBUUlVFKVxuY3JlYXRlX3Njb3JlX2JhcnBsb3RfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0E0ODVcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0KVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBkaWZmX2RUQUdfRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdEaWZmU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgZGlmZl9BNDg1X0RNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnRGlmZlNjb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9BNDg1XFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0LCBzZSA9IFRSVUUpXG5gYGBcbmBgYCJ9 -->

```r
```r

name <- \chromo_cons_annoPromoter\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
iterate_loop_functions(data, figDir, paste0(name, \_\, \all\), unique(data$Anno2))
iterate_loop_functions(data, figDir, paste0(name, \_\, \p-p\), c(\P-P\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \p-n\), c(\P-N\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \n-n\), c(\N-N\))

colorList <- colorListPromoter
loopList <- c(\N-N\, \P-N\, \P-P\)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_DMSO\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_DMSO\), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                     loopList, colorList, se = TRUE)

create_score_barplot_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                      loopList, colorList)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                     loopList, colorList, se = TRUE)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                     loopList, colorList, se = TRUE)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### 50kb vs 200 kb

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVibUZ0WlNBOExTQmNJbU5vY205dGIxOWpiMjV6WDJGdWJtOUZibWhoYm1ObGNsd2lYRzVrWVhSaElEd3RJR1p5WldGa0tHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWENJdWRITjJYQ0lwS1NsY2JtbDBaWEpoZEdWZmJHOXZjRjltZFc1amRHbHZibk1vWkdGMFlTd2dabWxuUkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWENKZlhDSXNJRndpWVd4c1hDSXBMQ0IxYm1seGRXVW9aR0YwWVNSQmJtNXZNaWtwWEc1cGRHVnlZWFJsWDJ4dmIzQmZablZ1WTNScGIyNXpLR1JoZEdFc0lHWnBaMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRndpWDF3aUxDQmNJbVV0WlZ3aUtTd2dZeWhjSWtVdFJWd2lLU2xjYm1sMFpYSmhkR1ZmYkc5dmNGOW1kVzVqZEdsdmJuTW9aR0YwWVN3Z1ptbG5SR2x5TENCd1lYTjBaVEFvYm1GdFpTd2dYQ0pmWENJc0lGd2laUzF1WENJcExDQmpLRndpUlMxT1hDSXBLVnh1YVhSbGNtRjBaVjlzYjI5d1gyWjFibU4wYVc5dWN5aGtZWFJoTENCbWFXZEVhWElzSUhCaGMzUmxNQ2h1WVcxbExDQmNJbDljSWl3Z1hDSnVMVzVjSWlrc0lHTW9YQ0pPTFU1Y0lpa3BYRzVjYm1OdmJHOXlUR2x6ZENBOExTQmpiMnh2Y2t4cGMzUkZibWhoYm1ObGNseHViRzl2Y0V4cGMzUWdQQzBnWXloY0lrNHRUbHdpTENCY0lrVXRUbHdpTENCY0lrVXRSVndpS1Z4dVhHNTBaVzF3SUR3dElHUmhkR0VnSlQ0bElHUndiSGx5T2pwdGRYUmhkR1VvWkdsemRHRnVZMlVnUFNCemRHRnlkRElnTFNCemRHRnlkREVwSUNVK0pTQmtjR3g1Y2pvNmMyVnNaV04wS0dScGMzUmhibU5sTENCRVRWTlBMQ0JCYm01dk1pbGNibU52Ykc1aGJXVnpLSFJsYlhBcElEd3RJR01vWENKa2FYTjBZVzVqWlZ3aUxDQmNJbk5qYjNKbFhDSXNJRndpUVc1dWJ6SmNJaWxjYm1OeVpXRjBaVjlrYVhOMFgzWnpYMkYyWjFOamIzSmxYM0JsY2xSeVpXRjBiV1Z1ZENoMFpXMXdMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY0lsOUVUVk5QWENJcExDQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JzYjI5d1RHbHpkQ3dnWTI5c2IzSk1hWE4wTENCelpTQTlJRlJTVlVVcFhHNWpjbVZoZEdWZmMyTnZjbVZmWW1GeWNHeHZkRjl3WlhKVWNtVmhkRzFsYm5Rb2RHVnRjQ3dnWm1sblJHbHlMQ0J3WVhOMFpUQW9ibUZ0WlN3Z1hDSmZSRTFUVDF3aUtTd2dYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUd4dmIzQk1hWE4wTENCamIyeHZja3hwYzNRcFhHNTBaVzF3SUR3dElHUmhkR0VnSlQ0bElHUndiSGx5T2pwdGRYUmhkR1VvWkdsemRHRnVZMlVnUFNCemRHRnlkRElnTFNCemRHRnlkREVwSUNVK0pTQmtjR3g1Y2pvNmMyVnNaV04wS0dScGMzUmhibU5sTENCa1ZFRkhMQ0JCYm01dk1pbGNibU52Ykc1aGJXVnpLSFJsYlhBcElEd3RJR01vWENKa2FYTjBZVzVqWlZ3aUxDQmNJbk5qYjNKbFhDSXNJRndpUVc1dWJ6SmNJaWxjYm1OeVpXRjBaVjlrYVhOMFgzWnpYMkYyWjFOamIzSmxYM0JsY2xSeVpXRjBiV1Z1ZENoMFpXMXdMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY0lsOWtWRUZIWENJcExDQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JzYjI5d1RHbHpkQ3dnWTI5c2IzSk1hWE4wTENCelpTQTlJRlJTVlVVcFhHNWpjbVZoZEdWZmMyTnZjbVZmWW1GeWNHeHZkRjl3WlhKVWNtVmhkRzFsYm5Rb2RHVnRjQ3dnWm1sblJHbHlMQ0J3WVhOMFpUQW9ibUZ0WlN3Z1hDSmZaRlJCUjF3aUtTd2dYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUd4dmIzQk1hWE4wTENCamIyeHZja3hwYzNRcFhHNTBaVzF3SUR3dElHUmhkR0VnSlQ0bElHUndiSGx5T2pwdGRYUmhkR1VvWkdsemRHRnVZMlVnUFNCemRHRnlkRElnTFNCemRHRnlkREVwSUNVK0pTQmtjR3g1Y2pvNmMyVnNaV04wS0dScGMzUmhibU5sTENCQk5EZzFMQ0JCYm01dk1pbGNibU52Ykc1aGJXVnpLSFJsYlhBcElEd3RJR01vWENKa2FYTjBZVzVqWlZ3aUxDQmNJbk5qYjNKbFhDSXNJRndpUVc1dWJ6SmNJaWxjYm1OeVpXRjBaVjlrYVhOMFgzWnpYMkYyWjFOamIzSmxYM0JsY2xSeVpXRjBiV1Z1ZENoMFpXMXdMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY0lsOUJORGcxWENJcExDQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JzYjI5d1RHbHpkQ3dnWTI5c2IzSk1hWE4wTENCelpTQTlJRlJTVlVVcFhHNWpjbVZoZEdWZmMyTnZjbVZmWW1GeWNHeHZkRjl3WlhKVWNtVmhkRzFsYm5Rb2RHVnRjQ3dnWm1sblJHbHlMQ0J3WVhOMFpUQW9ibUZ0WlN3Z1hDSmZRVFE0TlZ3aUtTd2dYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUd4dmIzQk1hWE4wTENCamIyeHZja3hwYzNRcFhHNWNiblJsYlhBZ1BDMGdaR0YwWVNBbFBpVWdaSEJzZVhJNk9tMTFkR0YwWlNoa2FYTjBZVzVqWlNBOUlITjBZWEowTWlBdElITjBZWEowTVNrZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1pHbHpkR0Z1WTJVc0lHUnBabVpmWkZSQlIxOUVUVk5QTENCQmJtNXZNaWxjYm1OdmJHNWhiV1Z6S0hSbGJYQXBJRHd0SUdNb1hDSmthWE4wWVc1alpWd2lMQ0JjSW5OamIzSmxYQ0lzSUZ3aVFXNXViekpjSWlsY2JtTnlaV0YwWlY5a2FYTjBYM1p6WDJGMlowUnBabVpUWTI5eVpWOXdaWEpVY21WaGRHMWxiblFvZEdWdGNDd2dabWxuUkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWENKZlpGUkJSMXdpS1N3Z1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiRzl2Y0V4cGMzUXNJR052Ykc5eVRHbHpkQ3dnYzJVZ1BTQlVVbFZGS1Z4dVhHNTBaVzF3SUR3dElHUmhkR0VnSlQ0bElHUndiSGx5T2pwdGRYUmhkR1VvWkdsemRHRnVZMlVnUFNCemRHRnlkRElnTFNCemRHRnlkREVwSUNVK0pTQmtjR3g1Y2pvNmMyVnNaV04wS0dScGMzUmhibU5sTENCa2FXWm1YMEUwT0RWZlJFMVRUeXdnUVc1dWJ6SXBYRzVqYjJ4dVlXMWxjeWgwWlcxd0tTQThMU0JqS0Z3aVpHbHpkR0Z1WTJWY0lpd2dYQ0p6WTI5eVpWd2lMQ0JjSWtGdWJtOHlYQ0lwWEc1amNtVmhkR1ZmWkdsemRGOTJjMTloZG1kRWFXWm1VMk52Y21WZmNHVnlWSEpsWVhSdFpXNTBLSFJsYlhBc0lHWnBaMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRndpWDBFME9EVmNJaWtzSUZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHeHZiM0JNYVhOMExDQmpiMnh2Y2t4cGMzUXNJSE5sSUQwZ1ZGSlZSU2xjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vRW5oYW5jZXJcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXGFsbFxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpKVxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxlLWVcXCksIGMoXFxFLUVcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXGUtblxcKSwgYyhcXEUtTlxcKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxcbi1uXFwpLCBjKFxcTi1OXFwpKVxuXG5jb2xvckxpc3QgPC0gY29sb3JMaXN0RW5oYW5jZXJcbmxvb3BMaXN0IDwtIGMoXFxOLU5cXCwgXFxFLU5cXCwgXFxFLUVcXClcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfRE1TT1xcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdCwgc2UgPSBUUlVFKVxuY3JlYXRlX3Njb3JlX2JhcnBsb3RfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0RNU09cXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0KVxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgZFRBRywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfZFRBR1xcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdCwgc2UgPSBUUlVFKVxuY3JlYXRlX3Njb3JlX2JhcnBsb3RfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0KVxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgQTQ4NSwgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdCwgc2UgPSBUUlVFKVxuY3JlYXRlX3Njb3JlX2JhcnBsb3RfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0E0ODVcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0KVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBkaWZmX2RUQUdfRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdEaWZmU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgZGlmZl9BNDg1X0RNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnRGlmZlNjb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9BNDg1XFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0LCBzZSA9IFRSVUUpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
name <- \chromo_cons_annoEnhancer\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
iterate_loop_functions(data, figDir, paste0(name, \_\, \all\), unique(data$Anno2))
iterate_loop_functions(data, figDir, paste0(name, \_\, \e-e\), c(\E-E\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \e-n\), c(\E-N\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \n-n\), c(\N-N\))

colorList <- colorListEnhancer
loopList <- c(\N-N\, \E-N\, \E-E\)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_DMSO\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_DMSO\), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                      loopList, colorList)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                     loopList, colorList, se = TRUE)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                     loopList, colorList, se = TRUE)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJtRnRaU0E4TFNCY1hHTm9jbTl0YjE5amIyNXpYMkZ1Ym05RmJtaGhibU5sY2x4Y1hHNWtZWFJoSUR3dElHWnlaV0ZrS0dobGNtVW9ZMjl1YzJWdWMzVnpSR2x5TENCd1lYTjBaVEFvYm1GdFpTd2dYRnd1ZEhOMlhGd3BLU2xjYm1sMFpYSmhkR1ZmYkc5dmNGOW1kVzVqZEdsdmJuTW9aR0YwWVN3Z1ptbG5SR2x5TENCd1lYTjBaVEFvYm1GdFpTd2dYRnhmWEZ3c0lGeGNZV3hzWEZ3cExDQjFibWx4ZFdVb1pHRjBZU1JCYm01dk1pa3BYRzVwZEdWeVlYUmxYMnh2YjNCZlpuVnVZM1JwYjI1ektHUmhkR0VzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGeGNYMXhjTENCY1hHVXRaVnhjS1N3Z1l5aGNYRVV0UlZ4Y0tTbGNibWwwWlhKaGRHVmZiRzl2Y0Y5bWRXNWpkR2x2Ym5Nb1pHRjBZU3dnWm1sblJHbHlMQ0J3WVhOMFpUQW9ibUZ0WlN3Z1hGeGZYRndzSUZ4Y1pTMXVYRndwTENCaktGeGNSUzFPWEZ3cEtWeHVhWFJsY21GMFpWOXNiMjl3WDJaMWJtTjBhVzl1Y3loa1lYUmhMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY1hGOWNYQ3dnWEZ4dUxXNWNYQ2tzSUdNb1hGeE9MVTVjWENrcFhHNWNibU52Ykc5eVRHbHpkQ0E4TFNCamIyeHZja3hwYzNSRmJtaGhibU5sY2x4dWJHOXZjRXhwYzNRZ1BDMGdZeWhjWEU0dFRseGNMQ0JjWEVVdFRseGNMQ0JjWEVVdFJWeGNLVnh1WEc1MFpXMXdJRHd0SUdSaGRHRWdKVDRsSUdSd2JIbHlPanB0ZFhSaGRHVW9aR2x6ZEdGdVkyVWdQU0J6ZEdGeWRESWdMU0J6ZEdGeWRERXBJQ1UrSlNCa2NHeDVjam82YzJWc1pXTjBLR1JwYzNSaGJtTmxMQ0JFVFZOUExDQkJibTV2TWlsY2JtTnZiRzVoYldWektIUmxiWEFwSUR3dElHTW9YRnhrYVhOMFlXNWpaVnhjTENCY1hITmpiM0psWEZ3c0lGeGNRVzV1YnpKY1hDbGNibU55WldGMFpWOWthWE4wWDNaelgyRjJaMU5qYjNKbFgzQmxjbFJ5WldGMGJXVnVkQ2gwWlcxd0xDQm1hV2RFYVhJc0lIQmhjM1JsTUNodVlXMWxMQ0JjWEY5RVRWTlBYRndwTENCY2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnNiMjl3VEdsemRDd2dZMjlzYjNKTWFYTjBMQ0J6WlNBOUlGUlNWVVVwWEc1amNtVmhkR1ZmYzJOdmNtVmZZbUZ5Y0d4dmRGOXdaWEpVY21WaGRHMWxiblFvZEdWdGNDd2dabWxuUkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWEZ4ZlJFMVRUMXhjS1N3Z1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3h2YjNCTWFYTjBMQ0JqYjJ4dmNreHBjM1FwWEc1MFpXMXdJRHd0SUdSaGRHRWdKVDRsSUdSd2JIbHlPanB0ZFhSaGRHVW9aR2x6ZEdGdVkyVWdQU0J6ZEdGeWRESWdMU0J6ZEdGeWRERXBJQ1UrSlNCa2NHeDVjam82YzJWc1pXTjBLR1JwYzNSaGJtTmxMQ0JrVkVGSExDQkJibTV2TWlsY2JtTnZiRzVoYldWektIUmxiWEFwSUR3dElHTW9YRnhrYVhOMFlXNWpaVnhjTENCY1hITmpiM0psWEZ3c0lGeGNRVzV1YnpKY1hDbGNibU55WldGMFpWOWthWE4wWDNaelgyRjJaMU5qYjNKbFgzQmxjbFJ5WldGMGJXVnVkQ2gwWlcxd0xDQm1hV2RFYVhJc0lIQmhjM1JsTUNodVlXMWxMQ0JjWEY5a1ZFRkhYRndwTENCY2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnNiMjl3VEdsemRDd2dZMjlzYjNKTWFYTjBMQ0J6WlNBOUlGUlNWVVVwWEc1amNtVmhkR1ZmYzJOdmNtVmZZbUZ5Y0d4dmRGOXdaWEpVY21WaGRHMWxiblFvZEdWdGNDd2dabWxuUkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWEZ4ZlpGUkJSMXhjS1N3Z1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3h2YjNCTWFYTjBMQ0JqYjJ4dmNreHBjM1FwWEc1MFpXMXdJRHd0SUdSaGRHRWdKVDRsSUdSd2JIbHlPanB0ZFhSaGRHVW9aR2x6ZEdGdVkyVWdQU0J6ZEdGeWRESWdMU0J6ZEdGeWRERXBJQ1UrSlNCa2NHeDVjam82YzJWc1pXTjBLR1JwYzNSaGJtTmxMQ0JCTkRnMUxDQkJibTV2TWlsY2JtTnZiRzVoYldWektIUmxiWEFwSUR3dElHTW9YRnhrYVhOMFlXNWpaVnhjTENCY1hITmpiM0psWEZ3c0lGeGNRVzV1YnpKY1hDbGNibU55WldGMFpWOWthWE4wWDNaelgyRjJaMU5qYjNKbFgzQmxjbFJ5WldGMGJXVnVkQ2gwWlcxd0xDQm1hV2RFYVhJc0lIQmhjM1JsTUNodVlXMWxMQ0JjWEY5Qk5EZzFYRndwTENCY2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnNiMjl3VEdsemRDd2dZMjlzYjNKTWFYTjBMQ0J6WlNBOUlGUlNWVVVwWEc1amNtVmhkR1ZmYzJOdmNtVmZZbUZ5Y0d4dmRGOXdaWEpVY21WaGRHMWxiblFvZEdWdGNDd2dabWxuUkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWEZ4ZlFUUTROVnhjS1N3Z1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3h2YjNCTWFYTjBMQ0JqYjJ4dmNreHBjM1FwWEc1Y2JuUmxiWEFnUEMwZ1pHRjBZU0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hrYVhOMFlXNWpaU0E5SUhOMFlYSjBNaUF0SUhOMFlYSjBNU2tnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWkdsemRHRnVZMlVzSUdScFptWmZaRlJCUjE5RVRWTlBMQ0JCYm01dk1pbGNibU52Ykc1aGJXVnpLSFJsYlhBcElEd3RJR01vWEZ4a2FYTjBZVzVqWlZ4Y0xDQmNYSE5qYjNKbFhGd3NJRnhjUVc1dWJ6SmNYQ2xjYm1OeVpXRjBaVjlrYVhOMFgzWnpYMkYyWjBScFptWlRZMjl5WlY5d1pYSlVjbVZoZEcxbGJuUW9kR1Z0Y0N3Z1ptbG5SR2x5TENCd1lYTjBaVEFvYm1GdFpTd2dYRnhmWkZSQlIxeGNLU3dnWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JHOXZjRXhwYzNRc0lHTnZiRzl5VEdsemRDd2djMlVnUFNCVVVsVkZLVnh1WEc1MFpXMXdJRHd0SUdSaGRHRWdKVDRsSUdSd2JIbHlPanB0ZFhSaGRHVW9aR2x6ZEdGdVkyVWdQU0J6ZEdGeWRESWdMU0J6ZEdGeWRERXBJQ1UrSlNCa2NHeDVjam82YzJWc1pXTjBLR1JwYzNSaGJtTmxMQ0JrYVdabVgwRTBPRFZmUkUxVFR5d2dRVzV1YnpJcFhHNWpiMnh1WVcxbGN5aDBaVzF3S1NBOExTQmpLRnhjWkdsemRHRnVZMlZjWEN3Z1hGeHpZMjl5WlZ4Y0xDQmNYRUZ1Ym04eVhGd3BYRzVqY21WaGRHVmZaR2x6ZEY5MmMxOWhkbWRFYVdabVUyTnZjbVZmY0dWeVZISmxZWFJ0Wlc1MEtIUmxiWEFzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGeGNYMEUwT0RWY1hDa3NJRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUd4dmIzQk1hWE4wTENCamIyeHZja3hwYzNRc0lITmxJRDBnVkZKVlJTbGNibUJnWUZ4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG5gYGByXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0VuaGFuY2VyXFxcbmRhdGEgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpKVxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxhbGxcXCksIHVuaXF1ZShkYXRhJEFubm8yKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxcZS1lXFwpLCBjKFxcRS1FXFwpKVxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxlLW5cXCksIGMoXFxFLU5cXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXG4tblxcKSwgYyhcXE4tTlxcKSlcblxuY29sb3JMaXN0IDwtIGNvbG9yTGlzdEVuaGFuY2VyXG5sb29wTGlzdCA8LSBjKFxcTi1OXFwsIFxcRS1OXFwsIFxcRS1FXFwpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIERNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0RNU09cXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9ETVNPXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRUQUcsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIEE0ODUsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0E0ODVcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9BNDg1XFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgZGlmZl9kVEFHX0RNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnRGlmZlNjb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0LCBzZSA9IFRSVUUpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRpZmZfQTQ4NV9ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdCwgc2UgPSBUUlVFKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9FbmhhbmNlclxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxcYWxsXFwpLCB1bmlxdWUoZGF0YSRBbm5vMikpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXGUtZVxcKSwgYyhcXEUtRVxcKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxcZS1uXFwpLCBjKFxcRS1OXFwpKVxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxuLW5cXCksIGMoXFxOLU5cXCkpXG5cbmNvbG9yTGlzdCA8LSBjb2xvckxpc3RFbmhhbmNlclxubG9vcExpc3QgPC0gYyhcXE4tTlxcLCBcXEUtTlxcLCBcXEUtRVxcKVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9ETVNPXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0LCBzZSA9IFRSVUUpXG5jcmVhdGVfc2NvcmVfYmFycGxvdF9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfRE1TT1xcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QpXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBkVEFHLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0LCBzZSA9IFRSVUUpXG5jcmVhdGVfc2NvcmVfYmFycGxvdF9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfZFRBR1xcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QpXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBBNDg1LCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9BNDg1XFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0LCBzZSA9IFRSVUUpXG5jcmVhdGVfc2NvcmVfYmFycGxvdF9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRpZmZfZFRBR19ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfZFRBR1xcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdCwgc2UgPSBUUlVFKVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBkaWZmX0E0ODVfRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdEaWZmU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0E0ODVcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmBgYFxuYGBgIn0= -->

```r
```r
name <- \chromo_cons_annoEnhancer\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
iterate_loop_functions(data, figDir, paste0(name, \_\, \all\), unique(data$Anno2))
iterate_loop_functions(data, figDir, paste0(name, \_\, \e-e\), c(\E-E\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \e-n\), c(\E-N\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \n-n\), c(\N-N\))

colorList <- colorListEnhancer
loopList <- c(\N-N\, \E-N\, \E-E\)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_DMSO\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_DMSO\), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                      loopList, colorList)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                     loopList, colorList, se = TRUE)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                     loopList, colorList, se = TRUE)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### One feature annotation - promoter

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVibUZ0WlNBOExTQmNJbU5vY205dGIxOWpiMjV6WDJGdWJtOVRkSEoxWTNSMWNtVmNJbHh1WkdGMFlTQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ3aUxuUnpkbHdpS1NrcFhHNXBkR1Z5WVhSbFgyeHZiM0JmWm5WdVkzUnBiMjV6S0dSaGRHRXNJR1pwWjBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ3aVgxd2lMQ0JjSW1Gc2JGd2lLU3dnZFc1cGNYVmxLR1JoZEdFa1FXNXVieklwS1Z4dWFYUmxjbUYwWlY5c2IyOXdYMloxYm1OMGFXOXVjeWhrWVhSaExDQm1hV2RFYVhJc0lIQmhjM1JsTUNodVlXMWxMQ0JjSWw5Y0lpd2dYQ0p6TFhOY0lpa3NJR01vWENKVExWTmNJaWtwWEc1cGRHVnlZWFJsWDJ4dmIzQmZablZ1WTNScGIyNXpLR1JoZEdFc0lHWnBaMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRndpWDF3aUxDQmNJbk10Ymx3aUtTd2dZeWhjSWxNdFRsd2lLU2xjYm1sMFpYSmhkR1ZmYkc5dmNGOW1kVzVqZEdsdmJuTW9aR0YwWVN3Z1ptbG5SR2x5TENCd1lYTjBaVEFvYm1GdFpTd2dYQ0pmWENJc0lGd2liaTF1WENJcExDQmpLRndpVGkxT1hDSXBLVnh1WEc1amIyeHZja3hwYzNRZ1BDMGdZMjlzYjNKTWFYTjBVM1J5ZFdOMGRYSmxYRzVzYjI5d1RHbHpkQ0E4TFNCaktGd2lUaTFPWENJc0lGd2lVeTFPWENJc0lGd2lVeTFUWENJcFhHNWNiblJsYlhBZ1BDMGdaR0YwWVNBbFBpVWdaSEJzZVhJNk9tMTFkR0YwWlNoa2FYTjBZVzVqWlNBOUlITjBZWEowTWlBdElITjBZWEowTVNrZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1pHbHpkR0Z1WTJVc0lFUk5VMDhzSUVGdWJtOHlLVnh1WTI5c2JtRnRaWE1vZEdWdGNDa2dQQzBnWXloY0ltUnBjM1JoYm1ObFhDSXNJRndpYzJOdmNtVmNJaXdnWENKQmJtNXZNbHdpS1Z4dVkzSmxZWFJsWDJScGMzUmZkbk5mWVhablUyTnZjbVZmY0dWeVZISmxZWFJ0Wlc1MEtIUmxiWEFzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lYMFJOVTA5Y0lpa3NJRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUd4dmIzQk1hWE4wTENCamIyeHZja3hwYzNRc0lITmxJRDBnVkZKVlJTbGNibU55WldGMFpWOXpZMjl5WlY5aVlYSndiRzkwWDNCbGNsUnlaV0YwYldWdWRDaDBaVzF3TENCbWFXZEVhWElzSUhCaGMzUmxNQ2h1WVcxbExDQmNJbDlFVFZOUFhDSXBMQ0JjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JHOXZjRXhwYzNRc0lHTnZiRzl5VEdsemRDbGNiblJsYlhBZ1BDMGdaR0YwWVNBbFBpVWdaSEJzZVhJNk9tMTFkR0YwWlNoa2FYTjBZVzVqWlNBOUlITjBZWEowTWlBdElITjBZWEowTVNrZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1pHbHpkR0Z1WTJVc0lHUlVRVWNzSUVGdWJtOHlLVnh1WTI5c2JtRnRaWE1vZEdWdGNDa2dQQzBnWXloY0ltUnBjM1JoYm1ObFhDSXNJRndpYzJOdmNtVmNJaXdnWENKQmJtNXZNbHdpS1Z4dVkzSmxZWFJsWDJScGMzUmZkbk5mWVhablUyTnZjbVZmY0dWeVZISmxZWFJ0Wlc1MEtIUmxiWEFzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lYMlJVUVVkY0lpa3NJRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUd4dmIzQk1hWE4wTENCamIyeHZja3hwYzNRc0lITmxJRDBnVkZKVlJTbGNibU55WldGMFpWOXpZMjl5WlY5aVlYSndiRzkwWDNCbGNsUnlaV0YwYldWdWRDaDBaVzF3TENCbWFXZEVhWElzSUhCaGMzUmxNQ2h1WVcxbExDQmNJbDlrVkVGSFhDSXBMQ0JjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JHOXZjRXhwYzNRc0lHTnZiRzl5VEdsemRDbGNiblJsYlhBZ1BDMGdaR0YwWVNBbFBpVWdaSEJzZVhJNk9tMTFkR0YwWlNoa2FYTjBZVzVqWlNBOUlITjBZWEowTWlBdElITjBZWEowTVNrZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1pHbHpkR0Z1WTJVc0lFRTBPRFVzSUVGdWJtOHlLVnh1WTI5c2JtRnRaWE1vZEdWdGNDa2dQQzBnWXloY0ltUnBjM1JoYm1ObFhDSXNJRndpYzJOdmNtVmNJaXdnWENKQmJtNXZNbHdpS1Z4dVkzSmxZWFJsWDJScGMzUmZkbk5mWVhablUyTnZjbVZmY0dWeVZISmxZWFJ0Wlc1MEtIUmxiWEFzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lYMEUwT0RWY0lpa3NJRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUd4dmIzQk1hWE4wTENCamIyeHZja3hwYzNRc0lITmxJRDBnVkZKVlJTbGNibU55WldGMFpWOXpZMjl5WlY5aVlYSndiRzkwWDNCbGNsUnlaV0YwYldWdWRDaDBaVzF3TENCbWFXZEVhWElzSUhCaGMzUmxNQ2h1WVcxbExDQmNJbDlCTkRnMVhDSXBMQ0JjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JHOXZjRXhwYzNRc0lHTnZiRzl5VEdsemRDbGNibHh1ZEdWdGNDQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZiWFYwWVhSbEtHUnBjM1JoYm1ObElEMGdjM1JoY25ReUlDMGdjM1JoY25ReEtTQWxQaVVnWkhCc2VYSTZPbk5sYkdWamRDaGthWE4wWVc1alpTd2daR2xtWmw5a1ZFRkhYMFJOVTA4c0lFRnVibTh5S1Z4dVkyOXNibUZ0WlhNb2RHVnRjQ2tnUEMwZ1l5aGNJbVJwYzNSaGJtTmxYQ0lzSUZ3aWMyTnZjbVZjSWl3Z1hDSkJibTV2TWx3aUtWeHVZM0psWVhSbFgyUnBjM1JmZG5OZllYWm5SR2xtWmxOamIzSmxYM0JsY2xSeVpXRjBiV1Z1ZENoMFpXMXdMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY0lsOWtWRUZIWENJcExDQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JzYjI5d1RHbHpkQ3dnWTI5c2IzSk1hWE4wTENCelpTQTlJRlJTVlVVcFhHNWNiblJsYlhBZ1BDMGdaR0YwWVNBbFBpVWdaSEJzZVhJNk9tMTFkR0YwWlNoa2FYTjBZVzVqWlNBOUlITjBZWEowTWlBdElITjBZWEowTVNrZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1pHbHpkR0Z1WTJVc0lHUnBabVpmUVRRNE5WOUVUVk5QTENCQmJtNXZNaWxjYm1OdmJHNWhiV1Z6S0hSbGJYQXBJRHd0SUdNb1hDSmthWE4wWVc1alpWd2lMQ0JjSW5OamIzSmxYQ0lzSUZ3aVFXNXViekpjSWlsY2JtTnlaV0YwWlY5a2FYTjBYM1p6WDJGMlowUnBabVpUWTI5eVpWOXdaWEpVY21WaGRHMWxiblFvZEdWdGNDd2dabWxuUkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWENKZlFUUTROVndpS1N3Z1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiRzl2Y0V4cGMzUXNJR052Ykc5eVRHbHpkQ3dnYzJVZ1BTQlVVbFZGS1Z4dVhHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9TdHJ1Y3R1cmVcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXGFsbFxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpKVxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxzLXNcXCksIGMoXFxTLVNcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXHMtblxcKSwgYyhcXFMtTlxcKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxcbi1uXFwpLCBjKFxcTi1OXFwpKVxuXG5jb2xvckxpc3QgPC0gY29sb3JMaXN0U3RydWN0dXJlXG5sb29wTGlzdCA8LSBjKFxcTi1OXFwsIFxcUy1OXFwsIFxcUy1TXFwpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIERNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0RNU09cXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9ETVNPXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRUQUcsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIEE0ODUsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0E0ODVcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9BNDg1XFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgZGlmZl9kVEFHX0RNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnRGlmZlNjb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0LCBzZSA9IFRSVUUpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRpZmZfQTQ4NV9ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdCwgc2UgPSBUUlVFKVxuXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
name <- \chromo_cons_annoStructure\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
iterate_loop_functions(data, figDir, paste0(name, \_\, \all\), unique(data$Anno2))
iterate_loop_functions(data, figDir, paste0(name, \_\, \s-s\), c(\S-S\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \s-n\), c(\S-N\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \n-n\), c(\N-N\))

colorList <- colorListStructure
loopList <- c(\N-N\, \S-N\, \S-S\)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_DMSO\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_DMSO\), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                      loopList, colorList)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                     loopList, colorList, se = TRUE)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                     loopList, colorList, se = TRUE)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJtRnRaU0E4TFNCY1hHTm9jbTl0YjE5amIyNXpYMkZ1Ym05VGRISjFZM1IxY21WY1hGeHVaR0YwWVNBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRnhjTG5SemRseGNLU2twWEc1cGRHVnlZWFJsWDJ4dmIzQmZablZ1WTNScGIyNXpLR1JoZEdFc0lHWnBaMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRnhjWDF4Y0xDQmNYR0ZzYkZ4Y0tTd2dkVzVwY1hWbEtHUmhkR0VrUVc1dWJ6SXBLVnh1YVhSbGNtRjBaVjlzYjI5d1gyWjFibU4wYVc5dWN5aGtZWFJoTENCbWFXZEVhWElzSUhCaGMzUmxNQ2h1WVcxbExDQmNYRjljWEN3Z1hGeHpMWE5jWENrc0lHTW9YRnhUTFZOY1hDa3BYRzVwZEdWeVlYUmxYMnh2YjNCZlpuVnVZM1JwYjI1ektHUmhkR0VzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGeGNYMXhjTENCY1hITXRibHhjS1N3Z1l5aGNYRk10VGx4Y0tTbGNibWwwWlhKaGRHVmZiRzl2Y0Y5bWRXNWpkR2x2Ym5Nb1pHRjBZU3dnWm1sblJHbHlMQ0J3WVhOMFpUQW9ibUZ0WlN3Z1hGeGZYRndzSUZ4Y2JpMXVYRndwTENCaktGeGNUaTFPWEZ3cEtWeHVYRzVqYjJ4dmNreHBjM1FnUEMwZ1kyOXNiM0pNYVhOMFUzUnlkV04wZFhKbFhHNXNiMjl3VEdsemRDQThMU0JqS0Z4Y1RpMU9YRndzSUZ4Y1V5MU9YRndzSUZ4Y1V5MVRYRndwWEc1Y2JuUmxiWEFnUEMwZ1pHRjBZU0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hrYVhOMFlXNWpaU0E5SUhOMFlYSjBNaUF0SUhOMFlYSjBNU2tnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWkdsemRHRnVZMlVzSUVSTlUwOHNJRUZ1Ym04eUtWeHVZMjlzYm1GdFpYTW9kR1Z0Y0NrZ1BDMGdZeWhjWEdScGMzUmhibU5sWEZ3c0lGeGNjMk52Y21WY1hDd2dYRnhCYm01dk1seGNLVnh1WTNKbFlYUmxYMlJwYzNSZmRuTmZZWFpuVTJOdmNtVmZjR1Z5VkhKbFlYUnRaVzUwS0hSbGJYQXNJR1pwWjBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gwUk5VMDljWENrc0lGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3h2YjNCTWFYTjBMQ0JqYjJ4dmNreHBjM1FzSUhObElEMGdWRkpWUlNsY2JtTnlaV0YwWlY5elkyOXlaVjlpWVhKd2JHOTBYM0JsY2xSeVpXRjBiV1Z1ZENoMFpXMXdMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY1hGOUVUVk5QWEZ3cExDQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYkc5dmNFeHBjM1FzSUdOdmJHOXlUR2x6ZENsY2JuUmxiWEFnUEMwZ1pHRjBZU0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hrYVhOMFlXNWpaU0E5SUhOMFlYSjBNaUF0SUhOMFlYSjBNU2tnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWkdsemRHRnVZMlVzSUdSVVFVY3NJRUZ1Ym04eUtWeHVZMjlzYm1GdFpYTW9kR1Z0Y0NrZ1BDMGdZeWhjWEdScGMzUmhibU5sWEZ3c0lGeGNjMk52Y21WY1hDd2dYRnhCYm01dk1seGNLVnh1WTNKbFlYUmxYMlJwYzNSZmRuTmZZWFpuVTJOdmNtVmZjR1Z5VkhKbFlYUnRaVzUwS0hSbGJYQXNJR1pwWjBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gyUlVRVWRjWENrc0lGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3h2YjNCTWFYTjBMQ0JqYjJ4dmNreHBjM1FzSUhObElEMGdWRkpWUlNsY2JtTnlaV0YwWlY5elkyOXlaVjlpWVhKd2JHOTBYM0JsY2xSeVpXRjBiV1Z1ZENoMFpXMXdMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY1hGOWtWRUZIWEZ3cExDQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYkc5dmNFeHBjM1FzSUdOdmJHOXlUR2x6ZENsY2JuUmxiWEFnUEMwZ1pHRjBZU0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hrYVhOMFlXNWpaU0E5SUhOMFlYSjBNaUF0SUhOMFlYSjBNU2tnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWkdsemRHRnVZMlVzSUVFME9EVXNJRUZ1Ym04eUtWeHVZMjlzYm1GdFpYTW9kR1Z0Y0NrZ1BDMGdZeWhjWEdScGMzUmhibU5sWEZ3c0lGeGNjMk52Y21WY1hDd2dYRnhCYm01dk1seGNLVnh1WTNKbFlYUmxYMlJwYzNSZmRuTmZZWFpuVTJOdmNtVmZjR1Z5VkhKbFlYUnRaVzUwS0hSbGJYQXNJR1pwWjBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gwRTBPRFZjWENrc0lGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3h2YjNCTWFYTjBMQ0JqYjJ4dmNreHBjM1FzSUhObElEMGdWRkpWUlNsY2JtTnlaV0YwWlY5elkyOXlaVjlpWVhKd2JHOTBYM0JsY2xSeVpXRjBiV1Z1ZENoMFpXMXdMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY1hGOUJORGcxWEZ3cExDQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYkc5dmNFeHBjM1FzSUdOdmJHOXlUR2x6ZENsY2JseHVkR1Z0Y0NBOExTQmtZWFJoSUNVK0pTQmtjR3g1Y2pvNmJYVjBZWFJsS0dScGMzUmhibU5sSUQwZ2MzUmhjblF5SUMwZ2MzUmhjblF4S1NBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoa2FYTjBZVzVqWlN3Z1pHbG1abDlrVkVGSFgwUk5VMDhzSUVGdWJtOHlLVnh1WTI5c2JtRnRaWE1vZEdWdGNDa2dQQzBnWXloY1hHUnBjM1JoYm1ObFhGd3NJRnhjYzJOdmNtVmNYQ3dnWEZ4QmJtNXZNbHhjS1Z4dVkzSmxZWFJsWDJScGMzUmZkbk5mWVhablJHbG1abE5qYjNKbFgzQmxjbFJ5WldGMGJXVnVkQ2gwWlcxd0xDQm1hV2RFYVhJc0lIQmhjM1JsTUNodVlXMWxMQ0JjWEY5a1ZFRkhYRndwTENCY2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnNiMjl3VEdsemRDd2dZMjlzYjNKTWFYTjBMQ0J6WlNBOUlGUlNWVVVwWEc1Y2JuUmxiWEFnUEMwZ1pHRjBZU0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hrYVhOMFlXNWpaU0E5SUhOMFlYSjBNaUF0SUhOMFlYSjBNU2tnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWkdsemRHRnVZMlVzSUdScFptWmZRVFE0TlY5RVRWTlBMQ0JCYm01dk1pbGNibU52Ykc1aGJXVnpLSFJsYlhBcElEd3RJR01vWEZ4a2FYTjBZVzVqWlZ4Y0xDQmNYSE5qYjNKbFhGd3NJRnhjUVc1dWJ6SmNYQ2xjYm1OeVpXRjBaVjlrYVhOMFgzWnpYMkYyWjBScFptWlRZMjl5WlY5d1pYSlVjbVZoZEcxbGJuUW9kR1Z0Y0N3Z1ptbG5SR2x5TENCd1lYTjBaVEFvYm1GdFpTd2dYRnhmUVRRNE5WeGNLU3dnWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JHOXZjRXhwYzNRc0lHTnZiRzl5VEdsemRDd2djMlVnUFNCVVVsVkZLVnh1WEc1Z1lHQmNibUJnWUNKOSAtLT5cblxuYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9TdHJ1Y3R1cmVcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXGFsbFxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpKVxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxzLXNcXCksIGMoXFxTLVNcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXHMtblxcKSwgYyhcXFMtTlxcKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxcbi1uXFwpLCBjKFxcTi1OXFwpKVxuXG5jb2xvckxpc3QgPC0gY29sb3JMaXN0U3RydWN0dXJlXG5sb29wTGlzdCA8LSBjKFxcTi1OXFwsIFxcUy1OXFwsIFxcUy1TXFwpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIERNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0RNU09cXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9ETVNPXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRUQUcsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIEE0ODUsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0E0ODVcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9BNDg1XFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgZGlmZl9kVEFHX0RNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnRGlmZlNjb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0LCBzZSA9IFRSVUUpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRpZmZfQTQ4NV9ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdCwgc2UgPSBUUlVFKVxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9TdHJ1Y3R1cmVcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXGFsbFxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpKVxuaXRlcmF0ZV9sb29wX2Z1bmN0aW9ucyhkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9cXCwgXFxzLXNcXCksIGMoXFxTLVNcXCkpXG5pdGVyYXRlX2xvb3BfZnVuY3Rpb25zKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX1xcLCBcXHMtblxcKSwgYyhcXFMtTlxcKSlcbml0ZXJhdGVfbG9vcF9mdW5jdGlvbnMoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfXFwsIFxcbi1uXFwpLCBjKFxcTi1OXFwpKVxuXG5jb2xvckxpc3QgPC0gY29sb3JMaXN0U3RydWN0dXJlXG5sb29wTGlzdCA8LSBjKFxcTi1OXFwsIFxcUy1OXFwsIFxcUy1TXFwpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIERNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0RNU09cXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9ETVNPXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRUQUcsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIEE0ODUsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50KHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0E0ODVcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BMaXN0LCBjb2xvckxpc3QsIHNlID0gVFJVRSlcbmNyZWF0ZV9zY29yZV9iYXJwbG90X3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9BNDg1XFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdClcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgZGlmZl9kVEFHX0RNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnRGlmZlNjb3JlX3BlclRyZWF0bWVudCh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHXFwpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wTGlzdCwgY29sb3JMaXN0LCBzZSA9IFRSVUUpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGRpZmZfQTQ4NV9ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnQodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NVxcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcExpc3QsIGNvbG9yTGlzdCwgc2UgPSBUUlVFKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
name <- \chromo_cons_annoStructure\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
iterate_loop_functions(data, figDir, paste0(name, \_\, \all\), unique(data$Anno2))
iterate_loop_functions(data, figDir, paste0(name, \_\, \s-s\), c(\S-S\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \s-n\), c(\S-N\))
iterate_loop_functions(data, figDir, paste0(name, \_\, \n-n\), c(\N-N\))

colorList <- colorListStructure
loopList <- c(\N-N\, \S-N\, \S-S\)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_DMSO\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_DMSO\), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                      loopList, colorList)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_dTAG\), 
                                     loopList, colorList, se = TRUE)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, \_A485\), 
                                     loopList, colorList, se = TRUE)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### One feature annotation - enhancer

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVaR0YwWVNBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z1hDSmphSEp2Ylc5ZlkyOXVjMTl6WTI5eVpTNTBjM1pjSWlrcElDVStKVnh1SUNCa2NHeDVjam82YlhWMFlYUmxLR1JwYzNSaGJtTmxJRDBnYzNSaGNuUXlJQzBnYzNSaGNuUXhMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJSEpsY3lBOUlHVnVaREVnTFNCemRHRnlkREVwWEc1Y2JuQXhJRHd0SUdkbmNHeHZkQ2hrWVhSaExDQmhaWE1vZUNBOUlHUnBjM1JoYm1ObExDQm1hV3hzSUQwZ1ptRmpkRzl5S0hKbGN5a3BLU0FyWEc0Z0lHZGxiMjFmYUdsemRHOW5jbUZ0S0dKcGJuZHBaSFJvSUQwZ05UQXdNREFzSUdGc2NHaGhJRDBnTVNrZ0sxeHVJQ0JzWVdKektIUnBkR3hsSUQwZ1hDSkVhWE4wY21saWRYUnBiMjRnYjJZZ1JHbHpkR0Z1WTJVZ1lua2dVbVZ6YjJ4MWRHbHZibHdpTEZ4dUlDQWdJQ0FnSUhnZ1BTQmNJa1JwYzNSaGJtTmxYQ0lzWEc0Z0lDQWdJQ0FnZVNBOUlGd2lRMjkxYm5SelhDSXBJQ3NnWEc0Z0lHWmhZMlYwWDNkeVlYQW9maUJ5WlhNc0lHNWpiMndnUFNBeExDQnpZMkZzWlhNZ1BTQmNJbVp5WldWY0lpa2dLeUJjYmlBZ2MyTmhiR1ZmZUY5amIyNTBhVzUxYjNWektHeGhZbVZzY3lBOUlHeGhZbVZzWDJ0aVgyMWlMQ0JzYVcxcGRITWdQU0JqS0RBc0lEVmxOaWtwSUNzZ1hHNGdJSFJvWlcxbFgyTnNZWE56YVdNb0tTQXJYRzRnSUhSb1pXMWxLR3hsWjJWdVpDNXdiM05wZEdsdmJpQTlJRndpYm05dVpWd2lMRnh1SUNBZ0lDQWdJQ0J3Ykc5MExuUnBkR3hsSUQwZ1pXeGxiV1Z1ZEY5MFpYaDBLSE5wZW1VZ1BTQTRLU2tnSUNNZ1VtVnRiM1psY3lCMGFHVWdiR1ZuWlc1a1hHNWNibkJ1Wnlob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tGd2lZMjl1YzJWdWMzVnpYMlJwYzNSZmNHVnlYM0psY3k1d2JtZGNJaWtwTENCY2JpQWdJQ0J5WlhNZ1BTQTJNREFzSUhWdWFYUnpJRDBnWENKcGJsd2lMQ0IzYVdSMGFDQTlJRE1zSUdobGFXZG9kQ0E5SURZcFhHNXdjbWx1ZENod01TbGNibVJsZGk1dlptWW9LVnh1WEc1d01pQThMU0JuWjNCc2IzUW9aR0YwWVN3Z1lXVnpLSGdnUFNCa2FYTjBZVzVqWlN3Z1ptbHNiQ0E5SUdaaFkzUnZjaWh5WlhNcEtTa2dLMXh1SUNCblpXOXRYMmhwYzNSdlozSmhiU2hpYVc1M2FXUjBhQ0E5SURVd01EQXdMQ0JoYkhCb1lTQTlJREVwSUN0Y2JpQWdiR0ZpY3loMGFYUnNaU0E5SUZ3aVJHbHpkSEpwWW5WMGFXOXVJRzltSUVScGMzUmhibU5sSUdKNUlGSmxjMjlzZFhScGIyNWNJaXhjYmlBZ0lDQWdJQ0I0SUQwZ1hDSkVhWE4wWVc1alpWd2lMRnh1SUNBZ0lDQWdJSGtnUFNCY0lrTnZkVzUwYzF3aUtTQXJJRnh1SUNCbVlXTmxkRjkzY21Gd0tINGdjbVZ6TENCdVkyOXNJRDBnTVN3Z2MyTmhiR1Z6SUQwZ1hDSm1jbVZsWENJcElDc2dYRzRnSUhOallXeGxYM2hmWTI5dWRHbHVkVzkxY3loc1lXSmxiSE1nUFNCc1lXSmxiRjlyWWw5dFlpd2diR2x0YVhSeklEMGdZeWd3TENBeVpUWXBLU0FySUZ4dUlDQjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0sxeHVJQ0IwYUdWdFpTaHNaV2RsYm1RdWNHOXphWFJwYjI0Z1BTQmNJbTV2Ym1WY0lpeGNiaUFnSUNBZ0lDQWdjR3h2ZEM1MGFYUnNaU0E5SUdWc1pXMWxiblJmZEdWNGRDaHphWHBsSUQwZ09Da3BJQ0FqSUZKbGJXOTJaWE1nZEdobElHeGxaMlZ1WkZ4dVhHNWNibkJ1Wnlob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tGd2lZMjl1YzJWdWMzVnpYMlJwYzNSZmNHVnlYM0psYzE4eWJXSXVjRzVuWENJcEtTd2dYRzRnSUNBZ2NtVnpJRDBnTmpBd0xDQjFibWwwY3lBOUlGd2lhVzVjSWl3Z2QybGtkR2dnUFNBekxDQm9aV2xuYUhRZ1BTQTJLVnh1Y0hKcGJuUW9jRElwWEc1a1pYWXViMlptS0NsY2JseHVYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmRhdGEgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfc2NvcmUudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICByZXMgPSBlbmQxIC0gc3RhcnQxKVxuXG5wMSA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBkaXN0YW5jZSwgZmlsbCA9IGZhY3RvcihyZXMpKSkgK1xuICBnZW9tX2hpc3RvZ3JhbShiaW53aWR0aCA9IDUwMDAwLCBhbHBoYSA9IDEpICtcbiAgbGFicyh0aXRsZSA9IFxcRGlzdHJpYnV0aW9uIG9mIERpc3RhbmNlIGJ5IFJlc29sdXRpb25cXCxcbiAgICAgICB4ID0gXFxEaXN0YW5jZVxcLFxuICAgICAgIHkgPSBcXENvdW50c1xcKSArIFxuICBmYWNldF93cmFwKH4gcmVzLCBuY29sID0gMSwgc2NhbGVzID0gXFxmcmVlXFwpICsgXG4gIHNjYWxlX3hfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYiwgbGltaXRzID0gYygwLCA1ZTYpKSArIFxuICB0aGVtZV9jbGFzc2ljKCkgK1xuICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXCxcbiAgICAgICAgcGxvdC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gOCkpICAjIFJlbW92ZXMgdGhlIGxlZ2VuZFxuXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChcXGNvbnNlbnN1c19kaXN0X3Blcl9yZXMucG5nXFwpKSwgXG4gICAgcmVzID0gNjAwLCB1bml0cyA9IFxcaW5cXCwgd2lkdGggPSAzLCBoZWlnaHQgPSA2KVxucHJpbnQocDEpXG5kZXYub2ZmKClcblxucDIgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZGlzdGFuY2UsIGZpbGwgPSBmYWN0b3IocmVzKSkpICtcbiAgZ2VvbV9oaXN0b2dyYW0oYmlud2lkdGggPSA1MDAwMCwgYWxwaGEgPSAxKSArXG4gIGxhYnModGl0bGUgPSBcXERpc3RyaWJ1dGlvbiBvZiBEaXN0YW5jZSBieSBSZXNvbHV0aW9uXFwsXG4gICAgICAgeCA9IFxcRGlzdGFuY2VcXCxcbiAgICAgICB5ID0gXFxDb3VudHNcXCkgKyBcbiAgZmFjZXRfd3JhcCh+IHJlcywgbmNvbCA9IDEsIHNjYWxlcyA9IFxcZnJlZVxcKSArIFxuICBzY2FsZV94X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIsIGxpbWl0cyA9IGMoMCwgMmU2KSkgKyBcbiAgdGhlbWVfY2xhc3NpYygpICtcbiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwsXG4gICAgICAgIHBsb3QudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDgpKSAgIyBSZW1vdmVzIHRoZSBsZWdlbmRcblxuXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChcXGNvbnNlbnN1c19kaXN0X3Blcl9yZXNfMm1iLnBuZ1xcKSksIFxuICAgIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gMywgaGVpZ2h0ID0gNilcbnByaW50KHAyKVxuZGV2Lm9mZigpXG5cblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
data <- fread(here(consensusDir, \chromo_cons_score.tsv\)) %>%
  dplyr::mutate(distance = start2 - start1,
                res = end1 - start1)

p1 <- ggplot(data, aes(x = distance, fill = factor(res))) +
  geom_histogram(binwidth = 50000, alpha = 1) +
  labs(title = \Distribution of Distance by Resolution\,
       x = \Distance\,
       y = \Counts\) + 
  facet_wrap(~ res, ncol = 1, scales = \free\) + 
  scale_x_continuous(labels = label_kb_mb, limits = c(0, 5e6)) + 
  theme_classic() +
  theme(legend.position = \none\,
        plot.title = element_text(size = 8))  # Removes the legend

png(here(figDir, paste0(\consensus_dist_per_res.png\)), 
    res = 600, units = \in\, width = 3, height = 6)
print(p1)
dev.off()

p2 <- ggplot(data, aes(x = distance, fill = factor(res))) +
  geom_histogram(binwidth = 50000, alpha = 1) +
  labs(title = \Distribution of Distance by Resolution\,
       x = \Distance\,
       y = \Counts\) + 
  facet_wrap(~ res, ncol = 1, scales = \free\) + 
  scale_x_continuous(labels = label_kb_mb, limits = c(0, 2e6)) + 
  theme_classic() +
  theme(legend.position = \none\,
        plot.title = element_text(size = 8))  # Removes the legend


png(here(figDir, paste0(\consensus_dist_per_res_2mb.png\)), 
    res = 600, units = \in\, width = 3, height = 6)
print(p2)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVpHRjBZU0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnWEZ4amFISnZiVzlmWTI5dWMxOXpZMjl5WlM1MGMzWmNYQ2twSUNVK0pWeHVJQ0JrY0d4NWNqbzZiWFYwWVhSbEtHUnBjM1JoYm1ObElEMGdjM1JoY25ReUlDMGdjM1JoY25ReExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lISmxjeUE5SUdWdVpERWdMU0J6ZEdGeWRERXBYRzVjYm5BeElEd3RJR2RuY0d4dmRDaGtZWFJoTENCaFpYTW9lQ0E5SUdScGMzUmhibU5sTENCbWFXeHNJRDBnWm1GamRHOXlLSEpsY3lrcEtTQXJYRzRnSUdkbGIyMWZhR2x6ZEc5bmNtRnRLR0pwYm5kcFpIUm9JRDBnTlRBd01EQXNJR0ZzY0doaElEMGdNU2tnSzF4dUlDQnNZV0p6S0hScGRHeGxJRDBnWEZ4RWFYTjBjbWxpZFhScGIyNGdiMllnUkdsemRHRnVZMlVnWW5rZ1VtVnpiMngxZEdsdmJseGNMRnh1SUNBZ0lDQWdJSGdnUFNCY1hFUnBjM1JoYm1ObFhGd3NYRzRnSUNBZ0lDQWdlU0E5SUZ4Y1EyOTFiblJ6WEZ3cElDc2dYRzRnSUdaaFkyVjBYM2R5WVhBb2ZpQnlaWE1zSUc1amIyd2dQU0F4TENCelkyRnNaWE1nUFNCY1hHWnlaV1ZjWENrZ0t5QmNiaUFnYzJOaGJHVmZlRjlqYjI1MGFXNTFiM1Z6S0d4aFltVnNjeUE5SUd4aFltVnNYMnRpWDIxaUxDQnNhVzFwZEhNZ1BTQmpLREFzSURWbE5pa3BJQ3NnWEc0Z0lIUm9aVzFsWDJOc1lYTnphV01vS1NBclhHNGdJSFJvWlcxbEtHeGxaMlZ1WkM1d2IzTnBkR2x2YmlBOUlGeGNibTl1WlZ4Y0xGeHVJQ0FnSUNBZ0lDQndiRzkwTG5ScGRHeGxJRDBnWld4bGJXVnVkRjkwWlhoMEtITnBlbVVnUFNBNEtTa2dJQ01nVW1WdGIzWmxjeUIwYUdVZ2JHVm5aVzVrWEc1Y2JuQnVaeWhvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0Z4Y1kyOXVjMlZ1YzNWelgyUnBjM1JmY0dWeVgzSmxjeTV3Ym1kY1hDa3BMQ0JjYmlBZ0lDQnlaWE1nUFNBMk1EQXNJSFZ1YVhSeklEMGdYRnhwYmx4Y0xDQjNhV1IwYUNBOUlETXNJR2hsYVdkb2RDQTlJRFlwWEc1d2NtbHVkQ2h3TVNsY2JtUmxkaTV2Wm1Zb0tWeHVYRzV3TWlBOExTQm5aM0JzYjNRb1pHRjBZU3dnWVdWektIZ2dQU0JrYVhOMFlXNWpaU3dnWm1sc2JDQTlJR1poWTNSdmNpaHlaWE1wS1NrZ0sxeHVJQ0JuWlc5dFgyaHBjM1J2WjNKaGJTaGlhVzUzYVdSMGFDQTlJRFV3TURBd0xDQmhiSEJvWVNBOUlERXBJQ3RjYmlBZ2JHRmljeWgwYVhSc1pTQTlJRnhjUkdsemRISnBZblYwYVc5dUlHOW1JRVJwYzNSaGJtTmxJR0o1SUZKbGMyOXNkWFJwYjI1Y1hDeGNiaUFnSUNBZ0lDQjRJRDBnWEZ4RWFYTjBZVzVqWlZ4Y0xGeHVJQ0FnSUNBZ0lIa2dQU0JjWEVOdmRXNTBjMXhjS1NBcklGeHVJQ0JtWVdObGRGOTNjbUZ3S0g0Z2NtVnpMQ0J1WTI5c0lEMGdNU3dnYzJOaGJHVnpJRDBnWEZ4bWNtVmxYRndwSUNzZ1hHNGdJSE5qWVd4bFgzaGZZMjl1ZEdsdWRXOTFjeWhzWVdKbGJITWdQU0JzWVdKbGJGOXJZbDl0WWl3Z2JHbHRhWFJ6SUQwZ1l5Z3dMQ0F5WlRZcEtTQXJJRnh1SUNCMGFHVnRaVjlqYkdGemMybGpLQ2tnSzF4dUlDQjBhR1Z0WlNoc1pXZGxibVF1Y0c5emFYUnBiMjRnUFNCY1hHNXZibVZjWEN4Y2JpQWdJQ0FnSUNBZ2NHeHZkQzUwYVhSc1pTQTlJR1ZzWlcxbGJuUmZkR1Y0ZENoemFYcGxJRDBnT0NrcElDQWpJRkpsYlc5MlpYTWdkR2hsSUd4bFoyVnVaRnh1WEc1Y2JuQnVaeWhvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0Z4Y1kyOXVjMlZ1YzNWelgyUnBjM1JmY0dWeVgzSmxjMTh5YldJdWNHNW5YRndwS1N3Z1hHNGdJQ0FnY21WeklEMGdOakF3TENCMWJtbDBjeUE5SUZ4Y2FXNWNYQ3dnZDJsa2RHZ2dQU0F6TENCb1pXbG5hSFFnUFNBMktWeHVjSEpwYm5Rb2NESXBYRzVrWlhZdWIyWm1LQ2xjYmx4dVhHNWdZR0JjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbmBgYHJcbmRhdGEgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfc2NvcmUudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICByZXMgPSBlbmQxIC0gc3RhcnQxKVxuXG5wMSA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBkaXN0YW5jZSwgZmlsbCA9IGZhY3RvcihyZXMpKSkgK1xuICBnZW9tX2hpc3RvZ3JhbShiaW53aWR0aCA9IDUwMDAwLCBhbHBoYSA9IDEpICtcbiAgbGFicyh0aXRsZSA9IFxcRGlzdHJpYnV0aW9uIG9mIERpc3RhbmNlIGJ5IFJlc29sdXRpb25cXCxcbiAgICAgICB4ID0gXFxEaXN0YW5jZVxcLFxuICAgICAgIHkgPSBcXENvdW50c1xcKSArIFxuICBmYWNldF93cmFwKH4gcmVzLCBuY29sID0gMSwgc2NhbGVzID0gXFxmcmVlXFwpICsgXG4gIHNjYWxlX3hfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYiwgbGltaXRzID0gYygwLCA1ZTYpKSArIFxuICB0aGVtZV9jbGFzc2ljKCkgK1xuICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXCxcbiAgICAgICAgcGxvdC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gOCkpICAjIFJlbW92ZXMgdGhlIGxlZ2VuZFxuXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChcXGNvbnNlbnN1c19kaXN0X3Blcl9yZXMucG5nXFwpKSwgXG4gICAgcmVzID0gNjAwLCB1bml0cyA9IFxcaW5cXCwgd2lkdGggPSAzLCBoZWlnaHQgPSA2KVxucHJpbnQocDEpXG5kZXYub2ZmKClcblxucDIgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZGlzdGFuY2UsIGZpbGwgPSBmYWN0b3IocmVzKSkpICtcbiAgZ2VvbV9oaXN0b2dyYW0oYmlud2lkdGggPSA1MDAwMCwgYWxwaGEgPSAxKSArXG4gIGxhYnModGl0bGUgPSBcXERpc3RyaWJ1dGlvbiBvZiBEaXN0YW5jZSBieSBSZXNvbHV0aW9uXFwsXG4gICAgICAgeCA9IFxcRGlzdGFuY2VcXCxcbiAgICAgICB5ID0gXFxDb3VudHNcXCkgKyBcbiAgZmFjZXRfd3JhcCh+IHJlcywgbmNvbCA9IDEsIHNjYWxlcyA9IFxcZnJlZVxcKSArIFxuICBzY2FsZV94X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIsIGxpbWl0cyA9IGMoMCwgMmU2KSkgKyBcbiAgdGhlbWVfY2xhc3NpYygpICtcbiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwsXG4gICAgICAgIHBsb3QudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDgpKSAgIyBSZW1vdmVzIHRoZSBsZWdlbmRcblxuXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChcXGNvbnNlbnN1c19kaXN0X3Blcl9yZXNfMm1iLnBuZ1xcKSksIFxuICAgIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gMywgaGVpZ2h0ID0gNilcbnByaW50KHAyKVxuZGV2Lm9mZigpXG5cblxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19zY29yZS50c3ZcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHJlcyA9IGVuZDEgLSBzdGFydDEpXG5cbnAxIDwtIGdncGxvdChkYXRhLCBhZXMoeCA9IGRpc3RhbmNlLCBmaWxsID0gZmFjdG9yKHJlcykpKSArXG4gIGdlb21faGlzdG9ncmFtKGJpbndpZHRoID0gNTAwMDAsIGFscGhhID0gMSkgK1xuICBsYWJzKHRpdGxlID0gXFxEaXN0cmlidXRpb24gb2YgRGlzdGFuY2UgYnkgUmVzb2x1dGlvblxcLFxuICAgICAgIHggPSBcXERpc3RhbmNlXFwsXG4gICAgICAgeSA9IFxcQ291bnRzXFwpICsgXG4gIGZhY2V0X3dyYXAofiByZXMsIG5jb2wgPSAxLCBzY2FsZXMgPSBcXGZyZWVcXCkgKyBcbiAgc2NhbGVfeF9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iLCBsaW1pdHMgPSBjKDAsIDVlNikpICsgXG4gIHRoZW1lX2NsYXNzaWMoKSArXG4gIHRoZW1lKGxlZ2VuZC5wb3NpdGlvbiA9IFxcbm9uZVxcLFxuICAgICAgICBwbG90LnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA4KSkgICMgUmVtb3ZlcyB0aGUgbGVnZW5kXG5cbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKFxcY29uc2Vuc3VzX2Rpc3RfcGVyX3Jlcy5wbmdcXCkpLCBcbiAgICByZXMgPSA2MDAsIHVuaXRzID0gXFxpblxcLCB3aWR0aCA9IDMsIGhlaWdodCA9IDYpXG5wcmludChwMSlcbmRldi5vZmYoKVxuXG5wMiA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBkaXN0YW5jZSwgZmlsbCA9IGZhY3RvcihyZXMpKSkgK1xuICBnZW9tX2hpc3RvZ3JhbShiaW53aWR0aCA9IDUwMDAwLCBhbHBoYSA9IDEpICtcbiAgbGFicyh0aXRsZSA9IFxcRGlzdHJpYnV0aW9uIG9mIERpc3RhbmNlIGJ5IFJlc29sdXRpb25cXCxcbiAgICAgICB4ID0gXFxEaXN0YW5jZVxcLFxuICAgICAgIHkgPSBcXENvdW50c1xcKSArIFxuICBmYWNldF93cmFwKH4gcmVzLCBuY29sID0gMSwgc2NhbGVzID0gXFxmcmVlXFwpICsgXG4gIHNjYWxlX3hfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYiwgbGltaXRzID0gYygwLCAyZTYpKSArIFxuICB0aGVtZV9jbGFzc2ljKCkgK1xuICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXCxcbiAgICAgICAgcGxvdC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gOCkpICAjIFJlbW92ZXMgdGhlIGxlZ2VuZFxuXG5cbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKFxcY29uc2Vuc3VzX2Rpc3RfcGVyX3Jlc18ybWIucG5nXFwpKSwgXG4gICAgcmVzID0gNjAwLCB1bml0cyA9IFxcaW5cXCwgd2lkdGggPSAzLCBoZWlnaHQgPSA2KVxucHJpbnQocDIpXG5kZXYub2ZmKClcblxuXG5gYGBcbmBgYCJ9 -->

```r
```r
data <- fread(here(consensusDir, \chromo_cons_score.tsv\)) %>%
  dplyr::mutate(distance = start2 - start1,
                res = end1 - start1)

p1 <- ggplot(data, aes(x = distance, fill = factor(res))) +
  geom_histogram(binwidth = 50000, alpha = 1) +
  labs(title = \Distribution of Distance by Resolution\,
       x = \Distance\,
       y = \Counts\) + 
  facet_wrap(~ res, ncol = 1, scales = \free\) + 
  scale_x_continuous(labels = label_kb_mb, limits = c(0, 5e6)) + 
  theme_classic() +
  theme(legend.position = \none\,
        plot.title = element_text(size = 8))  # Removes the legend

png(here(figDir, paste0(\consensus_dist_per_res.png\)), 
    res = 600, units = \in\, width = 3, height = 6)
print(p1)
dev.off()

p2 <- ggplot(data, aes(x = distance, fill = factor(res))) +
  geom_histogram(binwidth = 50000, alpha = 1) +
  labs(title = \Distribution of Distance by Resolution\,
       x = \Distance\,
       y = \Counts\) + 
  facet_wrap(~ res, ncol = 1, scales = \free\) + 
  scale_x_continuous(labels = label_kb_mb, limits = c(0, 2e6)) + 
  theme_classic() +
  theme(legend.position = \none\,
        plot.title = element_text(size = 8))  # Removes the legend


png(here(figDir, paste0(\consensus_dist_per_res_2mb.png\)), 
    res = 600, units = \in\, width = 3, height = 6)
print(p2)
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### One feature annotation - structure


<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSUVScGMzUmhibU5sSUhaeklITmpiM0psWEc0Z0lGeHVJQ0IwWlcxd0lEd3RJR1JoZEdFZ0pUNGxJR1J3YkhseU9qcHRkWFJoZEdVb1pHbHpkR0Z1WTJVZ1BTQnpkR0Z5ZERJZ0xTQnpkR0Z5ZERFcElDVStKU0JrY0d4NWNqbzZjMlZzWldOMEtHUnBjM1JoYm1ObExDQkVUVk5QTENCa1ZFRkhMQ0JCTkRnMUtWeHVJQ0JjYmlBZ1lYWm5YM05qYjNKbGN5QThMU0IwWlcxd0lDVStKVnh1SUNBZ0lHZHliM1Z3WDJKNUtHUnBjM1JoYm1ObEtTQWxQaVZjYmlBZ0lDQnpkVzF0WVhKcGMyVW9ZV055YjNOektITjBZWEowYzE5M2FYUm9LRndpUkUxVFQxd2lLVHB6ZEdGeWRITmZkMmwwYUNoY0lrRTBPRFZjSWlrc0lHMWxZVzRzSUc1aExuSnRJRDBnVkZKVlJTa3BYRzRnSUZ4dUlDQmhkbWRmYzJOdmNtVnpYMnh2Ym1jZ1BDMGdZWFpuWDNOamIzSmxjeUFsUGlWY2JpQWdJQ0J3YVhadmRGOXNiMjVuWlhJb1kyOXNjeUE5SUVSTlUwODZRVFE0TlN3Z2JtRnRaWE5mZEc4Z1BTQmNJbU52Ym1ScGRHbHZibHdpTENCMllXeDFaWE5mZEc4Z1BTQmNJbUYyWjE5elkyOXlaVndpS1Z4dUlDQmhkbWRmYzJOdmNtVnpYMnh2Ym1ja1kyOXVaR2wwYVc5dUlEd3RJR1poWTNSdmNpaGhkbWRmYzJOdmNtVnpYMnh2Ym1ja1kyOXVaR2wwYVc5dUxDQnNaWFpsYkhNZ1BTQmpLRndpUkUxVFQxd2lMQ0JjSW1SVVFVZGNJaXdnWENKQk5EZzFYQ0lwS1Z4dUlDQWpJRU55WldGMFpTQjBhR1VnY0d4dmRGeHVJQ0J3TkNBOExTQm5aM0JzYjNRb1lYWm5YM05qYjNKbGMxOXNiMjVuTENCaFpYTW9lQ0E5SUdScGMzUmhibU5sTENCNUlEMGdZWFpuWDNOamIzSmxMQ0JqYjJ4dmNpQTlJR052Ym1ScGRHbHZiaXdnWm1sc2JDQTlJR052Ym1ScGRHbHZiaWtwSUN0Y2JpQWdJQ0JuWlc5dFgzTnRiMjkwYUNoemFHOTNMbXhsWjJWdVpDQTlJRlJTVlVVcElDc2dlV3hwYlNnd0xDQXdMalVwSUN0Y2JpQWdJQ0IwYUdWdFpWOWpiR0Z6YzJsaktDa2dLeUFnYzJOaGJHVmZlRjlqYjI1MGFXNTFiM1Z6S0d4aFltVnNjeUE5SUd4aFltVnNYMnRpWDIxaUtTQXJYRzRnSUNBZ2MyTmhiR1ZmWTI5c2IzSmZiV0Z1ZFdGc0tIWmhiSFZsY3lBOUlHTW9YQ0pFVFZOUFhDSWdQU0JjSW1keVpYbGNJaXdnWENKa1ZFRkhYQ0lnUFNCY0luQnBibXRjSWl3Z1hDSkJORGcxWENJZ1BTQmNJbk5yZVdKc2RXVmNJaWtwSUN0Y2JpQWdJQ0J6WTJGc1pWOW1hV3hzWDIxaGJuVmhiQ2gyWVd4MVpYTWdQU0JqS0Z3aVJFMVRUMXdpSUQwZ1hDSm5jbVY1T0RCY0lpd2dYQ0prVkVGSFhDSWdQU0JjSW5CcGJtdGNJaXdnWENKQk5EZzFYQ0lnUFNCY0luTnJlV0pzZFdWY0lpa3BJQ3RjYmlBZ0lDQnNZV0p6S0hScGRHeGxJRDBnY0dGemRHVXdLRndpUkdsemRHRnVZMlVnZG5NdUlFRjJaWEpoWjJVZ1UyTnZjbVVzSUZ3aUxDQnViM1JsS1N4Y2JpQWdJQ0FnSUNBZ0lIZ2dQU0JjSWtScGMzUmhibU5sWENJc1hHNGdJQ0FnSUNBZ0lDQjVJRDBnWENKQmRtVnlZV2RsSUZOamIzSmxYQ0lwSUN0Y2JpQWdJQ0IwYUdWdFpTaHdiRzkwTG5ScGRHeGxJRDBnWld4bGJXVnVkRjkwWlhoMEtITnBlbVVnUFNBeE1pa3BYRzRnSUhCdVp5aG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLRndpWTI5dWMyVnVjM1Z6WDJScGMzUmZkbk5mWVhablUyTnZjbVZmWVd4c1VtVnpYM0IxTVRBd2NIb3hNREJmWENJc0lHNXZkR1VzSUZ3aUxuQnVaMXdpS1Nrc0lGeHVJQ0FnSUNBZ2NtVnpJRDBnTmpBd0xDQjFibWwwY3lBOUlGd2lhVzVjSWl3Z2QybGtkR2dnUFNBMExDQm9aV2xuYUhRZ1BTQXpLVnh1SUNCd2NtbHVkQ2h3TkNsY2JpQWdaR1YyTG05bVppZ3BYRzVjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbiMjIyBEaXN0YW5jZSB2cyBzY29yZVxuICBcbiAgdGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgRE1TTywgZFRBRywgQTQ4NSlcbiAgXG4gIGF2Z19zY29yZXMgPC0gdGVtcCAlPiVcbiAgICBncm91cF9ieShkaXN0YW5jZSkgJT4lXG4gICAgc3VtbWFyaXNlKGFjcm9zcyhzdGFydHNfd2l0aChcXERNU09cXCk6c3RhcnRzX3dpdGgoXFxBNDg1XFwpLCBtZWFuLCBuYS5ybSA9IFRSVUUpKVxuICBcbiAgYXZnX3Njb3Jlc19sb25nIDwtIGF2Z19zY29yZXMgJT4lXG4gICAgcGl2b3RfbG9uZ2VyKGNvbHMgPSBETVNPOkE0ODUsIG5hbWVzX3RvID0gXFxjb25kaXRpb25cXCwgdmFsdWVzX3RvID0gXFxhdmdfc2NvcmVcXClcbiAgYXZnX3Njb3Jlc19sb25nJGNvbmRpdGlvbiA8LSBmYWN0b3IoYXZnX3Njb3Jlc19sb25nJGNvbmRpdGlvbiwgbGV2ZWxzID0gYyhcXERNU09cXCwgXFxkVEFHXFwsIFxcQTQ4NVxcKSlcbiAgIyBDcmVhdGUgdGhlIHBsb3RcbiAgcDQgPC0gZ2dwbG90KGF2Z19zY29yZXNfbG9uZywgYWVzKHggPSBkaXN0YW5jZSwgeSA9IGF2Z19zY29yZSwgY29sb3IgPSBjb25kaXRpb24sIGZpbGwgPSBjb25kaXRpb24pKSArXG4gICAgZ2VvbV9zbW9vdGgoc2hvdy5sZWdlbmQgPSBUUlVFKSArIHlsaW0oMCwgMC41KSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgIHNjYWxlX3hfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgK1xuICAgIHNjYWxlX2NvbG9yX21hbnVhbCh2YWx1ZXMgPSBjKFxcRE1TT1xcID0gXFxncmV5XFwsIFxcZFRBR1xcID0gXFxwaW5rXFwsIFxcQTQ4NVxcID0gXFxza3libHVlXFwpKSArXG4gICAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcXERNU09cXCA9IFxcZ3JleTgwXFwsIFxcZFRBR1xcID0gXFxwaW5rXFwsIFxcQTQ4NVxcID0gXFxza3libHVlXFwpKSArXG4gICAgbGFicyh0aXRsZSA9IHBhc3RlMChcXERpc3RhbmNlIHZzLiBBdmVyYWdlIFNjb3JlXG4ifQ== -->
### Distance vs score
  
  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, dTAG, A485)
  
  avg_scores <- temp %>%
    group_by(distance) %>%
    summarise(across(starts_with(\DMSO\):starts_with(\A485\), mean, na.rm = TRUE))
  
  avg_scores_long <- avg_scores %>%
    pivot_longer(cols = DMSO:A485, names_to = \condition\, values_to = \avg_score\)
  avg_scores_long$condition <- factor(avg_scores_long$condition, levels = c(\DMSO\, \dTAG\, \A485\))
  # Create the plot
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +
    geom_smooth(show.legend = TRUE) + ylim(0, 0.5) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = c(\DMSO\ = \grey\, \dTAG\ = \pink\, \A485\ = \skyblue\)) +
    scale_fill_manual(values = c(\DMSO\ = \grey80\, \dTAG\ = \pink\, \A485\ = \skyblue\)) +
    labs(title = paste0(\Distance vs. Average Score
```r
### Distance vs score
  
  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, dTAG, A485)
  
  avg_scores <- temp %>%
    group_by(distance) %>%
    summarise(across(starts_with(\DMSO\):starts_with(\A485\), mean, na.rm = TRUE))
  
  avg_scores_long <- avg_scores %>%
    pivot_longer(cols = DMSO:A485, names_to = \condition\, values_to = \avg_score\)
  avg_scores_long$condition <- factor(avg_scores_long$condition, levels = c(\DMSO\, \dTAG\, \A485\))
  # Create the plot
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +
    geom_smooth(show.legend = TRUE) + ylim(0, 0.5) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = c(\DMSO\ = \grey\, \dTAG\ = \pink\, \A485\ = \skyblue\)) +
    scale_fill_manual(values = c(\DMSO\ = \grey80\, \dTAG\ = \pink\, \A485\ = \skyblue\)) +
    labs(title = paste0(\Distance vs. Average Score

[2.7] Distance vs loop # and score


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBBbm5vdGF0aW5nIGdlbmVzIGJhc2VkIG9uIHByb21vdGVyIGFuY2hvclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiLnRzdlwiKSkpXG5gYGAifQ== -->

```r
# Annotating genes based on promoter anchor
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
```

<!-- rnb-source-end -->
```r
# Annotating genes based on promoter anchor
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZmxhbmtTaXplIDwtIDI1MDBcbmdlbmUuVFNTLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcIm1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFwiK1wiLCBWMiwgVjMpLFxuICAgICAgICAgICAgICAgIFRTU3N0YXJ0ID0gVFNTIC0gZmxhbmtTaXplLFxuICAgICAgICAgICAgICAgIFRTU2VuZCA9IFRTUyArIGZsYW5rU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTU3N0YXJ0LCBUU1NlbmQsIFY0LCBWNSwgVjYpXG5jb2xuYW1lcyhnZW5lLlRTUy50YikgPC0gYyhcImNoclwiLCBcInN0YXJ0XCIsIFwiZW5kXCIsIFwic3RyYW5kXCIsIFwiZ2VuZVwiLCBcImVuc2VtYmxcIilcblxuZndyaXRlKGdlbmUuVFNTLnRiLCBoZXJlKHJlZkRpciwgXCJtbTEwX0dSQ20zOC5wNl9UU1MyLjVrYi5iZWRcIiksIHNlcCA9IFwiXFx0XCIsIGNvbC5uYW1lcyA9IEZBTFNFLCByb3cubmFtZXMgPSBGQUxTRSlcblxuZmluZE92ZXJsYXBHZW5lIDwtIGZ1bmN0aW9uKGdlbmUuVFNTLnRiLCBjaHJvbTEsIHN0YXJ0MSwgZW5kMSl7XG4gIHRlbXAgPC0gZ2VuZS5UU1MudGIgJT4lIGRwbHlyOjpmaWx0ZXIoY2hyID09IGNocm9tMSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcigoc3RhcnQgPD0gZW5kMSkgJiAoZW5kID49IHN0YXJ0MSkpXG4gIHJldHVybih0ZW1wJGdlbmUpXG59XG5maW5kT3ZlcmxhcEVuc2VtYmwgPC0gZnVuY3Rpb24oZ2VuZS5UU1MudGIsIGNocm9tMSwgc3RhcnQxLCBlbmQxKXtcbiAgdGVtcCA8LSBnZW5lLlRTUy50YiAlPiUgZHBseXI6OmZpbHRlcihjaHIgPT0gY2hyb20xKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKChzdGFydCA8PSBlbmQxKSAmIChlbmQgPj0gc3RhcnQxKSlcbiAgcmV0dXJuKHRlbXAkZW5zZW1ibClcbn1cblxudGVtcCA8LSBkYXRhICU+JSByb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoQTFfZ2VuZSA9IGlmZWxzZShBMSA9PSBcIlBcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxpc3QoZmluZE92ZXJsYXBHZW5lKGdlbmUuVFNTLnRiLCBjaHJvbTEsIHN0YXJ0MSwgZW5kMSkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgTkEpLFxuICAgICAgICAgICAgICAgIEEyX2dlbmUgPSBpZmVsc2UoQTIgPT0gXCJQXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsaXN0KGZpbmRPdmVybGFwR2VuZShnZW5lLlRTUy50YiwgY2hyb20yLCBzdGFydDIsIGVuZDIpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5BKSxcbiAgICAgICAgICAgICAgICBnZW5lID0gbGlzdCh1bmlxdWUoYyhBMV9nZW5lLCBBMl9nZW5lKSkpKVxuXG50ZW1wX3BfbiA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcIlAtUFwiLCBcIlAtRVwiLCBcIlAtU1wiLCBcIlAtWFwiKSkgJT4lIGRwbHlyOjpzZWxlY3QoLWMoXCJBMV9nZW5lXCIsIFwiQTJfZ2VuZVwiKSlcbmZ3cml0ZSh0ZW1wX3BfbiwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcIl9wLW5fZ2VuZUxpc3QudHN2XCIpKSwgc2VwID0gXCJcXHRcIilcblxudGVtcF9wX3BlIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFwiUC1QXCIsIFwiUC1FXCIpKSAlPiUgZHBseXI6OnNlbGVjdCgtYyhcIkExX2dlbmVcIiwgXCJBMl9nZW5lXCIpKVxuZndyaXRlKHRlbXBfcF9wZSwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcIl9wLXBlX2dlbmVMaXN0LnRzdlwiKSksIHNlcCA9IFwiXFx0XCIpXG5cbnRlbXAgPC0gZGF0YSAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKEExX2dlbmUgPSBpZmVsc2UoQTEgPT0gXCJQXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsaXN0KGZpbmRPdmVybGFwRW5zZW1ibChnZW5lLlRTUy50YiwgY2hyb20xLCBzdGFydDEsIGVuZDEpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5BKSxcbiAgICAgICAgICAgICAgICBBMl9nZW5lID0gaWZlbHNlKEEyID09IFwiUFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGlzdChmaW5kT3ZlcmxhcEVuc2VtYmwoZ2VuZS5UU1MudGIsIGNocm9tMiwgc3RhcnQyLCBlbmQyKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOQSksXG4gICAgICAgICAgICAgICAgZ2VuZSA9IGxpc3QodW5pcXVlKGMoQTFfZ2VuZSwgQTJfZ2VuZSkpKSlcblxudGVtcF9wX24gPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXCJQLVBcIiwgXCJQLUVcIiwgXCJQLVNcIiwgXCJQLVhcIikpICU+JSBkcGx5cjo6c2VsZWN0KC1jKFwiQTFfZ2VuZVwiLCBcIkEyX2dlbmVcIikpXG5md3JpdGUodGVtcF9wX24sIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXCJfcC1uX2Vuc2VtYmxMaXN0LnRzdlwiKSksIHNlcCA9IFwiXFx0XCIpXG5cbnRlbXBfcF9wZSA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcIlAtUFwiLCBcIlAtRVwiKSkgJT4lIGRwbHlyOjpzZWxlY3QoLWMoXCJBMV9nZW5lXCIsIFwiQTJfZ2VuZVwiKSlcbmZ3cml0ZSh0ZW1wX3BfcGUsIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXCJfcC1wZV9lbnNlbWJsTGlzdC50c3ZcIikpLCBzZXAgPSBcIlxcdFwiKVxuXG5gYGAifQ== -->\n\n```r\nflankSize <- 2500\ngene.TSS.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)\ncolnames(gene.TSS.tb) <- c(\\chr\\, \\start\\, \\end\\, \\strand\\, \\gene\\, \\ensembl\\)\n\nfwrite(gene.TSS.tb, here(refDir, \\mm10_GRCm38.p6_TSS2.5kb.bed\\), sep = \\\\t\\, col.names = FALSE, row.names = FALSE)\n\nfindOverlapGene <- function(gene.TSS.tb, chrom1, start1, end1){\n  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%\n    dplyr::filter((start <= end1) & (end >= start1))\n  return(temp$gene)\n}\nfindOverlapEnsembl <- function(gene.TSS.tb, chrom1, start1, end1){\n  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%\n    dplyr::filter((start <= end1) & (end >= start1))\n  return(temp$ensembl)\n}\n\ntemp <- data %>% rowwise() %>%\n  dplyr::mutate(A1_gene = ifelse(A1 == \\P\\,\n                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),\n                                 NA),\n                A2_gene = ifelse(A2 == \\P\\,\n                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),\n                                 NA),\n                gene = list(unique(c(A1_gene, A2_gene))))\n\ntemp_p_n <- temp %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>% dplyr::select(-c(\\A1_gene\\, \\A2_gene\\))\nfwrite(temp_p_n, here(consensusDir, paste0(name, \\_p-n_geneList.tsv\\)), sep = \\\\t\\)\n\ntemp_p_pe <- temp %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\)) %>% dplyr::select(-c(\\A1_gene\\, \\A2_gene\\))\nfwrite(temp_p_pe, here(consensusDir, paste0(name, \\_p-pe_geneList.tsv\\)), sep = \\\\t\\)\n\ntemp <- data %>% rowwise() %>%\n  dplyr::mutate(A1_gene = ifelse(A1 == \\P\\,\n                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),\n                                 NA),\n                A2_gene = ifelse(A2 == \\P\\,\n                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),\n                                 NA),\n                gene = list(unique(c(A1_gene, A2_gene))))\n\ntemp_p_n <- temp %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>% dplyr::select(-c(\\A1_gene\\, \\A2_gene\\))\nfwrite(temp_p_n, here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)), sep = \\\\t\\)\n\ntemp_p_pe <- temp %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\)) %>% dplyr::select(-c(\\A1_gene\\, \\A2_gene\\))\nfwrite(temp_p_pe, here(consensusDir, paste0(name, \\_p-pe_ensemblList.tsv\\)), sep = \\\\t\\)\n\n```\n\n<!-- rnb-source-end -->\n"} -->
flankSize <- 2500
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)
colnames(gene.TSS.tb) <- c(\chr\, \start\, \end\, \strand\, \gene\, \ensembl\)

fwrite(gene.TSS.tb, here(refDir, \mm10_GRCm38.p6_TSS2.5kb.bed\), sep = \\t\, col.names = FALSE, row.names = FALSE)

findOverlapGene <- function(gene.TSS.tb, chrom1, start1, end1){
  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%
    dplyr::filter((start <= end1) & (end >= start1))
  return(temp$gene)
}
findOverlapEnsembl <- function(gene.TSS.tb, chrom1, start1, end1){
  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%
    dplyr::filter((start <= end1) & (end >= start1))
  return(temp$ensembl)
}

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 == \P\,
                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 == \P\,
                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \P-S\, \P-X\)) %>% dplyr::select(-c(\A1_gene\, \A2_gene\))
fwrite(temp_p_n, here(consensusDir, paste0(name, \_p-n_geneList.tsv\)), sep = \\t\)

temp_p_pe <- temp %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\)) %>% dplyr::select(-c(\A1_gene\, \A2_gene\))
fwrite(temp_p_pe, here(consensusDir, paste0(name, \_p-pe_geneList.tsv\)), sep = \\t\)

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 == \P\,
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 == \P\,
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \P-S\, \P-X\)) %>% dplyr::select(-c(\A1_gene\, \A2_gene\))
fwrite(temp_p_n, here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)), sep = \\t\)

temp_p_pe <- temp %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\)) %>% dplyr::select(-c(\A1_gene\, \A2_gene\))
fwrite(temp_p_pe, here(consensusDir, paste0(name, \_p-pe_ensemblList.tsv\)), sep = \\t\)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZmxhbmtTaXplIDwtIDI1MDBcbmdlbmUuVFNTLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpLFxuICAgICAgICAgICAgICAgIFRTU3N0YXJ0ID0gVFNTIC0gZmxhbmtTaXplLFxuICAgICAgICAgICAgICAgIFRTU2VuZCA9IFRTUyArIGZsYW5rU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTU3N0YXJ0LCBUU1NlbmQsIFY0LCBWNSwgVjYpXG5jb2xuYW1lcyhnZW5lLlRTUy50YikgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcc3RyYW5kXFwsIFxcZ2VuZVxcLCBcXGVuc2VtYmxcXClcblxuZndyaXRlKGdlbmUuVFNTLnRiLCBoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9UU1MyLjVrYi5iZWRcXCksIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IEZBTFNFLCByb3cubmFtZXMgPSBGQUxTRSlcblxuZmluZE92ZXJsYXBHZW5lIDwtIGZ1bmN0aW9uKGdlbmUuVFNTLnRiLCBjaHJvbTEsIHN0YXJ0MSwgZW5kMSl7XG4gIHRlbXAgPC0gZ2VuZS5UU1MudGIgJT4lIGRwbHlyOjpmaWx0ZXIoY2hyID09IGNocm9tMSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcigoc3RhcnQgPD0gZW5kMSkgJiAoZW5kID49IHN0YXJ0MSkpXG4gIHJldHVybih0ZW1wJGdlbmUpXG59XG5maW5kT3ZlcmxhcEVuc2VtYmwgPC0gZnVuY3Rpb24oZ2VuZS5UU1MudGIsIGNocm9tMSwgc3RhcnQxLCBlbmQxKXtcbiAgdGVtcCA8LSBnZW5lLlRTUy50YiAlPiUgZHBseXI6OmZpbHRlcihjaHIgPT0gY2hyb20xKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKChzdGFydCA8PSBlbmQxKSAmIChlbmQgPj0gc3RhcnQxKSlcbiAgcmV0dXJuKHRlbXAkZW5zZW1ibClcbn1cblxudGVtcCA8LSBkYXRhICU+JSByb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoQTFfZ2VuZSA9IGlmZWxzZShBMSA9PSBcXFBcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxpc3QoZmluZE92ZXJsYXBHZW5lKGdlbmUuVFNTLnRiLCBjaHJvbTEsIHN0YXJ0MSwgZW5kMSkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgTkEpLFxuICAgICAgICAgICAgICAgIEEyX2dlbmUgPSBpZmVsc2UoQTIgPT0gXFxQXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsaXN0KGZpbmRPdmVybGFwR2VuZShnZW5lLlRTUy50YiwgY2hyb20yLCBzdGFydDIsIGVuZDIpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5BKSxcbiAgICAgICAgICAgICAgICBnZW5lID0gbGlzdCh1bmlxdWUoYyhBMV9nZW5lLCBBMl9nZW5lKSkpKVxuXG50ZW1wX3BfbiA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcKSkgJT4lIGRwbHlyOjpzZWxlY3QoLWMoXFxBMV9nZW5lXFwsIFxcQTJfZ2VuZVxcKSlcbmZ3cml0ZSh0ZW1wX3BfbiwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLW5fZ2VuZUxpc3QudHN2XFwpKSwgc2VwID0gXFxcXHRcXClcblxudGVtcF9wX3BlIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUC1QXFwsIFxcUC1FXFwpKSAlPiUgZHBseXI6OnNlbGVjdCgtYyhcXEExX2dlbmVcXCwgXFxBMl9nZW5lXFwpKVxuZndyaXRlKHRlbXBfcF9wZSwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLXBlX2dlbmVMaXN0LnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG5cbnRlbXAgPC0gZGF0YSAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKEExX2dlbmUgPSBpZmVsc2UoQTEgPT0gXFxQXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsaXN0KGZpbmRPdmVybGFwRW5zZW1ibChnZW5lLlRTUy50YiwgY2hyb20xLCBzdGFydDEsIGVuZDEpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5BKSxcbiAgICAgICAgICAgICAgICBBMl9nZW5lID0gaWZlbHNlKEEyID09IFxcUFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGlzdChmaW5kT3ZlcmxhcEVuc2VtYmwoZ2VuZS5UU1MudGIsIGNocm9tMiwgc3RhcnQyLCBlbmQyKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOQSksXG4gICAgICAgICAgICAgICAgZ2VuZSA9IGxpc3QodW5pcXVlKGMoQTFfZ2VuZSwgQTJfZ2VuZSkpKSlcblxudGVtcF9wX24gPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpICU+JSBkcGx5cjo6c2VsZWN0KC1jKFxcQTFfZ2VuZVxcLCBcXEEyX2dlbmVcXCkpXG5md3JpdGUodGVtcF9wX24sIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1uX2Vuc2VtYmxMaXN0LnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG5cbnRlbXBfcF9wZSA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcKSkgJT4lIGRwbHlyOjpzZWxlY3QoLWMoXFxBMV9nZW5lXFwsIFxcQTJfZ2VuZVxcKSlcbmZ3cml0ZSh0ZW1wX3BfcGUsIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1wZV9lbnNlbWJsTGlzdC50c3ZcXCkpLCBzZXAgPSBcXFxcdFxcKVxuXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\nflankSize <- 2500\ngene.TSS.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)\ncolnames(gene.TSS.tb) <- c(\\chr\\, \\start\\, \\end\\, \\strand\\, \\gene\\, \\ensembl\\)\n\nfwrite(gene.TSS.tb, here(refDir, \\mm10_GRCm38.p6_TSS2.5kb.bed\\), sep = \\\\t\\, col.names = FALSE, row.names = FALSE)\n\nfindOverlapGene <- function(gene.TSS.tb, chrom1, start1, end1){\n  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%\n    dplyr::filter((start <= end1) & (end >= start1))\n  return(temp$gene)\n}\nfindOverlapEnsembl <- function(gene.TSS.tb, chrom1, start1, end1){\n  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%\n    dplyr::filter((start <= end1) & (end >= start1))\n  return(temp$ensembl)\n}\n\ntemp <- data %>% rowwise() %>%\n  dplyr::mutate(A1_gene = ifelse(A1 == \\P\\,\n                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),\n                                 NA),\n                A2_gene = ifelse(A2 == \\P\\,\n                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),\n                                 NA),\n                gene = list(unique(c(A1_gene, A2_gene))))\n\ntemp_p_n <- temp %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>% dplyr::select(-c(\\A1_gene\\, \\A2_gene\\))\nfwrite(temp_p_n, here(consensusDir, paste0(name, \\_p-n_geneList.tsv\\)), sep = \\\\t\\)\n\ntemp_p_pe <- temp %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\)) %>% dplyr::select(-c(\\A1_gene\\, \\A2_gene\\))\nfwrite(temp_p_pe, here(consensusDir, paste0(name, \\_p-pe_geneList.tsv\\)), sep = \\\\t\\)\n\ntemp <- data %>% rowwise() %>%\n  dplyr::mutate(A1_gene = ifelse(A1 == \\P\\,\n                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),\n                                 NA),\n                A2_gene = ifelse(A2 == \\P\\,\n                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),\n                                 NA),\n                gene = list(unique(c(A1_gene, A2_gene))))\n\ntemp_p_n <- temp %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>% dplyr::select(-c(\\A1_gene\\, \\A2_gene\\))\nfwrite(temp_p_n, here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)), sep = \\\\t\\)\n\ntemp_p_pe <- temp %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\)) %>% dplyr::select(-c(\\A1_gene\\, \\A2_gene\\))\nfwrite(temp_p_pe, here(consensusDir, paste0(name, \\_p-pe_ensemblList.tsv\\)), sep = \\\\t\\)\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZmxhbmtTaXplIDwtIDI1MDBcbmdlbmUuVFNTLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpLFxuICAgICAgICAgICAgICAgIFRTU3N0YXJ0ID0gVFNTIC0gZmxhbmtTaXplLFxuICAgICAgICAgICAgICAgIFRTU2VuZCA9IFRTUyArIGZsYW5rU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTU3N0YXJ0LCBUU1NlbmQsIFY0LCBWNSwgVjYpXG5jb2xuYW1lcyhnZW5lLlRTUy50YikgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcc3RyYW5kXFwsIFxcZ2VuZVxcLCBcXGVuc2VtYmxcXClcblxuZndyaXRlKGdlbmUuVFNTLnRiLCBoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9UU1MyLjVrYi5iZWRcXCksIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IEZBTFNFLCByb3cubmFtZXMgPSBGQUxTRSlcblxuZmluZE92ZXJsYXBHZW5lIDwtIGZ1bmN0aW9uKGdlbmUuVFNTLnRiLCBjaHJvbTEsIHN0YXJ0MSwgZW5kMSl7XG4gIHRlbXAgPC0gZ2VuZS5UU1MudGIgJT4lIGRwbHlyOjpmaWx0ZXIoY2hyID09IGNocm9tMSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcigoc3RhcnQgPD0gZW5kMSkgJiAoZW5kID49IHN0YXJ0MSkpXG4gIHJldHVybih0ZW1wJGdlbmUpXG59XG5maW5kT3ZlcmxhcEVuc2VtYmwgPC0gZnVuY3Rpb24oZ2VuZS5UU1MudGIsIGNocm9tMSwgc3RhcnQxLCBlbmQxKXtcbiAgdGVtcCA8LSBnZW5lLlRTUy50YiAlPiUgZHBseXI6OmZpbHRlcihjaHIgPT0gY2hyb20xKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKChzdGFydCA8PSBlbmQxKSAmIChlbmQgPj0gc3RhcnQxKSlcbiAgcmV0dXJuKHRlbXAkZW5zZW1ibClcbn1cblxudGVtcCA8LSBkYXRhICU+JSByb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoQTFfZ2VuZSA9IGlmZWxzZShBMSA9PSBcXFBcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxpc3QoZmluZE92ZXJsYXBHZW5lKGdlbmUuVFNTLnRiLCBjaHJvbTEsIHN0YXJ0MSwgZW5kMSkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgTkEpLFxuICAgICAgICAgICAgICAgIEEyX2dlbmUgPSBpZmVsc2UoQTIgPT0gXFxQXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsaXN0KGZpbmRPdmVybGFwR2VuZShnZW5lLlRTUy50YiwgY2hyb20yLCBzdGFydDIsIGVuZDIpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5BKSxcbiAgICAgICAgICAgICAgICBnZW5lID0gbGlzdCh1bmlxdWUoYyhBMV9nZW5lLCBBMl9nZW5lKSkpKVxuXG50ZW1wX3BfbiA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcKSkgJT4lIGRwbHlyOjpzZWxlY3QoLWMoXFxBMV9nZW5lXFwsIFxcQTJfZ2VuZVxcKSlcbmZ3cml0ZSh0ZW1wX3BfbiwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLW5fZ2VuZUxpc3QudHN2XFwpKSwgc2VwID0gXFxcXHRcXClcblxudGVtcF9wX3BlIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUC1QXFwsIFxcUC1FXFwpKSAlPiUgZHBseXI6OnNlbGVjdCgtYyhcXEExX2dlbmVcXCwgXFxBMl9nZW5lXFwpKVxuZndyaXRlKHRlbXBfcF9wZSwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLXBlX2dlbmVMaXN0LnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG5cbnRlbXAgPC0gZGF0YSAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKEExX2dlbmUgPSBpZmVsc2UoQTEgPT0gXFxQXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsaXN0KGZpbmRPdmVybGFwRW5zZW1ibChnZW5lLlRTUy50YiwgY2hyb20xLCBzdGFydDEsIGVuZDEpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5BKSxcbiAgICAgICAgICAgICAgICBBMl9nZW5lID0gaWZlbHNlKEEyID09IFxcUFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGlzdChmaW5kT3ZlcmxhcEVuc2VtYmwoZ2VuZS5UU1MudGIsIGNocm9tMiwgc3RhcnQyLCBlbmQyKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBOQSksXG4gICAgICAgICAgICAgICAgZ2VuZSA9IGxpc3QodW5pcXVlKGMoQTFfZ2VuZSwgQTJfZ2VuZSkpKSlcblxudGVtcF9wX24gPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpICU+JSBkcGx5cjo6c2VsZWN0KC1jKFxcQTFfZ2VuZVxcLCBcXEEyX2dlbmVcXCkpXG5md3JpdGUodGVtcF9wX24sIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1uX2Vuc2VtYmxMaXN0LnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG5cbnRlbXBfcF9wZSA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcKSkgJT4lIGRwbHlyOjpzZWxlY3QoLWMoXFxBMV9nZW5lXFwsIFxcQTJfZ2VuZVxcKSlcbmZ3cml0ZSh0ZW1wX3BfcGUsIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1wZV9lbnNlbWJsTGlzdC50c3ZcXCkpLCBzZXAgPSBcXFxcdFxcKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
flankSize <- 2500
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)
colnames(gene.TSS.tb) <- c(\chr\, \start\, \end\, \strand\, \gene\, \ensembl\)

fwrite(gene.TSS.tb, here(refDir, \mm10_GRCm38.p6_TSS2.5kb.bed\), sep = \\t\, col.names = FALSE, row.names = FALSE)

findOverlapGene <- function(gene.TSS.tb, chrom1, start1, end1){
  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%
    dplyr::filter((start <= end1) & (end >= start1))
  return(temp$gene)
}
findOverlapEnsembl <- function(gene.TSS.tb, chrom1, start1, end1){
  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%
    dplyr::filter((start <= end1) & (end >= start1))
  return(temp$ensembl)
}

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 == \P\,
                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 == \P\,
                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \P-S\, \P-X\)) %>% dplyr::select(-c(\A1_gene\, \A2_gene\))
fwrite(temp_p_n, here(consensusDir, paste0(name, \_p-n_geneList.tsv\)), sep = \\t\)

temp_p_pe <- temp %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\)) %>% dplyr::select(-c(\A1_gene\, \A2_gene\))
fwrite(temp_p_pe, here(consensusDir, paste0(name, \_p-pe_geneList.tsv\)), sep = \\t\)

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 == \P\,
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 == \P\,
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \P-S\, \P-X\)) %>% dplyr::select(-c(\A1_gene\, \A2_gene\))
fwrite(temp_p_n, here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)), sep = \\t\)

temp_p_pe <- temp %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\)) %>% dplyr::select(-c(\A1_gene\, \A2_gene\))
fwrite(temp_p_pe, here(consensusDir, paste0(name, \_p-pe_ensemblList.tsv\)), sep = \\t\)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [2.8] Annotating genes to P-P and P-E loops
#### Link gene to promoter anchor
Here, anchor was linked to a gene based on whether the anchor overlaps with TSS +- 2.5kb region

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuY3JlYXRlX2Rpc3RfYmFycGxvdCA8LSBmdW5jdGlvbihkYXRhLCBmaWdEaXIsIG5hbWUsIG5vdGUsIGxvb3BMaXN0LCBkaWZmQ3V0b2ZmKXtcbiAgdGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KEFubm8yLCBkaXN0YW5jZSwgdXBkb3duX2RUQUdfRE1TTywgdXBkb3duX0E0ODVfRE1TTykgJT4lXG4gICAgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGxvb3BMaXN0LFxuICAgICAgICAgICAgICAgICAgdXBkb3duX2RUQUdfRE1TTyAlaW4lIGMoXCJVUFwiLCBcIk5PXCIsIFwiRE9XTlwiKSlcbiAgcCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSB1cGRvd25fZFRBR19ETVNPLCB5ID0gZGlzdGFuY2UpKSArXG4gICAgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSB1cGRvd25fZFRBR19ETVNPKSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSB1cGRvd25fZFRBR19ETVNPKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcInJlZFwiLCBjb2xvciA9IFwiYmxhY2tcIikgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUobm90ZSkgK1xuICAgIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYilcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFwic2l6ZV9iYXJwbG90X1wiLCBuYW1lLCBcIl9kVEFHX3ZzX0RNU09fXCIsIG5vdGUsIFwiX1wiLCBkaWZmQ3V0b2ZmKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSA0XG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIFxuICBcbiAgdGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KEFubm8yLCBkaXN0YW5jZSwgdXBkb3duX2RUQUdfRE1TTywgdXBkb3duX0E0ODVfRE1TTykgJT4lXG4gICAgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGxvb3BMaXN0LFxuICAgICAgICAgICAgICAgICAgdXBkb3duX0E0ODVfRE1TTyAlaW4lIGMoXCJVUFwiLCBcIk5PXCIsICBcIkRPV05cIikpXG4gIHAgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gdXBkb3duX0E0ODVfRE1TTywgeSA9IGRpc3RhbmNlKSkgK1xuICAgIGdlb21fdmlvbGluKGFlcyhmaWxsID0gdXBkb3duX0E0ODVfRE1TTykpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gdXBkb3duX0E0ODVfRE1TTyksIGZ1biA9IG1lYW4sIGdlb20gPSBcInBvaW50XCIsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCIpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBnZ3RpdGxlKG5vdGUpICtcbiAgICBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcInNpemVfYmFycGxvdF9cIiwgbmFtZSwgXCJfQTQ4NV92c19ETVNPX1wiLCBub3RlLCBcIl9cIiwgZGlmZkN1dG9mZilcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gNFxuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG5cbm5hbWVcbmRpZmZDdXRvZmYgPC0gMC4yXG5uYW1lIDwtIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVwiXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXCIudHN2XCIpKSlcbmRhdGEgPC0gZGF0YSAlPiVcbiAgZHBseXI6Om11dGF0ZSh1cGRvd25fZFRBR19ETVNPID0gaWZlbHNlKGRpZmZfZFRBR19ETVNPID4gZGlmZkN1dG9mZiwgXCJVUFwiLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcIk5PXCIsIFwiRE9XTlwiKSksXG4gICAgICAgICAgICAgICAgdXBkb3duX0E0ODVfRE1TTyA9IGlmZWxzZShkaWZmX0E0ODVfRE1TTyA+IGRpZmZDdXRvZmYsIFwiVVBcIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiAtZGlmZkN1dG9mZiwgXCJOT1wiLCBcIkRPV05cIikpLFxuICAgICAgICAgICAgICAgIGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKVxuZGF0YSR1cGRvd25fZFRBR19ETVNPIDwtIGZhY3RvcihkYXRhJHVwZG93bl9kVEFHX0RNU08sIGxldmVscyA9IGMoXCJVUFwiLCBcIk5PXCIsIFwiRE9XTlwiKSlcbmRhdGEkdXBkb3duX0E0ODVfRE1TTyA8LSBmYWN0b3IoZGF0YSR1cGRvd25fQTQ4NV9ETVNPLCBsZXZlbHMgPSBjKFwiVVBcIiwgXCJOT1wiLCBcIkRPV05cIikpXG5jcmVhdGVfZGlzdF9iYXJwbG90KGRhdGEsIGZpZ0RpciwgbmFtZSwgXCJwLW5cIiwgYyhcIlAtUFwiLCBcIlAtRVwiLCBcIlAtU1wiLCBcIlAtWFwiKSwgMC4yKVxuY3JlYXRlX2Rpc3RfYmFycGxvdChkYXRhLCBmaWdEaXIsIG5hbWUsIFwicC1wZVwiLCBjKFwiUC1QXCIsIFwiUC1FXCIpLCAwLjIpXG5jcmVhdGVfZGlzdF9iYXJwbG90KGRhdGEsIGZpZ0RpciwgbmFtZSwgXCJwZS1wZVwiLCBjKFwiUC1QXCIsIFwiUC1FXCIsIFwiRS1FXCIpLCAwLjIpXG5jcmVhdGVfZGlzdF9iYXJwbG90KGRhdGEsIGZpZ0RpciwgbmFtZSwgXCJzdHJcIiwgYyhcIlMtU1wiLCBcIlMtWFwiKSwgMC4yKVxuXG5gYGAifQ== -->\n\n```r\ncreate_dist_barplot <- function(data, figDir, name, note, loopList, diffCutoff){\n  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%\n    dplyr::filter(Anno2 %in% loopList,\n                  updown_dTAG_DMSO %in% c(\\UP\\, \\NO\\, \\DOWN\\))\n  p <- ggplot(temp, aes(x = updown_dTAG_DMSO, y = distance)) +\n    geom_violin(aes(fill = updown_dTAG_DMSO)) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = updown_dTAG_DMSO), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + ggtitle(note) +\n    scale_y_continuous(labels = label_kb_mb)\n  fileName <- paste0(\\size_barplot_\\, name, \\_dTAG_vs_DMSO_\\, note, \\_\\, diffCutoff)\n  height <- 3\n  width <- 4\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n  \n  \n  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%\n    dplyr::filter(Anno2 %in% loopList,\n                  updown_A485_DMSO %in% c(\\UP\\, \\NO\\,  \\DOWN\\))\n  p <- ggplot(temp, aes(x = updown_A485_DMSO, y = distance)) +\n    geom_violin(aes(fill = updown_A485_DMSO)) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = updown_A485_DMSO), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + ggtitle(note) +\n    scale_y_continuous(labels = label_kb_mb)\n  fileName <- paste0(\\size_barplot_\\, name, \\_A485_vs_DMSO_\\, note, \\_\\, diffCutoff)\n  height <- 3\n  width <- 4\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n\nname\ndiffCutoff <- 0.2\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ndata <- data %>%\n  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                distance = start2 - start1)\ndata$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\ndata$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\ncreate_dist_barplot(data, figDir, name, \\p-n\\, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\), 0.2)\ncreate_dist_barplot(data, figDir, name, \\p-pe\\, c(\\P-P\\, \\P-E\\), 0.2)\ncreate_dist_barplot(data, figDir, name, \\pe-pe\\, c(\\P-P\\, \\P-E\\, \\E-E\\), 0.2)\ncreate_dist_barplot(data, figDir, name, \\str\\, c(\\S-S\\, \\S-X\\), 0.2)\n\n```\n\n<!-- rnb-source-end -->\n"} -->
create_dist_barplot <- function(data, figDir, name, note, loopList, diffCutoff){
  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%
    dplyr::filter(Anno2 %in% loopList,
                  updown_dTAG_DMSO %in% c(\UP\, \NO\, \DOWN\))
  p <- ggplot(temp, aes(x = updown_dTAG_DMSO, y = distance)) +
    geom_violin(aes(fill = updown_dTAG_DMSO)) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = updown_dTAG_DMSO), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + ggtitle(note) +
    scale_y_continuous(labels = label_kb_mb)
  fileName <- paste0(\size_barplot_\, name, \_dTAG_vs_DMSO_\, note, \_\, diffCutoff)
  height <- 3
  width <- 4
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
  
  
  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%
    dplyr::filter(Anno2 %in% loopList,
                  updown_A485_DMSO %in% c(\UP\, \NO\,  \DOWN\))
  p <- ggplot(temp, aes(x = updown_A485_DMSO, y = distance)) +
    geom_violin(aes(fill = updown_A485_DMSO)) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = updown_A485_DMSO), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + ggtitle(note) +
    scale_y_continuous(labels = label_kb_mb)
  fileName <- paste0(\size_barplot_\, name, \_A485_vs_DMSO_\, note, \_\, diffCutoff)
  height <- 3
  width <- 4
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}


name
diffCutoff <- 0.2
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
data <- data %>%
  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)),
                distance = start2 - start1)
data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
create_dist_barplot(data, figDir, name, \p-n\, c(\P-P\, \P-E\, \P-S\, \P-X\), 0.2)
create_dist_barplot(data, figDir, name, \p-pe\, c(\P-P\, \P-E\), 0.2)
create_dist_barplot(data, figDir, name, \pe-pe\, c(\P-P\, \P-E\, \E-E\), 0.2)
create_dist_barplot(data, figDir, name, \str\, c(\S-S\, \S-X\), 0.2)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuY3JlYXRlX2Rpc3RfYmFycGxvdCA8LSBmdW5jdGlvbihkYXRhLCBmaWdEaXIsIG5hbWUsIG5vdGUsIGxvb3BMaXN0LCBkaWZmQ3V0b2ZmKXtcbiAgdGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KEFubm8yLCBkaXN0YW5jZSwgdXBkb3duX2RUQUdfRE1TTywgdXBkb3duX0E0ODVfRE1TTykgJT4lXG4gICAgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGxvb3BMaXN0LFxuICAgICAgICAgICAgICAgICAgdXBkb3duX2RUQUdfRE1TTyAlaW4lIGMoXFxVUFxcLCBcXE5PXFwsIFxcRE9XTlxcKSlcbiAgcCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSB1cGRvd25fZFRBR19ETVNPLCB5ID0gZGlzdGFuY2UpKSArXG4gICAgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSB1cGRvd25fZFRBR19ETVNPKSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSB1cGRvd25fZFRBR19ETVNPKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUobm90ZSkgK1xuICAgIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYilcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcc2l6ZV9iYXJwbG90X1xcLCBuYW1lLCBcXF9kVEFHX3ZzX0RNU09fXFwsIG5vdGUsIFxcX1xcLCBkaWZmQ3V0b2ZmKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSA0XG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIFxuICBcbiAgdGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KEFubm8yLCBkaXN0YW5jZSwgdXBkb3duX2RUQUdfRE1TTywgdXBkb3duX0E0ODVfRE1TTykgJT4lXG4gICAgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGxvb3BMaXN0LFxuICAgICAgICAgICAgICAgICAgdXBkb3duX0E0ODVfRE1TTyAlaW4lIGMoXFxVUFxcLCBcXE5PXFwsICBcXERPV05cXCkpXG4gIHAgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gdXBkb3duX0E0ODVfRE1TTywgeSA9IGRpc3RhbmNlKSkgK1xuICAgIGdlb21fdmlvbGluKGFlcyhmaWxsID0gdXBkb3duX0E0ODVfRE1TTykpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gdXBkb3duX0E0ODVfRE1TTyksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBnZ3RpdGxlKG5vdGUpICtcbiAgICBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXHNpemVfYmFycGxvdF9cXCwgbmFtZSwgXFxfQTQ4NV92c19ETVNPX1xcLCBub3RlLCBcXF9cXCwgZGlmZkN1dG9mZilcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gNFxuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG5cbm5hbWVcbmRpZmZDdXRvZmYgPC0gMC4yXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcbmRhdGEgPC0gZGF0YSAlPiVcbiAgZHBseXI6Om11dGF0ZSh1cGRvd25fZFRBR19ETVNPID0gaWZlbHNlKGRpZmZfZFRBR19ETVNPID4gZGlmZkN1dG9mZiwgXFxVUFxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcXE5PXFwsIFxcRE9XTlxcKSksXG4gICAgICAgICAgICAgICAgdXBkb3duX0E0ODVfRE1TTyA9IGlmZWxzZShkaWZmX0E0ODVfRE1TTyA+IGRpZmZDdXRvZmYsIFxcVVBcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiAtZGlmZkN1dG9mZiwgXFxOT1xcLCBcXERPV05cXCkpLFxuICAgICAgICAgICAgICAgIGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKVxuZGF0YSR1cGRvd25fZFRBR19ETVNPIDwtIGZhY3RvcihkYXRhJHVwZG93bl9kVEFHX0RNU08sIGxldmVscyA9IGMoXFxVUFxcLCBcXE5PXFwsIFxcRE9XTlxcKSlcbmRhdGEkdXBkb3duX0E0ODVfRE1TTyA8LSBmYWN0b3IoZGF0YSR1cGRvd25fQTQ4NV9ETVNPLCBsZXZlbHMgPSBjKFxcVVBcXCwgXFxOT1xcLCBcXERPV05cXCkpXG5jcmVhdGVfZGlzdF9iYXJwbG90KGRhdGEsIGZpZ0RpciwgbmFtZSwgXFxwLW5cXCwgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcKSwgMC4yKVxuY3JlYXRlX2Rpc3RfYmFycGxvdChkYXRhLCBmaWdEaXIsIG5hbWUsIFxccC1wZVxcLCBjKFxcUC1QXFwsIFxcUC1FXFwpLCAwLjIpXG5jcmVhdGVfZGlzdF9iYXJwbG90KGRhdGEsIGZpZ0RpciwgbmFtZSwgXFxwZS1wZVxcLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCAwLjIpXG5jcmVhdGVfZGlzdF9iYXJwbG90KGRhdGEsIGZpZ0RpciwgbmFtZSwgXFxzdHJcXCwgYyhcXFMtU1xcLCBcXFMtWFxcKSwgMC4yKVxuXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\ncreate_dist_barplot <- function(data, figDir, name, note, loopList, diffCutoff){\n  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%\n    dplyr::filter(Anno2 %in% loopList,\n                  updown_dTAG_DMSO %in% c(\\UP\\, \\NO\\, \\DOWN\\))\n  p <- ggplot(temp, aes(x = updown_dTAG_DMSO, y = distance)) +\n    geom_violin(aes(fill = updown_dTAG_DMSO)) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = updown_dTAG_DMSO), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + ggtitle(note) +\n    scale_y_continuous(labels = label_kb_mb)\n  fileName <- paste0(\\size_barplot_\\, name, \\_dTAG_vs_DMSO_\\, note, \\_\\, diffCutoff)\n  height <- 3\n  width <- 4\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n  \n  \n  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%\n    dplyr::filter(Anno2 %in% loopList,\n                  updown_A485_DMSO %in% c(\\UP\\, \\NO\\,  \\DOWN\\))\n  p <- ggplot(temp, aes(x = updown_A485_DMSO, y = distance)) +\n    geom_violin(aes(fill = updown_A485_DMSO)) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = updown_A485_DMSO), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + ggtitle(note) +\n    scale_y_continuous(labels = label_kb_mb)\n  fileName <- paste0(\\size_barplot_\\, name, \\_A485_vs_DMSO_\\, note, \\_\\, diffCutoff)\n  height <- 3\n  width <- 4\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n\nname\ndiffCutoff <- 0.2\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ndata <- data %>%\n  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                          ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                distance = start2 - start1)\ndata$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\ndata$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\\UP\\, \\NO\\, \\DOWN\\))\ncreate_dist_barplot(data, figDir, name, \\p-n\\, c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\), 0.2)\ncreate_dist_barplot(data, figDir, name, \\p-pe\\, c(\\P-P\\, \\P-E\\), 0.2)\ncreate_dist_barplot(data, figDir, name, \\pe-pe\\, c(\\P-P\\, \\P-E\\, \\E-E\\), 0.2)\ncreate_dist_barplot(data, figDir, name, \\str\\, c(\\S-S\\, \\S-X\\), 0.2)\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuY3JlYXRlX2Rpc3RfYmFycGxvdCA8LSBmdW5jdGlvbihkYXRhLCBmaWdEaXIsIG5hbWUsIG5vdGUsIGxvb3BMaXN0LCBkaWZmQ3V0b2ZmKXtcbiAgdGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KEFubm8yLCBkaXN0YW5jZSwgdXBkb3duX2RUQUdfRE1TTywgdXBkb3duX0E0ODVfRE1TTykgJT4lXG4gICAgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGxvb3BMaXN0LFxuICAgICAgICAgICAgICAgICAgdXBkb3duX2RUQUdfRE1TTyAlaW4lIGMoXFxVUFxcLCBcXE5PXFwsIFxcRE9XTlxcKSlcbiAgcCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSB1cGRvd25fZFRBR19ETVNPLCB5ID0gZGlzdGFuY2UpKSArXG4gICAgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSB1cGRvd25fZFRBR19ETVNPKSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSB1cGRvd25fZFRBR19ETVNPKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUobm90ZSkgK1xuICAgIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYilcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcc2l6ZV9iYXJwbG90X1xcLCBuYW1lLCBcXF9kVEFHX3ZzX0RNU09fXFwsIG5vdGUsIFxcX1xcLCBkaWZmQ3V0b2ZmKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSA0XG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIFxuICBcbiAgdGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KEFubm8yLCBkaXN0YW5jZSwgdXBkb3duX2RUQUdfRE1TTywgdXBkb3duX0E0ODVfRE1TTykgJT4lXG4gICAgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGxvb3BMaXN0LFxuICAgICAgICAgICAgICAgICAgdXBkb3duX0E0ODVfRE1TTyAlaW4lIGMoXFxVUFxcLCBcXE5PXFwsICBcXERPV05cXCkpXG4gIHAgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gdXBkb3duX0E0ODVfRE1TTywgeSA9IGRpc3RhbmNlKSkgK1xuICAgIGdlb21fdmlvbGluKGFlcyhmaWxsID0gdXBkb3duX0E0ODVfRE1TTykpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gdXBkb3duX0E0ODVfRE1TTyksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBnZ3RpdGxlKG5vdGUpICtcbiAgICBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXHNpemVfYmFycGxvdF9cXCwgbmFtZSwgXFxfQTQ4NV92c19ETVNPX1xcLCBub3RlLCBcXF9cXCwgZGlmZkN1dG9mZilcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gNFxuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG5cbm5hbWVcbmRpZmZDdXRvZmYgPC0gMC4yXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcbmRhdGEgPC0gZGF0YSAlPiVcbiAgZHBseXI6Om11dGF0ZSh1cGRvd25fZFRBR19ETVNPID0gaWZlbHNlKGRpZmZfZFRBR19ETVNPID4gZGlmZkN1dG9mZiwgXFxVUFxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcXE5PXFwsIFxcRE9XTlxcKSksXG4gICAgICAgICAgICAgICAgdXBkb3duX0E0ODVfRE1TTyA9IGlmZWxzZShkaWZmX0E0ODVfRE1TTyA+IGRpZmZDdXRvZmYsIFxcVVBcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiAtZGlmZkN1dG9mZiwgXFxOT1xcLCBcXERPV05cXCkpLFxuICAgICAgICAgICAgICAgIGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKVxuZGF0YSR1cGRvd25fZFRBR19ETVNPIDwtIGZhY3RvcihkYXRhJHVwZG93bl9kVEFHX0RNU08sIGxldmVscyA9IGMoXFxVUFxcLCBcXE5PXFwsIFxcRE9XTlxcKSlcbmRhdGEkdXBkb3duX0E0ODVfRE1TTyA8LSBmYWN0b3IoZGF0YSR1cGRvd25fQTQ4NV9ETVNPLCBsZXZlbHMgPSBjKFxcVVBcXCwgXFxOT1xcLCBcXERPV05cXCkpXG5jcmVhdGVfZGlzdF9iYXJwbG90KGRhdGEsIGZpZ0RpciwgbmFtZSwgXFxwLW5cXCwgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcKSwgMC4yKVxuY3JlYXRlX2Rpc3RfYmFycGxvdChkYXRhLCBmaWdEaXIsIG5hbWUsIFxccC1wZVxcLCBjKFxcUC1QXFwsIFxcUC1FXFwpLCAwLjIpXG5jcmVhdGVfZGlzdF9iYXJwbG90KGRhdGEsIGZpZ0RpciwgbmFtZSwgXFxwZS1wZVxcLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCAwLjIpXG5jcmVhdGVfZGlzdF9iYXJwbG90KGRhdGEsIGZpZ0RpciwgbmFtZSwgXFxzdHJcXCwgYyhcXFMtU1xcLCBcXFMtWFxcKSwgMC4yKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
create_dist_barplot <- function(data, figDir, name, note, loopList, diffCutoff){
  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%
    dplyr::filter(Anno2 %in% loopList,
                  updown_dTAG_DMSO %in% c(\UP\, \NO\, \DOWN\))
  p <- ggplot(temp, aes(x = updown_dTAG_DMSO, y = distance)) +
    geom_violin(aes(fill = updown_dTAG_DMSO)) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = updown_dTAG_DMSO), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + ggtitle(note) +
    scale_y_continuous(labels = label_kb_mb)
  fileName <- paste0(\size_barplot_\, name, \_dTAG_vs_DMSO_\, note, \_\, diffCutoff)
  height <- 3
  width <- 4
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
  
  
  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%
    dplyr::filter(Anno2 %in% loopList,
                  updown_A485_DMSO %in% c(\UP\, \NO\,  \DOWN\))
  p <- ggplot(temp, aes(x = updown_A485_DMSO, y = distance)) +
    geom_violin(aes(fill = updown_A485_DMSO)) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = updown_A485_DMSO), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + ggtitle(note) +
    scale_y_continuous(labels = label_kb_mb)
  fileName <- paste0(\size_barplot_\, name, \_A485_vs_DMSO_\, note, \_\, diffCutoff)
  height <- 3
  width <- 4
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}


name
diffCutoff <- 0.2
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
data <- data %>%
  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                          ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)),
                distance = start2 - start1)
data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
create_dist_barplot(data, figDir, name, \p-n\, c(\P-P\, \P-E\, \P-S\, \P-X\), 0.2)
create_dist_barplot(data, figDir, name, \p-pe\, c(\P-P\, \P-E\), 0.2)
create_dist_barplot(data, figDir, name, \pe-pe\, c(\P-P\, \P-E\, \E-E\), 0.2)
create_dist_barplot(data, figDir, name, \str\, c(\S-S\, \S-X\), 0.2)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVSMDlrYVhJZ1BDMGdhR1Z5WlNoY0lpNHVMeTR1WENJc0lGd2ljbVZ6ZFd4MFhDSXNJRndpYkc5dmNGd2lMQ0JjSWtkUFhDSXBYRzVrYVhJdVkzSmxZWFJsS0VkUFpHbHlMQ0J6YUc5M1YyRnlibWx1WjNNZ1BTQkdRVXhUUlN3Z2NtVmpkWEp6YVhabElEMGdWRkpWUlNsY2JseHVaMlYwUjA4Z1BDMGdablZ1WTNScGIyNG9ibUZ0WlN3Z1ptbG5SR2x5TENCblpXNWxUR2x6ZEN3Z1kyRjBaV2R2Y25sT2RXMGdQU0F4TlN3Z2FHVnBaMmgwSUQwZ01UQXNJSGRwWkhSb0lEMGdOeWw3WEc0Z0lFZFBJRHd0SUdWdWNtbGphRWRQS0dkbGJtVWdQU0JuWlc1bFRHbHpkQ3dnVDNKblJHSWdQU0J2Y21jdVRXMHVaV2N1WkdJc0lHdGxlVlI1Y0dVZ1BTQmNJa1ZPVTBWTlFreGNJaXdnYjI1MElEMGdYQ0pDVUZ3aUtWeHVJQ0JIVHk1eVpXRmtZV0pzWlNBOExTQnpaWFJTWldGa1lXSnNaU2hIVHl3Z1QzSm5SR0lnUFNCdmNtY3VUVzB1WldjdVpHSXBYRzRnSUdaM2NtbDBaU2hoY3k1a1lYUmhMbVp5WVcxbEtFZFBLU3dnYUdWeVpTaEhUMlJwY2l3Z2NHRnpkR1V3S0Z3aVIwOWZYQ0lzSUc1aGJXVXNJRndpWDJWdWMyVnRZbXd1ZEhOMlhDSXBLU3dnYzJWd0lEMGdYQ0pjWEhSY0lpbGNiaUFnWm5keWFYUmxLR0Z6TG1SaGRHRXVabkpoYldVb1IwOHVjbVZoWkdGaWJHVXBMQ0JvWlhKbEtFZFBaR2x5TENCd1lYTjBaVEFvWENKSFQxOWNJaXdnYm1GdFpTd2dYQ0pmY21WaFpHRmliR1V1ZEhOMlhDSXBLU3dnYzJWd0lEMGdYQ0pjWEhSY0lpbGNiaUFnWEc0Z0lHbG1LRzV5YjNjb1lYTXVaR0YwWVM1bWNtRnRaU2hIVHlrcElDRTlJREFwZTF4dUlDQWdJQ01qSXlNalhHNGdJQ0FnWm1sc1pVNWhiV1VnUEMwZ2NHRnpkR1V3S0Z3aVIwOWZYQ0lzSUc1aGJXVXBYRzRnSUNBZ2MzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNJaTV6ZG1kY0lpa3BMQ0JvWldsbmFIUWdQU0JvWldsbmFIUXNJSGRwWkhSb0lEMGdkMmxrZEdncFhHNGdJQ0FnY0hKcGJuUW9aRzkwY0d4dmRDaEhUeXdnYzJodmQwTmhkR1ZuYjNKNUlEMGdZMkYwWldkdmNubE9kVzBzSUhScGRHeGxJRDBnYm1GdFpTa2dLeUJjYmlBZ0lDQWdJQ0FnSUNBZ0lITmpZV3hsWDJOdmJHOXlYMk52Ym5ScGJuVnZkWE1vYkdsdGFYUnpJRDBnWXlnd0xDQXdMakExS1N3Z2JHOTNJRDBnWENKeVpXUmNJaXdnYUdsbmFDQTlJRndpWW14aFkydGNJaWtwWEc0Z0lDQWdaR1YyTG05bVppZ3BYRzRnSUNBZ2NHNW5LR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ3aUxuQnVaMXdpS1Nrc0lHaGxhV2RvZENBOUlHaGxhV2RvZEN3Z2QybGtkR2dnUFNCM2FXUjBhQ3dnY21WeklEMGdOakF3TENCMWJtbDBJRDBnWENKcGJsd2lLVnh1SUNBZ0lIQnlhVzUwS0dSdmRIQnNiM1FvUjA4c0lITm9iM2REWVhSbFoyOXllU0E5SUdOaGRHVm5iM0o1VG5WdExDQjBhWFJzWlNBOUlHNWhiV1VwSUNzZ1hHNGdJQ0FnSUNBZ0lDQWdJQ0J6WTJGc1pWOWpiMnh2Y2w5amIyNTBhVzUxYjNWektHeHBiV2wwY3lBOUlHTW9NQ3dnTUM0d05Ta3NJR3h2ZHlBOUlGd2ljbVZrWENJc0lHaHBaMmdnUFNCY0ltSnNZV05yWENJcEtWeHVJQ0FnSUdSbGRpNXZabVlvS1Z4dUlDQjlJRnh1ZlZ4dVhHNWpiMjUyVUhaaGJIVmxJRHd0SUdaMWJtTjBhVzl1S0hCMllXeDFaU2w3WEc0Z0lHOTFkQ0E4TFNCcFptVnNjMlVvY0haaGJIVmxJRHdnTUM0d01EQXhMQ0JjSWlvcUtpcGNJaXhjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JwWm1Wc2MyVW9jSFpoYkhWbElEd2dNQzR3TURFc0lGd2lLaW9xWENJc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdsbVpXeHpaU2h3ZG1Gc2RXVWdQQ0F3TGpBeExDQmNJaW9xWENJc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JwWm1Wc2MyVW9jSFpoYkhWbElEd2dNQzR3TlN3Z1hDSXFYQ0lzSUZ3aWJuTmNJaWtwS1NsY2JpQWdjbVYwZFhKdUtHOTFkQ2xjYm4xY2JseHViRzloWkV4dmIzQkJibTV2UkdGMFlTQThMU0JtZFc1amRHbHZiaWhtYVd4bFRtRnRaU3dnWkdsbVprTjFkRzltWmlBOUlEQXVNaXdnWVc1dWIweHBjM1FnUFNCaktGd2lVQzFRWENJc0lGd2lVQzFGWENJc0lGd2lVQzFUWENJc0lGd2lVQzFZWENJcEtYdGNiaUFnWkdGMFlTQThMU0JtY21WaFpDaG1hV3hsVG1GdFpTa2dKVDRsWEc0Z0lDQWdaSEJzZVhJNk9tMTFkR0YwWlNoMWNHUnZkMjVmWkZSQlIxOUVUVk5QSUQwZ2FXWmxiSE5sS0dScFptWmZaRlJCUjE5RVRWTlBJRDRnWkdsbVprTjFkRzltWml3Z1hDSlZVRndpTENCY2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2FXWmxiSE5sS0dScFptWmZaRlJCUjE5RVRWTlBJRDRnTFdScFptWkRkWFJ2Wm1Zc0lGd2lUazljSWl3Z1hDSkVUMWRPWENJcEtTeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJSFZ3Wkc5M2JsOUJORGcxWDBSTlUwOGdQU0JwWm1Wc2MyVW9aR2xtWmw5Qk5EZzFYMFJOVTA4Z1BpQmthV1ptUTNWMGIyWm1MQ0JjSWxWUVhDSXNJRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JwWm1Wc2MyVW9aR2xtWmw5Qk5EZzFYMFJOVTA4Z1BpQXRaR2xtWmtOMWRHOW1aaXdnWENKT1Qxd2lMQ0JjSWtSUFYwNWNJaWtwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1oyVnVaU0E5SUhOMGNuTndiR2wwS0dkbGJtVXNJQ2RjWEZ4Y2ZDY3BLU0FsUGlWY2JpQWdJQ0JrY0d4NWNqbzZabWxzZEdWeUtFRnVibTh5SUNWcGJpVWdJR0Z1Ym05TWFYTjBLVnh1SUNCa1lYUmhKSFZ3Wkc5M2JsOWtWRUZIWDBSTlUwOGdQQzBnWm1GamRHOXlLR1JoZEdFa2RYQmtiM2R1WDJSVVFVZGZSRTFUVHl3Z2JHVjJaV3h6SUQwZ1l5aGNJbFZRWENJc0lGd2lUazljSWl3Z1hDSkVUMWRPWENJcEtWeHVJQ0JrWVhSaEpIVndaRzkzYmw5Qk5EZzFYMFJOVTA4Z1BDMGdabUZqZEc5eUtHUmhkR0VrZFhCa2IzZHVYMEUwT0RWZlJFMVRUeXdnYkdWMlpXeHpJRDBnWXloY0lsVlFYQ0lzSUZ3aVRrOWNJaXdnWENKRVQxZE9YQ0lwS1Z4dUlDQmNiaUFnY21WMGRYSnVLR1JoZEdFcFhHNTlYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbkdPZGlyIDwtIGhlcmUoXFwuLi8uLlxcLCBcXHJlc3VsdFxcLCBcXGxvb3BcXCwgXFxHT1xcKVxuZGlyLmNyZWF0ZShHT2Rpciwgc2hvd1dhcm5pbmdzID0gRkFMU0UsIHJlY3Vyc2l2ZSA9IFRSVUUpXG5cbmdldEdPIDwtIGZ1bmN0aW9uKG5hbWUsIGZpZ0RpciwgZ2VuZUxpc3QsIGNhdGVnb3J5TnVtID0gMTUsIGhlaWdodCA9IDEwLCB3aWR0aCA9IDcpe1xuICBHTyA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbiAgR08ucmVhZGFibGUgPC0gc2V0UmVhZGFibGUoR08sIE9yZ0RiID0gb3JnLk1tLmVnLmRiKVxuICBmd3JpdGUoYXMuZGF0YS5mcmFtZShHTyksIGhlcmUoR09kaXIsIHBhc3RlMChcXEdPX1xcLCBuYW1lLCBcXF9lbnNlbWJsLnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG4gIGZ3cml0ZShhcy5kYXRhLmZyYW1lKEdPLnJlYWRhYmxlKSwgaGVyZShHT2RpciwgcGFzdGUwKFxcR09fXFwsIG5hbWUsIFxcX3JlYWRhYmxlLnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG4gIFxuICBpZihucm93KGFzLmRhdGEuZnJhbWUoR08pKSAhPSAwKXtcbiAgICAjIyMjI1xuICAgIGZpbGVOYW1lIDwtIHBhc3RlMChcXEdPX1xcLCBuYW1lKVxuICAgIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICAgIHByaW50KGRvdHBsb3QoR08sIHNob3dDYXRlZ29yeSA9IGNhdGVnb3J5TnVtLCB0aXRsZSA9IG5hbWUpICsgXG4gICAgICAgICAgICBzY2FsZV9jb2xvcl9jb250aW51b3VzKGxpbWl0cyA9IGMoMCwgMC4wNSksIGxvdyA9IFxccmVkXFwsIGhpZ2ggPSBcXGJsYWNrXFwpKVxuICAgIGRldi5vZmYoKVxuICAgIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgsIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXClcbiAgICBwcmludChkb3RwbG90KEdPLCBzaG93Q2F0ZWdvcnkgPSBjYXRlZ29yeU51bSwgdGl0bGUgPSBuYW1lKSArIFxuICAgICAgICAgICAgc2NhbGVfY29sb3JfY29udGludW91cyhsaW1pdHMgPSBjKDAsIDAuMDUpLCBsb3cgPSBcXHJlZFxcLCBoaWdoID0gXFxibGFja1xcKSlcbiAgICBkZXYub2ZmKClcbiAgfSBcbn1cblxuY29udlB2YWx1ZSA8LSBmdW5jdGlvbihwdmFsdWUpe1xuICBvdXQgPC0gaWZlbHNlKHB2YWx1ZSA8IDAuMDAwMSwgXFwqKioqXFwsXG4gICAgICAgICAgICAgICAgaWZlbHNlKHB2YWx1ZSA8IDAuMDAxLCBcXCoqKlxcLFxuICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UocHZhbHVlIDwgMC4wMSwgXFwqKlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKHB2YWx1ZSA8IDAuMDUsIFxcKlxcLCBcXG5zXFwpKSkpXG4gIHJldHVybihvdXQpXG59XG5cbmxvYWRMb29wQW5ub0RhdGEgPC0gZnVuY3Rpb24oZmlsZU5hbWUsIGRpZmZDdXRvZmYgPSAwLjIsIGFubm9MaXN0ID0gYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcKSl7XG4gIGRhdGEgPC0gZnJlYWQoZmlsZU5hbWUpICU+JVxuICAgIGRwbHlyOjptdXRhdGUodXBkb3duX2RUQUdfRE1TTyA9IGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IGRpZmZDdXRvZmYsIFxcVVBcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcXE5PXFwsIFxcRE9XTlxcKSksXG4gICAgICAgICAgICAgICAgICB1cGRvd25fQTQ4NV9ETVNPID0gaWZlbHNlKGRpZmZfQTQ4NV9ETVNPID4gZGlmZkN1dG9mZiwgXFxVUFxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGRpZmZfQTQ4NV9ETVNPID4gLWRpZmZDdXRvZmYsIFxcTk9cXCwgXFxET1dOXFwpKSxcbiAgICAgICAgICAgICAgICAgIGdlbmUgPSBzdHJzcGxpdChnZW5lLCAnXFxcXHwnKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lICBhbm5vTGlzdClcbiAgZGF0YSR1cGRvd25fZFRBR19ETVNPIDwtIGZhY3RvcihkYXRhJHVwZG93bl9kVEFHX0RNU08sIGxldmVscyA9IGMoXFxVUFxcLCBcXE5PXFwsIFxcRE9XTlxcKSlcbiAgZGF0YSR1cGRvd25fQTQ4NV9ETVNPIDwtIGZhY3RvcihkYXRhJHVwZG93bl9BNDg1X0RNU08sIGxldmVscyA9IGMoXFxVUFxcLCBcXE5PXFwsIFxcRE9XTlxcKSlcbiAgXG4gIHJldHVybihkYXRhKVxufVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
GOdir <- here(\../..\, \result\, \loop\, \GO\)
dir.create(GOdir, showWarnings = FALSE, recursive = TRUE)

getGO <- function(name, figDir, geneList, categoryNum = 15, height = 10, width = 7){
  GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
  GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
  fwrite(as.data.frame(GO), here(GOdir, paste0(\GO_\, name, \_ensembl.tsv\)), sep = \\t\)
  fwrite(as.data.frame(GO.readable), here(GOdir, paste0(\GO_\, name, \_readable.tsv\)), sep = \\t\)
  
  if(nrow(as.data.frame(GO)) != 0){
    #####
    fileName <- paste0(\GO_\, name)
    svglite(here(figDir, paste0(fileName, \.svg\)), height = height, width = width)
    print(dotplot(GO, showCategory = categoryNum, title = name) + 
            scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))
    dev.off()
    png(here(figDir, paste0(fileName, \.png\)), height = height, width = width, res = 600, unit = \in\)
    print(dotplot(GO, showCategory = categoryNum, title = name) + 
            scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))
    dev.off()
  } 
}

convPvalue <- function(pvalue){
  out <- ifelse(pvalue < 0.0001, \****\,
                ifelse(pvalue < 0.001, \***\,
                       ifelse(pvalue < 0.01, \**\,
                              ifelse(pvalue < 0.05, \*\, \ns\))))
  return(out)
}

loadLoopAnnoData <- function(fileName, diffCutoff = 0.2, annoList = c(\P-P\, \P-E\, \P-S\, \P-X\)){
  data <- fread(fileName) %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  gene = strsplit(gene, '\\|')) %>%
    dplyr::filter(Anno2 %in%  annoList)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  
  return(data)
}



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVIwOWthWElnUEMwZ2FHVnlaU2hjWEM0dUx5NHVYRndzSUZ4Y2NtVnpkV3gwWEZ3c0lGeGNiRzl2Y0Z4Y0xDQmNYRWRQWEZ3cFhHNWthWEl1WTNKbFlYUmxLRWRQWkdseUxDQnphRzkzVjJGeWJtbHVaM01nUFNCR1FVeFRSU3dnY21WamRYSnphWFpsSUQwZ1ZGSlZSU2xjYmx4dVoyVjBSMDhnUEMwZ1puVnVZM1JwYjI0b2JtRnRaU3dnWm1sblJHbHlMQ0JuWlc1bFRHbHpkQ3dnWTJGMFpXZHZjbmxPZFcwZ1BTQXhOU3dnYUdWcFoyaDBJRDBnTVRBc0lIZHBaSFJvSUQwZ055bDdYRzRnSUVkUElEd3RJR1Z1Y21samFFZFBLR2RsYm1VZ1BTQm5aVzVsVEdsemRDd2dUM0puUkdJZ1BTQnZjbWN1VFcwdVpXY3VaR0lzSUd0bGVWUjVjR1VnUFNCY1hFVk9VMFZOUWt4Y1hDd2diMjUwSUQwZ1hGeENVRnhjS1Z4dUlDQkhUeTV5WldGa1lXSnNaU0E4TFNCelpYUlNaV0ZrWVdKc1pTaEhUeXdnVDNKblJHSWdQU0J2Y21jdVRXMHVaV2N1WkdJcFhHNGdJR1ozY21sMFpTaGhjeTVrWVhSaExtWnlZVzFsS0VkUEtTd2dhR1Z5WlNoSFQyUnBjaXdnY0dGemRHVXdLRnhjUjA5ZlhGd3NJRzVoYldVc0lGeGNYMlZ1YzJWdFltd3VkSE4yWEZ3cEtTd2djMlZ3SUQwZ1hGeGNYSFJjWENsY2JpQWdabmR5YVhSbEtHRnpMbVJoZEdFdVpuSmhiV1VvUjA4dWNtVmhaR0ZpYkdVcExDQm9aWEpsS0VkUFpHbHlMQ0J3WVhOMFpUQW9YRnhIVDE5Y1hDd2dibUZ0WlN3Z1hGeGZjbVZoWkdGaWJHVXVkSE4yWEZ3cEtTd2djMlZ3SUQwZ1hGeGNYSFJjWENsY2JpQWdYRzRnSUdsbUtHNXliM2NvWVhNdVpHRjBZUzVtY21GdFpTaEhUeWtwSUNFOUlEQXBlMXh1SUNBZ0lDTWpJeU1qWEc0Z0lDQWdabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRnhjUjA5ZlhGd3NJRzVoYldVcFhHNGdJQ0FnYzNabmJHbDBaU2hvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY1hDNXpkbWRjWENrcExDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc0Z0lDQWdjSEpwYm5Rb1pHOTBjR3h2ZENoSFR5d2djMmh2ZDBOaGRHVm5iM0o1SUQwZ1kyRjBaV2R2Y25sT2RXMHNJSFJwZEd4bElEMGdibUZ0WlNrZ0t5QmNiaUFnSUNBZ0lDQWdJQ0FnSUhOallXeGxYMk52Ykc5eVgyTnZiblJwYm5WdmRYTW9iR2x0YVhSeklEMGdZeWd3TENBd0xqQTFLU3dnYkc5M0lEMGdYRnh5WldSY1hDd2dhR2xuYUNBOUlGeGNZbXhoWTJ0Y1hDa3BYRzRnSUNBZ1pHVjJMbTltWmlncFhHNGdJQ0FnY0c1bktHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRnhjTG5CdVoxeGNLU2tzSUdobGFXZG9kQ0E5SUdobGFXZG9kQ3dnZDJsa2RHZ2dQU0IzYVdSMGFDd2djbVZ6SUQwZ05qQXdMQ0IxYm1sMElEMGdYRnhwYmx4Y0tWeHVJQ0FnSUhCeWFXNTBLR1J2ZEhCc2IzUW9SMDhzSUhOb2IzZERZWFJsWjI5eWVTQTlJR05oZEdWbmIzSjVUblZ0TENCMGFYUnNaU0E5SUc1aGJXVXBJQ3NnWEc0Z0lDQWdJQ0FnSUNBZ0lDQnpZMkZzWlY5amIyeHZjbDlqYjI1MGFXNTFiM1Z6S0d4cGJXbDBjeUE5SUdNb01Dd2dNQzR3TlNrc0lHeHZkeUE5SUZ4Y2NtVmtYRndzSUdocFoyZ2dQU0JjWEdKc1lXTnJYRndwS1Z4dUlDQWdJR1JsZGk1dlptWW9LVnh1SUNCOUlGeHVmVnh1WEc1amIyNTJVSFpoYkhWbElEd3RJR1oxYm1OMGFXOXVLSEIyWVd4MVpTbDdYRzRnSUc5MWRDQThMU0JwWm1Wc2MyVW9jSFpoYkhWbElEd2dNQzR3TURBeExDQmNYQ29xS2lwY1hDeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnBabVZzYzJVb2NIWmhiSFZsSUR3Z01DNHdNREVzSUZ4Y0tpb3FYRndzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaHdkbUZzZFdVZ1BDQXdMakF4TENCY1hDb3FYRndzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnBabVZzYzJVb2NIWmhiSFZsSUR3Z01DNHdOU3dnWEZ3cVhGd3NJRnhjYm5OY1hDa3BLU2xjYmlBZ2NtVjBkWEp1S0c5MWRDbGNibjFjYmx4dWJHOWhaRXh2YjNCQmJtNXZSR0YwWVNBOExTQm1kVzVqZEdsdmJpaG1hV3hsVG1GdFpTd2daR2xtWmtOMWRHOW1aaUE5SURBdU1pd2dZVzV1YjB4cGMzUWdQU0JqS0Z4Y1VDMVFYRndzSUZ4Y1VDMUZYRndzSUZ4Y1VDMVRYRndzSUZ4Y1VDMVlYRndwS1h0Y2JpQWdaR0YwWVNBOExTQm1jbVZoWkNobWFXeGxUbUZ0WlNrZ0pUNGxYRzRnSUNBZ1pIQnNlWEk2T20xMWRHRjBaU2gxY0dSdmQyNWZaRlJCUjE5RVRWTlBJRDBnYVdabGJITmxLR1JwWm1aZlpGUkJSMTlFVFZOUElENGdaR2xtWmtOMWRHOW1aaXdnWEZ4VlVGeGNMQ0JjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR1JwWm1aZlpGUkJSMTlFVFZOUElENGdMV1JwWm1aRGRYUnZabVlzSUZ4Y1RrOWNYQ3dnWEZ4RVQxZE9YRndwS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lIVndaRzkzYmw5Qk5EZzFYMFJOVTA4Z1BTQnBabVZzYzJVb1pHbG1abDlCTkRnMVgwUk5VMDhnUGlCa2FXWm1RM1YwYjJabUxDQmNYRlZRWEZ3c0lGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnBabVZzYzJVb1pHbG1abDlCTkRnMVgwUk5VMDhnUGlBdFpHbG1aa04xZEc5bVppd2dYRnhPVDF4Y0xDQmNYRVJQVjA1Y1hDa3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWjJWdVpTQTlJSE4wY25Od2JHbDBLR2RsYm1Vc0lDZGNYRnhjZkNjcEtTQWxQaVZjYmlBZ0lDQmtjR3g1Y2pvNlptbHNkR1Z5S0VGdWJtOHlJQ1ZwYmlVZ0lHRnVibTlNYVhOMEtWeHVJQ0JrWVhSaEpIVndaRzkzYmw5a1ZFRkhYMFJOVTA4Z1BDMGdabUZqZEc5eUtHUmhkR0VrZFhCa2IzZHVYMlJVUVVkZlJFMVRUeXdnYkdWMlpXeHpJRDBnWXloY1hGVlFYRndzSUZ4Y1RrOWNYQ3dnWEZ4RVQxZE9YRndwS1Z4dUlDQmtZWFJoSkhWd1pHOTNibDlCTkRnMVgwUk5VMDhnUEMwZ1ptRmpkRzl5S0dSaGRHRWtkWEJrYjNkdVgwRTBPRFZmUkUxVFR5d2diR1YyWld4eklEMGdZeWhjWEZWUVhGd3NJRnhjVGs5Y1hDd2dYRnhFVDFkT1hGd3BLVnh1SUNCY2JpQWdjbVYwZFhKdUtHUmhkR0VwWEc1OVhHNWdZR0JjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbmBgYHJcbkdPZGlyIDwtIGhlcmUoXFwuLi8uLlxcLCBcXHJlc3VsdFxcLCBcXGxvb3BcXCwgXFxHT1xcKVxuZGlyLmNyZWF0ZShHT2Rpciwgc2hvd1dhcm5pbmdzID0gRkFMU0UsIHJlY3Vyc2l2ZSA9IFRSVUUpXG5cbmdldEdPIDwtIGZ1bmN0aW9uKG5hbWUsIGZpZ0RpciwgZ2VuZUxpc3QsIGNhdGVnb3J5TnVtID0gMTUsIGhlaWdodCA9IDEwLCB3aWR0aCA9IDcpe1xuICBHTyA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbiAgR08ucmVhZGFibGUgPC0gc2V0UmVhZGFibGUoR08sIE9yZ0RiID0gb3JnLk1tLmVnLmRiKVxuICBmd3JpdGUoYXMuZGF0YS5mcmFtZShHTyksIGhlcmUoR09kaXIsIHBhc3RlMChcXEdPX1xcLCBuYW1lLCBcXF9lbnNlbWJsLnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG4gIGZ3cml0ZShhcy5kYXRhLmZyYW1lKEdPLnJlYWRhYmxlKSwgaGVyZShHT2RpciwgcGFzdGUwKFxcR09fXFwsIG5hbWUsIFxcX3JlYWRhYmxlLnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG4gIFxuICBpZihucm93KGFzLmRhdGEuZnJhbWUoR08pKSAhPSAwKXtcbiAgICAjIyMjI1xuICAgIGZpbGVOYW1lIDwtIHBhc3RlMChcXEdPX1xcLCBuYW1lKVxuICAgIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICAgIHByaW50KGRvdHBsb3QoR08sIHNob3dDYXRlZ29yeSA9IGNhdGVnb3J5TnVtLCB0aXRsZSA9IG5hbWUpICsgXG4gICAgICAgICAgICBzY2FsZV9jb2xvcl9jb250aW51b3VzKGxpbWl0cyA9IGMoMCwgMC4wNSksIGxvdyA9IFxccmVkXFwsIGhpZ2ggPSBcXGJsYWNrXFwpKVxuICAgIGRldi5vZmYoKVxuICAgIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgsIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXClcbiAgICBwcmludChkb3RwbG90KEdPLCBzaG93Q2F0ZWdvcnkgPSBjYXRlZ29yeU51bSwgdGl0bGUgPSBuYW1lKSArIFxuICAgICAgICAgICAgc2NhbGVfY29sb3JfY29udGludW91cyhsaW1pdHMgPSBjKDAsIDAuMDUpLCBsb3cgPSBcXHJlZFxcLCBoaWdoID0gXFxibGFja1xcKSlcbiAgICBkZXYub2ZmKClcbiAgfSBcbn1cblxuY29udlB2YWx1ZSA8LSBmdW5jdGlvbihwdmFsdWUpe1xuICBvdXQgPC0gaWZlbHNlKHB2YWx1ZSA8IDAuMDAwMSwgXFwqKioqXFwsXG4gICAgICAgICAgICAgICAgaWZlbHNlKHB2YWx1ZSA8IDAuMDAxLCBcXCoqKlxcLFxuICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UocHZhbHVlIDwgMC4wMSwgXFwqKlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKHB2YWx1ZSA8IDAuMDUsIFxcKlxcLCBcXG5zXFwpKSkpXG4gIHJldHVybihvdXQpXG59XG5cbmxvYWRMb29wQW5ub0RhdGEgPC0gZnVuY3Rpb24oZmlsZU5hbWUsIGRpZmZDdXRvZmYgPSAwLjIsIGFubm9MaXN0ID0gYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcKSl7XG4gIGRhdGEgPC0gZnJlYWQoZmlsZU5hbWUpICU+JVxuICAgIGRwbHlyOjptdXRhdGUodXBkb3duX2RUQUdfRE1TTyA9IGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IGRpZmZDdXRvZmYsIFxcVVBcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcXE5PXFwsIFxcRE9XTlxcKSksXG4gICAgICAgICAgICAgICAgICB1cGRvd25fQTQ4NV9ETVNPID0gaWZlbHNlKGRpZmZfQTQ4NV9ETVNPID4gZGlmZkN1dG9mZiwgXFxVUFxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGRpZmZfQTQ4NV9ETVNPID4gLWRpZmZDdXRvZmYsIFxcTk9cXCwgXFxET1dOXFwpKSxcbiAgICAgICAgICAgICAgICAgIGdlbmUgPSBzdHJzcGxpdChnZW5lLCAnXFxcXHwnKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lICBhbm5vTGlzdClcbiAgZGF0YSR1cGRvd25fZFRBR19ETVNPIDwtIGZhY3RvcihkYXRhJHVwZG93bl9kVEFHX0RNU08sIGxldmVscyA9IGMoXFxVUFxcLCBcXE5PXFwsIFxcRE9XTlxcKSlcbiAgZGF0YSR1cGRvd25fQTQ4NV9ETVNPIDwtIGZhY3RvcihkYXRhJHVwZG93bl9BNDg1X0RNU08sIGxldmVscyA9IGMoXFxVUFxcLCBcXE5PXFwsIFxcRE9XTlxcKSlcbiAgXG4gIHJldHVybihkYXRhKVxufVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuR09kaXIgPC0gaGVyZShcXC4uLy4uXFwsIFxccmVzdWx0XFwsIFxcbG9vcFxcLCBcXEdPXFwpXG5kaXIuY3JlYXRlKEdPZGlyLCBzaG93V2FybmluZ3MgPSBGQUxTRSwgcmVjdXJzaXZlID0gVFJVRSlcblxuZ2V0R08gPC0gZnVuY3Rpb24obmFtZSwgZmlnRGlyLCBnZW5lTGlzdCwgY2F0ZWdvcnlOdW0gPSAxNSwgaGVpZ2h0ID0gMTAsIHdpZHRoID0gNyl7XG4gIEdPIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuICBHTy5yZWFkYWJsZSA8LSBzZXRSZWFkYWJsZShHTywgT3JnRGIgPSBvcmcuTW0uZWcuZGIpXG4gIGZ3cml0ZShhcy5kYXRhLmZyYW1lKEdPKSwgaGVyZShHT2RpciwgcGFzdGUwKFxcR09fXFwsIG5hbWUsIFxcX2Vuc2VtYmwudHN2XFwpKSwgc2VwID0gXFxcXHRcXClcbiAgZndyaXRlKGFzLmRhdGEuZnJhbWUoR08ucmVhZGFibGUpLCBoZXJlKEdPZGlyLCBwYXN0ZTAoXFxHT19cXCwgbmFtZSwgXFxfcmVhZGFibGUudHN2XFwpKSwgc2VwID0gXFxcXHRcXClcbiAgXG4gIGlmKG5yb3coYXMuZGF0YS5mcmFtZShHTykpICE9IDApe1xuICAgICMjIyMjXG4gICAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcR09fXFwsIG5hbWUpXG4gICAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gICAgcHJpbnQoZG90cGxvdChHTywgc2hvd0NhdGVnb3J5ID0gY2F0ZWdvcnlOdW0sIHRpdGxlID0gbmFtZSkgKyBcbiAgICAgICAgICAgIHNjYWxlX2NvbG9yX2NvbnRpbnVvdXMobGltaXRzID0gYygwLCAwLjA1KSwgbG93ID0gXFxyZWRcXCwgaGlnaCA9IFxcYmxhY2tcXCkpXG4gICAgZGV2Lm9mZigpXG4gICAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aCwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcKVxuICAgIHByaW50KGRvdHBsb3QoR08sIHNob3dDYXRlZ29yeSA9IGNhdGVnb3J5TnVtLCB0aXRsZSA9IG5hbWUpICsgXG4gICAgICAgICAgICBzY2FsZV9jb2xvcl9jb250aW51b3VzKGxpbWl0cyA9IGMoMCwgMC4wNSksIGxvdyA9IFxccmVkXFwsIGhpZ2ggPSBcXGJsYWNrXFwpKVxuICAgIGRldi5vZmYoKVxuICB9IFxufVxuXG5jb252UHZhbHVlIDwtIGZ1bmN0aW9uKHB2YWx1ZSl7XG4gIG91dCA8LSBpZmVsc2UocHZhbHVlIDwgMC4wMDAxLCBcXCoqKipcXCxcbiAgICAgICAgICAgICAgICBpZmVsc2UocHZhbHVlIDwgMC4wMDEsIFxcKioqXFwsXG4gICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShwdmFsdWUgPCAwLjAxLCBcXCoqXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UocHZhbHVlIDwgMC4wNSwgXFwqXFwsIFxcbnNcXCkpKSlcbiAgcmV0dXJuKG91dClcbn1cblxubG9hZExvb3BBbm5vRGF0YSA8LSBmdW5jdGlvbihmaWxlTmFtZSwgZGlmZkN1dG9mZiA9IDAuMiwgYW5ub0xpc3QgPSBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcUC1TXFwsIFxcUC1YXFwpKXtcbiAgZGF0YSA8LSBmcmVhZChmaWxlTmFtZSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZSh1cGRvd25fZFRBR19ETVNPID0gaWZlbHNlKGRpZmZfZFRBR19ETVNPID4gZGlmZkN1dG9mZiwgXFxVUFxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGRpZmZfZFRBR19ETVNPID4gLWRpZmZDdXRvZmYsIFxcTk9cXCwgXFxET1dOXFwpKSxcbiAgICAgICAgICAgICAgICAgIHVwZG93bl9BNDg1X0RNU08gPSBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiBkaWZmQ3V0b2ZmLCBcXFVQXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9BNDg1X0RNU08gPiAtZGlmZkN1dG9mZiwgXFxOT1xcLCBcXERPV05cXCkpLFxuICAgICAgICAgICAgICAgICAgZ2VuZSA9IHN0cnNwbGl0KGdlbmUsICdcXFxcfCcpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgIGFubm9MaXN0KVxuICBkYXRhJHVwZG93bl9kVEFHX0RNU08gPC0gZmFjdG9yKGRhdGEkdXBkb3duX2RUQUdfRE1TTywgbGV2ZWxzID0gYyhcXFVQXFwsIFxcTk9cXCwgXFxET1dOXFwpKVxuICBkYXRhJHVwZG93bl9BNDg1X0RNU08gPC0gZmFjdG9yKGRhdGEkdXBkb3duX0E0ODVfRE1TTywgbGV2ZWxzID0gYyhcXFVQXFwsIFxcTk9cXCwgXFxET1dOXFwpKVxuICBcbiAgcmV0dXJuKGRhdGEpXG59XG5gYGBcbmBgYCJ9 -->

```r
```r
GOdir <- here(\../..\, \result\, \loop\, \GO\)
dir.create(GOdir, showWarnings = FALSE, recursive = TRUE)

getGO <- function(name, figDir, geneList, categoryNum = 15, height = 10, width = 7){
  GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
  GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
  fwrite(as.data.frame(GO), here(GOdir, paste0(\GO_\, name, \_ensembl.tsv\)), sep = \\t\)
  fwrite(as.data.frame(GO.readable), here(GOdir, paste0(\GO_\, name, \_readable.tsv\)), sep = \\t\)
  
  if(nrow(as.data.frame(GO)) != 0){
    #####
    fileName <- paste0(\GO_\, name)
    svglite(here(figDir, paste0(fileName, \.svg\)), height = height, width = width)
    print(dotplot(GO, showCategory = categoryNum, title = name) + 
            scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))
    dev.off()
    png(here(figDir, paste0(fileName, \.png\)), height = height, width = width, res = 600, unit = \in\)
    print(dotplot(GO, showCategory = categoryNum, title = name) + 
            scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))
    dev.off()
  } 
}

convPvalue <- function(pvalue){
  out <- ifelse(pvalue < 0.0001, \****\,
                ifelse(pvalue < 0.001, \***\,
                       ifelse(pvalue < 0.01, \**\,
                              ifelse(pvalue < 0.05, \*\, \ns\))))
  return(out)
}

loadLoopAnnoData <- function(fileName, diffCutoff = 0.2, annoList = c(\P-P\, \P-E\, \P-S\, \P-X\)){
  data <- fread(fileName) %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  gene = strsplit(gene, '\\|')) %>%
    dplyr::filter(Anno2 %in%  annoList)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  
  return(data)
}
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

### [2.9] Size distribution of diff loops


<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\nloopType <- \"p-n\"\n\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \"diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \"diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \"chromo_cons_annoHierarchy\"\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\"P-P\", \"P-E\", \"P-S\", \"P-X\"))%>%\n  dplyr::mutate(distance = start2 - start1)\n# geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n#                                       diffCutoff = diffCutoff,\n#                                       annoList = c(\"P-P\"))%>% \n#   dplyr::mutate(distance = start2 - start1)\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% c(), \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \"gene_avgScore_fc_dTAG_p-n.tsv\"), sep = \"\\t\")\n\n#\n# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n#                       label = ifelse(flag != \"0NO\", external_gene_name, NA),\n#                       shape = as.factor(maxFlag))) +\n#   geom_point() + geom_text_repel() + theme_classic() +\n#   ggtitle(\"dTAG\") +\n#   geom_hline(yintercept = 0) +\n#   geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n#   geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") +\n#   geom_vline(xintercept = 0) +\n#   geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n#   geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n#   scale_color_manual(values = c(\"0NO\" = \"grey\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n#   scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n#\n# fileName <- paste0(\"log2FC_vs_avgScore_dTAG_\", loopType, \"_diffCutoff_\", diffCutoff)\n# height <- 4\n# width <- 7\n# png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\n# print(p)\n# dev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \"2DOWN\",\n                              ifelse(gene %in% c(), \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n# fwrite(temp, here(consensusDir, paste0(\"gene_avgScore_fc_dTAG_\", loopType, \"_noFCcutoff.tsv\")), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point(size = 1, alpha = 1,\n      stroke = 0) + geom_text_repel() + theme_classic() + \n  guides(color = \"none\", shape = \"none\") + \n  geom_hline(yintercept = 0, alpha = 1,\n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\") +\n  geom_hline(yintercept = c(diffCutoff, -diffCutoff), linetype = \"dashed\", alpha = 1,\n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\") +\n  geom_vline(xintercept = 0, alpha = 1,\n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\") +\n  geom_vline(xintercept = c(fcCutoff, -fcCutoff), linetype = \"dashed\", alpha = 1,\n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\") +\n  theme(\n    axis.title.x = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),    \n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) + labs(y = \"Avg. Δ loop score\", x = \"log2(shrunken FC)\") +\n  scale_color_manual(values = c(\"0NO\" = \"#A9A8A9\", \"1UP\" = \"#CB333A\", \"2DOWN\" = \"#4852A0\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_dTAG_\", loopType, \"_diffCutoff_\", diffCutoff, \"_noFCcutoff\")\nheight <- 42*mmToInch\nwidth <- 50*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - up and down\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.updown.RNA.noFCcutoff, \"2DOWN\",\n                              ifelse(gene %in% c(), \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"dTAG\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"grey\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_dTAG_\", loopType, \"_diffCutoff_\", diffCutoff, \"_noFCcutoffupdown\")\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n# \n# ## RNA + PRO-seq\n# temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n#   unnest(gene) %>% group_by(gene) %>%\n#   summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n# \n# temp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n#   dplyr::mutate(flag = ifelse(gene %in% geneList.down, \"2DOWN\",\n#                               ifelse(gene %in% geneList.up, \"1UP\", \"0NO\")),\n#                 maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n#                 shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n#   dplyr::arrange(flag)\n# \n# fwrite(temp, here(consensusDir, \"gene_avgScore_fc_dTAG_\", loopType, \".tsv\"), sep = \"\\t\")\n# \n# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n#                       label = ifelse(flag != \"0NO\", external_gene_name, NA),\n#                       shape = as.factor(maxFlag))) +\n#   geom_point() + geom_text_repel() + theme_classic() + \n#   ggtitle(\"dTAG\") +\n#   geom_hline(yintercept = 0) +\n#   geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n#   geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n#   geom_vline(xintercept = 0) +\n#   geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n#   geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n#   scale_color_manual(values = c(\"0NO\" = \"grey\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n#   scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n# \n# fileName <- paste0(\"log2FC_vs_avgScore_dTAG_\", loopType, \"_diffCutoff_\", diffCutoff, \"_RNA-PRO\")\n# height <- 4\n# width <- 7\n# png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\n# print(p)\n# dev.off()\n```"} -->\n\n```r\nloopType <- \\p-n\\\n\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>%\n  dplyr::mutate(distance = start2 - start1)\n# geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n#                                       diffCutoff = diffCutoff,\n#                                       annoList = c(\\P-P\\))%>% \n#   dplyr::mutate(distance = start2 - start1)\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\n#\n# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n#                       label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n#                       shape = as.factor(maxFlag))) +\n#   geom_point() + geom_text_repel() + theme_classic() +\n#   ggtitle(\\dTAG\\) +\n#   geom_hline(yintercept = 0) +\n#   geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n#   geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n#   geom_vline(xintercept = 0) +\n#   geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n#   geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n#   scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n#   scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n#\n# fileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff)\n# height <- 4\n# width <- 7\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n# fwrite(temp, here(consensusDir, paste0(\\gene_avgScore_fc_dTAG_\\, loopType, \\_noFCcutoff.tsv\\)), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point(size = 1, alpha = 1,\n      stroke = 0) + geom_text_repel() + theme_classic() + \n  guides(color = \\none\\, shape = \\none\\) + \n  geom_hline(yintercept = 0, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_hline(yintercept = c(diffCutoff, -diffCutoff), linetype = \\dashed\\, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_vline(xintercept = 0, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_vline(xintercept = c(fcCutoff, -fcCutoff), linetype = \\dashed\\, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  theme(\n    axis.title.x = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) + labs(y = \\Avg. Δ loop score\\, x = \\log2(shrunken FC)\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\#A9A8A9\\, \\1UP\\ = \\#CB333A\\, \\2DOWN\\ = \\#4852A0\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff, \\_noFCcutoff\\)\nheight <- 42*mmToInch\nwidth <- 50*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - up and down\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.updown.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff, \\_noFCcutoffupdown\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# \n# ## RNA + PRO-seq\n# temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n#   unnest(gene) %>% group_by(gene) %>%\n#   summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n# \n# temp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n#   dplyr::mutate(flag = ifelse(gene %in% geneList.down, \\2DOWN\\,\n#                               ifelse(gene %in% geneList.up, \\1UP\\, \\0NO\\)),\n#                 maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n#                 shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n#   dplyr::arrange(flag)\n# \n# fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_\\, loopType, \\.tsv\\), sep = \\\\t\\)\n# \n# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n#                       label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n#                       shape = as.factor(maxFlag))) +\n#   geom_point() + geom_text_repel() + theme_classic() + \n#   ggtitle(\\dTAG\\) +\n#   geom_hline(yintercept = 0) +\n#   geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n#   geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n#   geom_vline(xintercept = 0) +\n#   geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n#   geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n#   scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n#   scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n# \n# fileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff, \\_RNA-PRO\\)\n# height <- 4\n# width <- 7\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
loopType <- \p-n\

# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>%
  dplyr::mutate(distance = start2 - start1)
# geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
#                                       diffCutoff = diffCutoff,
#                                       annoList = c(\P-P\))%>% 
#   dplyr::mutate(distance = start2 - start1)
# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

#
# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
#                       label = ifelse(flag != \0NO\, external_gene_name, NA),
#                       shape = as.factor(maxFlag))) +
#   geom_point() + geom_text_repel() + theme_classic() +
#   ggtitle(\dTAG\) +
#   geom_hline(yintercept = 0) +
#   geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
#   geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
#   geom_vline(xintercept = 0) +
#   geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
#   geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
#   scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
#   scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))
#
# fileName <- paste0(\log2FC_vs_avgScore_dTAG_\, loopType, \_diffCutoff_\, diffCutoff)
# height <- 4
# width <- 7
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

# fwrite(temp, here(consensusDir, paste0(\gene_avgScore_fc_dTAG_\, loopType, \_noFCcutoff.tsv\)), sep = \\t\)

p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point(size = 1, alpha = 1,
      stroke = 0) + geom_text_repel() + theme_classic() + 
  guides(color = \none\, shape = \none\) + 
  geom_hline(yintercept = 0, alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) +
  geom_hline(yintercept = c(diffCutoff, -diffCutoff), linetype = \dashed\, alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) +
  geom_vline(xintercept = 0, alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) +
  geom_vline(xintercept = c(fcCutoff, -fcCutoff), linetype = \dashed\, alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) +
  theme(
    axis.title.x = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) + labs(y = \Avg. Δ loop score\, x = \log2(shrunken FC)\) +
  scale_color_manual(values = c(\0NO\ = \#A9A8A9\, \1UP\ = \#CB333A\, \2DOWN\ = \#4852A0\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_\, loopType, \_diffCutoff_\, diffCutoff, \_noFCcutoff\)
height <- 42*mmToInch
width <- 50*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - up and down
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.updown.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_\, loopType, \_diffCutoff_\, diffCutoff, \_noFCcutoffupdown\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# 
# ## RNA + PRO-seq
# temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% 
#   unnest(gene) %>% group_by(gene) %>%
#   summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')
# 
# temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
#   dplyr::mutate(flag = ifelse(gene %in% geneList.down, \2DOWN\,
#                               ifelse(gene %in% geneList.up, \1UP\, \0NO\)),
#                 maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
#                 shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
#   dplyr::arrange(flag)
# 
# fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_\, loopType, \.tsv\), sep = \\t\)
# 
# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
#                       label = ifelse(flag != \0NO\, external_gene_name, NA),
#                       shape = as.factor(maxFlag))) +
#   geom_point() + geom_text_repel() + theme_classic() + 
#   ggtitle(\dTAG\) +
#   geom_hline(yintercept = 0) +
#   geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
#   geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
#   geom_vline(xintercept = 0) +
#   geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
#   geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
#   scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
#   scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))
# 
# fileName <- paste0(\log2FC_vs_avgScore_dTAG_\, loopType, \_diffCutoff_\, diffCutoff, \_RNA-PRO\)
# height <- 4
# width <- 7
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\nloopType <- \\p-n\\\n\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>%\n  dplyr::mutate(distance = start2 - start1)\n# geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n#                                       diffCutoff = diffCutoff,\n#                                       annoList = c(\\P-P\\))%>% \n#   dplyr::mutate(distance = start2 - start1)\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\n#\n# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n#                       label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n#                       shape = as.factor(maxFlag))) +\n#   geom_point() + geom_text_repel() + theme_classic() +\n#   ggtitle(\\dTAG\\) +\n#   geom_hline(yintercept = 0) +\n#   geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n#   geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n#   geom_vline(xintercept = 0) +\n#   geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n#   geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n#   scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n#   scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n#\n# fileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff)\n# height <- 4\n# width <- 7\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n# fwrite(temp, here(consensusDir, paste0(\\gene_avgScore_fc_dTAG_\\, loopType, \\_noFCcutoff.tsv\\)), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point(size = 1, alpha = 1,\n      stroke = 0) + geom_text_repel() + theme_classic() + \n  guides(color = \\none\\, shape = \\none\\) + \n  geom_hline(yintercept = 0, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_hline(yintercept = c(diffCutoff, -diffCutoff), linetype = \\dashed\\, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_vline(xintercept = 0, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_vline(xintercept = c(fcCutoff, -fcCutoff), linetype = \\dashed\\, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  theme(\n    axis.title.x = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) + labs(y = \\Avg. Δ loop score\\, x = \\log2(shrunken FC)\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\#A9A8A9\\, \\1UP\\ = \\#CB333A\\, \\2DOWN\\ = \\#4852A0\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff, \\_noFCcutoff\\)\nheight <- 42*mmToInch\nwidth <- 50*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - up and down\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.updown.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff, \\_noFCcutoffupdown\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# \n# ## RNA + PRO-seq\n# temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n#   unnest(gene) %>% group_by(gene) %>%\n#   summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n# \n# temp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n#   dplyr::mutate(flag = ifelse(gene %in% geneList.down, \\2DOWN\\,\n#                               ifelse(gene %in% geneList.up, \\1UP\\, \\0NO\\)),\n#                 maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n#                 shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n#   dplyr::arrange(flag)\n# \n# fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_\\, loopType, \\.tsv\\), sep = \\\\t\\)\n# \n# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n#                       label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n#                       shape = as.factor(maxFlag))) +\n#   geom_point() + geom_text_repel() + theme_classic() + \n#   ggtitle(\\dTAG\\) +\n#   geom_hline(yintercept = 0) +\n#   geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n#   geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n#   geom_vline(xintercept = 0) +\n#   geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n#   geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n#   scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n#   scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n# \n# fileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff, \\_RNA-PRO\\)\n# height <- 4\n# width <- 7\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n```\n```"} -->\n\n```r\n```r\nloopType <- \\p-n\\\n\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>%\n  dplyr::mutate(distance = start2 - start1)\n# geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n#                                       diffCutoff = diffCutoff,\n#                                       annoList = c(\\P-P\\))%>% \n#   dplyr::mutate(distance = start2 - start1)\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\n#\n# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n#                       label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n#                       shape = as.factor(maxFlag))) +\n#   geom_point() + geom_text_repel() + theme_classic() +\n#   ggtitle(\\dTAG\\) +\n#   geom_hline(yintercept = 0) +\n#   geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n#   geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n#   geom_vline(xintercept = 0) +\n#   geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n#   geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n#   scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n#   scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n#\n# fileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff)\n# height <- 4\n# width <- 7\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n# fwrite(temp, here(consensusDir, paste0(\\gene_avgScore_fc_dTAG_\\, loopType, \\_noFCcutoff.tsv\\)), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point(size = 1, alpha = 1,\n      stroke = 0) + geom_text_repel() + theme_classic() + \n  guides(color = \\none\\, shape = \\none\\) + \n  geom_hline(yintercept = 0, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_hline(yintercept = c(diffCutoff, -diffCutoff), linetype = \\dashed\\, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_vline(xintercept = 0, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_vline(xintercept = c(fcCutoff, -fcCutoff), linetype = \\dashed\\, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  theme(\n    axis.title.x = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) + labs(y = \\Avg. Δ loop score\\, x = \\log2(shrunken FC)\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\#A9A8A9\\, \\1UP\\ = \\#CB333A\\, \\2DOWN\\ = \\#4852A0\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff, \\_noFCcutoff\\)\nheight <- 42*mmToInch\nwidth <- 50*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - up and down\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.updown.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff, \\_noFCcutoffupdown\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# \n# ## RNA + PRO-seq\n# temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n#   unnest(gene) %>% group_by(gene) %>%\n#   summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n# \n# temp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n#   dplyr::mutate(flag = ifelse(gene %in% geneList.down, \\2DOWN\\,\n#                               ifelse(gene %in% geneList.up, \\1UP\\, \\0NO\\)),\n#                 maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n#                 shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n#   dplyr::arrange(flag)\n# \n# fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_\\, loopType, \\.tsv\\), sep = \\\\t\\)\n# \n# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n#                       label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n#                       shape = as.factor(maxFlag))) +\n#   geom_point() + geom_text_repel() + theme_classic() + \n#   ggtitle(\\dTAG\\) +\n#   geom_hline(yintercept = 0) +\n#   geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n#   geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n#   geom_vline(xintercept = 0) +\n#   geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n#   geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n#   scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n#   scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n# \n# fileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff, \\_RNA-PRO\\)\n# height <- 4\n# width <- 7\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\nloopType <- \\p-n\\\n\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>%\n  dplyr::mutate(distance = start2 - start1)\n# geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n#                                       diffCutoff = diffCutoff,\n#                                       annoList = c(\\P-P\\))%>% \n#   dplyr::mutate(distance = start2 - start1)\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\n#\n# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,\n#                       label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n#                       shape = as.factor(maxFlag))) +\n#   geom_point() + geom_text_repel() + theme_classic() +\n#   ggtitle(\\dTAG\\) +\n#   geom_hline(yintercept = 0) +\n#   geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n#   geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) +\n#   geom_vline(xintercept = 0) +\n#   geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n#   geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n#   scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n#   scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n#\n# fileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff)\n# height <- 4\n# width <- 7\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n# fwrite(temp, here(consensusDir, paste0(\\gene_avgScore_fc_dTAG_\\, loopType, \\_noFCcutoff.tsv\\)), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point(size = 1, alpha = 1,\n      stroke = 0) + geom_text_repel() + theme_classic() + \n  guides(color = \\none\\, shape = \\none\\) + \n  geom_hline(yintercept = 0, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_hline(yintercept = c(diffCutoff, -diffCutoff), linetype = \\dashed\\, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_vline(xintercept = 0, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_vline(xintercept = c(fcCutoff, -fcCutoff), linetype = \\dashed\\, alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  theme(\n    axis.title.x = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) + labs(y = \\Avg. Δ loop score\\, x = \\log2(shrunken FC)\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\#A9A8A9\\, \\1UP\\ = \\#CB333A\\, \\2DOWN\\ = \\#4852A0\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff, \\_noFCcutoff\\)\nheight <- 42*mmToInch\nwidth <- 50*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - up and down\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.updown.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff, \\_noFCcutoffupdown\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# \n# ## RNA + PRO-seq\n# temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% \n#   unnest(gene) %>% group_by(gene) %>%\n#   summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')\n# \n# temp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n#   dplyr::mutate(flag = ifelse(gene %in% geneList.down, \\2DOWN\\,\n#                               ifelse(gene %in% geneList.up, \\1UP\\, \\0NO\\)),\n#                 maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n#                 shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n#   dplyr::arrange(flag)\n# \n# fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_\\, loopType, \\.tsv\\), sep = \\\\t\\)\n# \n# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n#                       label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n#                       shape = as.factor(maxFlag))) +\n#   geom_point() + geom_text_repel() + theme_classic() + \n#   ggtitle(\\dTAG\\) +\n#   geom_hline(yintercept = 0) +\n#   geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n#   geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n#   geom_vline(xintercept = 0) +\n#   geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n#   geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n#   scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n#   scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n# \n# fileName <- paste0(\\log2FC_vs_avgScore_dTAG_\\, loopType, \\_diffCutoff_\\, diffCutoff, \\_RNA-PRO\\)\n# height <- 4\n# width <- 7\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n```\n```"} -->

```r
```r
loopType <- \p-n\

# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>%
  dplyr::mutate(distance = start2 - start1)
# geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
#                                       diffCutoff = diffCutoff,
#                                       annoList = c(\P-P\))%>% 
#   dplyr::mutate(distance = start2 - start1)
# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

#
# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
#                       label = ifelse(flag != \0NO\, external_gene_name, NA),
#                       shape = as.factor(maxFlag))) +
#   geom_point() + geom_text_repel() + theme_classic() +
#   ggtitle(\dTAG\) +
#   geom_hline(yintercept = 0) +
#   geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
#   geom_hline(yintercept = - diffCutoff, linetype = \dashed\) +
#   geom_vline(xintercept = 0) +
#   geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
#   geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
#   scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
#   scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))
#
# fileName <- paste0(\log2FC_vs_avgScore_dTAG_\, loopType, \_diffCutoff_\, diffCutoff)
# height <- 4
# width <- 7
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

# fwrite(temp, here(consensusDir, paste0(\gene_avgScore_fc_dTAG_\, loopType, \_noFCcutoff.tsv\)), sep = \\t\)

p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point(size = 1, alpha = 1,
      stroke = 0) + geom_text_repel() + theme_classic() + 
  guides(color = \none\, shape = \none\) + 
  geom_hline(yintercept = 0, alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) +
  geom_hline(yintercept = c(diffCutoff, -diffCutoff), linetype = \dashed\, alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) +
  geom_vline(xintercept = 0, alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) +
  geom_vline(xintercept = c(fcCutoff, -fcCutoff), linetype = \dashed\, alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) +
  theme(
    axis.title.x = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) + labs(y = \Avg. Δ loop score\, x = \log2(shrunken FC)\) +
  scale_color_manual(values = c(\0NO\ = \#A9A8A9\, \1UP\ = \#CB333A\, \2DOWN\ = \#4852A0\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_\, loopType, \_diffCutoff_\, diffCutoff, \_noFCcutoff\)
height <- 42*mmToInch
width <- 50*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - up and down
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.updown.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_\, loopType, \_diffCutoff_\, diffCutoff, \_noFCcutoffupdown\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# 
# ## RNA + PRO-seq
# temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% 
#   unnest(gene) %>% group_by(gene) %>%
#   summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')
# 
# temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
#   dplyr::mutate(flag = ifelse(gene %in% geneList.down, \2DOWN\,
#                               ifelse(gene %in% geneList.up, \1UP\, \0NO\)),
#                 maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
#                 shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
#   dplyr::arrange(flag)
# 
# fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_\, loopType, \.tsv\), sep = \\t\)
# 
# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
#                       label = ifelse(flag != \0NO\, external_gene_name, NA),
#                       shape = as.factor(maxFlag))) +
#   geom_point() + geom_text_repel() + theme_classic() + 
#   ggtitle(\dTAG\) +
#   geom_hline(yintercept = 0) +
#   geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
#   geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
#   geom_vline(xintercept = 0) +
#   geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
#   geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
#   scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
#   scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))
# 
# fileName <- paste0(\log2FC_vs_avgScore_dTAG_\, loopType, \_diffCutoff_\, diffCutoff, \_RNA-PRO\)
# height <- 4
# width <- 7
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

### [2.10] Linking with RNA-seq/PRO-seq
#### Function & parameter

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n\nloopType <- \"p-pe\"\n\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \"diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \"diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \"chromo_cons_annoHierarchy\"\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\"P-P\", \"P-E\", \"P-S\", \"P-X\"))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\"loopScore_cons_obsexp.tsv\"))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\"id\"))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% c(), \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \"gene_avgScore_fc_dTAG_p-n.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"dTAG\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"grey\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_dTAG_OE_\", loopType, \"_avgLogOE\")\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \"2DOWN\",\n                              ifelse(gene %in% c(), \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"dTAG\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"grey\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_dTAG_OE_\", loopType, \"_avgLogOE_noFCcutoff\")\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\n\nloopType <- \\p-pe\\\n\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_\\, loopType, \\_avgLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_\\, loopType, \\_avgLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->

loopType <- \p-pe\

# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\id\))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_\, loopType, \_avgLogOE\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_\, loopType, \_avgLogOE_noFCcutoff\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n\nloopType <- \\p-pe\\\n\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_\\, loopType, \\_avgLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_\\, loopType, \\_avgLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\n\nloopType <- \\p-pe\\\n\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_\\, loopType, \\_avgLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_\\, loopType, \\_avgLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n\nloopType <- \\p-pe\\\n\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_\\, loopType, \\_avgLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_\\, loopType, \\_avgLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r

loopType <- \p-pe\

# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\id\))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_\, loopType, \_avgLogOE\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_\, loopType, \_avgLogOE_noFCcutoff\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### dTAG Scatterplot

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \"diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \"diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \"chromo_cons_annoHierarchy\"\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\"P-P\", \"P-E\", \"P-S\", \"P-X\"))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\"loopScore_cons_obsexp.tsv\"))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\"id\"))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% c(), \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \"gene_avgScore_fc_dTAG_p-n.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"dTAG\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"grey\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE\")\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \"2DOWN\",\n                              ifelse(gene %in% c(), \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"dTAG\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"grey\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE_noFCcutoff\")\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\id\))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE_noFCcutoff\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\id\))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE_noFCcutoff\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



#### dTAG Scatterplot OE
##### Avg

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \"diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \"diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \"chromo_cons_annoHierarchy\"\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\"P-P\", \"P-E\", \"P-S\", \"P-X\"))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\"loopScore_cons_obsexp.tsv\"))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\"id\"))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')\n\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% c(), \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \"gene_avgScore_fc_dTAG_p-n.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"dTAG\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"grey\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE\")\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \"2DOWN\",\n                              ifelse(gene %in% c(), \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"dTAG\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"grey\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE_noFCcutoff\")\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')\n\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\id\))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')


temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE_noFCcutoff\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')\n\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')\n\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')\n\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\id\))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')


temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE_noFCcutoff\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### Sum

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \"diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \"diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \"chromo_cons_annoHierarchy\"\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\"P-P\", \"P-E\", \"P-S\", \"P-X\"))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\"loopScore_cons_obsexp.tsv\"))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\"id\"))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>% \n  slice_min(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% c(), \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \"gene_avgScore_fc_dTAG_p-n.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"dTAG\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"grey\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE\")\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  slice_min(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \"2DOWN\",\n                              ifelse(gene %in% c(), \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"dTAG\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"grey\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE_noFCcutoff\")\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>% \n  slice_min(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  slice_min(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\id\))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% 
  unnest(gene) %>% group_by(gene) %>% 
  slice_min(distance, with_ties = FALSE) %>% 
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% 
  unnest(gene) %>% group_by(gene) %>%
  slice_min(distance, with_ties = FALSE) %>% 
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE_noFCcutoff\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>% \n  slice_min(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  slice_min(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>% \n  slice_min(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  slice_min(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>% \n  slice_min(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  slice_min(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\id\))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% 
  unnest(gene) %>% group_by(gene) %>% 
  slice_min(distance, with_ties = FALSE) %>% 
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% 
  unnest(gene) %>% group_by(gene) %>%
  slice_min(distance, with_ties = FALSE) %>% 
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE_noFCcutoff\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### abs max

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \"diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \"diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \"chromo_cons_annoHierarchy\"\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\"P-P\", \"P-E\", \"P-S\", \"P-X\"))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\"loopScore_cons_obsexp.tsv\"))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\"id\"))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>% \n  slice_max(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% c(), \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \"gene_avgScore_fc_dTAG_p-n.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"dTAG\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"grey\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE\")\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  slice_max(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \"2DOWN\",\n                              ifelse(gene %in% c(), \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"dTAG\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"grey\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE_noFCcutoff\")\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>% \n  slice_max(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  slice_max(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\id\))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% 
  unnest(gene) %>% group_by(gene) %>% 
  slice_max(distance, with_ties = FALSE) %>% 
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% 
  unnest(gene) %>% group_by(gene) %>%
  slice_max(distance, with_ties = FALSE) %>% 
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE_noFCcutoff\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>% \n  slice_max(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  slice_max(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>% \n  slice_max(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  slice_max(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\n# Loading OE loop score\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,\n                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))\ngeneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id\ngeneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id\n\ngeneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,\n                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 2\n\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>% \n  slice_max(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n#fwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# No FC cutoff option - down only\ntemp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  slice_max(distance, with_ties = FALSE) %>% \n  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \\2DOWN\\,\n                              ifelse(gene %in% c(), \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\n\np <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\dTAG\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\grey\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE_noFCcutoff\\)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\id\))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% 
  unnest(gene) %>% group_by(gene) %>% 
  slice_max(distance, with_ties = FALSE) %>% 
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% 
  unnest(gene) %>% group_by(gene) %>%
  slice_max(distance, with_ties = FALSE) %>% 
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, \2DOWN\,
                              ifelse(gene %in% c(), \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\dTAG\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \grey\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE_noFCcutoff\)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### Closest P-N loop

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \"diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \"chromo_cons_annoHierarchy\"\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\"P-P\", \"P-E\", \"P-S\", \"P-X\"))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \"diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% geneList.up.RNA, \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \"gene_avgScore_fc_dTAG_p-n.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"A485\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"black\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_A485_p-n_diffCutoff_\", diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% geneList.up.RNA, \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \"gene_sumScore_fc_dTAG_p-n.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"A485\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"black\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_sumScore_A485_p-n_diffCutoff_\", diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% geneList.up.RNA, \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \"gene_maxAbsScore_fc_dTAG_p-n.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"A485\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"black\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_maxAbsScore_A485_p-n_diffCutoff_\", diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n```"} -->\n\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_A485_p-n_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_sumScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_sumScore_A485_p-n_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_maxAbsScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_maxAbsScore_A485_p-n_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n```\n\n<!-- rnb-source-end -->\n"} -->
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.G1.A485 <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)

# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1)

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_A485_p-n_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# [2] Sum of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_sumScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_sumScore_A485_p-n_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


# [3] Max of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_maxAbsScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_maxAbsScore_A485_p-n_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_A485_p-n_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_sumScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_sumScore_A485_p-n_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_maxAbsScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_maxAbsScore_A485_p-n_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n```\n```"} -->\n\n```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_A485_p-n_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_sumScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_sumScore_A485_p-n_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_maxAbsScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_maxAbsScore_A485_p-n_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_A485_p-n_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_sumScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_sumScore_A485_p-n_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_maxAbsScore_fc_dTAG_p-n.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_maxAbsScore_A485_p-n_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n```\n```"} -->

```r
```r
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.G1.A485 <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)

# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1)

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_A485_p-n_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# [2] Sum of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_sumScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_sumScore_A485_p-n_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


# [3] Max of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_maxAbsScore_fc_dTAG_p-n.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_maxAbsScore_A485_p-n_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### Farthest P-N loop

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \"diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \"chromo_cons_annoHierarchy\"\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\"P-P\", \"P-E\"))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \"diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% geneList.up.RNA, \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \"gene_avgScore_fc_dTAG_p-pe.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"A485\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"black\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_A485_p-pe_diffCutoff_\", diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% geneList.up.RNA, \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \"gene_sumScore_fc_dTAG_p-pe.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"A485\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"black\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_sumScore_A485_p-pe_diffCutoff_\", diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% geneList.up.RNA, \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \"gene_maxAbsScore_fc_dTAG_p-pe.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"A485\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"black\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_maxAbsScore_A485_p-pe_diffCutoff_\", diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-pe.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_A485_p-pe_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_sumScore_fc_dTAG_p-pe.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_sumScore_A485_p-pe_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_maxAbsScore_fc_dTAG_p-pe.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_maxAbsScore_A485_p-pe_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.G1.A485 <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)

# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\))%>% 
  dplyr::mutate(distance = start2 - start1)

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-pe.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_A485_p-pe_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# [2] Sum of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_sumScore_fc_dTAG_p-pe.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_sumScore_A485_p-pe_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


# [3] Max of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_maxAbsScore_fc_dTAG_p-pe.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_maxAbsScore_A485_p-pe_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-pe.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_A485_p-pe_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_sumScore_fc_dTAG_p-pe.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_sumScore_A485_p-pe_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_maxAbsScore_fc_dTAG_p-pe.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_maxAbsScore_A485_p-pe_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-pe.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_A485_p-pe_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_sumScore_fc_dTAG_p-pe.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_sumScore_A485_p-pe_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_maxAbsScore_fc_dTAG_p-pe.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_maxAbsScore_A485_p-pe_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-pe.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_A485_p-pe_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_sumScore_fc_dTAG_p-pe.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_sumScore_A485_p-pe_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_maxAbsScore_fc_dTAG_p-pe.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_maxAbsScore_A485_p-pe_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.G1.A485 <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)

# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\))%>% 
  dplyr::mutate(distance = start2 - start1)

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-pe.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_A485_p-pe_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# [2] Sum of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_sumScore_fc_dTAG_p-pe.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_sumScore_A485_p-pe_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


# [3] Max of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_maxAbsScore_fc_dTAG_p-pe.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_maxAbsScore_A485_p-pe_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### A485 Scatterplot
##### P-N

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \"diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \"chromo_cons_annoHierarchy\"\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\"P-S\"))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \"diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% geneList.up.RNA, \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \"gene_avgScore_fc_dTAG_p-s.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"A485\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"black\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_avgScore_A485_p-s_diffCutoff_\", diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% geneList.up.RNA, \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \"gene_sumScore_fc_dTAG_p-s.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"A485\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"black\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_sumScore_A485_p-s_diffCutoff_\", diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \"2DOWN\",\n                              ifelse(gene %in% geneList.up.RNA, \"1UP\", \"0NO\")),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \"gene_maxAbsScore_fc_dTAG_p-s.tsv\"), sep = \"\\t\")\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \"0NO\", external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\"A485\") +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \"dashed\") +\n  geom_hline(yintercept = - diffCutoff, linetype = \"dashed\") + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \"dashed\") +\n  geom_vline(xintercept = -fcCutoff, linetype = \"dashed\") +\n  scale_color_manual(values = c(\"0NO\" = \"black\", \"1UP\" = \"red\", \"2DOWN\" = \"blue\")) +  # Corrected color mapping\n  scale_shape_manual(values = c(\"TRUE\" = 2, \"FALSE\" = 19))\n\nfileName <- paste0(\"log2FC_vs_maxAbsScore_A485_p-s_diffCutoff_\", diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-S\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-s.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_A485_p-s_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_sumScore_fc_dTAG_p-s.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_sumScore_A485_p-s_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_maxAbsScore_fc_dTAG_p-s.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_maxAbsScore_A485_p-s_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.G1.A485 <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)

# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-S\))%>% 
  dplyr::mutate(distance = start2 - start1)

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-s.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_A485_p-s_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# [2] Sum of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_sumScore_fc_dTAG_p-s.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_sumScore_A485_p-s_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


# [3] Max of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_maxAbsScore_fc_dTAG_p-s.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_maxAbsScore_A485_p-s_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-S\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-s.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_A485_p-s_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_sumScore_fc_dTAG_p-s.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_sumScore_A485_p-s_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_maxAbsScore_fc_dTAG_p-s.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_maxAbsScore_A485_p-s_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-S\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-s.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_A485_p-s_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_sumScore_fc_dTAG_p-s.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_sumScore_A485_p-s_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_maxAbsScore_fc_dTAG_p-s.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_maxAbsScore_A485_p-s_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n# getting list of genes of interest from RNA-seq and PRO-seq\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.A485 <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\n\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-S\\))%>% \n  dplyr::mutate(distance = start2 - start1)\n\n# Testing different ways to calculate representative feature of loops for each gene\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ngeneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id\ngeneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id\n\n\n# [1] Average of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_avgScore_fc_dTAG_p-s.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_avgScore_A485_p-s_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n# [2] Sum of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_sumScore_fc_dTAG_p-s.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_sumScore_A485_p-s_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n# [3] Max of differential loop scores for each gene\n## RNA only\nfcCutoff <- 0.5\nalpha <- 0.05\nmaxLog2FC <- 4\n\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \\2DOWN\\,\n                              ifelse(gene %in% geneList.up.RNA, \\1UP\\, \\0NO\\)),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag)\n\nfwrite(temp, here(consensusDir, \\gene_maxAbsScore_fc_dTAG_p-s.tsv\\), sep = \\\\t\\)\n\np <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, \n                      label = ifelse(flag != \\0NO\\, external_gene_name, NA),\n                      shape = as.factor(maxFlag))) +\n  geom_point() + geom_text_repel() + theme_classic() + \n  ggtitle(\\A485\\) +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = diffCutoff, linetype = \\dashed\\) +\n  geom_hline(yintercept = - diffCutoff, linetype = \\dashed\\) + \n  geom_vline(xintercept = 0) +\n  geom_vline(xintercept = fcCutoff, linetype = \\dashed\\) +\n  geom_vline(xintercept = -fcCutoff, linetype = \\dashed\\) +\n  scale_color_manual(values = c(\\0NO\\ = \\black\\, \\1UP\\ = \\red\\, \\2DOWN\\ = \\blue\\)) +  # Corrected color mapping\n  scale_shape_manual(values = c(\\TRUE\\ = 2, \\FALSE\\ = 19))\n\nfileName <- paste0(\\log2FC_vs_maxAbsScore_A485_p-s_diffCutoff_\\, diffCutoff)\nheight <- 4\nwidth <- 7\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.G1.A485 <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)

# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-S\))%>% 
  dplyr::mutate(distance = start2 - start1)

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_avgScore_fc_dTAG_p-s.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_avgScore_A485_p-s_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

# [2] Sum of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_sumScore_fc_dTAG_p-s.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_sumScore_A485_p-s_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


# [3] Max of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, \2DOWN\,
                              ifelse(gene %in% geneList.up.RNA, \1UP\, \0NO\)),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, \gene_maxAbsScore_fc_dTAG_p-s.tsv\), sep = \\t\)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, 
                      label = ifelse(flag != \0NO\, external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle(\A485\) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = \dashed\) +
  geom_hline(yintercept = - diffCutoff, linetype = \dashed\) + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = \dashed\) +
  geom_vline(xintercept = -fcCutoff, linetype = \dashed\) +
  scale_color_manual(values = c(\0NO\ = \black\, \1UP\ = \red\, \2DOWN\ = \blue\)) +  # Corrected color mapping
  scale_shape_manual(values = c(\TRUE\ = 2, \FALSE\ = 19))

fileName <- paste0(\log2FC_vs_maxAbsScore_A485_p-s_diffCutoff_\, diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### P-PE

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJKVFZCUFVsUkpUa2NnUjBWT1JTQkJUazVQSUVSQlZFRWdSazlTSUZBdFRpQk1UMDlRVTF4dWJtRnRaU0E4TFNCY0ltTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsY0lseHVYRzVuWlc1bFFXNXViMFJoZEdFZ1BDMGdiRzloWkV4dmIzQkJibTV2UkdGMFlTaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ3aVgzQXRibDlsYm5ObGJXSnNUR2x6ZEM1MGMzWmNJaWtwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmthV1ptUTNWMGIyWm1JRDBnTUM0eUxGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JoYm01dlRHbHpkQ0E5SUdNb1hDSlFMVkJjSWl3Z1hDSlFMVVZjSWl3Z1hDSlFMVk5jSWl3Z1hDSlFMVmhjSWlrcEpUNGxJRnh1SUNCa2NHeDVjam82YlhWMFlYUmxLR1JwYzNSaGJtTmxJRDBnYzNSaGNuUXlJQzBnYzNSaGNuUXhMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJSEJsWVd0SlJDQTlJSEJoYzNSbEtHTm9jbTl0TVN3Z2MzUmhjblF4TENCemRHRnlkRElzSUhObGNDQTlJRndpWDF3aUtTbGNibHh1WEc0aklFTnZkVzUwYVc1bklHNTFiV0psY2lCdlppQnNiMjl3SUhCbGNpQm5aVzVsYzF4dWRHVnRjRk4xYlNBOExTQm5aVzVsUVc1dWIwUmhkR0VnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvY0dWaGEwbEVMQ0JuWlc1bExDQkJibTV2TWlrZ0pUNGxJSFZ1Ym1WemRDaG5aVzVsS1NBbFBpVWdaM0p2ZFhCZllua29aMlZ1WlNrZ0pUNGxJQ0J6ZFcxdFlYSnBlbVVvWEc0Z0lDQWdjR1ZoYXlBOUlHeHBjM1FvY0dWaGEwbEVLU3hjYmlBZ0lDQmhibTV2TWlBOUlHeHBjM1FvUVc1dWJ6SXBMRnh1SUNBZ0lHTnZkVzUwSUQwZ2JpZ3BLVnh1WEc1blozQnNiM1FvZEdWdGNGTjFiU3dnWVdWektIZ2dQU0JqYjNWdWRDa3BJQ3NnWjJWdmJWOW9hWE4wYjJkeVlXMG9ZbWx1ZDJsa2RHZ2dQU0F4S1NBcklIUm9aVzFsWDJOc1lYTnphV01vS1NBcklGeHVJQ0JuWjNScGRHeGxLRndpSXlCdlppQlFMVTRnYkc5dmNITWdabTl5SUdWaFkyZ2daMlZ1WlZ3aUtTQXJJSE5qWVd4bFgzbGZiRzluTVRBb0tWeHVYRzRqSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSTF4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG4jIElNUE9SVElORyBHRU5FIEFOTk8gREFUQSBGT1IgUC1OIExPT1BTXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5cbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1uX2Vuc2VtYmxMaXN0LnRzdlxcKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9MaXN0ID0gYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcKSklPiUgXG4gIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgcGVha0lEID0gcGFzdGUoY2hyb20xLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKVxuXG5cbiMgQ291bnRpbmcgbnVtYmVyIG9mIGxvb3AgcGVyIGdlbmVzXG50ZW1wU3VtIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChwZWFrSUQsIGdlbmUsIEFubm8yKSAlPiUgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiUgIHN1bW1hcml6ZShcbiAgICBwZWFrID0gbGlzdChwZWFrSUQpLFxuICAgIGFubm8yID0gbGlzdChBbm5vMiksXG4gICAgY291bnQgPSBuKCkpXG5cbmdncGxvdCh0ZW1wU3VtLCBhZXMoeCA9IGNvdW50KSkgKyBnZW9tX2hpc3RvZ3JhbShiaW53aWR0aCA9IDEpICsgdGhlbWVfY2xhc3NpYygpICsgXG4gIGdndGl0bGUoXFwjIG9mIFAtTiBsb29wcyBmb3IgZWFjaCBnZW5lXFwpICsgc2NhbGVfeV9sb2cxMCgpXG5cbiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
# IMPORTING GENE ANNO DATA FOR P-N LOOPS
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))


# Counting number of loop per genes
tempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(
    peak = list(peakID),
    anno2 = list(Anno2),
    count = n())

ggplot(tempSum, aes(x = count)) + geom_histogram(binwidth = 1) + theme_classic() + 
  ggtitle(\# of P-N loops for each gene\) + scale_y_log10()

###################################################################################



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QkpUVkJQVWxSSlRrY2dSMFZPUlNCQlRrNVBJRVJCVkVFZ1JrOVNJRkF0VGlCTVQwOVFVMXh1Ym1GdFpTQThMU0JjWEdOb2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxjWEZ4dVhHNW5aVzVsUVc1dWIwUmhkR0VnUEMwZ2JHOWhaRXh2YjNCQmJtNXZSR0YwWVNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRnhjWDNBdGJsOWxibk5sYldKc1RHbHpkQzUwYzNaY1hDa3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCa2FXWm1RM1YwYjJabUlEMGdNQzR5TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmhibTV2VEdsemRDQTlJR01vWEZ4UUxWQmNYQ3dnWEZ4UUxVVmNYQ3dnWEZ4UUxWTmNYQ3dnWEZ4UUxWaGNYQ2twSlQ0bElGeHVJQ0JrY0d4NWNqbzZiWFYwWVhSbEtHUnBjM1JoYm1ObElEMGdjM1JoY25ReUlDMGdjM1JoY25ReExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lIQmxZV3RKUkNBOUlIQmhjM1JsS0dOb2NtOXRNU3dnYzNSaGNuUXhMQ0J6ZEdGeWRESXNJSE5sY0NBOUlGeGNYMXhjS1NsY2JseHVYRzRqSUVOdmRXNTBhVzVuSUc1MWJXSmxjaUJ2WmlCc2IyOXdJSEJsY2lCblpXNWxjMXh1ZEdWdGNGTjFiU0E4TFNCblpXNWxRVzV1YjBSaGRHRWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9jR1ZoYTBsRUxDQm5aVzVsTENCQmJtNXZNaWtnSlQ0bElIVnVibVZ6ZENoblpXNWxLU0FsUGlVZ1ozSnZkWEJmWW5rb1oyVnVaU2tnSlQ0bElDQnpkVzF0WVhKcGVtVW9YRzRnSUNBZ2NHVmhheUE5SUd4cGMzUW9jR1ZoYTBsRUtTeGNiaUFnSUNCaGJtNXZNaUE5SUd4cGMzUW9RVzV1YnpJcExGeHVJQ0FnSUdOdmRXNTBJRDBnYmlncEtWeHVYRzVuWjNCc2IzUW9kR1Z0Y0ZOMWJTd2dZV1Z6S0hnZ1BTQmpiM1Z1ZENrcElDc2daMlZ2YlY5b2FYTjBiMmR5WVcwb1ltbHVkMmxrZEdnZ1BTQXhLU0FySUhSb1pXMWxYMk5zWVhOemFXTW9LU0FySUZ4dUlDQm5aM1JwZEd4bEtGeGNJeUJ2WmlCUUxVNGdiRzl2Y0hNZ1ptOXlJR1ZoWTJnZ1oyVnVaVnhjS1NBcklITmpZV3hsWDNsZmJHOW5NVEFvS1Z4dVhHNGpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJMXh1WUdCZ1hHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuYGBgclxuIyBJTVBPUlRJTkcgR0VORSBBTk5PIERBVEEgRk9SIFAtTiBMT09QU1xubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSlcblxuXG4jIENvdW50aW5nIG51bWJlciBvZiBsb29wIHBlciBnZW5lc1xudGVtcFN1bSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QocGVha0lELCBnZW5lLCBBbm5vMikgJT4lIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lICBzdW1tYXJpemUoXG4gICAgcGVhayA9IGxpc3QocGVha0lEKSxcbiAgICBhbm5vMiA9IGxpc3QoQW5ubzIpLFxuICAgIGNvdW50ID0gbigpKVxuXG5nZ3Bsb3QodGVtcFN1bSwgYWVzKHggPSBjb3VudCkpICsgZ2VvbV9oaXN0b2dyYW0oYmlud2lkdGggPSAxKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBnZ3RpdGxlKFxcIyBvZiBQLU4gbG9vcHMgZm9yIGVhY2ggZ2VuZVxcKSArIHNjYWxlX3lfbG9nMTAoKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBJTVBPUlRJTkcgR0VORSBBTk5PIERBVEEgRk9SIFAtTiBMT09QU1xubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSlcblxuXG4jIENvdW50aW5nIG51bWJlciBvZiBsb29wIHBlciBnZW5lc1xudGVtcFN1bSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QocGVha0lELCBnZW5lLCBBbm5vMikgJT4lIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lICBzdW1tYXJpemUoXG4gICAgcGVhayA9IGxpc3QocGVha0lEKSxcbiAgICBhbm5vMiA9IGxpc3QoQW5ubzIpLFxuICAgIGNvdW50ID0gbigpKVxuXG5nZ3Bsb3QodGVtcFN1bSwgYWVzKHggPSBjb3VudCkpICsgZ2VvbV9oaXN0b2dyYW0oYmlud2lkdGggPSAxKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBnZ3RpdGxlKFxcIyBvZiBQLU4gbG9vcHMgZm9yIGVhY2ggZ2VuZVxcKSArIHNjYWxlX3lfbG9nMTAoKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuYGBgXG5gYGAifQ== -->

```r
```r
# IMPORTING GENE ANNO DATA FOR P-N LOOPS
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))


# Counting number of loop per genes
tempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(
    peak = list(peakID),
    anno2 = list(Anno2),
    count = n())

ggplot(tempSum, aes(x = count)) + geom_histogram(binwidth = 1) + theme_classic() + 
  ggtitle(\# of P-N loops for each gene\) + scale_y_log10()

###################################################################################
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### P-S

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJKVFZCUFVsUkpUa2NnUjBWT1JTQkJUazVQSUVSQlZFRWdSazlTSUZBdFRpQk1UMDlRVTF4dWJtRnRaU0E4TFNCY0ltTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsY0lseHVYRzVuWlc1bFFXNXViMFJoZEdFZ1BDMGdiRzloWkV4dmIzQkJibTV2UkdGMFlTaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ3aVgzQXRibDlsYm5ObGJXSnNUR2x6ZEM1MGMzWmNJaWtwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmthV1ptUTNWMGIyWm1JRDBnTUM0eUxGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JoYm01dlRHbHpkQ0E5SUdNb1hDSlFMVkJjSWl3Z1hDSlFMVVZjSWl3Z1hDSlFMVk5jSWl3Z1hDSlFMVmhjSWlrcFhHNWNiblJsYlhCVFJTQThMU0JuWlc1bFFXNXViMFJoZEdFZ0pUNGxJSFZ1Ym1WemRDaG5aVzVsS1NBbFBpVWdaM0p2ZFhCZllua29aMlZ1WlNrZ0pUNGxJSE4xYlcxaGNtbDZaU2hUUlNBOUlHbG1aV3h6WlNoaGJua29RVzV1YjFORklEMDlJRndpVTBWY0lpa3NJREVzSURBcEtWeHVYRzVjYm1keWIzVndNU0E4TFNCbWNtVmhaQ2hvWlhKbEtISmxaa1JwY2l3Z1hDSm5aVzVsVEdsemRGOWtWRUZIWDNaelgwUk5VMDlmVWs1QlgyeHZiM0JmWjNKdmRYQXhMblJ6ZGx3aUtTa2taMlZ1WlZ4dVozSnZkWEF5SUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNJbWRsYm1WTWFYTjBYMlJVUVVkZmRuTmZSRTFUVDE5U1RrRmZiRzl2Y0Y5bmNtOTFjREl1ZEhOMlhDSXBLU1JuWlc1bFhHNW5jbTkxY0RVZ1BDMGdabkpsWVdRb2FHVnlaU2h5WldaRWFYSXNJRndpWjJWdVpVeHBjM1JmWkZSQlIxOTJjMTlFVFZOUFgxSk9RVjlzYjI5d1gyZHliM1Z3TlM1MGMzWmNJaWtwSkdkbGJtVmNibWR5YjNWd09DQThMU0JtY21WaFpDaG9aWEpsS0hKbFprUnBjaXdnWENKblpXNWxUR2x6ZEY5a1ZFRkhYM1p6WDBSTlUwOWZVazVCWDJ4dmIzQmZaM0p2ZFhBNExuUnpkbHdpS1Nra1oyVnVaVnh1WEc1Y2JuUmxiWEJUUlNBOExTQjBaVzF3VTBVZ0pUNGxJSEp2ZDNkcGMyVW9LU0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hjYmlBZ1ozSnZkWEFnUFNCcFptVnNjMlVvWjJWdVpTQWxhVzRsSUdkeWIzVndNU3dnWENKbmNtOTFjREZjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2FXWmxiSE5sS0dkbGJtVWdKV2x1SlNCbmNtOTFjRElzSUZ3aVozSnZkWEF5WENJc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCcFptVnNjMlVvWjJWdVpTQWxhVzRsSUdkeWIzVndOU3dnWENKbmNtOTFjRFZjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JwWm1Wc2MyVW9aMlZ1WlNBbGFXNGxJR2R5YjNWd09Dd2dYQ0puY205MWNEaGNJaXdnVGtFcEtTa3BLU0FsUGlVZ1hHNGdJR1J3YkhseU9qcG1hV3gwWlhJb0lXbHpMbTVoS0dkeWIzVndLU2xjYmx4dWNHVnlZeTVuY205MWNERWdQQzBnYm5KdmR5aDBaVzF3VTBVZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1ozSnZkWEFnUFQwZ1hDSm5jbTkxY0RGY0lpd2dVMFVnUFQwZ01Ta3BMMXh1SUNCdWNtOTNLSFJsYlhCVFJTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaG5jbTkxY0NBOVBTQmNJbWR5YjNWd01Wd2lLU2xjYmx4dWNHVnlZeTVuY205MWNESWdQQzBnYm5KdmR5aDBaVzF3VTBVZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1ozSnZkWEFnUFQwZ1hDSm5jbTkxY0RKY0lpd2dVMFVnUFQwZ01Ta3BMMXh1SUNCdWNtOTNLSFJsYlhCVFJTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaG5jbTkxY0NBOVBTQmNJbWR5YjNWd01sd2lLU2xjYmx4dWNHVnlZeTVuY205MWNEVWdQQzBnYm5KdmR5aDBaVzF3VTBVZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1ozSnZkWEFnUFQwZ1hDSm5jbTkxY0RWY0lpd2dVMFVnUFQwZ01Ta3BMMXh1SUNCdWNtOTNLSFJsYlhCVFJTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaG5jbTkxY0NBOVBTQmNJbWR5YjNWd05Wd2lLU2xjYmx4dWNHVnlZeTVuY205MWNEZ2dQQzBnYm5KdmR5aDBaVzF3VTBVZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1ozSnZkWEFnUFQwZ1hDSm5jbTkxY0RoY0lpd2dVMFVnUFQwZ01Ta3BMMXh1SUNCdWNtOTNLSFJsYlhCVFJTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaG5jbTkxY0NBOVBTQmNJbWR5YjNWd09Gd2lLU2xjYmx4dWRHVnRjRkJzYjNRZ1BDMGdkR2xpWW14bEtHZHliM1Z3SUQwZ1l5aGNJbWR5YjNWd01Wd2lMQ0JjSW1keWIzVndNbHdpTENCY0ltZHliM1Z3TlZ3aUxDQmNJbWR5YjNWd09Gd2lLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCd1pYSmpJRDBnWXlod1pYSmpMbWR5YjNWd01Td2djR1Z5WXk1bmNtOTFjRElzSUhCbGNtTXVaM0p2ZFhBMUxDQndaWEpqTG1keWIzVndPQ2twWEc1Y2JtZG5jR3h2ZENoMFpXMXdVR3h2ZEN3Z1lXVnpLSGdnUFNCbmNtOTFjQ3dnZVNBOUlIQmxjbU1wS1NBcklHZGxiMjFmY0c5cGJuUW9LU0FySUhSb1pXMWxYMk5zWVhOemFXTW9LU0FySUhsc2FXMG9NQ3dnTUM0eUtWeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuIyBJTVBPUlRJTkcgR0VORSBBTk5PIERBVEEgRk9SIFAtTiBMT09QU1xubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpXG5cbnRlbXBTRSA8LSBnZW5lQW5ub0RhdGEgJT4lIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lIHN1bW1hcml6ZShTRSA9IGlmZWxzZShhbnkoQW5ub1NFID09IFxcU0VcXCksIDEsIDApKVxuXG5cbmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAxLnRzdlxcKSkkZ2VuZVxuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDIudHN2XFwpKSRnZW5lXG5ncm91cDUgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwNS50c3ZcXCkpJGdlbmVcbmdyb3VwOCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA4LnRzdlxcKSkkZ2VuZVxuXG5cbnRlbXBTRSA8LSB0ZW1wU0UgJT4lIHJvd3dpc2UoKSAlPiUgZHBseXI6Om11dGF0ZShcbiAgZ3JvdXAgPSBpZmVsc2UoZ2VuZSAlaW4lIGdyb3VwMSwgXFxncm91cDFcXCxcbiAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBncm91cDIsIFxcZ3JvdXAyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdyb3VwNSwgXFxncm91cDVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdyb3VwOCwgXFxncm91cDhcXCwgTkEpKSkpKSAlPiUgXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSlcblxucGVyYy5ncm91cDEgPC0gbnJvdyh0ZW1wU0UgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDFcXCwgU0UgPT0gMSkpL1xuICBucm93KHRlbXBTRSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwMVxcKSlcblxucGVyYy5ncm91cDIgPC0gbnJvdyh0ZW1wU0UgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDJcXCwgU0UgPT0gMSkpL1xuICBucm93KHRlbXBTRSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwMlxcKSlcblxucGVyYy5ncm91cDUgPC0gbnJvdyh0ZW1wU0UgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDVcXCwgU0UgPT0gMSkpL1xuICBucm93KHRlbXBTRSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwNVxcKSlcblxucGVyYy5ncm91cDggPC0gbnJvdyh0ZW1wU0UgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDhcXCwgU0UgPT0gMSkpL1xuICBucm93KHRlbXBTRSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwOFxcKSlcblxudGVtcFBsb3QgPC0gdGliYmxlKGdyb3VwID0gYyhcXGdyb3VwMVxcLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSxcbiAgICAgICAgICAgICAgICAgICBwZXJjID0gYyhwZXJjLmdyb3VwMSwgcGVyYy5ncm91cDIsIHBlcmMuZ3JvdXA1LCBwZXJjLmdyb3VwOCkpXG5cbmdncGxvdCh0ZW1wUGxvdCwgYWVzKHggPSBncm91cCwgeSA9IHBlcmMpKSArIGdlb21fcG9pbnQoKSArIHRoZW1lX2NsYXNzaWMoKSArIHlsaW0oMCwgMC4yKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
# IMPORTING GENE ANNO DATA FOR P-N LOOPS
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))

tempSE <- geneAnnoData %>% unnest(gene) %>% group_by(gene) %>% summarize(SE = ifelse(any(AnnoSE == \SE\), 1, 0))


group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene


tempSE <- tempSE %>% rowwise() %>% dplyr::mutate(
  group = ifelse(gene %in% group1, \group1\,
                 ifelse(gene %in% group2, \group2\,
                        ifelse(gene %in% group5, \group5\,
                               ifelse(gene %in% group8, \group8\, NA))))) %>% 
  dplyr::filter(!is.na(group))

perc.group1 <- nrow(tempSE %>% dplyr::filter(group == \group1\, SE == 1))/
  nrow(tempSE %>% dplyr::filter(group == \group1\))

perc.group2 <- nrow(tempSE %>% dplyr::filter(group == \group2\, SE == 1))/
  nrow(tempSE %>% dplyr::filter(group == \group2\))

perc.group5 <- nrow(tempSE %>% dplyr::filter(group == \group5\, SE == 1))/
  nrow(tempSE %>% dplyr::filter(group == \group5\))

perc.group8 <- nrow(tempSE %>% dplyr::filter(group == \group8\, SE == 1))/
  nrow(tempSE %>% dplyr::filter(group == \group8\))

tempPlot <- tibble(group = c(\group1\, \group2\, \group5\, \group8\),
                   perc = c(perc.group1, perc.group2, perc.group5, perc.group8))

ggplot(tempPlot, aes(x = group, y = perc)) + geom_point() + theme_classic() + ylim(0, 0.2)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QkpUVkJQVWxSSlRrY2dSMFZPUlNCQlRrNVBJRVJCVkVFZ1JrOVNJRkF0VGlCTVQwOVFVMXh1Ym1GdFpTQThMU0JjWEdOb2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxjWEZ4dVhHNW5aVzVsUVc1dWIwUmhkR0VnUEMwZ2JHOWhaRXh2YjNCQmJtNXZSR0YwWVNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRnhjWDNBdGJsOWxibk5sYldKc1RHbHpkQzUwYzNaY1hDa3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCa2FXWm1RM1YwYjJabUlEMGdNQzR5TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmhibTV2VEdsemRDQTlJR01vWEZ4UUxWQmNYQ3dnWEZ4UUxVVmNYQ3dnWEZ4UUxWTmNYQ3dnWEZ4UUxWaGNYQ2twWEc1Y2JuUmxiWEJUUlNBOExTQm5aVzVsUVc1dWIwUmhkR0VnSlQ0bElIVnVibVZ6ZENoblpXNWxLU0FsUGlVZ1ozSnZkWEJmWW5rb1oyVnVaU2tnSlQ0bElITjFiVzFoY21sNlpTaFRSU0E5SUdsbVpXeHpaU2hoYm5rb1FXNXViMU5GSUQwOUlGeGNVMFZjWENrc0lERXNJREFwS1Z4dVhHNWNibWR5YjNWd01TQThMU0JtY21WaFpDaG9aWEpsS0hKbFprUnBjaXdnWEZ4blpXNWxUR2x6ZEY5a1ZFRkhYM1p6WDBSTlUwOWZVazVCWDJ4dmIzQmZaM0p2ZFhBeExuUnpkbHhjS1Nra1oyVnVaVnh1WjNKdmRYQXlJRHd0SUdaeVpXRmtLR2hsY21Vb2NtVm1SR2x5TENCY1hHZGxibVZNYVhOMFgyUlVRVWRmZG5OZlJFMVRUMTlTVGtGZmJHOXZjRjluY205MWNESXVkSE4yWEZ3cEtTUm5aVzVsWEc1bmNtOTFjRFVnUEMwZ1puSmxZV1FvYUdWeVpTaHlaV1pFYVhJc0lGeGNaMlZ1WlV4cGMzUmZaRlJCUjE5MmMxOUVUVk5QWDFKT1FWOXNiMjl3WDJkeWIzVndOUzUwYzNaY1hDa3BKR2RsYm1WY2JtZHliM1Z3T0NBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYRnhuWlc1bFRHbHpkRjlrVkVGSFgzWnpYMFJOVTA5ZlVrNUJYMnh2YjNCZlozSnZkWEE0TG5SemRseGNLU2trWjJWdVpWeHVYRzVjYm5SbGJYQlRSU0E4TFNCMFpXMXdVMFVnSlQ0bElISnZkM2RwYzJVb0tTQWxQaVVnWkhCc2VYSTZPbTExZEdGMFpTaGNiaUFnWjNKdmRYQWdQU0JwWm1Wc2MyVW9aMlZ1WlNBbGFXNGxJR2R5YjNWd01Td2dYRnhuY205MWNERmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0JuY205MWNESXNJRnhjWjNKdmRYQXlYRndzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JwWm1Wc2MyVW9aMlZ1WlNBbGFXNGxJR2R5YjNWd05Td2dYRnhuY205MWNEVmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnBabVZzYzJVb1oyVnVaU0FsYVc0bElHZHliM1Z3T0N3Z1hGeG5jbTkxY0RoY1hDd2dUa0VwS1NrcEtTQWxQaVVnWEc0Z0lHUndiSGx5T2pwbWFXeDBaWElvSVdsekxtNWhLR2R5YjNWd0tTbGNibHh1Y0dWeVl5NW5jbTkxY0RFZ1BDMGdibkp2ZHloMFpXMXdVMFVnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWjNKdmRYQWdQVDBnWEZ4bmNtOTFjREZjWEN3Z1UwVWdQVDBnTVNrcEwxeHVJQ0J1Y205M0tIUmxiWEJUUlNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFNCY1hHZHliM1Z3TVZ4Y0tTbGNibHh1Y0dWeVl5NW5jbTkxY0RJZ1BDMGdibkp2ZHloMFpXMXdVMFVnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWjNKdmRYQWdQVDBnWEZ4bmNtOTFjREpjWEN3Z1UwVWdQVDBnTVNrcEwxeHVJQ0J1Y205M0tIUmxiWEJUUlNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFNCY1hHZHliM1Z3TWx4Y0tTbGNibHh1Y0dWeVl5NW5jbTkxY0RVZ1BDMGdibkp2ZHloMFpXMXdVMFVnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWjNKdmRYQWdQVDBnWEZ4bmNtOTFjRFZjWEN3Z1UwVWdQVDBnTVNrcEwxeHVJQ0J1Y205M0tIUmxiWEJUUlNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFNCY1hHZHliM1Z3TlZ4Y0tTbGNibHh1Y0dWeVl5NW5jbTkxY0RnZ1BDMGdibkp2ZHloMFpXMXdVMFVnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWjNKdmRYQWdQVDBnWEZ4bmNtOTFjRGhjWEN3Z1UwVWdQVDBnTVNrcEwxeHVJQ0J1Y205M0tIUmxiWEJUUlNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFNCY1hHZHliM1Z3T0Z4Y0tTbGNibHh1ZEdWdGNGQnNiM1FnUEMwZ2RHbGlZbXhsS0dkeWIzVndJRDBnWXloY1hHZHliM1Z3TVZ4Y0xDQmNYR2R5YjNWd01seGNMQ0JjWEdkeWIzVndOVnhjTENCY1hHZHliM1Z3T0Z4Y0tTeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J3WlhKaklEMGdZeWh3WlhKakxtZHliM1Z3TVN3Z2NHVnlZeTVuY205MWNESXNJSEJsY21NdVozSnZkWEExTENCd1pYSmpMbWR5YjNWd09Da3BYRzVjYm1kbmNHeHZkQ2gwWlcxd1VHeHZkQ3dnWVdWektIZ2dQU0JuY205MWNDd2dlU0E5SUhCbGNtTXBLU0FySUdkbGIyMWZjRzlwYm5Rb0tTQXJJSFJvWlcxbFgyTnNZWE56YVdNb0tTQXJJSGxzYVcwb01Dd2dNQzR5S1Z4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbiMgSU1QT1JUSU5HIEdFTkUgQU5OTyBEQVRBIEZPUiBQLU4gTE9PUFNcbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5XFxcblxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLW5fZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IDAuMixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYW5ub0xpc3QgPSBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcUC1TXFwsIFxcUC1YXFwpKVxuXG50ZW1wU0UgPC0gZ2VuZUFubm9EYXRhICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JSBzdW1tYXJpemUoU0UgPSBpZmVsc2UoYW55KEFubm9TRSA9PSBcXFNFXFwpLCAxLCAwKSlcblxuXG5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMS50c3ZcXCkpJGdlbmVcbmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAyLnRzdlxcKSkkZ2VuZVxuZ3JvdXA1IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDUudHN2XFwpKSRnZW5lXG5ncm91cDggPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwOC50c3ZcXCkpJGdlbmVcblxuXG50ZW1wU0UgPC0gdGVtcFNFICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGdlbmUgJWluJSBncm91cDEsIFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ3JvdXAyLCBcXGdyb3VwMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBncm91cDUsIFxcZ3JvdXA1XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBncm91cDgsIFxcZ3JvdXA4XFwsIE5BKSkpKSkgJT4lIFxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cbnBlcmMuZ3JvdXAxIDwtIG5yb3codGVtcFNFICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IFxcZ3JvdXAxXFwsIFNFID09IDEpKS9cbiAgbnJvdyh0ZW1wU0UgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDFcXCkpXG5cbnBlcmMuZ3JvdXAyIDwtIG5yb3codGVtcFNFICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IFxcZ3JvdXAyXFwsIFNFID09IDEpKS9cbiAgbnJvdyh0ZW1wU0UgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDJcXCkpXG5cbnBlcmMuZ3JvdXA1IDwtIG5yb3codGVtcFNFICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IFxcZ3JvdXA1XFwsIFNFID09IDEpKS9cbiAgbnJvdyh0ZW1wU0UgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDVcXCkpXG5cbnBlcmMuZ3JvdXA4IDwtIG5yb3codGVtcFNFICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IFxcZ3JvdXA4XFwsIFNFID09IDEpKS9cbiAgbnJvdyh0ZW1wU0UgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDhcXCkpXG5cbnRlbXBQbG90IDwtIHRpYmJsZShncm91cCA9IGMoXFxncm91cDFcXCwgXFxncm91cDJcXCwgXFxncm91cDVcXCwgXFxncm91cDhcXCksXG4gICAgICAgICAgICAgICAgICAgcGVyYyA9IGMocGVyYy5ncm91cDEsIHBlcmMuZ3JvdXAyLCBwZXJjLmdyb3VwNSwgcGVyYy5ncm91cDgpKVxuXG5nZ3Bsb3QodGVtcFBsb3QsIGFlcyh4ID0gZ3JvdXAsIHkgPSBwZXJjKSkgKyBnZW9tX3BvaW50KCkgKyB0aGVtZV9jbGFzc2ljKCkgKyB5bGltKDAsIDAuMilcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBJTVBPUlRJTkcgR0VORSBBTk5PIERBVEEgRk9SIFAtTiBMT09QU1xubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpXG5cbnRlbXBTRSA8LSBnZW5lQW5ub0RhdGEgJT4lIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lIHN1bW1hcml6ZShTRSA9IGlmZWxzZShhbnkoQW5ub1NFID09IFxcU0VcXCksIDEsIDApKVxuXG5cbmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAxLnRzdlxcKSkkZ2VuZVxuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDIudHN2XFwpKSRnZW5lXG5ncm91cDUgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwNS50c3ZcXCkpJGdlbmVcbmdyb3VwOCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA4LnRzdlxcKSkkZ2VuZVxuXG5cbnRlbXBTRSA8LSB0ZW1wU0UgJT4lIHJvd3dpc2UoKSAlPiUgZHBseXI6Om11dGF0ZShcbiAgZ3JvdXAgPSBpZmVsc2UoZ2VuZSAlaW4lIGdyb3VwMSwgXFxncm91cDFcXCxcbiAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBncm91cDIsIFxcZ3JvdXAyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdyb3VwNSwgXFxncm91cDVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdyb3VwOCwgXFxncm91cDhcXCwgTkEpKSkpKSAlPiUgXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSlcblxucGVyYy5ncm91cDEgPC0gbnJvdyh0ZW1wU0UgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDFcXCwgU0UgPT0gMSkpL1xuICBucm93KHRlbXBTRSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwMVxcKSlcblxucGVyYy5ncm91cDIgPC0gbnJvdyh0ZW1wU0UgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDJcXCwgU0UgPT0gMSkpL1xuICBucm93KHRlbXBTRSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwMlxcKSlcblxucGVyYy5ncm91cDUgPC0gbnJvdyh0ZW1wU0UgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDVcXCwgU0UgPT0gMSkpL1xuICBucm93KHRlbXBTRSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwNVxcKSlcblxucGVyYy5ncm91cDggPC0gbnJvdyh0ZW1wU0UgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDhcXCwgU0UgPT0gMSkpL1xuICBucm93KHRlbXBTRSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwOFxcKSlcblxudGVtcFBsb3QgPC0gdGliYmxlKGdyb3VwID0gYyhcXGdyb3VwMVxcLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSxcbiAgICAgICAgICAgICAgICAgICBwZXJjID0gYyhwZXJjLmdyb3VwMSwgcGVyYy5ncm91cDIsIHBlcmMuZ3JvdXA1LCBwZXJjLmdyb3VwOCkpXG5cbmdncGxvdCh0ZW1wUGxvdCwgYWVzKHggPSBncm91cCwgeSA9IHBlcmMpKSArIGdlb21fcG9pbnQoKSArIHRoZW1lX2NsYXNzaWMoKSArIHlsaW0oMCwgMC4yKVxuYGBgXG5gYGAifQ== -->

```r
```r
# IMPORTING GENE ANNO DATA FOR P-N LOOPS
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))

tempSE <- geneAnnoData %>% unnest(gene) %>% group_by(gene) %>% summarize(SE = ifelse(any(AnnoSE == \SE\), 1, 0))


group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene


tempSE <- tempSE %>% rowwise() %>% dplyr::mutate(
  group = ifelse(gene %in% group1, \group1\,
                 ifelse(gene %in% group2, \group2\,
                        ifelse(gene %in% group5, \group5\,
                               ifelse(gene %in% group8, \group8\, NA))))) %>% 
  dplyr::filter(!is.na(group))

perc.group1 <- nrow(tempSE %>% dplyr::filter(group == \group1\, SE == 1))/
  nrow(tempSE %>% dplyr::filter(group == \group1\))

perc.group2 <- nrow(tempSE %>% dplyr::filter(group == \group2\, SE == 1))/
  nrow(tempSE %>% dplyr::filter(group == \group2\))

perc.group5 <- nrow(tempSE %>% dplyr::filter(group == \group5\, SE == 1))/
  nrow(tempSE %>% dplyr::filter(group == \group5\))

perc.group8 <- nrow(tempSE %>% dplyr::filter(group == \group8\, SE == 1))/
  nrow(tempSE %>% dplyr::filter(group == \group8\))

tempPlot <- tibble(group = c(\group1\, \group2\, \group5\, \group8\),
                   perc = c(perc.group1, perc.group2, perc.group5, perc.group8))

ggplot(tempPlot, aes(x = group, y = perc)) + geom_point() + theme_classic() + ylim(0, 0.2)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



## [2.11] How many loops per gene?

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjR3h2ZEY5cGJuTlRZMjl5WlNBOExTQm1kVzVqZEdsdmJpaDBaVzF3TG5SaUxDQnViM1JsTENCNWJXbHVJRDBnTUN3Z2VXMWhlQ0E5SURFdU5TbDdYRzRnSUhBeE1pQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXVkR0lzSUZ3aVozSnZkWEF4WENJc0lGd2laM0p2ZFhBeVhDSXBMQ0ExS1Z4dUlDQndNVFVnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaDBaVzF3TG5SaUxDQmNJbWR5YjNWd01Wd2lMQ0JjSW1keWIzVndOVndpS1N3Z05TbGNiaUFnY0RFNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDNTBZaXdnWENKbmNtOTFjREZjSWl3Z1hDSm5jbTkxY0RoY0lpa3NJRFVwWEc0Z0lIQXlOU0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEF1ZEdJc0lGd2laM0p2ZFhBeVhDSXNJRndpWjNKdmRYQTFYQ0lwTENBMUtWeHVJQ0J3TWpnZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xuUmlMQ0JjSW1keWIzVndNbHdpTENCY0ltZHliM1Z3T0Z3aUtTd2dOU2xjYmlBZ2NEVTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQzUwWWl3Z1hDSm5jbTkxY0RWY0lpd2dYQ0puY205MWNEaGNJaWtzSURVcFhHNGdJRnh1SUNCd0lEd3RJR2RuY0d4dmRDaDBaVzF3TG5SaUxDQmhaWE1vZUNBOUlHZHliM1Z3TENCNUlEMGdjMk52Y21VcEtTQXJJR2RsYjIxZmRtbHZiR2x1S0dGbGN5aG1hV3hzSUQwZ1ozSnZkWEFwTENCemFHOTNMbXhsWjJWdVpDQTlJRVpCVEZORktTQXJJRnh1SUNBZ0lHZGxiMjFmWW05NGNHeHZkQ2gzYVdSMGFDQTlJREF1TVN3Z2IzVjBiR2xsY2k1emFHRndaU0E5SUU1QktTQXJYRzRnSUNBZ2MzUmhkRjl6ZFcxdFlYSjVLR0ZsY3lobmNtOTFjQ0E5SUdkeWIzVndLU3dnWm5WdUlEMGdiV1ZoYml3Z1oyVnZiU0E5SUZ3aWNHOXBiblJjSWl3Z2MyaGhjR1VnUFNBeU1Td2djMmw2WlNBOUlESXNJR1pwYkd3Z1BTQmNJbkpsWkZ3aUxDQmpiMnh2Y2lBOUlGd2lZbXhoWTJ0Y0lpa2dLMXh1SUNBZ0lIUm9aVzFsWDJOc1lYTnphV01vS1NBcklHTnZiM0prWDJOaGNuUmxjMmxoYmloNWJHbHRJRDBnWXloNWJXbHVMQ0I1YldGNEtTa2dLMXh1SUNBZ0lHRnVibTkwWVhSbEtGd2lkR1Y0ZEZ3aUxDQjRJRDBnTVN3Z2VTQTlJSGx0YVc0Z0t5QXhMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNJbkF4TWpvZ1hDSXNJR052Ym5aUWRtRnNkV1VvY0RFeUtTd2dYQ0pjWEc1Y0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ3aWNERTFPaUJjSWl3Z1kyOXVkbEIyWVd4MVpTaHdNVFVwTENCY0lseGNibHdpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p3TVRnNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hBeE9Da3NJRndpWEZ4dVhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQXlOVG9nWENJc0lHTnZiblpRZG1Gc2RXVW9jREkxS1N3Z1hDSmNYRzVjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0RJNE9pQmNJaXdnWTI5dWRsQjJZV3gxWlNod01qZ3BMQ0JjSWx4Y2Jsd2lMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hDSndOVGc2SUZ3aUxHTnZiblpRZG1Gc2RXVW9JSEExT0Nrc0lGd2lYRnh1WENJcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUdOdmJHOXlJRDBnWENKaWJHRmphMXdpTENCb2FuVnpkQ0E5SURBc0lITnBlbVVnUFNBektWeHVJQ0JjYmlBZ1hHNGdJR1pwYkdWT1lXMWxJRHd0SUhCaGMzUmxNQ2hjSW1sdWMzVnNZWFJwYjI1ZmMyTnZjbVZmWENJc0lHNXZkR1VwWEc0Z0lHaGxhV2RvZENBOExTQXpYRzRnSUhkcFpIUm9JRHd0SUROY2JpQWdjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGd2lMbkJ1WjF3aUtTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRndpYVc1Y0lpd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dUlDQndjbWx1ZENod0tWeHVJQ0JrWlhZdWIyWm1LQ2xjYmlBZ2MzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNJaTV6ZG1kY0lpa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVJQ0J3Y21sdWRDaHdLVnh1SUNCa1pYWXViMlptS0NsY2JuMWNibHh1SXlCRVRWTlBYRzUwWlcxd0xuUmlJRHd0SUdkbGJtVXVhVzV6VTJOdmNtVWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aM0p2ZFhBc0lHSnZkVzVrWVhKNVNXNXpVMk52Y21WZlJFMVRUeWxjYm1OdmJHNWhiV1Z6S0hSbGJYQXVkR0lwSUR3dElHTW9YQ0puY205MWNGd2lMQ0JjSW5OamIzSmxYQ0lwWEc1d2JHOTBYMmx1YzFOamIzSmxLSFJsYlhBdWRHSXNJRndpYm1WaGNtVnpkRUp2ZFc1a1lYSjVYMFJOVTA5Y0lpbGNibHh1WEc1Y2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5wbG90X2luc1Njb3JlIDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAwLCB5bWF4ID0gMS41KXtcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDJcXCksIDUpXG4gIHAxNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDJcXCwgXFxncm91cDVcXCksIDUpXG4gIHAyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBwNTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBzY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDEyOiBcXCwgY29udlB2YWx1ZShwMTIpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTU6IFxcLCBjb252UHZhbHVlKHAxNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxODogXFwsIGNvbnZQdmFsdWUocDE4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI1OiBcXCwgY29udlB2YWx1ZShwMjUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjg6IFxcLCBjb252UHZhbHVlKHAyOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHA1ODogXFwsY29udlB2YWx1ZSggcDU4KSwgXFxcXG5cXCksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcaW5zdWxhdGlvbl9zY29yZV9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG4jIERNU09cbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcXGdyb3VwXFwsIFxcc2NvcmVcXClcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXFxuZWFyZXN0Qm91bmRhcnlfRE1TT1xcKVxuXG5cblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO\)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWNHeHZkRjlwYm5OVFkyOXlaU0E4TFNCbWRXNWpkR2x2YmloMFpXMXdMblJpTENCdWIzUmxMQ0I1YldsdUlEMGdNQ3dnZVcxaGVDQTlJREV1TlNsN1hHNGdJSEF4TWlBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBdWRHSXNJRnhjWjNKdmRYQXhYRndzSUZ4Y1ozSnZkWEF5WEZ3cExDQTFLVnh1SUNCd01UVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMblJpTENCY1hHZHliM1Z3TVZ4Y0xDQmNYR2R5YjNWd05WeGNLU3dnTlNsY2JpQWdjREU0SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0M1MFlpd2dYRnhuY205MWNERmNYQ3dnWEZ4bmNtOTFjRGhjWENrc0lEVXBYRzRnSUhBeU5TQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXVkR0lzSUZ4Y1ozSnZkWEF5WEZ3c0lGeGNaM0p2ZFhBMVhGd3BMQ0ExS1Z4dUlDQndNamdnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaDBaVzF3TG5SaUxDQmNYR2R5YjNWd01seGNMQ0JjWEdkeWIzVndPRnhjS1N3Z05TbGNiaUFnY0RVNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDNTBZaXdnWEZ4bmNtOTFjRFZjWEN3Z1hGeG5jbTkxY0RoY1hDa3NJRFVwWEc0Z0lGeHVJQ0J3SUR3dElHZG5jR3h2ZENoMFpXMXdMblJpTENCaFpYTW9lQ0E5SUdkeWIzVndMQ0I1SUQwZ2MyTnZjbVVwS1NBcklHZGxiMjFmZG1sdmJHbHVLR0ZsY3lobWFXeHNJRDBnWjNKdmRYQXBMQ0J6YUc5M0xteGxaMlZ1WkNBOUlFWkJURk5GS1NBcklGeHVJQ0FnSUdkbGIyMWZZbTk0Y0d4dmRDaDNhV1IwYUNBOUlEQXVNU3dnYjNWMGJHbGxjaTV6YUdGd1pTQTlJRTVCS1NBclhHNGdJQ0FnYzNSaGRGOXpkVzF0WVhKNUtHRmxjeWhuY205MWNDQTlJR2R5YjNWd0tTd2dablZ1SUQwZ2JXVmhiaXdnWjJWdmJTQTlJRnhjY0c5cGJuUmNYQ3dnYzJoaGNHVWdQU0F5TVN3Z2MybDZaU0E5SURJc0lHWnBiR3dnUFNCY1hISmxaRnhjTENCamIyeHZjaUE5SUZ4Y1lteGhZMnRjWENrZ0sxeHVJQ0FnSUhSb1pXMWxYMk5zWVhOemFXTW9LU0FySUdOdmIzSmtYMk5oY25SbGMybGhiaWg1YkdsdElEMGdZeWg1YldsdUxDQjViV0Y0S1NrZ0sxeHVJQ0FnSUdGdWJtOTBZWFJsS0Z4Y2RHVjRkRnhjTENCNElEMGdNU3dnZVNBOUlIbHRhVzRnS3lBeExDQnNZV0psYkNBOUlIQmhjM1JsTUNoY1hIQXhNam9nWEZ3c0lHTnZiblpRZG1Gc2RXVW9jREV5S1N3Z1hGeGNYRzVjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRnhjY0RFMU9pQmNYQ3dnWTI5dWRsQjJZV3gxWlNod01UVXBMQ0JjWEZ4Y2JseGNMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hGeHdNVGc2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEF4T0Nrc0lGeGNYRnh1WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhBeU5Ub2dYRndzSUdOdmJuWlFkbUZzZFdVb2NESTFLU3dnWEZ4Y1hHNWNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjREk0T2lCY1hDd2dZMjl1ZGxCMllXeDFaU2h3TWpncExDQmNYRnhjYmx4Y0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWEZ4d05UZzZJRnhjTEdOdmJuWlFkbUZzZFdVb0lIQTFPQ2tzSUZ4Y1hGeHVYRndwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJR052Ykc5eUlEMGdYRnhpYkdGamExeGNMQ0JvYW5WemRDQTlJREFzSUhOcGVtVWdQU0F6S1Z4dUlDQmNiaUFnWEc0Z0lHWnBiR1ZPWVcxbElEd3RJSEJoYzNSbE1DaGNYR2x1YzNWc1lYUnBiMjVmYzJOdmNtVmZYRndzSUc1dmRHVXBYRzRnSUdobGFXZG9kQ0E4TFNBelhHNGdJSGRwWkhSb0lEd3RJRE5jYmlBZ2NHNW5LR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ4Y0xuQnVaMXhjS1Nrc0lISmxjeUE5SURZd01Dd2dkVzVwZENBOUlGeGNhVzVjWEN3Z2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1SUNCd2NtbHVkQ2h3S1Z4dUlDQmtaWFl1YjJabUtDbGNiaUFnYzNabmJHbDBaU2hvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY1hDNXpkbWRjWENrcExDQWdhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dUlDQndjbWx1ZENod0tWeHVJQ0JrWlhZdWIyWm1LQ2xjYm4xY2JseHVJeUJFVFZOUFhHNTBaVzF3TG5SaUlEd3RJR2RsYm1VdWFXNXpVMk52Y21VZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1ozSnZkWEFzSUdKdmRXNWtZWEo1U1c1elUyTnZjbVZmUkUxVFR5bGNibU52Ykc1aGJXVnpLSFJsYlhBdWRHSXBJRHd0SUdNb1hGeG5jbTkxY0Z4Y0xDQmNYSE5qYjNKbFhGd3BYRzV3Ykc5MFgybHVjMU5qYjNKbEtIUmxiWEF1ZEdJc0lGeGNibVZoY21WemRFSnZkVzVrWVhKNVgwUk5VMDljWENsY2JseHVYRzVjYm1CZ1lGeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYGBgclxucGxvdF9pbnNTY29yZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEuNSl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYyh5bWluLCB5bWF4KSkgK1xuICAgIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IHltaW4gKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE1OiBcXCwgY29udlB2YWx1ZShwMTUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTg6IFxcLCBjb252UHZhbHVlKHAxOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyNTogXFwsIGNvbnZQdmFsdWUocDI1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI4OiBcXCwgY29udlB2YWx1ZShwMjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwNTg6IFxcLGNvbnZQdmFsdWUoIHA1OCksIFxcXFxuXFwpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGluc3VsYXRpb25fc2NvcmVfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cblxuIyBETVNPXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfRE1TTylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXFxncm91cFxcLCBcXHNjb3JlXFwpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFxcbmVhcmVzdEJvdW5kYXJ5X0RNU09cXClcblxuXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxucGxvdF9pbnNTY29yZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEuNSl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYyh5bWluLCB5bWF4KSkgK1xuICAgIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IHltaW4gKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE1OiBcXCwgY29udlB2YWx1ZShwMTUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTg6IFxcLCBjb252UHZhbHVlKHAxOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyNTogXFwsIGNvbnZQdmFsdWUocDI1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI4OiBcXCwgY29udlB2YWx1ZShwMjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwNTg6IFxcLGNvbnZQdmFsdWUoIHA1OCksIFxcXFxuXFwpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGluc3VsYXRpb25fc2NvcmVfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cblxuIyBETVNPXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfRE1TTylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXFxncm91cFxcLCBcXHNjb3JlXFwpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFxcbmVhcmVzdEJvdW5kYXJ5X0RNU09cXClcblxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO\)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


## [2.11.2] SuperEnhancer?

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVibUZ0WlNBOExTQmNJbU5vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGNJbHh1WEc1blpXNWxRVzV1YjBSaGRHRWdQQzBnYkc5aFpFeHZiM0JCYm01dlJHRjBZU2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lYM0F0Ymw5bGJuTmxiV0pzVEdsemRDNTBjM1pjSWlrcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JrYVdabVEzVjBiMlptSUQwZ01DNHlMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCaGJtNXZUR2x6ZENBOUlHTW9YQ0pRTFZCY0lpd2dYQ0pRTFVWY0lpd2dYQ0pRTFZOY0lpd2dYQ0pRTFZoY0lpa3BKVDRsSUZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0dScGMzUmhibU5sSUQwZ2MzUmhjblF5SUMwZ2MzUmhjblF4TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUhCbFlXdEpSQ0E5SUhCaGMzUmxLR05vY205dE1Td2djM1JoY25ReExDQnpkR0Z5ZERJc0lITmxjQ0E5SUZ3aVgxd2lLU2xjYmx4dVhHNGpJeUJFYVhacFpHbHVaeUJuWlc1bGN5QnBiblJ2SUdkeWIzVndjMXh1ZEdWdGNDQThMU0JuWlc1bFFXNXViMFJoZEdFZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1pHbG1abDlrVkVGSFgwUk5VMDhzSUdScGMzUmhibU5sTENCblpXNWxLU0FsUGlVZ1hHNGdJSFZ1Ym1WemRDaG5aVzVsS1NBbFBpVWdaM0p2ZFhCZllua29aMlZ1WlNrZ0pUNGxYRzRnSUhOMWJXMWhjbWw2WlNodFpXRnVYMlJwWm1aZmMyTnZjbVVnUFNCdFpXRnVLR1JwWm1aZlpGUkJSMTlFVFZOUEtTeGNiaUFnSUNBZ0lDQWdJQ0FnSUcxbFlXNWZaR2x6ZEdGdVkyVWdQU0J0WldGdUtHUnBjM1JoYm1ObEtTeGNiaUFnSUNBZ0lDQWdJQ0FnSUM1bmNtOTFjSE1nUFNBblpISnZjQ2NwWEc1Y2JtUnBabVl1VWs1QklEd3RJR1p5WldGa0tHaGxjbVVvY21WbVJHbHlMQ0JjSW1ScFptWmZSekV1WkZSQlIxOUhNUzR5YVM1a1ZFRkhYM1p6WDBjeExqSnBMa1JOVTA4dWRITjJYQ0lwS1NBbFBpVmNiaUFnWkhCc2VYSTZPbk5sYkdWamRDaGxibk5sYldKc1gyZGxibVZmYVdRc0lHeHZaekpHYjJ4a1EyaGhibWRsTENCemFISnBibXRsWkY5c2IyY3lSa01zSUhCaFpHb3NJR1Y0ZEdWeWJtRnNYMmRsYm1WZmJtRnRaU2xjYmx4dWJXRjRURzluTWtaRElEMGdNbHh1WEc1MFpXMXdJRHd0SUd4bFpuUmZhbTlwYmloMFpXMXdMQ0JrYVdabUxsSk9RU3dnWW5rZ1BTQmpLRndpWjJWdVpWd2lJRDBnWENKbGJuTmxiV0pzWDJkbGJtVmZhV1JjSWlrcElDVStKU0JjYmlBZ1pISnZjRjl1WVNoemFISnBibXRsWkY5c2IyY3lSa01wWEc1Y2JseHVkR1Z0Y0NBOExTQjBaVzF3SUNVK0pWeHVJQ0JrY0d4NWNqbzZiWFYwWVhSbEtHZHliM1Z3SUQwZ2FXWmxiSE5sS0hCaFpHb2dQQ0F3TGpBMUlDWWdjMmh5YVc1clpXUmZiRzluTWtaRElEd2dNQ3dnTVN3Z1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLRzFsWVc1ZlpHbG1abDl6WTI5eVpTQThJREFzSURJc0lETXBLU2xjYmx4dVhHNWNibVpqUTNWMGIyWm1JRHd0SURBdU5WeHVaR2xtWmtOMWRHOW1aaUE4TFNBd0xqSmNibHh1WjJWdVpTNW5jbTkxY0RFZ1BDMGdLSFJsYlhBZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1ozSnZkWEFnUFQwZ01Ta3BKR2RsYm1WY2JtZGxibVV1WjNKdmRYQXlJRHd0SUNoMFpXMXdJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLR2R5YjNWd0lEMDlJRElwS1NSblpXNWxYRzVtZDNKcGRHVW9LSFJsYlhBZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1ozSnZkWEFnUFQwZ01Ta3BMQ0JvWlhKbEtISmxaa1JwY2l3Z1hDSm5aVzVsVEdsemRGOWtWRUZIWDNaelgwUk5VMDlmVWs1QlgyeHZiM0JmWW1sdVlYSjVSM0p2ZFhBeExuUnpkbHdpS1N3Z2MyVndJRDBnWENKY1hIUmNJaWxjYm1aM2NtbDBaU2dvZEdWdGNDQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaG5jbTkxY0NBOVBTQXlLU2tzSUdobGNtVW9jbVZtUkdseUxDQmNJbWRsYm1WTWFYTjBYMlJVUVVkZmRuTmZSRTFUVDE5U1RrRmZiRzl2Y0Y5aWFXNWhjbmxIY205MWNESXVkSE4yWENJcExDQnpaWEFnUFNCY0lseGNkRndpS1Z4dVhHNWNiaU1nUVdSa2FXNW5JR2R5YjNWd0lHbHVabTl5YldGMGFXOXVJSFJ2SUdkbGJtVkJibTV2WEc1blpXNWxRVzV1YjBSaGRHRWdQQzBnWjJWdVpVRnVibTlFWVhSaElDVStKU0IxYm01bGMzUW9aMlZ1WlNrZ0pUNGxJR1J3YkhseU9qcHRkWFJoZEdVb1hHNGdJR2R5YjNWd0lEMGdhV1psYkhObEtHZGxibVVnSldsdUpTQm5aVzVsTG1keWIzVndNU3dnWENKbmNtOTFjREZjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2FXWmxiSE5sS0dkbGJtVWdKV2x1SlNCblpXNWxMbWR5YjNWd01pd2dYQ0puY205MWNESmNJaXdnVGtFcEtWeHVLVnh1WEc1Y2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5cbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1uX2Vuc2VtYmxMaXN0LnRzdlxcKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9MaXN0ID0gYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcKSklPiUgXG4gIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgcGVha0lEID0gcGFzdGUoY2hyb20xLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKVxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX2RUQUdfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9kVEFHX0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxuXG50ZW1wIDwtIHRlbXAgJT4lXG4gIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBpZmVsc2UocGFkaiA8IDAuMDUgJiBzaHJpbmtlZF9sb2cyRkMgPCAwLCAxLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UobWVhbl9kaWZmX3Njb3JlIDwgMCwgMiwgMykpKVxuXG5cblxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuMlxuXG5nZW5lLmdyb3VwMSA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAxKSkkZ2VuZVxuZ2VuZS5ncm91cDIgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMikpJGdlbmVcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAxKSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDIpKSwgaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5cblxuIyBBZGRpbmcgZ3JvdXAgaW5mb3JtYXRpb24gdG8gZ2VuZUFubm9cbmdlbmVBbm5vRGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIHVubmVzdChnZW5lKSAlPiUgZHBseXI6Om11dGF0ZShcbiAgZ3JvdXAgPSBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAxLCBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAyLCBcXGdyb3VwMlxcLCBOQSkpXG4pXG5cblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))


## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)


temp <- temp %>%
  dplyr::mutate(group = ifelse(padj < 0.05 & shrinked_log2FC < 0, 1, 
                               ifelse(mean_diff_score < 0, 2, 3)))



fcCutoff <- 0.5
diffCutoff <- 0.2

gene.group1 <- (temp %>% dplyr::filter(group == 1))$gene
gene.group2 <- (temp %>% dplyr::filter(group == 2))$gene
fwrite((temp %>% dplyr::filter(group == 1)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 2)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\), sep = \\t\)


# Adding group information to geneAnno
geneAnnoData <- geneAnnoData %>% unnest(gene) %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\, NA))
)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJtRnRaU0E4TFNCY1hHTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsY1hGeHVYRzVuWlc1bFFXNXViMFJoZEdFZ1BDMGdiRzloWkV4dmIzQkJibTV2UkdGMFlTaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gzQXRibDlsYm5ObGJXSnNUR2x6ZEM1MGMzWmNYQ2twTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmthV1ptUTNWMGIyWm1JRDBnTUM0eUxGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JoYm01dlRHbHpkQ0E5SUdNb1hGeFFMVkJjWEN3Z1hGeFFMVVZjWEN3Z1hGeFFMVk5jWEN3Z1hGeFFMVmhjWENrcEpUNGxJRnh1SUNCa2NHeDVjam82YlhWMFlYUmxLR1JwYzNSaGJtTmxJRDBnYzNSaGNuUXlJQzBnYzNSaGNuUXhMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJSEJsWVd0SlJDQTlJSEJoYzNSbEtHTm9jbTl0TVN3Z2MzUmhjblF4TENCemRHRnlkRElzSUhObGNDQTlJRnhjWDF4Y0tTbGNibHh1WEc0akl5QkVhWFpwWkdsdVp5Qm5aVzVsY3lCcGJuUnZJR2R5YjNWd2MxeHVkR1Z0Y0NBOExTQm5aVzVsUVc1dWIwUmhkR0VnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWkdsbVpsOWtWRUZIWDBSTlUwOHNJR1JwYzNSaGJtTmxMQ0JuWlc1bEtTQWxQaVVnWEc0Z0lIVnVibVZ6ZENoblpXNWxLU0FsUGlVZ1ozSnZkWEJmWW5rb1oyVnVaU2tnSlQ0bFhHNGdJSE4xYlcxaGNtbDZaU2h0WldGdVgyUnBabVpmYzJOdmNtVWdQU0J0WldGdUtHUnBabVpmWkZSQlIxOUVUVk5QS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJRzFsWVc1ZlpHbHpkR0Z1WTJVZ1BTQnRaV0Z1S0dScGMzUmhibU5sS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQzVuY205MWNITWdQU0FuWkhKdmNDY3BYRzVjYm1ScFptWXVVazVCSUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNYR1JwWm1aZlJ6RXVaRlJCUjE5SE1TNHlhUzVrVkVGSFgzWnpYMGN4TGpKcExrUk5VMDh1ZEhOMlhGd3BLU0FsUGlWY2JpQWdaSEJzZVhJNk9uTmxiR1ZqZENobGJuTmxiV0pzWDJkbGJtVmZhV1FzSUd4dlp6SkdiMnhrUTJoaGJtZGxMQ0J6YUhKcGJtdGxaRjlzYjJjeVJrTXNJSEJoWkdvc0lHVjRkR1Z5Ym1Gc1gyZGxibVZmYm1GdFpTbGNibHh1YldGNFRHOW5Na1pESUQwZ01seHVYRzUwWlcxd0lEd3RJR3hsWm5SZmFtOXBiaWgwWlcxd0xDQmthV1ptTGxKT1FTd2dZbmtnUFNCaktGeGNaMlZ1WlZ4Y0lEMGdYRnhsYm5ObGJXSnNYMmRsYm1WZmFXUmNYQ2twSUNVK0pTQmNiaUFnWkhKdmNGOXVZU2h6YUhKcGJtdGxaRjlzYjJjeVJrTXBYRzVjYmx4dWRHVnRjQ0E4TFNCMFpXMXdJQ1UrSlZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0dkeWIzVndJRDBnYVdabGJITmxLSEJoWkdvZ1BDQXdMakExSUNZZ2MyaHlhVzVyWldSZmJHOW5Na1pESUR3Z01Dd2dNU3dnWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHMWxZVzVmWkdsbVpsOXpZMjl5WlNBOElEQXNJRElzSURNcEtTbGNibHh1WEc1Y2JtWmpRM1YwYjJabUlEd3RJREF1TlZ4dVpHbG1aa04xZEc5bVppQThMU0F3TGpKY2JseHVaMlZ1WlM1bmNtOTFjREVnUEMwZ0tIUmxiWEFnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWjNKdmRYQWdQVDBnTVNrcEpHZGxibVZjYm1kbGJtVXVaM0p2ZFhBeUlEd3RJQ2gwWlcxd0lDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHZHliM1Z3SUQwOUlESXBLU1JuWlc1bFhHNW1kM0pwZEdVb0tIUmxiWEFnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWjNKdmRYQWdQVDBnTVNrcExDQm9aWEpsS0hKbFprUnBjaXdnWEZ4blpXNWxUR2x6ZEY5a1ZFRkhYM1p6WDBSTlUwOWZVazVCWDJ4dmIzQmZZbWx1WVhKNVIzSnZkWEF4TG5SemRseGNLU3dnYzJWd0lEMGdYRnhjWEhSY1hDbGNibVozY21sMFpTZ29kR1Z0Y0NBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFNBeUtTa3NJR2hsY21Vb2NtVm1SR2x5TENCY1hHZGxibVZNYVhOMFgyUlVRVWRmZG5OZlJFMVRUMTlTVGtGZmJHOXZjRjlpYVc1aGNubEhjbTkxY0RJdWRITjJYRndwTENCelpYQWdQU0JjWEZ4Y2RGeGNLVnh1WEc1Y2JpTWdRV1JrYVc1bklHZHliM1Z3SUdsdVptOXliV0YwYVc5dUlIUnZJR2RsYm1WQmJtNXZYRzVuWlc1bFFXNXViMFJoZEdFZ1BDMGdaMlZ1WlVGdWJtOUVZWFJoSUNVK0pTQjFibTVsYzNRb1oyVnVaU2tnSlQ0bElHUndiSGx5T2pwdGRYUmhkR1VvWEc0Z0lHZHliM1Z3SUQwZ2FXWmxiSE5sS0dkbGJtVWdKV2x1SlNCblpXNWxMbWR5YjNWd01Td2dYRnhuY205MWNERmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0JuWlc1bExtZHliM1Z3TWl3Z1hGeG5jbTkxY0RKY1hDd2dUa0VwS1Z4dUtWeHVYRzVjYm1CZ1lGeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSlcblxuXG4jIyBEaXZpZGluZyBnZW5lcyBpbnRvIGdyb3Vwc1xudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZl9kVEFHX0RNU08sIGRpc3RhbmNlLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmZfZFRBR19ETVNPKSxcbiAgICAgICAgICAgIG1lYW5fZGlzdGFuY2UgPSBtZWFuKGRpc3RhbmNlKSxcbiAgICAgICAgICAgIC5ncm91cHMgPSAnZHJvcCcpXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxubWF4TG9nMkZDID0gMlxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cblxudGVtcCA8LSB0ZW1wICU+JVxuICBkcGx5cjo6bXV0YXRlKGdyb3VwID0gaWZlbHNlKHBhZGogPCAwLjA1ICYgc2hyaW5rZWRfbG9nMkZDIDwgMCwgMSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKG1lYW5fZGlmZl9zY29yZSA8IDAsIDIsIDMpKSlcblxuXG5cbmZjQ3V0b2ZmIDwtIDAuNVxuZGlmZkN1dG9mZiA8LSAwLjJcblxuZ2VuZS5ncm91cDEgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMSkpJGdlbmVcbmdlbmUuZ3JvdXAyIDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDIpKSRnZW5lXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMSkpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAyKSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG5cbiMgQWRkaW5nIGdyb3VwIGluZm9ybWF0aW9uIHRvIGdlbmVBbm5vXG5nZW5lQW5ub0RhdGEgPC0gZ2VuZUFubm9EYXRhICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwMSwgXFxncm91cDFcXCxcbiAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwMiwgXFxncm91cDJcXCwgTkEpKVxuKVxuXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSlcblxuXG4jIyBEaXZpZGluZyBnZW5lcyBpbnRvIGdyb3Vwc1xudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZl9kVEFHX0RNU08sIGRpc3RhbmNlLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmZfZFRBR19ETVNPKSxcbiAgICAgICAgICAgIG1lYW5fZGlzdGFuY2UgPSBtZWFuKGRpc3RhbmNlKSxcbiAgICAgICAgICAgIC5ncm91cHMgPSAnZHJvcCcpXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxubWF4TG9nMkZDID0gMlxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cblxudGVtcCA8LSB0ZW1wICU+JVxuICBkcGx5cjo6bXV0YXRlKGdyb3VwID0gaWZlbHNlKHBhZGogPCAwLjA1ICYgc2hyaW5rZWRfbG9nMkZDIDwgMCwgMSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKG1lYW5fZGlmZl9zY29yZSA8IDAsIDIsIDMpKSlcblxuXG5cbmZjQ3V0b2ZmIDwtIDAuNVxuZGlmZkN1dG9mZiA8LSAwLjJcblxuZ2VuZS5ncm91cDEgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMSkpJGdlbmVcbmdlbmUuZ3JvdXAyIDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDIpKSRnZW5lXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMSkpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAyKSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG5cbiMgQWRkaW5nIGdyb3VwIGluZm9ybWF0aW9uIHRvIGdlbmVBbm5vXG5nZW5lQW5ub0RhdGEgPC0gZ2VuZUFubm9EYXRhICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwMSwgXFxncm91cDFcXCxcbiAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwMiwgXFxncm91cDJcXCwgTkEpKVxuKVxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))


## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)


temp <- temp %>%
  dplyr::mutate(group = ifelse(padj < 0.05 & shrinked_log2FC < 0, 1, 
                               ifelse(mean_diff_score < 0, 2, 3)))



fcCutoff <- 0.5
diffCutoff <- 0.2

gene.group1 <- (temp %>% dplyr::filter(group == 1))$gene
gene.group2 <- (temp %>% dplyr::filter(group == 2))$gene
fwrite((temp %>% dplyr::filter(group == 1)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 2)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\), sep = \\t\)


# Adding group information to geneAnno
geneAnnoData <- geneAnnoData %>% unnest(gene) %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\, NA))
)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5nZW5lLmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlwiKSkkZ2VuZVxuZ2VuZS5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcIikpJGdlbmVcblxuR08xIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiLCByZWFkYWJsZSA9IFRSVUUpXG5HTzIgPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmUuZ3JvdXAyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFwiRU5TRU1CTFwiLCBvbnQgPSBcIkJQXCIsIHJlYWRhYmxlID0gVFJVRSlcbkdPMS5kZiA8LSBhcy5kYXRhLmZyYW1lKEdPMSlcbkdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKEdPMilcbiMgZndyaXRlKEdPMS5kZiwgaGVyZShcIkdPX2JpbmFyeV9ncm91cDEudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuIyBmd3JpdGUoR08yLmRmLCBoZXJlKFwiR09fYmluYXJ5X2dyb3VwMi50c3ZcIiksIHNlcCA9IFwiXFx0XCIpXG5HTzEuZGYgPC0gZnJlYWQoaGVyZShcIkdPX2JpbmFyeV9ncm91cDEudHN2XCIpKVxuR08yLmRmIDwtIGZyZWFkKGhlcmUoXCJHT19iaW5hcnlfZ3JvdXAyLnRzdlwiKSlcblxuc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwiR3JvdXAgMVwiKSAlPiVcbiAgZHBseXI6OmFycmFuZ2UocC5hZGp1c3QpXG5zdWJzZXQxJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MSRHZW5lUmF0aW8sIFwiL1wiKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5cbnN1YnNldDIgPC0gR08yLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcIkdyb3VwIDJcIikgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuc3Vic2V0MiRHZW5lUmF0aW8gPC0gc2FwcGx5KHN0cnNwbGl0KHN1YnNldDIkR2VuZVJhdGlvLCBcIi9cIiksIGZ1bmN0aW9uKHgpIGFzLm51bWVyaWMoeFsxXSkgLyBhcy5udW1lcmljKHhbMl0pKVxuXG5cbkdPbGlzdCA8LSBmYWN0b3IoYyhcIkdPOjAwMDE4MjRcIiwgXCJHTzowMDMwODc5XCIsIFwiR086MDAyMTk1M1wiLCBcIkdPOjAwMTk4MjdcIiwgXG4gICAgICAgICAgICAgICAgIFwiR086MDAyMjYxM1wiLCBcIkdPOjAwNTA3NjdcIiwgXCJHTzowMDM0NDcwXCIsIFwiR086MDAxNjA1NVwiLCBcbiAgICAgICAgICAgICAgICAgXCJHTzowMDA2Mzk3XCIsIFwiR086MDAzMDkwMFwiLCBcIkdPOjAwMDgzODBcIikpXG5cbmRhdGEgPC0gYmluZF9yb3dzKHN1YnNldDEsIHN1YnNldDIpICU+JVxuICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuXG5kZXNjT3JkZXIgPC0gc29ydCh1bmlxdWUoZGF0YSREZXNjcmlwdGlvbikpW2MoNCwgMTAsIDIsIDEsIDMsIDExLCA3LCA4LCA2LCA1LCA5KV1cbnBWYWx1ZUxvZ01heCA8LSAxMFxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6cm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKHBWYWx1ZUxvZyA9IG1pbigtbG9nMTAocC5hZGp1c3QpLCBwVmFsdWVMb2dNYXgpKVxucCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IGZhY3RvcihEZXNjcmlwdGlvbiwgbGV2ZWxzID0gZGVzY09yZGVyKSwgc2l6ZSA9IHBWYWx1ZUxvZywgZmlsbCA9IEdlbmVSYXRpbykpICsgXG4gIGdlb21fcG9pbnQoc2hhcGUgPSAyMSwgICAgICAgICMgRW5zdXJlcyBhIHBvaW50IHdpdGggYW4gb3V0bGluZVxuICAgICAgICAgICAgIHN0cm9rZSA9IDEqcHRUb01NKSArIFxuICBzY2FsZV9zaXplX2NvbnRpbnVvdXMocmFuZ2UgPSBjKDAuNSwgMikpICsgICMgU2V0IG1pbiBhbmQgbWF4IHBvaW50IHNpemVzIGhlcmVcbiAgc2NhbGVfZmlsbF9ncmFkaWVudChsb3cgPSBcIndoaXRlXCIsIGhpZ2ggPSBcIiNDQjMzM0FcIixcbiAgICAgICAgICAgICAgICAgICAgICAjIGxpbWl0cyA9IGMoMCwgMSksXG4gICAgICAgICAgICAgICAgICAgICAgb29iID0gc2NhbGVzOjpzcXVpc2gsICMgRGVmaW5lIGdyYWRpZW50IGNvbG9yc1xuICAgICAgICAgICAgICAgICAgICAgIGd1aWRlID0gZ3VpZGVfY29sb3JiYXIoXG4gICAgICAgICAgICAgICAgICAgICAgICBiYXJ3aWR0aCA9IDEuNS81LjA4LCAgIyBBZGp1c3Qgd2lkdGggb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyaGVpZ2h0ID0gMTUvNS4wOCAgICMgQWRqdXN0IGhlaWdodCBvZiB0aGUgY29sb3IgYmFyXG4gICAgICAgICAgICAgICAgICAgICAgKVxuICApICsgXG4gIGxhYnMoeCA9IE5VTEwsIHkgPSBOVUxMKSArXG4gIHRoZW1lX2J3KCkgKyAgIyBBcHBseSB0aGVtZV9idyBmaXJzdCwgc28gY3VzdG9tIHRoZW1lIHNldHRpbmdzIGNvbWUgYWZ0ZXJcbiAgdGhlbWUoXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXCJ0cmFuc3BhcmVudFwiKSwgICMgT3ZlcnJpZGUgdGhlbWVfYncgcGFuZWxcbiAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUyxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCAgICAgICAgICMgRW5zdXJlIHNpemUgaXMgc2V0IGZvciB4LWF4aXMgdGV4dFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLFxuICAgICksXG4gICAgYXhpcy50ZXh0LnkgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCAgICAgICAgICMgRW5zdXJlIHNpemUgaXMgc2V0IGZvciB5LWF4aXMgdGV4dFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLFxuICAgICAgbGluZWhlaWdodCA9IDAuOSAgICAgICAgICAjIEFsbG93cyB3cmFwcGluZyBmb3IgeS1heGlzIGxhYmVscyB0byBmaXQgaW50byAyIGxpbmVzXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcInNxdWFyZVwiXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKVxuICBcblxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgXCIuLlwiLCBcIkdPXCIsIFwiR09fZ3JvdXBzX2JpbmFyeUdyb3VwaW5nXCIpXG53aWR0aCA8LSBwYW5lbFNpemUoMi41KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjIpKm1tVG9JbmNoXG5zdmdsaXRlKHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGAifQ== -->\n\n```r\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nGO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE)\nGO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE)\nGO1.df <- as.data.frame(GO1)\nGO2.df <- as.data.frame(GO2)\n# fwrite(GO1.df, here(\\GO_binary_group1.tsv\\), sep = \\\\t\\)\n# fwrite(GO2.df, here(\\GO_binary_group2.tsv\\), sep = \\\\t\\)\nGO1.df <- fread(here(\\GO_binary_group1.tsv\\))\nGO2.df <- fread(here(\\GO_binary_group2.tsv\\))\n\nsubset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 1\\) %>%\n  dplyr::arrange(p.adjust)\nsubset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\n\nsubset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 2\\) %>%\n  dplyr::arrange(p.adjust)\nsubset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\n\n\nGOlist <- factor(c(\\GO:0001824\\, \\GO:0030879\\, \\GO:0021953\\, \\GO:0019827\\, \n                 \\GO:0022613\\, \\GO:0050767\\, \\GO:0034470\\, \\GO:0016055\\, \n                 \\GO:0006397\\, \\GO:0030900\\, \\GO:0008380\\))\n\ndata <- bind_rows(subset1, subset2) %>%\n  dplyr::filter(ID %in% GOlist)\n\ndescOrder <- sort(unique(data$Description))[c(4, 10, 2, 1, 3, 11, 7, 8, 6, 5, 9)]\npValueLogMax <- 10\ndata <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))\np <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + \n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM) + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      # limits = c(0, 1),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL) +\n  theme_bw() +  # Apply theme_bw first, so custom theme settings come after\n  theme(\n    panel.background = element_rect(fill = \\transparent\\),  # Override theme_bw panel\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      size = fontSizeS,         # Ensure size is set for x-axis text\n      family = fontType,\n      color = \\#000000\\,\n    ),\n    axis.text.y = element_text(\n      size = fontSizeS,         # Ensure size is set for y-axis text\n      family = fontType,\n      color = \\#000000\\,\n      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n  \n\n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_binaryGrouping\\)\nwidth <- panelSize(2.5)*mmToInch\nheight <- panelSize(1.2)*mmToInch\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

GO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE)
GO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE)
GO1.df <- as.data.frame(GO1)
GO2.df <- as.data.frame(GO2)
# fwrite(GO1.df, here(\GO_binary_group1.tsv\), sep = \\t\)
# fwrite(GO2.df, here(\GO_binary_group2.tsv\), sep = \\t\)
GO1.df <- fread(here(\GO_binary_group1.tsv\))
GO2.df <- fread(here(\GO_binary_group2.tsv\))

subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 1\) %>%
  dplyr::arrange(p.adjust)
subset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))

subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 2\) %>%
  dplyr::arrange(p.adjust)
subset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))


GOlist <- factor(c(\GO:0001824\, \GO:0030879\, \GO:0021953\, \GO:0019827\, 
                 \GO:0022613\, \GO:0050767\, \GO:0034470\, \GO:0016055\, 
                 \GO:0006397\, \GO:0030900\, \GO:0008380\))

data <- bind_rows(subset1, subset2) %>%
  dplyr::filter(ID %in% GOlist)

descOrder <- sort(unique(data$Description))[c(4, 10, 2, 1, 3, 11, 7, 8, 6, 5, 9)]
pValueLogMax <- 10
data <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))
p <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + 
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM) + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = \white\, high = \#CB333A\,
                      # limits = c(0, 1),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL) +
  theme_bw() +  # Apply theme_bw first, so custom theme settings come after
  theme(
    panel.background = element_rect(fill = \transparent\),  # Override theme_bw panel
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      size = fontSizeS,         # Ensure size is set for x-axis text
      family = fontType,
      color = \#000000\,
    ),
    axis.text.y = element_text(
      size = fontSizeS,         # Ensure size is set for y-axis text
      family = fontType,
      color = \#000000\,
      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )
  


fileName <- here(figDir, \..\, \GO\, \GO_groups_binaryGrouping\)
width <- panelSize(2.5)*mmToInch
height <- panelSize(1.2)*mmToInch
svglite(paste0(fileName, \.svg\), height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5nZW5lLmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlxcKSkkZ2VuZVxuZ2VuZS5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuR08xIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcLCByZWFkYWJsZSA9IFRSVUUpXG5HTzIgPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmUuZ3JvdXAyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwsIHJlYWRhYmxlID0gVFJVRSlcbkdPMS5kZiA8LSBhcy5kYXRhLmZyYW1lKEdPMSlcbkdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKEdPMilcbiMgZndyaXRlKEdPMS5kZiwgaGVyZShcXEdPX2JpbmFyeV9ncm91cDEudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuIyBmd3JpdGUoR08yLmRmLCBoZXJlKFxcR09fYmluYXJ5X2dyb3VwMi50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5HTzEuZGYgPC0gZnJlYWQoaGVyZShcXEdPX2JpbmFyeV9ncm91cDEudHN2XFwpKVxuR08yLmRmIDwtIGZyZWFkKGhlcmUoXFxHT19iaW5hcnlfZ3JvdXAyLnRzdlxcKSlcblxuc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcR3JvdXAgMVxcKSAlPiVcbiAgZHBseXI6OmFycmFuZ2UocC5hZGp1c3QpXG5zdWJzZXQxJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MSRHZW5lUmF0aW8sIFxcL1xcKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5cbnN1YnNldDIgPC0gR08yLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXEdyb3VwIDJcXCkgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuc3Vic2V0MiRHZW5lUmF0aW8gPC0gc2FwcGx5KHN0cnNwbGl0KHN1YnNldDIkR2VuZVJhdGlvLCBcXC9cXCksIGZ1bmN0aW9uKHgpIGFzLm51bWVyaWMoeFsxXSkgLyBhcy5udW1lcmljKHhbMl0pKVxuXG5cbkdPbGlzdCA8LSBmYWN0b3IoYyhcXEdPOjAwMDE4MjRcXCwgXFxHTzowMDMwODc5XFwsIFxcR086MDAyMTk1M1xcLCBcXEdPOjAwMTk4MjdcXCwgXG4gICAgICAgICAgICAgICAgIFxcR086MDAyMjYxM1xcLCBcXEdPOjAwNTA3NjdcXCwgXFxHTzowMDM0NDcwXFwsIFxcR086MDAxNjA1NVxcLCBcbiAgICAgICAgICAgICAgICAgXFxHTzowMDA2Mzk3XFwsIFxcR086MDAzMDkwMFxcLCBcXEdPOjAwMDgzODBcXCkpXG5cbmRhdGEgPC0gYmluZF9yb3dzKHN1YnNldDEsIHN1YnNldDIpICU+JVxuICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuXG5kZXNjT3JkZXIgPC0gc29ydCh1bmlxdWUoZGF0YSREZXNjcmlwdGlvbikpW2MoNCwgMTAsIDIsIDEsIDMsIDExLCA3LCA4LCA2LCA1LCA5KV1cbnBWYWx1ZUxvZ01heCA8LSAxMFxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6cm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKHBWYWx1ZUxvZyA9IG1pbigtbG9nMTAocC5hZGp1c3QpLCBwVmFsdWVMb2dNYXgpKVxucCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IGZhY3RvcihEZXNjcmlwdGlvbiwgbGV2ZWxzID0gZGVzY09yZGVyKSwgc2l6ZSA9IHBWYWx1ZUxvZywgZmlsbCA9IEdlbmVSYXRpbykpICsgXG4gIGdlb21fcG9pbnQoc2hhcGUgPSAyMSwgICAgICAgICMgRW5zdXJlcyBhIHBvaW50IHdpdGggYW4gb3V0bGluZVxuICAgICAgICAgICAgIHN0cm9rZSA9IDEqcHRUb01NKSArIFxuICBzY2FsZV9zaXplX2NvbnRpbnVvdXMocmFuZ2UgPSBjKDAuNSwgMikpICsgICMgU2V0IG1pbiBhbmQgbWF4IHBvaW50IHNpemVzIGhlcmVcbiAgc2NhbGVfZmlsbF9ncmFkaWVudChsb3cgPSBcXHdoaXRlXFwsIGhpZ2ggPSBcXCNDQjMzM0FcXCxcbiAgICAgICAgICAgICAgICAgICAgICAjIGxpbWl0cyA9IGMoMCwgMSksXG4gICAgICAgICAgICAgICAgICAgICAgb29iID0gc2NhbGVzOjpzcXVpc2gsICMgRGVmaW5lIGdyYWRpZW50IGNvbG9yc1xuICAgICAgICAgICAgICAgICAgICAgIGd1aWRlID0gZ3VpZGVfY29sb3JiYXIoXG4gICAgICAgICAgICAgICAgICAgICAgICBiYXJ3aWR0aCA9IDEuNS81LjA4LCAgIyBBZGp1c3Qgd2lkdGggb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyaGVpZ2h0ID0gMTUvNS4wOCAgICMgQWRqdXN0IGhlaWdodCBvZiB0aGUgY29sb3IgYmFyXG4gICAgICAgICAgICAgICAgICAgICAgKVxuICApICsgXG4gIGxhYnMoeCA9IE5VTEwsIHkgPSBOVUxMKSArXG4gIHRoZW1lX2J3KCkgKyAgIyBBcHBseSB0aGVtZV9idyBmaXJzdCwgc28gY3VzdG9tIHRoZW1lIHNldHRpbmdzIGNvbWUgYWZ0ZXJcbiAgdGhlbWUoXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSwgICMgT3ZlcnJpZGUgdGhlbWVfYncgcGFuZWxcbiAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUyxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCAgICAgICAgICMgRW5zdXJlIHNpemUgaXMgc2V0IGZvciB4LWF4aXMgdGV4dFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICksXG4gICAgYXhpcy50ZXh0LnkgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCAgICAgICAgICMgRW5zdXJlIHNpemUgaXMgc2V0IGZvciB5LWF4aXMgdGV4dFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgbGluZWhlaWdodCA9IDAuOSAgICAgICAgICAjIEFsbG93cyB3cmFwcGluZyBmb3IgeS1heGlzIGxhYmVscyB0byBmaXQgaW50byAyIGxpbmVzXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKVxuICBcblxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgXFwuLlxcLCBcXEdPXFwsIFxcR09fZ3JvdXBzX2JpbmFyeUdyb3VwaW5nXFwpXG53aWR0aCA8LSBwYW5lbFNpemUoMi41KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjIpKm1tVG9JbmNoXG5zdmdsaXRlKHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nGO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE)\nGO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE)\nGO1.df <- as.data.frame(GO1)\nGO2.df <- as.data.frame(GO2)\n# fwrite(GO1.df, here(\\GO_binary_group1.tsv\\), sep = \\\\t\\)\n# fwrite(GO2.df, here(\\GO_binary_group2.tsv\\), sep = \\\\t\\)\nGO1.df <- fread(here(\\GO_binary_group1.tsv\\))\nGO2.df <- fread(here(\\GO_binary_group2.tsv\\))\n\nsubset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 1\\) %>%\n  dplyr::arrange(p.adjust)\nsubset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\n\nsubset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 2\\) %>%\n  dplyr::arrange(p.adjust)\nsubset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\n\n\nGOlist <- factor(c(\\GO:0001824\\, \\GO:0030879\\, \\GO:0021953\\, \\GO:0019827\\, \n                 \\GO:0022613\\, \\GO:0050767\\, \\GO:0034470\\, \\GO:0016055\\, \n                 \\GO:0006397\\, \\GO:0030900\\, \\GO:0008380\\))\n\ndata <- bind_rows(subset1, subset2) %>%\n  dplyr::filter(ID %in% GOlist)\n\ndescOrder <- sort(unique(data$Description))[c(4, 10, 2, 1, 3, 11, 7, 8, 6, 5, 9)]\npValueLogMax <- 10\ndata <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))\np <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + \n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM) + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      # limits = c(0, 1),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL) +\n  theme_bw() +  # Apply theme_bw first, so custom theme settings come after\n  theme(\n    panel.background = element_rect(fill = \\transparent\\),  # Override theme_bw panel\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      size = fontSizeS,         # Ensure size is set for x-axis text\n      family = fontType,\n      color = \\#000000\\,\n    ),\n    axis.text.y = element_text(\n      size = fontSizeS,         # Ensure size is set for y-axis text\n      family = fontType,\n      color = \\#000000\\,\n      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n  \n\n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_binaryGrouping\\)\nwidth <- panelSize(2.5)*mmToInch\nheight <- panelSize(1.2)*mmToInch\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5nZW5lLmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlxcKSkkZ2VuZVxuZ2VuZS5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuR08xIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcLCByZWFkYWJsZSA9IFRSVUUpXG5HTzIgPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmUuZ3JvdXAyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwsIHJlYWRhYmxlID0gVFJVRSlcbkdPMS5kZiA8LSBhcy5kYXRhLmZyYW1lKEdPMSlcbkdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKEdPMilcbiMgZndyaXRlKEdPMS5kZiwgaGVyZShcXEdPX2JpbmFyeV9ncm91cDEudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuIyBmd3JpdGUoR08yLmRmLCBoZXJlKFxcR09fYmluYXJ5X2dyb3VwMi50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5HTzEuZGYgPC0gZnJlYWQoaGVyZShcXEdPX2JpbmFyeV9ncm91cDEudHN2XFwpKVxuR08yLmRmIDwtIGZyZWFkKGhlcmUoXFxHT19iaW5hcnlfZ3JvdXAyLnRzdlxcKSlcblxuc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcR3JvdXAgMVxcKSAlPiVcbiAgZHBseXI6OmFycmFuZ2UocC5hZGp1c3QpXG5zdWJzZXQxJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MSRHZW5lUmF0aW8sIFxcL1xcKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5cbnN1YnNldDIgPC0gR08yLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXEdyb3VwIDJcXCkgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuc3Vic2V0MiRHZW5lUmF0aW8gPC0gc2FwcGx5KHN0cnNwbGl0KHN1YnNldDIkR2VuZVJhdGlvLCBcXC9cXCksIGZ1bmN0aW9uKHgpIGFzLm51bWVyaWMoeFsxXSkgLyBhcy5udW1lcmljKHhbMl0pKVxuXG5cbkdPbGlzdCA8LSBmYWN0b3IoYyhcXEdPOjAwMDE4MjRcXCwgXFxHTzowMDMwODc5XFwsIFxcR086MDAyMTk1M1xcLCBcXEdPOjAwMTk4MjdcXCwgXG4gICAgICAgICAgICAgICAgIFxcR086MDAyMjYxM1xcLCBcXEdPOjAwNTA3NjdcXCwgXFxHTzowMDM0NDcwXFwsIFxcR086MDAxNjA1NVxcLCBcbiAgICAgICAgICAgICAgICAgXFxHTzowMDA2Mzk3XFwsIFxcR086MDAzMDkwMFxcLCBcXEdPOjAwMDgzODBcXCkpXG5cbmRhdGEgPC0gYmluZF9yb3dzKHN1YnNldDEsIHN1YnNldDIpICU+JVxuICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuXG5kZXNjT3JkZXIgPC0gc29ydCh1bmlxdWUoZGF0YSREZXNjcmlwdGlvbikpW2MoNCwgMTAsIDIsIDEsIDMsIDExLCA3LCA4LCA2LCA1LCA5KV1cbnBWYWx1ZUxvZ01heCA8LSAxMFxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6cm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKHBWYWx1ZUxvZyA9IG1pbigtbG9nMTAocC5hZGp1c3QpLCBwVmFsdWVMb2dNYXgpKVxucCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IGZhY3RvcihEZXNjcmlwdGlvbiwgbGV2ZWxzID0gZGVzY09yZGVyKSwgc2l6ZSA9IHBWYWx1ZUxvZywgZmlsbCA9IEdlbmVSYXRpbykpICsgXG4gIGdlb21fcG9pbnQoc2hhcGUgPSAyMSwgICAgICAgICMgRW5zdXJlcyBhIHBvaW50IHdpdGggYW4gb3V0bGluZVxuICAgICAgICAgICAgIHN0cm9rZSA9IDEqcHRUb01NKSArIFxuICBzY2FsZV9zaXplX2NvbnRpbnVvdXMocmFuZ2UgPSBjKDAuNSwgMikpICsgICMgU2V0IG1pbiBhbmQgbWF4IHBvaW50IHNpemVzIGhlcmVcbiAgc2NhbGVfZmlsbF9ncmFkaWVudChsb3cgPSBcXHdoaXRlXFwsIGhpZ2ggPSBcXCNDQjMzM0FcXCxcbiAgICAgICAgICAgICAgICAgICAgICAjIGxpbWl0cyA9IGMoMCwgMSksXG4gICAgICAgICAgICAgICAgICAgICAgb29iID0gc2NhbGVzOjpzcXVpc2gsICMgRGVmaW5lIGdyYWRpZW50IGNvbG9yc1xuICAgICAgICAgICAgICAgICAgICAgIGd1aWRlID0gZ3VpZGVfY29sb3JiYXIoXG4gICAgICAgICAgICAgICAgICAgICAgICBiYXJ3aWR0aCA9IDEuNS81LjA4LCAgIyBBZGp1c3Qgd2lkdGggb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyaGVpZ2h0ID0gMTUvNS4wOCAgICMgQWRqdXN0IGhlaWdodCBvZiB0aGUgY29sb3IgYmFyXG4gICAgICAgICAgICAgICAgICAgICAgKVxuICApICsgXG4gIGxhYnMoeCA9IE5VTEwsIHkgPSBOVUxMKSArXG4gIHRoZW1lX2J3KCkgKyAgIyBBcHBseSB0aGVtZV9idyBmaXJzdCwgc28gY3VzdG9tIHRoZW1lIHNldHRpbmdzIGNvbWUgYWZ0ZXJcbiAgdGhlbWUoXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSwgICMgT3ZlcnJpZGUgdGhlbWVfYncgcGFuZWxcbiAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUyxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCAgICAgICAgICMgRW5zdXJlIHNpemUgaXMgc2V0IGZvciB4LWF4aXMgdGV4dFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICksXG4gICAgYXhpcy50ZXh0LnkgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCAgICAgICAgICMgRW5zdXJlIHNpemUgaXMgc2V0IGZvciB5LWF4aXMgdGV4dFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgbGluZWhlaWdodCA9IDAuOSAgICAgICAgICAjIEFsbG93cyB3cmFwcGluZyBmb3IgeS1heGlzIGxhYmVscyB0byBmaXQgaW50byAyIGxpbmVzXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKVxuICBcblxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgXFwuLlxcLCBcXEdPXFwsIFxcR09fZ3JvdXBzX2JpbmFyeUdyb3VwaW5nXFwpXG53aWR0aCA8LSBwYW5lbFNpemUoMi41KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjIpKm1tVG9JbmNoXG5zdmdsaXRlKHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

GO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE)
GO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE)
GO1.df <- as.data.frame(GO1)
GO2.df <- as.data.frame(GO2)
# fwrite(GO1.df, here(\GO_binary_group1.tsv\), sep = \\t\)
# fwrite(GO2.df, here(\GO_binary_group2.tsv\), sep = \\t\)
GO1.df <- fread(here(\GO_binary_group1.tsv\))
GO2.df <- fread(here(\GO_binary_group2.tsv\))

subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 1\) %>%
  dplyr::arrange(p.adjust)
subset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))

subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 2\) %>%
  dplyr::arrange(p.adjust)
subset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))


GOlist <- factor(c(\GO:0001824\, \GO:0030879\, \GO:0021953\, \GO:0019827\, 
                 \GO:0022613\, \GO:0050767\, \GO:0034470\, \GO:0016055\, 
                 \GO:0006397\, \GO:0030900\, \GO:0008380\))

data <- bind_rows(subset1, subset2) %>%
  dplyr::filter(ID %in% GOlist)

descOrder <- sort(unique(data$Description))[c(4, 10, 2, 1, 3, 11, 7, 8, 6, 5, 9)]
pValueLogMax <- 10
data <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))
p <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + 
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM) + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = \white\, high = \#CB333A\,
                      # limits = c(0, 1),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL) +
  theme_bw() +  # Apply theme_bw first, so custom theme settings come after
  theme(
    panel.background = element_rect(fill = \transparent\),  # Override theme_bw panel
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      size = fontSizeS,         # Ensure size is set for x-axis text
      family = fontType,
      color = \#000000\,
    ),
    axis.text.y = element_text(
      size = fontSizeS,         # Ensure size is set for y-axis text
      family = fontType,
      color = \#000000\,
      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )
  


fileName <- here(figDir, \..\, \GO\, \GO_groups_binaryGrouping\)
width <- panelSize(2.5)*mmToInch
height <- panelSize(1.2)*mmToInch
svglite(paste0(fileName, \.svg\), height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



## [2.12] How many loops/distance per gene in each quadrant?
#### dTAG with binary grouping
##### Splitting genes to group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJEYUdWamEybHVaeUJoZG1WeVlXZGxJR1JwYzNSaGJtTmxJRzltSUd4dmIzQnpJSEJsY2lCblpXNWxYRzRqSUhSbGJYQWdhWE1nWVNCMGFXSmliR1VnZDJobGNtVWdaR1ZzZEdFZ2JHOXZjQ0JoYm1RZ2JHOW5NbVpqSUdGeVpTQnRaWEpuWldSY2JuUmxiWEFrWjNKdmRYQWdQQzBnWm1GamRHOXlLSFJsYlhBa1ozSnZkWEFwWEc1Y2JuUmxiWEFnUEMwZ2RHVnRjQ0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhuY205MWNDQWxhVzRsSUdNb01Td2dNaWtwWEc1Y2JseHVaMlYwVUhaaGJGZHBiR052ZUNBOExTQm1kVzVqZEdsdmJpaGtZWFJoTENCbmNtOTFjREVzSUdkeWIzVndNaWw3WEc0Z0lHUnBjM1JoYm1ObE1TQThMU0FvWkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaG5jbTkxY0NBOVBXZHliM1Z3TVNrZ0tTUnRaV0Z1WDJScGMzUmhibU5sWEc0Z0lHUnBjM1JoYm1ObE1pQThMU0FvWkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaG5jbTkxY0NBOVBXZHliM1Z3TWlrZ0tTUnRaV0Z1WDJScGMzUmhibU5sWEc0Z0lIZHBiQ0E4TFNCM2FXeGpiM2d1ZEdWemRDaGthWE4wWVc1alpURXNJR1JwYzNSaGJtTmxNaWxjYmlBZ2NtVjBkWEp1S0hkcGJDUndMblpoYkhWbEtWeHVmVnh1WEc1d2RqRXlJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnTVN3Z01pa3NJRFVwWEc1Y2JseHVYRzV3SUR3dElHZG5jR3h2ZENoMFpXMXdMQ0JoWlhNb2VDQTlJR2R5YjNWd0xDQjVJRDBnYldWaGJsOWthWE4wWVc1alpTa3BJQ3NnWjJWdmJWOTJhVzlzYVc0b1lXVnpLR1pwYkd3Z1BTQm5jbTkxY0Nrc0lITm9iM2N1YkdWblpXNWtJRDBnUmtGTVUwVXBJQ3RjYmlBZ1oyVnZiVjlpYjNod2JHOTBLSGRwWkhSb0lEMGdNQzR4TENCdmRYUnNhV1Z5TG5Ob1lYQmxJRDBnVGtFcElDc2dkR2hsYldWZlkyeGhjM05wWXlncElDc2djMk5oYkdWZmVWOWpiMjUwYVc1MWIzVnpLR3hoWW1Wc2N5QTlJR3hoWW1Wc1gydGlYMjFpS1NBclhHNGdJSE4wWVhSZmMzVnRiV0Z5ZVNoaFpYTW9aM0p2ZFhBZ1BTQm5jbTkxY0Nrc0lHWjFiaUE5SUcxbFlXNHNJR2RsYjIwZ1BTQmNJbkJ2YVc1MFhDSXNJSE5vWVhCbElEMGdNakVzSUhOcGVtVWdQU0F5TENCbWFXeHNJRDBnWENKeVpXUmNJaXdnWTI5c2IzSWdQU0JjSW1Kc1lXTnJYQ0lwSzF4dUlDQmhibTV2ZEdGMFpTaGNJblJsZUhSY0lpd2dlQ0E5SURFc0lIa2dQU0F4TURBd01EQXdMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNJbkIyTVRJNklGd2lMQ0J3ZGpFeUtTeGNiaUFnSUNBZ0lDQWdJQ0FnWTI5c2IzSWdQU0JjSW1Kc1lXTnJYQ0lzSUdocWRYTjBJRDBnTUN3Z2MybDZaU0E5SURNcFhHNGdJRnh1SUNCY2JtWnBiR1ZPWVcxbElEd3RJSEJoYzNSbE1DaGNJbk5wZW1WZlltRnljR3h2ZEY5a2FXWm1SM0p2ZFhCZlpGUkJSMTkyYzE5RVRWTlBYMkpwYm1GeWVVZHliM1Z3WENJcFhHNW9aV2xuYUhRZ1BDMGdNMXh1ZDJsa2RHZ2dQQzBnTWx4dWNHNW5LR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ3aUxuQnVaMXdpS1Nrc0lISmxjeUE5SURZd01Dd2dkVzVwZENBOUlGd2lhVzVjSWl3Z2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dWMzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNJaTV6ZG1kY0lpa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbiMgQ2hlY2tpbmcgYXZlcmFnZSBkaXN0YW5jZSBvZiBsb29wcyBwZXIgZ2VuZVxuIyB0ZW1wIGlzIGEgdGliYmxlIHdoZXJlIGRlbHRhIGxvb3AgYW5kIGxvZzJmYyBhcmUgbWVyZ2VkXG50ZW1wJGdyb3VwIDwtIGZhY3Rvcih0ZW1wJGdyb3VwKVxuXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgJWluJSBjKDEsIDIpKVxuXG5cbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDEpICkkbWVhbl9kaXN0YW5jZVxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDIpICkkbWVhbl9kaXN0YW5jZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxucHYxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIDEsIDIpLCA1KVxuXG5cblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBncm91cCwgeSA9IG1lYW5fZGlzdGFuY2UpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgK1xuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKStcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMTAwMDAwMCwgbGFiZWwgPSBwYXN0ZTAoXFxwdjEyOiBcXCwgcHYxMiksXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxzaXplX2JhcnBsb3RfZGlmZkdyb3VwX2RUQUdfdnNfRE1TT19iaW5hcnlHcm91cFxcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDJcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
# Checking average distance of loops per gene
# temp is a tibble where delta loop and log2fc are merged
temp$group <- factor(temp$group)

temp <- temp %>% dplyr::filter(group %in% c(1, 2))


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$mean_distance
  distance2 <- (data %>% dplyr::filter(group ==group2) )$mean_distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv12 <- round(getPvalWilcox(temp, 1, 2), 5)



p <- ggplot(temp, aes(x = group, y = mean_distance)) + geom_violin(aes(fill = group), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)+
  annotate(\text\, x = 1, y = 1000000, label = paste0(\pv12: \, pv12),
           color = \black\, hjust = 0, size = 3)
  
  
fileName <- paste0(\size_barplot_diffGroup_dTAG_vs_DMSO_binaryGroup\)
height <- 3
width <- 2
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QkRhR1ZqYTJsdVp5QmhkbVZ5WVdkbElHUnBjM1JoYm1ObElHOW1JR3h2YjNCeklIQmxjaUJuWlc1bFhHNGpJSFJsYlhBZ2FYTWdZU0IwYVdKaWJHVWdkMmhsY21VZ1pHVnNkR0VnYkc5dmNDQmhibVFnYkc5bk1tWmpJR0Z5WlNCdFpYSm5aV1JjYm5SbGJYQWtaM0p2ZFhBZ1BDMGdabUZqZEc5eUtIUmxiWEFrWjNKdmRYQXBYRzVjYm5SbGJYQWdQQzBnZEdWdGNDQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaG5jbTkxY0NBbGFXNGxJR01vTVN3Z01pa3BYRzVjYmx4dVoyVjBVSFpoYkZkcGJHTnZlQ0E4TFNCbWRXNWpkR2x2Ymloa1lYUmhMQ0JuY205MWNERXNJR2R5YjNWd01pbDdYRzRnSUdScGMzUmhibU5sTVNBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFdkeWIzVndNU2tnS1NSdFpXRnVYMlJwYzNSaGJtTmxYRzRnSUdScGMzUmhibU5sTWlBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFdkeWIzVndNaWtnS1NSdFpXRnVYMlJwYzNSaGJtTmxYRzRnSUhkcGJDQThMU0IzYVd4amIzZ3VkR1Z6ZENoa2FYTjBZVzVqWlRFc0lHUnBjM1JoYm1ObE1pbGNiaUFnY21WMGRYSnVLSGRwYkNSd0xuWmhiSFZsS1Z4dWZWeHVYRzV3ZGpFeUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dNU3dnTWlrc0lEVXBYRzVjYmx4dVhHNXdJRHd0SUdkbmNHeHZkQ2gwWlcxd0xDQmhaWE1vZUNBOUlHZHliM1Z3TENCNUlEMGdiV1ZoYmw5a2FYTjBZVzVqWlNrcElDc2daMlZ2YlY5MmFXOXNhVzRvWVdWektHWnBiR3dnUFNCbmNtOTFjQ2tzSUhOb2IzY3ViR1ZuWlc1a0lEMGdSa0ZNVTBVcElDdGNiaUFnWjJWdmJWOWliM2h3Ykc5MEtIZHBaSFJvSUQwZ01DNHhMQ0J2ZFhSc2FXVnlMbk5vWVhCbElEMGdUa0VwSUNzZ2RHaGxiV1ZmWTJ4aGMzTnBZeWdwSUNzZ2MyTmhiR1ZmZVY5amIyNTBhVzUxYjNWektHeGhZbVZzY3lBOUlHeGhZbVZzWDJ0aVgyMWlLU0FyWEc0Z0lITjBZWFJmYzNWdGJXRnllU2hoWlhNb1ozSnZkWEFnUFNCbmNtOTFjQ2tzSUdaMWJpQTlJRzFsWVc0c0lHZGxiMjBnUFNCY1hIQnZhVzUwWEZ3c0lITm9ZWEJsSUQwZ01qRXNJSE5wZW1VZ1BTQXlMQ0JtYVd4c0lEMGdYRnh5WldSY1hDd2dZMjlzYjNJZ1BTQmNYR0pzWVdOclhGd3BLMXh1SUNCaGJtNXZkR0YwWlNoY1hIUmxlSFJjWEN3Z2VDQTlJREVzSUhrZ1BTQXhNREF3TURBd0xDQnNZV0psYkNBOUlIQmhjM1JsTUNoY1hIQjJNVEk2SUZ4Y0xDQndkakV5S1N4Y2JpQWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNYR0pzWVdOclhGd3NJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJRE1wWEc0Z0lGeHVJQ0JjYm1acGJHVk9ZVzFsSUR3dElIQmhjM1JsTUNoY1hITnBlbVZmWW1GeWNHeHZkRjlrYVdabVIzSnZkWEJmWkZSQlIxOTJjMTlFVFZOUFgySnBibUZ5ZVVkeWIzVndYRndwWEc1b1pXbG5hSFFnUEMwZ00xeHVkMmxrZEdnZ1BDMGdNbHh1Y0c1bktHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRnhjTG5CdVoxeGNLU2tzSUhKbGN5QTlJRFl3TUN3Z2RXNXBkQ0E5SUZ4Y2FXNWNYQ3dnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1YzNabmJHbDBaU2hvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY1hDNXpkbWRjWENrcExDQWdhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dWNISnBiblFvY0NsY2JtUmxkaTV2Wm1Zb0tWeHVZR0JnWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5gYGByXG4jIENoZWNraW5nIGF2ZXJhZ2UgZGlzdGFuY2Ugb2YgbG9vcHMgcGVyIGdlbmVcbiMgdGVtcCBpcyBhIHRpYmJsZSB3aGVyZSBkZWx0YSBsb29wIGFuZCBsb2cyZmMgYXJlIG1lcmdlZFxudGVtcCRncm91cCA8LSBmYWN0b3IodGVtcCRncm91cClcblxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwICVpbiUgYygxLCAyKSlcblxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJG1lYW5fZGlzdGFuY2VcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJG1lYW5fZGlzdGFuY2VcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAxLCAyKSwgNSlcblxuXG5cbnAgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gZ3JvdXAsIHkgPSBtZWFuX2Rpc3RhbmNlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkrXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDEwMDAwMDAsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIHB2MTIpLFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcc2l6ZV9iYXJwbG90X2RpZmZHcm91cF9kVEFHX3ZzX0RNU09fYmluYXJ5R3JvdXBcXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAyXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBDaGVja2luZyBhdmVyYWdlIGRpc3RhbmNlIG9mIGxvb3BzIHBlciBnZW5lXG4jIHRlbXAgaXMgYSB0aWJibGUgd2hlcmUgZGVsdGEgbG9vcCBhbmQgbG9nMmZjIGFyZSBtZXJnZWRcbnRlbXAkZ3JvdXAgPC0gZmFjdG9yKHRlbXAkZ3JvdXApXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCAlaW4lIGMoMSwgMikpXG5cblxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMSkgKSRtZWFuX2Rpc3RhbmNlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRtZWFuX2Rpc3RhbmNlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgMSwgMiksIDUpXG5cblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGdyb3VwLCB5ID0gbWVhbl9kaXN0YW5jZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgc2NhbGVfeV9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAxMDAwMDAwLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyKSxcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXHNpemVfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPX2JpbmFyeUdyb3VwXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gMlxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
# Checking average distance of loops per gene
# temp is a tibble where delta loop and log2fc are merged
temp$group <- factor(temp$group)

temp <- temp %>% dplyr::filter(group %in% c(1, 2))


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$mean_distance
  distance2 <- (data %>% dplyr::filter(group ==group2) )$mean_distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv12 <- round(getPvalWilcox(temp, 1, 2), 5)



p <- ggplot(temp, aes(x = group, y = mean_distance)) + geom_violin(aes(fill = group), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)+
  annotate(\text\, x = 1, y = 1000000, label = paste0(\pv12: \, pv12),
           color = \black\, hjust = 0, size = 3)
  
  
fileName <- paste0(\size_barplot_diffGroup_dTAG_vs_DMSO_binaryGroup\)
height <- 3
width <- 2
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### - GO for each group


<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBDb3VudGluZyBudW1iZXIgb2YgbG9vcCBwZXIgZ2VuZXNcbnRlbXBTdW0gPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KHBlYWtJRCwgZ2VuZSwgQW5ubzIpICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JSAgc3VtbWFyaXplKFxuICAgIHBlYWsgPSBsaXN0KHBlYWtJRCksXG4gICAgYW5ubzIgPSBsaXN0KEFubm8yKSxcbiAgICBjb3VudCA9IG4oKSlcblxudGVtcFN1bSA8LSB0ZW1wU3VtICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDEsIFwiZ3JvdXAxXCIsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDIsIFwiZ3JvdXAyXCIsIE5BKSlcbikgJT4lIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSkgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgJWluJSBjKFwiZ3JvdXAxXCIsIFwiZ3JvdXAyXCIpKVxuXG4jIFxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMSkgKSRjb3VudFxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDIpICkkY291bnRcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucHYxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXCJncm91cDFcIiwgXCJncm91cDJcIiksIDUpXG4jIHB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFwiZ3JvdXAxXCIsIFwiZ3JvdXA1XCIpLCA1KVxuIyBwdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcImdyb3VwMVwiLCBcImdyb3VwOFwiKSwgNSlcbiMgcHYyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXCJncm91cDJcIiwgXCJncm91cDVcIiksIDUpXG4jIHB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFwiZ3JvdXAyXCIsIFwiZ3JvdXA4XCIpLCA1KVxuIyBwdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcImdyb3VwNVwiLCBcImdyb3VwOFwiKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wU3VtLCBhZXMoeCA9IGdyb3VwLCB5ID0gY291bnQsIGZpbGwgPSBncm91cCkpICsgXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BLCBjb2xvciA9IFwiYmxhY2tcIiwgYWxwaGEgPSAwLjYsXG4gICAgICAgICAgICAgICAgIGxpbmV3aWR0aCA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCIsIHNob3cubGVnZW5kID0gRkFMU0UpICsgdGhlbWVfY2xhc3NpYygpICsgICAgICAgXG4gIHNjYWxlX3lfY29udGludW91cyhicmVha3MgPSBzZXEoMCwgMTAsIGJ5ID0gMikpICsgXG4gIGxhYnMoeCA9IE5VTEwsIHkgPSBcIiMgb2YgUC1OIGxvb3BzIHBlciBnZW5lXCIpICtcbiAgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIDgpKSArXG4gIHN0YXRfc3VtbWFyeShcbiAgICBhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sXG4gICAgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDAuNSxcbiAgICBmaWxsID0gXCJibGFja1wiLCBjb2xvciA9IFwiYmxhY2tcIlxuICApK1xuICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcInB2MTI6IFwiLCBjb252UHZhbHVlKHB2MTIpKSxcbiAgICAgICAgICAgY29sb3IgPSBcImJsYWNrXCIsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpICtcbiAgdGhlbWUoXG4gICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiXG4gICAgKSxcbiAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIGFuZ2xlID0gNDUsICAgICAgIyBSb3RhdGUgeC1heGlzIGxhYmVscyA0NSBkZWdyZWVzXG4gICAgICBoanVzdCA9IDEsICAgICAgICMgQWRqdXN0IGhvcml6b250YWwganVzdGlmaWNhdGlvblxuICAgICAgdmp1c3QgPSAxICAgICAgICAjIEFkanVzdCB2ZXJ0aWNhbCBqdXN0aWZpY2F0aW9uXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCIsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcInNxdWFyZVwiXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcInRyYW5zcGFyZW50XCIpLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gICAgKVxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcImNvdW50X2JhcnBsb3RfZGlmZkdyb3VwX2RUQUdfdnNfRE1TT19iaW5hcnlHcm91cFwiKVxud2lkdGggPC0gcGFuZWxTaXplKDAuOCkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS41KSptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgIn0= -->\n\n```r\n# Counting number of loop per genes\ntempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(\n    peak = list(peakID),\n    anno2 = list(Anno2),\n    count = n())\n\ntempSum <- tempSum %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\, NA))\n) %>% dplyr::filter(!is.na(group)) %>% dplyr::filter(group %in% c(\\group1\\, \\group2\\))\n\n# \ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$count\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$count\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\npv12 <- round(getPvalWilcox(tempSum,\\group1\\, \\group2\\), 5)\n# pv15 <- round(getPvalWilcox(tempSum,\\group1\\, \\group5\\), 5)\n# pv18 <- round(getPvalWilcox(tempSum,\\group1\\, \\group8\\), 5)\n# pv25 <- round(getPvalWilcox(tempSum,\\group2\\, \\group5\\), 5)\n# pv28 <- round(getPvalWilcox(tempSum,\\group2\\, \\group8\\), 5)\n# pv58 <- round(getPvalWilcox(tempSum,\\group5\\, \\group8\\), 5)\n\n\np <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + \n  geom_boxplot(width = 0.5, outlier.shape = NA, color = \\black\\, alpha = 0.6,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\, show.legend = FALSE) + theme_classic() +       \n  scale_y_continuous(breaks = seq(0, 10, by = 2)) + \n  labs(x = NULL, y = \\# of P-N loops per gene\\) +\n  coord_cartesian(ylim = c(0, 8)) +\n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\\n  )+\n  annotate(\\text\\, x = 1, y = 3, label = paste0(\\pv12: \\, convPvalue(pv12)),\n           color = \\black\\, hjust = 0, size = 1) +\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\n\nfileName <- paste0(\\count_barplot_diffGroup_dTAG_vs_DMSO_binaryGroup\\)\nwidth <- panelSize(0.8)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# Counting number of loop per genes
tempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(
    peak = list(peakID),
    anno2 = list(Anno2),
    count = n())

tempSum <- tempSum %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\, NA))
) %>% dplyr::filter(!is.na(group)) %>% dplyr::filter(group %in% c(\group1\, \group2\))

# 
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$count
  distance2 <- (data %>% dplyr::filter(group ==group2) )$count
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


pv12 <- round(getPvalWilcox(tempSum,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(tempSum,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(tempSum,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(tempSum,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(tempSum,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(tempSum,\group5\, \group8\), 5)


p <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA, color = \black\, alpha = 0.6,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\, show.legend = FALSE) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  labs(x = NULL, y = \# of P-N loops per gene\) +
  coord_cartesian(ylim = c(0, 8)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  )+
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, convPvalue(pv12)),
           color = \black\, hjust = 0, size = 1) +
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )


fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_binaryGroup\)
width <- panelSize(0.8)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBDb3VudGluZyBudW1iZXIgb2YgbG9vcCBwZXIgZ2VuZXNcbnRlbXBTdW0gPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KHBlYWtJRCwgZ2VuZSwgQW5ubzIpICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JSAgc3VtbWFyaXplKFxuICAgIHBlYWsgPSBsaXN0KHBlYWtJRCksXG4gICAgYW5ubzIgPSBsaXN0KEFubm8yKSxcbiAgICBjb3VudCA9IG4oKSlcblxudGVtcFN1bSA8LSB0ZW1wU3VtICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDEsIFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDIsIFxcZ3JvdXAyXFwsIE5BKSlcbikgJT4lIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSkgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgJWluJSBjKFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpKVxuXG4jIFxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMSkgKSRjb3VudFxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDIpICkkY291bnRcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucHYxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXFxncm91cDFcXCwgXFxncm91cDJcXCksIDUpXG4jIHB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHYyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXFxncm91cDJcXCwgXFxncm91cDVcXCksIDUpXG4jIHB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxuIyBwdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wU3VtLCBhZXMoeCA9IGdyb3VwLCB5ID0gY291bnQsIGZpbGwgPSBncm91cCkpICsgXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BLCBjb2xvciA9IFxcYmxhY2tcXCwgYWxwaGEgPSAwLjYsXG4gICAgICAgICAgICAgICAgIGxpbmV3aWR0aCA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsIHNob3cubGVnZW5kID0gRkFMU0UpICsgdGhlbWVfY2xhc3NpYygpICsgICAgICAgXG4gIHNjYWxlX3lfY29udGludW91cyhicmVha3MgPSBzZXEoMCwgMTAsIGJ5ID0gMikpICsgXG4gIGxhYnMoeCA9IE5VTEwsIHkgPSBcXCMgb2YgUC1OIGxvb3BzIHBlciBnZW5lXFwpICtcbiAgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIDgpKSArXG4gIHN0YXRfc3VtbWFyeShcbiAgICBhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sXG4gICAgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDAuNSxcbiAgICBmaWxsID0gXFxibGFja1xcLCBjb2xvciA9IFxcYmxhY2tcXFxuICApK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBjb252UHZhbHVlKHB2MTIpKSxcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpICtcbiAgdGhlbWUoXG4gICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIGFuZ2xlID0gNDUsICAgICAgIyBSb3RhdGUgeC1heGlzIGxhYmVscyA0NSBkZWdyZWVzXG4gICAgICBoanVzdCA9IDEsICAgICAgICMgQWRqdXN0IGhvcml6b250YWwganVzdGlmaWNhdGlvblxuICAgICAgdmp1c3QgPSAxICAgICAgICAjIEFkanVzdCB2ZXJ0aWNhbCBqdXN0aWZpY2F0aW9uXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcXHRyYW5zcGFyZW50XFwpLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gICAgKVxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGNvdW50X2JhcnBsb3RfZGlmZkdyb3VwX2RUQUdfdnNfRE1TT19iaW5hcnlHcm91cFxcKVxud2lkdGggPC0gcGFuZWxTaXplKDAuOCkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS41KSptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n# Counting number of loop per genes\ntempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(\n    peak = list(peakID),\n    anno2 = list(Anno2),\n    count = n())\n\ntempSum <- tempSum %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\, NA))\n) %>% dplyr::filter(!is.na(group)) %>% dplyr::filter(group %in% c(\\group1\\, \\group2\\))\n\n# \ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$count\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$count\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\npv12 <- round(getPvalWilcox(tempSum,\\group1\\, \\group2\\), 5)\n# pv15 <- round(getPvalWilcox(tempSum,\\group1\\, \\group5\\), 5)\n# pv18 <- round(getPvalWilcox(tempSum,\\group1\\, \\group8\\), 5)\n# pv25 <- round(getPvalWilcox(tempSum,\\group2\\, \\group5\\), 5)\n# pv28 <- round(getPvalWilcox(tempSum,\\group2\\, \\group8\\), 5)\n# pv58 <- round(getPvalWilcox(tempSum,\\group5\\, \\group8\\), 5)\n\n\np <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + \n  geom_boxplot(width = 0.5, outlier.shape = NA, color = \\black\\, alpha = 0.6,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\, show.legend = FALSE) + theme_classic() +       \n  scale_y_continuous(breaks = seq(0, 10, by = 2)) + \n  labs(x = NULL, y = \\# of P-N loops per gene\\) +\n  coord_cartesian(ylim = c(0, 8)) +\n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\\n  )+\n  annotate(\\text\\, x = 1, y = 3, label = paste0(\\pv12: \\, convPvalue(pv12)),\n           color = \\black\\, hjust = 0, size = 1) +\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\n\nfileName <- paste0(\\count_barplot_diffGroup_dTAG_vs_DMSO_binaryGroup\\)\nwidth <- panelSize(0.8)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBDb3VudGluZyBudW1iZXIgb2YgbG9vcCBwZXIgZ2VuZXNcbnRlbXBTdW0gPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KHBlYWtJRCwgZ2VuZSwgQW5ubzIpICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JSAgc3VtbWFyaXplKFxuICAgIHBlYWsgPSBsaXN0KHBlYWtJRCksXG4gICAgYW5ubzIgPSBsaXN0KEFubm8yKSxcbiAgICBjb3VudCA9IG4oKSlcblxudGVtcFN1bSA8LSB0ZW1wU3VtICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDEsIFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDIsIFxcZ3JvdXAyXFwsIE5BKSlcbikgJT4lIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSkgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgJWluJSBjKFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpKVxuXG4jIFxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMSkgKSRjb3VudFxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDIpICkkY291bnRcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucHYxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXFxncm91cDFcXCwgXFxncm91cDJcXCksIDUpXG4jIHB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHYyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXFxncm91cDJcXCwgXFxncm91cDVcXCksIDUpXG4jIHB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxuIyBwdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wU3VtLCBhZXMoeCA9IGdyb3VwLCB5ID0gY291bnQsIGZpbGwgPSBncm91cCkpICsgXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BLCBjb2xvciA9IFxcYmxhY2tcXCwgYWxwaGEgPSAwLjYsXG4gICAgICAgICAgICAgICAgIGxpbmV3aWR0aCA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsIHNob3cubGVnZW5kID0gRkFMU0UpICsgdGhlbWVfY2xhc3NpYygpICsgICAgICAgXG4gIHNjYWxlX3lfY29udGludW91cyhicmVha3MgPSBzZXEoMCwgMTAsIGJ5ID0gMikpICsgXG4gIGxhYnMoeCA9IE5VTEwsIHkgPSBcXCMgb2YgUC1OIGxvb3BzIHBlciBnZW5lXFwpICtcbiAgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIDgpKSArXG4gIHN0YXRfc3VtbWFyeShcbiAgICBhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sXG4gICAgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDAuNSxcbiAgICBmaWxsID0gXFxibGFja1xcLCBjb2xvciA9IFxcYmxhY2tcXFxuICApK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBjb252UHZhbHVlKHB2MTIpKSxcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpICtcbiAgdGhlbWUoXG4gICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIGFuZ2xlID0gNDUsICAgICAgIyBSb3RhdGUgeC1heGlzIGxhYmVscyA0NSBkZWdyZWVzXG4gICAgICBoanVzdCA9IDEsICAgICAgICMgQWRqdXN0IGhvcml6b250YWwganVzdGlmaWNhdGlvblxuICAgICAgdmp1c3QgPSAxICAgICAgICAjIEFkanVzdCB2ZXJ0aWNhbCBqdXN0aWZpY2F0aW9uXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcXHRyYW5zcGFyZW50XFwpLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gICAgKVxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGNvdW50X2JhcnBsb3RfZGlmZkdyb3VwX2RUQUdfdnNfRE1TT19iaW5hcnlHcm91cFxcKVxud2lkdGggPC0gcGFuZWxTaXplKDAuOCkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS41KSptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
# Counting number of loop per genes
tempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(
    peak = list(peakID),
    anno2 = list(Anno2),
    count = n())

tempSum <- tempSum %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\, NA))
) %>% dplyr::filter(!is.na(group)) %>% dplyr::filter(group %in% c(\group1\, \group2\))

# 
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$count
  distance2 <- (data %>% dplyr::filter(group ==group2) )$count
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


pv12 <- round(getPvalWilcox(tempSum,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(tempSum,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(tempSum,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(tempSum,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(tempSum,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(tempSum,\group5\, \group8\), 5)


p <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA, color = \black\, alpha = 0.6,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\, show.legend = FALSE) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  labs(x = NULL, y = \# of P-N loops per gene\) +
  coord_cartesian(ylim = c(0, 8)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  )+
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, convPvalue(pv12)),
           color = \black\, hjust = 0, size = 1) +
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )


fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_binaryGroup\)
width <- panelSize(0.8)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



##### - Average loop size

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakkxeHVkR1Z0Y0RJZ1BDMGdkR1Z0Y0ZOMWJTQWxQaVVnY205M2QybHpaU2dwSUNVK0pTQnRkWFJoZEdVb2RHOTBZV3dnUFNCc1pXNW5kR2dvWVc1dWJ6SXBMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiblZ0WDNCd0lEMGdjM1Z0S0dGdWJtOHlJRDA5SUZ3aVVDMVFYQ0lwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYm5WdFgzQmxJRDBnYzNWdEtHRnVibTh5SUQwOUlGd2lVQzFGWENJcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0J6SUQwZ2MzVnRLR0Z1Ym04eUlEMDlJRndpVUMxVFhDSXBMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiblZ0WDNCNElEMGdjM1Z0S0dGdWJtOHlJRDA5SUZ3aVVDMVlYQ0lwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnY21GMGFXOWZjbVZuSUQwZ0tHNTFiVjl3Y0NBcklHNTFiVjl3WlNrdmRHOTBZV3dzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J5WVhScGIxOXpkSElnUFNCdWRXMWZjSE12ZEc5MFlXd3BYRzVjYmlOellYWmxVa1JUS0hSbGJYQXlMQ0JvWlhKbEtISmxjM1ZzZEVScGNpd2dYQ0puWlc1bFgyeHZiM0JmYkdsdWExOUJORGcxTG5Ka2Mxd2lLU2xjYmx4dVhHNXNiMjl3Vkhsd1pTQThMU0IwWlcxd01pQWxQaVVnWjNKdmRYQmZZbmtvWjNKdmRYQXBJQ1UrSlNCemRXMXRZWEpwYzJVb2JuVnRYM0J3SUQwZ2MzVnRLRzUxYlY5d2NDa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0JsSUQwZ2MzVnRLRzUxYlY5d1pTa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0J6SUQwZ2MzVnRLRzUxYlY5d2N5a3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0I0SUQwZ2MzVnRLRzUxYlY5d2VDa3BYRzVjYmx4dWJHOXZjRlI1Y0dWTWIyNW5JRHd0SUd4dmIzQlVlWEJsSUNVK0pTQndhWFp2ZEY5c2IyNW5aWElvTFdkeWIzVndMQ0J1WVcxbGMxOTBieUE5SUZ3aWRIbHdaVndpTENCMllXeDFaWE5mZEc4Z1BTQmNJbU52ZFc1MFhDSXBYRzVjYm14dmIzQlVlWEJsVEc5dVp5UjBlWEJsSUR3dElHWmhZM1J2Y2loc2IyOXdWSGx3WlV4dmJtY2tkSGx3WlN3Z2JHVjJaV3h6SUQwZ1l5aGNJbTUxYlY5d2NGd2lMQ0JjSW01MWJWOXdaVndpTENCY0ltNTFiVjl3YzF3aUxDQmNJbTUxYlY5d2VGd2lLU2xjYmx4dUl5QlFiRzkwZEdsdVoxeHVaMmR3Ykc5MEtHeHZiM0JVZVhCbFRHOXVaeXdnWVdWektHWnBiR3c5ZEhsd1pTd2dlVDFqYjNWdWRDd2dlRDFuY205MWNDa3BJQ3NnWEc0Z0lDQWdaMlZ2YlY5aVlYSW9jRzl6YVhScGIyNDlYQ0ptYVd4c1hDSXNJSE4wWVhROVhDSnBaR1Z1ZEdsMGVWd2lLU0FySUhSb1pXMWxYMk5zWVhOemFXTW9LVnh1WEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG4jIyMjIyMjXG50ZW1wMiA8LSB0ZW1wU3VtICU+JSByb3d3aXNlKCkgJT4lIG11dGF0ZSh0b3RhbCA9IGxlbmd0aChhbm5vMiksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHAgPSBzdW0oYW5ubzIgPT0gXFxQLVBcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcGUgPSBzdW0oYW5ubzIgPT0gXFxQLUVcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHMgPSBzdW0oYW5ubzIgPT0gXFxQLVNcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHggPSBzdW0oYW5ubzIgPT0gXFxQLVhcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICByYXRpb19yZWcgPSAobnVtX3BwICsgbnVtX3BlKS90b3RhbCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHJhdGlvX3N0ciA9IG51bV9wcy90b3RhbClcblxuI3NhdmVSRFModGVtcDIsIGhlcmUocmVzdWx0RGlyLCBcXGdlbmVfbG9vcF9saW5rX0E0ODUucmRzXFwpKVxuXG5cbmxvb3BUeXBlIDwtIHRlbXAyICU+JSBncm91cF9ieShncm91cCkgJT4lIHN1bW1hcmlzZShudW1fcHAgPSBzdW0obnVtX3BwKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcGUgPSBzdW0obnVtX3BlKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHMgPSBzdW0obnVtX3BzKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHggPSBzdW0obnVtX3B4KSlcblxuXG5sb29wVHlwZUxvbmcgPC0gbG9vcFR5cGUgJT4lIHBpdm90X2xvbmdlcigtZ3JvdXAsIG5hbWVzX3RvID0gXFx0eXBlXFwsIHZhbHVlc190byA9IFxcY291bnRcXClcblxubG9vcFR5cGVMb25nJHR5cGUgPC0gZmFjdG9yKGxvb3BUeXBlTG9uZyR0eXBlLCBsZXZlbHMgPSBjKFxcbnVtX3BwXFwsIFxcbnVtX3BlXFwsIFxcbnVtX3BzXFwsIFxcbnVtX3B4XFwpKVxuXG4jIFBsb3R0aW5nXG5nZ3Bsb3QobG9vcFR5cGVMb25nLCBhZXMoZmlsbD10eXBlLCB5PWNvdW50LCB4PWdyb3VwKSkgKyBcbiAgICBnZW9tX2Jhcihwb3NpdGlvbj1cXGZpbGxcXCwgc3RhdD1cXGlkZW50aXR5XFwpICsgdGhlbWVfY2xhc3NpYygpXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
#######
temp2 <- tempSum %>% rowwise() %>% mutate(total = length(anno2),
                                 num_pp = sum(anno2 == \P-P\),
                                 num_pe = sum(anno2 == \P-E\),
                                 num_ps = sum(anno2 == \P-S\),
                                 num_px = sum(anno2 == \P-X\),
                                 ratio_reg = (num_pp + num_pe)/total,
                                 ratio_str = num_ps/total)

#saveRDS(temp2, here(resultDir, \gene_loop_link_A485.rds\))


loopType <- temp2 %>% group_by(group) %>% summarise(num_pp = sum(num_pp),
                                        num_pe = sum(num_pe),
                                        num_ps = sum(num_ps),
                                        num_px = sum(num_px))


loopTypeLong <- loopType %>% pivot_longer(-group, names_to = \type\, values_to = \count\)

loopTypeLong$type <- factor(loopTypeLong$type, levels = c(\num_pp\, \num_pe\, \num_ps\, \num_px\))

# Plotting
ggplot(loopTypeLong, aes(fill=type, y=count, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSTF4dWRHVnRjRElnUEMwZ2RHVnRjRk4xYlNBbFBpVWdjbTkzZDJselpTZ3BJQ1UrSlNCdGRYUmhkR1VvZEc5MFlXd2dQU0JzWlc1bmRHZ29ZVzV1YnpJcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0J3SUQwZ2MzVnRLR0Z1Ym04eUlEMDlJRnhjVUMxUVhGd3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiblZ0WDNCbElEMGdjM1Z0S0dGdWJtOHlJRDA5SUZ4Y1VDMUZYRndwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYm5WdFgzQnpJRDBnYzNWdEtHRnVibTh5SUQwOUlGeGNVQzFUWEZ3cExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0I0SUQwZ2MzVnRLR0Z1Ym04eUlEMDlJRnhjVUMxWVhGd3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdjbUYwYVc5ZmNtVm5JRDBnS0c1MWJWOXdjQ0FySUc1MWJWOXdaU2t2ZEc5MFlXd3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnlZWFJwYjE5emRISWdQU0J1ZFcxZmNITXZkRzkwWVd3cFhHNWNiaU56WVhabFVrUlRLSFJsYlhBeUxDQm9aWEpsS0hKbGMzVnNkRVJwY2l3Z1hGeG5aVzVsWDJ4dmIzQmZiR2x1YTE5Qk5EZzFMbkprYzF4Y0tTbGNibHh1WEc1c2IyOXdWSGx3WlNBOExTQjBaVzF3TWlBbFBpVWdaM0p2ZFhCZllua29aM0p2ZFhBcElDVStKU0J6ZFcxdFlYSnBjMlVvYm5WdFgzQndJRDBnYzNWdEtHNTFiVjl3Y0Nrc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYm5WdFgzQmxJRDBnYzNWdEtHNTFiVjl3WlNrc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYm5WdFgzQnpJRDBnYzNWdEtHNTFiVjl3Y3lrc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYm5WdFgzQjRJRDBnYzNWdEtHNTFiVjl3ZUNrcFhHNWNibHh1Ykc5dmNGUjVjR1ZNYjI1bklEd3RJR3h2YjNCVWVYQmxJQ1UrSlNCd2FYWnZkRjlzYjI1blpYSW9MV2R5YjNWd0xDQnVZVzFsYzE5MGJ5QTlJRnhjZEhsd1pWeGNMQ0IyWVd4MVpYTmZkRzhnUFNCY1hHTnZkVzUwWEZ3cFhHNWNibXh2YjNCVWVYQmxURzl1WnlSMGVYQmxJRHd0SUdaaFkzUnZjaWhzYjI5d1ZIbHdaVXh2Ym1ja2RIbHdaU3dnYkdWMlpXeHpJRDBnWXloY1hHNTFiVjl3Y0Z4Y0xDQmNYRzUxYlY5d1pWeGNMQ0JjWEc1MWJWOXdjMXhjTENCY1hHNTFiVjl3ZUZ4Y0tTbGNibHh1SXlCUWJHOTBkR2x1WjF4dVoyZHdiRzkwS0d4dmIzQlVlWEJsVEc5dVp5d2dZV1Z6S0dacGJHdzlkSGx3WlN3Z2VUMWpiM1Z1ZEN3Z2VEMW5jbTkxY0NrcElDc2dYRzRnSUNBZ1oyVnZiVjlpWVhJb2NHOXphWFJwYjI0OVhGeG1hV3hzWEZ3c0lITjBZWFE5WEZ4cFpHVnVkR2wwZVZ4Y0tTQXJJSFJvWlcxbFgyTnNZWE56YVdNb0tWeHVYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG4jIyMjIyMjXG50ZW1wMiA8LSB0ZW1wU3VtICU+JSByb3d3aXNlKCkgJT4lIG11dGF0ZSh0b3RhbCA9IGxlbmd0aChhbm5vMiksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHAgPSBzdW0oYW5ubzIgPT0gXFxQLVBcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcGUgPSBzdW0oYW5ubzIgPT0gXFxQLUVcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHMgPSBzdW0oYW5ubzIgPT0gXFxQLVNcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHggPSBzdW0oYW5ubzIgPT0gXFxQLVhcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICByYXRpb19yZWcgPSAobnVtX3BwICsgbnVtX3BlKS90b3RhbCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHJhdGlvX3N0ciA9IG51bV9wcy90b3RhbClcblxuI3NhdmVSRFModGVtcDIsIGhlcmUocmVzdWx0RGlyLCBcXGdlbmVfbG9vcF9saW5rX0E0ODUucmRzXFwpKVxuXG5cbmxvb3BUeXBlIDwtIHRlbXAyICU+JSBncm91cF9ieShncm91cCkgJT4lIHN1bW1hcmlzZShudW1fcHAgPSBzdW0obnVtX3BwKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcGUgPSBzdW0obnVtX3BlKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHMgPSBzdW0obnVtX3BzKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHggPSBzdW0obnVtX3B4KSlcblxuXG5sb29wVHlwZUxvbmcgPC0gbG9vcFR5cGUgJT4lIHBpdm90X2xvbmdlcigtZ3JvdXAsIG5hbWVzX3RvID0gXFx0eXBlXFwsIHZhbHVlc190byA9IFxcY291bnRcXClcblxubG9vcFR5cGVMb25nJHR5cGUgPC0gZmFjdG9yKGxvb3BUeXBlTG9uZyR0eXBlLCBsZXZlbHMgPSBjKFxcbnVtX3BwXFwsIFxcbnVtX3BlXFwsIFxcbnVtX3BzXFwsIFxcbnVtX3B4XFwpKVxuXG4jIFBsb3R0aW5nXG5nZ3Bsb3QobG9vcFR5cGVMb25nLCBhZXMoZmlsbD10eXBlLCB5PWNvdW50LCB4PWdyb3VwKSkgKyBcbiAgICBnZW9tX2Jhcihwb3NpdGlvbj1cXGZpbGxcXCwgc3RhdD1cXGlkZW50aXR5XFwpICsgdGhlbWVfY2xhc3NpYygpXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjI1xudGVtcDIgPC0gdGVtcFN1bSAlPiUgcm93d2lzZSgpICU+JSBtdXRhdGUodG90YWwgPSBsZW5ndGgoYW5ubzIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BwID0gc3VtKGFubm8yID09IFxcUC1QXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BlID0gc3VtKGFubm8yID09IFxcUC1FXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BzID0gc3VtKGFubm8yID09IFxcUC1TXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3B4ID0gc3VtKGFubm8yID09IFxcUC1YXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcmF0aW9fcmVnID0gKG51bV9wcCArIG51bV9wZSkvdG90YWwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICByYXRpb19zdHIgPSBudW1fcHMvdG90YWwpXG5cbiNzYXZlUkRTKHRlbXAyLCBoZXJlKHJlc3VsdERpciwgXFxnZW5lX2xvb3BfbGlua19BNDg1LnJkc1xcKSlcblxuXG5sb29wVHlwZSA8LSB0ZW1wMiAlPiUgZ3JvdXBfYnkoZ3JvdXApICU+JSBzdW1tYXJpc2UobnVtX3BwID0gc3VtKG51bV9wcCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BlID0gc3VtKG51bV9wZSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BzID0gc3VtKG51bV9wcyksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3B4ID0gc3VtKG51bV9weCkpXG5cblxubG9vcFR5cGVMb25nIDwtIGxvb3BUeXBlICU+JSBwaXZvdF9sb25nZXIoLWdyb3VwLCBuYW1lc190byA9IFxcdHlwZVxcLCB2YWx1ZXNfdG8gPSBcXGNvdW50XFwpXG5cbmxvb3BUeXBlTG9uZyR0eXBlIDwtIGZhY3Rvcihsb29wVHlwZUxvbmckdHlwZSwgbGV2ZWxzID0gYyhcXG51bV9wcFxcLCBcXG51bV9wZVxcLCBcXG51bV9wc1xcLCBcXG51bV9weFxcKSlcblxuIyBQbG90dGluZ1xuZ2dwbG90KGxvb3BUeXBlTG9uZywgYWVzKGZpbGw9dHlwZSwgeT1jb3VudCwgeD1ncm91cCkpICsgXG4gICAgZ2VvbV9iYXIocG9zaXRpb249XFxmaWxsXFwsIHN0YXQ9XFxpZGVudGl0eVxcKSArIHRoZW1lX2NsYXNzaWMoKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
#######
temp2 <- tempSum %>% rowwise() %>% mutate(total = length(anno2),
                                 num_pp = sum(anno2 == \P-P\),
                                 num_pe = sum(anno2 == \P-E\),
                                 num_ps = sum(anno2 == \P-S\),
                                 num_px = sum(anno2 == \P-X\),
                                 ratio_reg = (num_pp + num_pe)/total,
                                 ratio_str = num_ps/total)

#saveRDS(temp2, here(resultDir, \gene_loop_link_A485.rds\))


loopType <- temp2 %>% group_by(group) %>% summarise(num_pp = sum(num_pp),
                                        num_pe = sum(num_pe),
                                        num_ps = sum(num_ps),
                                        num_px = sum(num_px))


loopTypeLong <- loopType %>% pivot_longer(-group, names_to = \type\, values_to = \count\)

loopTypeLong$type <- factor(loopTypeLong$type, levels = c(\num_pp\, \num_pe\, \num_ps\, \num_px\))

# Plotting
ggplot(loopTypeLong, aes(fill=type, y=count, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-N

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakl5TmNiaU5RTFZCY2JtUmhkR0VnUEMwZ2RHVnRjRElnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWjNKdmRYQXNJRzUxYlY5d2NDbGNibU52Ykc1aGJXVnpLR1JoZEdFcElEd3RJR01vWENKbmNtOTFjRndpTENCY0ltTnZkVzUwWENJcFhHNXdkakV5SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29aR0YwWVN4Y0ltZHliM1Z3TVZ3aUxDQmNJbWR5YjNWd01sd2lLU3dnTlNsY2JpTWdjSFl4TlNBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLR1JoZEdFc1hDSm5jbTkxY0RGY0lpd2dYQ0puY205MWNEVmNJaWtzSURVcFhHNGpJSEIyTVRnZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGd2laM0p2ZFhBeFhDSXNJRndpWjNKdmRYQTRYQ0lwTENBMUtWeHVJeUJ3ZGpJMUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvWkdGMFlTeGNJbWR5YjNWd01sd2lMQ0JjSW1keWIzVndOVndpS1N3Z05TbGNiaU1nY0hZeU9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYQ0puY205MWNESmNJaXdnWENKbmNtOTFjRGhjSWlrc0lEVXBYRzRqSUhCMk5UZ2dQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoa1lYUmhMRndpWjNKdmRYQTFYQ0lzSUZ3aVozSnZkWEE0WENJcExDQTFLVnh1WEc1Y2JuQWdQQzBnWjJkd2JHOTBLR1JoZEdFc0lHRmxjeWg0SUQwZ1ozSnZkWEFzSUhrZ1BTQmpiM1Z1ZEN3Z1ptbHNiQ0E5SUdkeWIzVndLU2tnS3lCY2JpQWdaMlZ2YlY5aWIzaHdiRzkwS0hkcFpIUm9JRDBnTUM0MUxDQnZkWFJzYVdWeUxuTm9ZWEJsSUQwZ1RrRXNJR052Ykc5eUlEMGdYQ0ppYkdGamExd2lMQ0JoYkhCb1lTQTlJREF1Tml4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JHbHVaWGRwWkhSb0lEMGdiR2x1WlZSb2FXTnJJQ29nYlcxVWIweHBibVZWYm1sMExDQnNhVzVsWlc1a0lEMGdYQ0p6Y1hWaGNtVmNJaXdnYzJodmR5NXNaV2RsYm1RZ1BTQkdRVXhUUlNrZ0t5QjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0t5QWdJQ0FnSUNCY2JpQWdjMk5oYkdWZmVWOWpiMjUwYVc1MWIzVnpLR0p5WldGcmN5QTlJSE5sY1Nnd0xDQXhNQ3dnWW5rZ1BTQXlLU2tnS3lCY2JpQWdiR0ZpY3loNElEMGdUbFZNVEN3Z2VTQTlJRndpSXlCdlppQlFMVkFnYkc5dmNITWdjR1Z5SUdkbGJtVmNJaWtnSzF4dUlDQmpiMjl5WkY5allYSjBaWE5wWVc0b2VXeHBiU0E5SUdNb01Dd2dOQ2twSUN0Y2JpQWdjM1JoZEY5emRXMXRZWEo1S0Z4dUlDQWdJR0ZsY3lobmNtOTFjQ0E5SUdkeWIzVndLU3dnWm5WdUlEMGdiV1ZoYml4Y2JpQWdJQ0JuWlc5dElEMGdYQ0p3YjJsdWRGd2lMQ0J6YUdGd1pTQTlJREl4TENCemFYcGxJRDBnTUM0MUxGeHVJQ0FnSUdacGJHd2dQU0JjSW1Kc1lXTnJYQ0lzSUdOdmJHOXlJRDBnWENKaWJHRmphMXdpWEc0Z0lDa3JYRzRnSUdGdWJtOTBZWFJsS0Z3aWRHVjRkRndpTENCNElEMGdNU3dnZVNBOUlETXNJR3hoWW1Wc0lEMGdjR0Z6ZEdVd0tGd2ljSFl4TWpvZ1hDSXNJR052Ym5aUWRtRnNkV1VvY0hZeE1pa3BMRnh1SUNBZ0lDQWdJQ0FnSUNCamIyeHZjaUE5SUZ3aVlteGhZMnRjSWl3Z2FHcDFjM1FnUFNBd0xDQnphWHBsSUQwZ01Ta2dLMXh1SUNCMGFHVnRaU2hjYmlBZ0lDQWdJR0Y0YVhNdWRHbDBiR1VnUFNCbGJHVnRaVzUwWDNSbGVIUW9YRzRnSUNBZ0lDQWdJSE5wZW1VZ1BTQm1iMjUwVTJsNlpVMHNYRzRnSUNBZ0lDQm1ZVzFwYkhrZ1BTQm1iMjUwVkhsd1pTeGNiaUFnSUNBZ0lHTnZiRzl5SUQwZ1hDSWpNREF3TURBd1hDSmNiaUFnSUNBcExGeHVJQ0FnSUdGNGFYTXVkR1Y0ZENBOUlHVnNaVzFsYm5SZmRHVjRkQ2hjYmlBZ0lDQWdJSE5wZW1VZ1BTQm1iMjUwVTJsNlpVMHNYRzRnSUNBZ0lDQm1ZVzFwYkhrZ1BTQm1iMjUwVkhsd1pTeGNiaUFnSUNBZ0lHTnZiRzl5SUQwZ1hDSWpNREF3TURBd1hDSmNiaUFnSUNBcExGeHVJQ0FnSUdGNGFYTXVkR1Y0ZEM1NElEMGdaV3hsYldWdWRGOTBaWGgwS0Z4dUlDQWdJQ0FnWVc1bmJHVWdQU0EwTlN3Z0lDQWdJQ0FqSUZKdmRHRjBaU0I0TFdGNGFYTWdiR0ZpWld4eklEUTFJR1JsWjNKbFpYTmNiaUFnSUNBZ0lHaHFkWE4wSUQwZ01Td2dJQ0FnSUNBZ0l5QkJaR3AxYzNRZ2FHOXlhWHB2Ym5SaGJDQnFkWE4wYVdacFkyRjBhVzl1WEc0Z0lDQWdJQ0IyYW5WemRDQTlJREVnSUNBZ0lDQWdJQ01nUVdScWRYTjBJSFpsY25ScFkyRnNJR3AxYzNScFptbGpZWFJwYjI1Y2JpQWdJQ0FwTEZ4dUlDQWdJR0Y0YVhNdWJHbHVaU0E5SUdWc1pXMWxiblJmYkdsdVpTaGNiaUFnSUNBZ0lHTnZiRzl5SUQwZ1hDSWpNREF3TURBd1hDSXNYRzRnSUNBZ0lDQnphWHBsSUQwZ2JHbHVaVlJvYVdOckttMXRWRzlNYVc1bFZXNXBkQ3hjYmlBZ0lDQWdJR3hwYm1WbGJtUWdQU0JjSW5OeGRXRnlaVndpWEc0Z0lDQWdLU3hjYmlBZ0lDQmhlR2x6TG5ScFkydHpJRDBnWld4bGJXVnVkRjlzYVc1bEtGeHVJQ0FnSUNBZ1kyOXNiM0lnUFNCY0lpTXdNREF3TURCY0lpeGNiaUFnSUNBZ0lITnBlbVVnUFNCc2FXNWxWR2hwWTJzcWJXMVViMHhwYm1WVmJtbDBMRnh1SUNBZ0lDQWdiR2x1WldWdVpDQTlJRndpYzNGMVlYSmxYQ0pjYmlBZ0lDQXBMRnh1SUNBZ0lIQmhibVZzTG1KaFkydG5jbTkxYm1RZ1BTQmxiR1Z0Wlc1MFgzSmxZM1FvWm1sc2JDQTlJRndpZEhKaGJuTndZWEpsYm5SY0lpa3NYRzRnSUNBZ2JHVm5aVzVrTG5SbGVIUWdQU0JsYkdWdFpXNTBYM1JsZUhRb1ptRnRhV3g1SUQwZ1ptOXVkRlI1Y0dVc0lITnBlbVVnUFNCbWIyNTBVMmw2WlZNcExGeHVJQ0FnSUd4bFoyVnVaQzUwYVhSc1pTQTlJR1ZzWlcxbGJuUmZkR1Y0ZENobVlXMXBiSGtnUFNCbWIyNTBWSGx3WlN3Z2MybDZaU0E5SUdadmJuUlRhWHBsVXlsY2JpQWdJQ0FwWEc1Y2JtWnBiR1ZPWVcxbElEd3RJSEJoYzNSbE1DaGNJbU52ZFc1MFgySmhjbkJzYjNSZlpHbG1aa2R5YjNWd1gyUlVRVWRmZG5OZlJFMVRUMTl3Y0Y5aWFXNWhjbmxIY205MWNGd2lLVnh1ZDJsa2RHZ2dQQzBnY0dGdVpXeFRhWHBsS0RBdU9Da3FiVzFVYjBsdVkyaGNibWhsYVdkb2RDQThMU0J3WVc1bGJGTnBlbVVvTVM0MUtTcHRiVlJ2U1c1amFGeHVjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGd2lMbkJ1WjF3aUtTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRndpYVc1Y0lpd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dWNISnBiblFvY0NsY2JtUmxkaTV2Wm1Zb0tWeHVjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjSWk1emRtZGNJaWtwTENBZ2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG4jIyMjIyMjI1xuI1AtUFxuZGF0YSA8LSB0ZW1wMiAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgbnVtX3BwKVxuY29sbmFtZXMoZGF0YSkgPC0gYyhcXGdyb3VwXFwsIFxcY291bnRcXClcbnB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuIyBwdjE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiMgcHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4jIHB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IGNvdW50LCBmaWxsID0gZ3JvdXApKSArIFxuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSwgY29sb3IgPSBcXGJsYWNrXFwsIGFscGhhID0gMC42LFxuICAgICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcXHNxdWFyZVxcLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIHRoZW1lX2NsYXNzaWMoKSArICAgICAgIFxuICBzY2FsZV95X2NvbnRpbnVvdXMoYnJlYWtzID0gc2VxKDAsIDEwLCBieSA9IDIpKSArIFxuICBsYWJzKHggPSBOVUxMLCB5ID0gXFwjIG9mIFAtUCBsb29wcyBwZXIgZ2VuZVxcKSArXG4gIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygwLCA0KSkgK1xuICBzdGF0X3N1bW1hcnkoXG4gICAgYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLFxuICAgIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAwLjUsXG4gICAgZmlsbCA9IFxcYmxhY2tcXCwgY29sb3IgPSBcXGJsYWNrXFxcbiAgKStcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMywgbGFiZWwgPSBwYXN0ZTAoXFxwdjEyOiBcXCwgY29udlB2YWx1ZShwdjEyKSksXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAxKSArXG4gIHRoZW1lKFxuICAgICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgICAgc2l6ZSA9IGZvbnRTaXplTSxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplTSxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCAgICAgICMgUm90YXRlIHgtYXhpcyBsYWJlbHMgNDUgZGVncmVlc1xuICAgICAgaGp1c3QgPSAxLCAgICAgICAjIEFkanVzdCBob3Jpem9udGFsIGp1c3RpZmljYXRpb25cbiAgICAgIHZqdXN0ID0gMSAgICAgICAgIyBBZGp1c3QgdmVydGljYWwganVzdGlmaWNhdGlvblxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICAgIClcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPX3BwX2JpbmFyeUdyb3VwXFwpXG53aWR0aCA8LSBwYW5lbFNpemUoMC44KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjUpKm1tVG9JbmNoXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
########
#P-P
data <- temp2 %>% dplyr::select(group, num_pp)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)


p <- ggplot(data, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA, color = \black\, alpha = 0.6,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\, show.legend = FALSE) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  labs(x = NULL, y = \# of P-P loops per gene\) +
  coord_cartesian(ylim = c(0, 4)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  )+
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, convPvalue(pv12)),
           color = \black\, hjust = 0, size = 1) +
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )

fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_pp_binaryGroup\)
width <- panelSize(0.8)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSXlOY2JpTlFMVkJjYm1SaGRHRWdQQzBnZEdWdGNESWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aM0p2ZFhBc0lHNTFiVjl3Y0NsY2JtTnZiRzVoYldWektHUmhkR0VwSUR3dElHTW9YRnhuY205MWNGeGNMQ0JjWEdOdmRXNTBYRndwWEc1d2RqRXlJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjWEdkeWIzVndNVnhjTENCY1hHZHliM1Z3TWx4Y0tTd2dOU2xjYmlNZ2NIWXhOU0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtHUmhkR0VzWEZ4bmNtOTFjREZjWEN3Z1hGeG5jbTkxY0RWY1hDa3NJRFVwWEc0aklIQjJNVGdnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaGtZWFJoTEZ4Y1ozSnZkWEF4WEZ3c0lGeGNaM0p2ZFhBNFhGd3BMQ0ExS1Z4dUl5QndkakkxSUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29aR0YwWVN4Y1hHZHliM1Z3TWx4Y0xDQmNYR2R5YjNWd05WeGNLU3dnTlNsY2JpTWdjSFl5T0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLR1JoZEdFc1hGeG5jbTkxY0RKY1hDd2dYRnhuY205MWNEaGNYQ2tzSURVcFhHNGpJSEIyTlRnZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGeGNaM0p2ZFhBMVhGd3NJRnhjWjNKdmRYQTRYRndwTENBMUtWeHVYRzVjYm5BZ1BDMGdaMmR3Ykc5MEtHUmhkR0VzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCamIzVnVkQ3dnWm1sc2JDQTlJR2R5YjNWd0tTa2dLeUJjYmlBZ1oyVnZiVjlpYjNod2JHOTBLSGRwWkhSb0lEMGdNQzQxTENCdmRYUnNhV1Z5TG5Ob1lYQmxJRDBnVGtFc0lHTnZiRzl5SUQwZ1hGeGliR0ZqYTF4Y0xDQmhiSEJvWVNBOUlEQXVOaXhjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYkdsdVpYZHBaSFJvSUQwZ2JHbHVaVlJvYVdOcklDb2diVzFVYjB4cGJtVlZibWwwTENCc2FXNWxaVzVrSUQwZ1hGeHpjWFZoY21WY1hDd2djMmh2ZHk1c1pXZGxibVFnUFNCR1FVeFRSU2tnS3lCMGFHVnRaVjlqYkdGemMybGpLQ2tnS3lBZ0lDQWdJQ0JjYmlBZ2MyTmhiR1ZmZVY5amIyNTBhVzUxYjNWektHSnlaV0ZyY3lBOUlITmxjU2d3TENBeE1Dd2dZbmtnUFNBeUtTa2dLeUJjYmlBZ2JHRmljeWg0SUQwZ1RsVk1UQ3dnZVNBOUlGeGNJeUJ2WmlCUUxWQWdiRzl2Y0hNZ2NHVnlJR2RsYm1WY1hDa2dLMXh1SUNCamIyOXlaRjlqWVhKMFpYTnBZVzRvZVd4cGJTQTlJR01vTUN3Z05Da3BJQ3RjYmlBZ2MzUmhkRjl6ZFcxdFlYSjVLRnh1SUNBZ0lHRmxjeWhuY205MWNDQTlJR2R5YjNWd0tTd2dablZ1SUQwZ2JXVmhiaXhjYmlBZ0lDQm5aVzl0SUQwZ1hGeHdiMmx1ZEZ4Y0xDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNQzQxTEZ4dUlDQWdJR1pwYkd3Z1BTQmNYR0pzWVdOclhGd3NJR052Ykc5eUlEMGdYRnhpYkdGamExeGNYRzRnSUNrclhHNGdJR0Z1Ym05MFlYUmxLRnhjZEdWNGRGeGNMQ0I0SUQwZ01Td2dlU0E5SURNc0lHeGhZbVZzSUQwZ2NHRnpkR1V3S0Z4Y2NIWXhNam9nWEZ3c0lHTnZiblpRZG1Gc2RXVW9jSFl4TWlrcExGeHVJQ0FnSUNBZ0lDQWdJQ0JqYjJ4dmNpQTlJRnhjWW14aFkydGNYQ3dnYUdwMWMzUWdQU0F3TENCemFYcGxJRDBnTVNrZ0sxeHVJQ0IwYUdWdFpTaGNiaUFnSUNBZ0lHRjRhWE11ZEdsMGJHVWdQU0JsYkdWdFpXNTBYM1JsZUhRb1hHNGdJQ0FnSUNBZ0lITnBlbVVnUFNCbWIyNTBVMmw2WlUwc1hHNGdJQ0FnSUNCbVlXMXBiSGtnUFNCbWIyNTBWSGx3WlN4Y2JpQWdJQ0FnSUdOdmJHOXlJRDBnWEZ3ak1EQXdNREF3WEZ4Y2JpQWdJQ0FwTEZ4dUlDQWdJR0Y0YVhNdWRHVjRkQ0E5SUdWc1pXMWxiblJmZEdWNGRDaGNiaUFnSUNBZ0lITnBlbVVnUFNCbWIyNTBVMmw2WlUwc1hHNGdJQ0FnSUNCbVlXMXBiSGtnUFNCbWIyNTBWSGx3WlN4Y2JpQWdJQ0FnSUdOdmJHOXlJRDBnWEZ3ak1EQXdNREF3WEZ4Y2JpQWdJQ0FwTEZ4dUlDQWdJR0Y0YVhNdWRHVjRkQzU0SUQwZ1pXeGxiV1Z1ZEY5MFpYaDBLRnh1SUNBZ0lDQWdZVzVuYkdVZ1BTQTBOU3dnSUNBZ0lDQWpJRkp2ZEdGMFpTQjRMV0Y0YVhNZ2JHRmlaV3h6SURRMUlHUmxaM0psWlhOY2JpQWdJQ0FnSUdocWRYTjBJRDBnTVN3Z0lDQWdJQ0FnSXlCQlpHcDFjM1FnYUc5eWFYcHZiblJoYkNCcWRYTjBhV1pwWTJGMGFXOXVYRzRnSUNBZ0lDQjJhblZ6ZENBOUlERWdJQ0FnSUNBZ0lDTWdRV1JxZFhOMElIWmxjblJwWTJGc0lHcDFjM1JwWm1sallYUnBiMjVjYmlBZ0lDQXBMRnh1SUNBZ0lHRjRhWE11YkdsdVpTQTlJR1ZzWlcxbGJuUmZiR2x1WlNoY2JpQWdJQ0FnSUdOdmJHOXlJRDBnWEZ3ak1EQXdNREF3WEZ3c1hHNGdJQ0FnSUNCemFYcGxJRDBnYkdsdVpWUm9hV05yS20xdFZHOU1hVzVsVlc1cGRDeGNiaUFnSUNBZ0lHeHBibVZsYm1RZ1BTQmNYSE54ZFdGeVpWeGNYRzRnSUNBZ0tTeGNiaUFnSUNCaGVHbHpMblJwWTJ0eklEMGdaV3hsYldWdWRGOXNhVzVsS0Z4dUlDQWdJQ0FnWTI5c2IzSWdQU0JjWENNd01EQXdNREJjWEN4Y2JpQWdJQ0FnSUhOcGVtVWdQU0JzYVc1bFZHaHBZMnNxYlcxVWIweHBibVZWYm1sMExGeHVJQ0FnSUNBZ2JHbHVaV1Z1WkNBOUlGeGNjM0YxWVhKbFhGeGNiaUFnSUNBcExGeHVJQ0FnSUhCaGJtVnNMbUpoWTJ0bmNtOTFibVFnUFNCbGJHVnRaVzUwWDNKbFkzUW9abWxzYkNBOUlGeGNkSEpoYm5Od1lYSmxiblJjWENrc1hHNGdJQ0FnYkdWblpXNWtMblJsZUhRZ1BTQmxiR1Z0Wlc1MFgzUmxlSFFvWm1GdGFXeDVJRDBnWm05dWRGUjVjR1VzSUhOcGVtVWdQU0JtYjI1MFUybDZaVk1wTEZ4dUlDQWdJR3hsWjJWdVpDNTBhWFJzWlNBOUlHVnNaVzFsYm5SZmRHVjRkQ2htWVcxcGJIa2dQU0JtYjI1MFZIbHdaU3dnYzJsNlpTQTlJR1p2Ym5SVGFYcGxVeWxjYmlBZ0lDQXBYRzVjYm1acGJHVk9ZVzFsSUR3dElIQmhjM1JsTUNoY1hHTnZkVzUwWDJKaGNuQnNiM1JmWkdsbVprZHliM1Z3WDJSVVFVZGZkbk5mUkUxVFQxOXdjRjlpYVc1aGNubEhjbTkxY0Z4Y0tWeHVkMmxrZEdnZ1BDMGdjR0Z1Wld4VGFYcGxLREF1T0NrcWJXMVViMGx1WTJoY2JtaGxhV2RvZENBOExTQndZVzVsYkZOcGVtVW9NUzQxS1NwdGJWUnZTVzVqYUZ4dWNHNW5LR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ4Y0xuQnVaMXhjS1Nrc0lISmxjeUE5SURZd01Dd2dkVzVwZENBOUlGeGNhVzVjWEN3Z2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dWMzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNYQzV6ZG1kY1hDa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1WUdCZ1hHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLVBcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wcClcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiMgcHYxNSA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4jIHB2MTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuIyBwdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiMgcHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4jIHB2NTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgKyBcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC41LCBvdXRsaWVyLnNoYXBlID0gTkEsIGNvbG9yID0gXFxibGFja1xcLCBhbHBoYSA9IDAuNixcbiAgICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCAxMCwgYnkgPSAyKSkgKyBcbiAgbGFicyh4ID0gTlVMTCwgeSA9IFxcIyBvZiBQLVAgbG9vcHMgcGVyIGdlbmVcXCkgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgNCkpICtcbiAgc3RhdF9zdW1tYXJ5KFxuICAgIGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkrXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIGNvbnZQdmFsdWUocHYxMikpLFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSkgK1xuICB0aGVtZShcbiAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgYW5nbGUgPSA0NSwgICAgICAjIFJvdGF0ZSB4LWF4aXMgbGFiZWxzIDQ1IGRlZ3JlZXNcbiAgICAgIGhqdXN0ID0gMSwgICAgICAgIyBBZGp1c3QgaG9yaXpvbnRhbCBqdXN0aWZpY2F0aW9uXG4gICAgICB2anVzdCA9IDEgICAgICAgICMgQWRqdXN0IHZlcnRpY2FsIGp1c3RpZmljYXRpb25cbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgICApXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGNvdW50X2JhcnBsb3RfZGlmZkdyb3VwX2RUQUdfdnNfRE1TT19wcF9iaW5hcnlHcm91cFxcKVxud2lkdGggPC0gcGFuZWxTaXplKDAuOCkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS41KSptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLVBcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wcClcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiMgcHYxNSA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4jIHB2MTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuIyBwdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiMgcHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4jIHB2NTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgKyBcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC41LCBvdXRsaWVyLnNoYXBlID0gTkEsIGNvbG9yID0gXFxibGFja1xcLCBhbHBoYSA9IDAuNixcbiAgICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCAxMCwgYnkgPSAyKSkgKyBcbiAgbGFicyh4ID0gTlVMTCwgeSA9IFxcIyBvZiBQLVAgbG9vcHMgcGVyIGdlbmVcXCkgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgNCkpICtcbiAgc3RhdF9zdW1tYXJ5KFxuICAgIGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkrXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIGNvbnZQdmFsdWUocHYxMikpLFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSkgK1xuICB0aGVtZShcbiAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgYW5nbGUgPSA0NSwgICAgICAjIFJvdGF0ZSB4LWF4aXMgbGFiZWxzIDQ1IGRlZ3JlZXNcbiAgICAgIGhqdXN0ID0gMSwgICAgICAgIyBBZGp1c3QgaG9yaXpvbnRhbCBqdXN0aWZpY2F0aW9uXG4gICAgICB2anVzdCA9IDEgICAgICAgICMgQWRqdXN0IHZlcnRpY2FsIGp1c3RpZmljYXRpb25cbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgICApXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGNvdW50X2JhcnBsb3RfZGlmZkdyb3VwX2RUQUdfdnNfRE1TT19wcF9iaW5hcnlHcm91cFxcKVxud2lkdGggPC0gcGFuZWxTaXplKDAuOCkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS41KSptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
########
#P-P
data <- temp2 %>% dplyr::select(group, num_pp)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)


p <- ggplot(data, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA, color = \black\, alpha = 0.6,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\, show.legend = FALSE) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  labs(x = NULL, y = \# of P-P loops per gene\) +
  coord_cartesian(ylim = c(0, 4)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  )+
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, convPvalue(pv12)),
           color = \black\, hjust = 0, size = 1) +
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )

fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_pp_binaryGroup\)
width <- panelSize(0.8)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Counting loop types

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakl5TmNiaU5RTFVWY2JtUmhkR0VnUEMwZ2RHVnRjRElnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWjNKdmRYQXNJRzUxYlY5d1pTbGNibU52Ykc1aGJXVnpLR1JoZEdFcElEd3RJR01vWENKbmNtOTFjRndpTENCY0ltTnZkVzUwWENJcFhHNXdkakV5SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29aR0YwWVN4Y0ltZHliM1Z3TVZ3aUxDQmNJbWR5YjNWd01sd2lLU3dnTlNsY2JseHVYRzV3SUR3dElHZG5jR3h2ZENoa1lYUmhMQ0JoWlhNb2VDQTlJR2R5YjNWd0xDQjVJRDBnWTI5MWJuUXNJR1pwYkd3Z1BTQm5jbTkxY0NrcElDc2dYRzRnSUdkbGIyMWZZbTk0Y0d4dmRDaDNhV1IwYUNBOUlEQXVOU3dnYjNWMGJHbGxjaTV6YUdGd1pTQTlJRTVCTENCamIyeHZjaUE5SUZ3aVlteGhZMnRjSWl3Z1lXeHdhR0VnUFNBd0xqWXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3hwYm1WM2FXUjBhQ0E5SUd4cGJtVlVhR2xqYXlBcUlHMXRWRzlNYVc1bFZXNXBkQ3dnYkdsdVpXVnVaQ0E5SUZ3aWMzRjFZWEpsWENJc0lITm9iM2N1YkdWblpXNWtJRDBnUmtGTVUwVXBJQ3NnZEdobGJXVmZZMnhoYzNOcFl5Z3BJQ3NnSUNBZ0lDQWdYRzRnSUhOallXeGxYM2xmWTI5dWRHbHVkVzkxY3loaWNtVmhhM01nUFNCelpYRW9NQ3dnTVRBc0lHSjVJRDBnTWlrcElDc2dYRzRnSUd4aFluTW9lQ0E5SUU1VlRFd3NJSGtnUFNCY0lpTWdiMllnVUMxRklHeHZiM0J6SUhCbGNpQm5aVzVsWENJcElDdGNiaUFnWTI5dmNtUmZZMkZ5ZEdWemFXRnVLSGxzYVcwZ1BTQmpLREFzSURRcEtTQXJYRzRnSUhOMFlYUmZjM1Z0YldGeWVTaGNiaUFnSUNCaFpYTW9aM0p2ZFhBZ1BTQm5jbTkxY0Nrc0lHWjFiaUE5SUcxbFlXNHNYRzRnSUNBZ1oyVnZiU0E5SUZ3aWNHOXBiblJjSWl3Z2MyaGhjR1VnUFNBeU1Td2djMmw2WlNBOUlEQXVOU3hjYmlBZ0lDQm1hV3hzSUQwZ1hDSmliR0ZqYTF3aUxDQmpiMnh2Y2lBOUlGd2lZbXhoWTJ0Y0lseHVJQ0FwSzF4dUlDQmhibTV2ZEdGMFpTaGNJblJsZUhSY0lpd2dlQ0E5SURFc0lIa2dQU0F6TENCc1lXSmxiQ0E5SUhCaGMzUmxNQ2hjSW5CMk1USTZJRndpTENCamIyNTJVSFpoYkhWbEtIQjJNVElwS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJREVwSUN0Y2JpQWdkR2hsYldVb1hHNGdJQ0FnSUNCaGVHbHpMblJwZEd4bElEMGdaV3hsYldWdWRGOTBaWGgwS0Z4dUlDQWdJQ0FnSUNCemFYcGxJRDBnWm05dWRGTnBlbVZOTEZ4dUlDQWdJQ0FnWm1GdGFXeDVJRDBnWm05dWRGUjVjR1VzWEc0Z0lDQWdJQ0JqYjJ4dmNpQTlJRndpSXpBd01EQXdNRndpWEc0Z0lDQWdLU3hjYmlBZ0lDQmhlR2x6TG5SbGVIUWdQU0JsYkdWdFpXNTBYM1JsZUhRb1hHNGdJQ0FnSUNCemFYcGxJRDBnWm05dWRGTnBlbVZOTEZ4dUlDQWdJQ0FnWm1GdGFXeDVJRDBnWm05dWRGUjVjR1VzWEc0Z0lDQWdJQ0JqYjJ4dmNpQTlJRndpSXpBd01EQXdNRndpWEc0Z0lDQWdLU3hjYmlBZ0lDQmhlR2x6TG5SbGVIUXVlQ0E5SUdWc1pXMWxiblJmZEdWNGRDaGNiaUFnSUNBZ0lHRnVaMnhsSUQwZ05EVXNJQ0FnSUNBZ0l5QlNiM1JoZEdVZ2VDMWhlR2x6SUd4aFltVnNjeUEwTlNCa1pXZHlaV1Z6WEc0Z0lDQWdJQ0JvYW5WemRDQTlJREVzSUNBZ0lDQWdJQ01nUVdScWRYTjBJR2h2Y21sNmIyNTBZV3dnYW5WemRHbG1hV05oZEdsdmJseHVJQ0FnSUNBZ2RtcDFjM1FnUFNBeElDQWdJQ0FnSUNBaklFRmthblZ6ZENCMlpYSjBhV05oYkNCcWRYTjBhV1pwWTJGMGFXOXVYRzRnSUNBZ0tTeGNiaUFnSUNCaGVHbHpMbXhwYm1VZ1BTQmxiR1Z0Wlc1MFgyeHBibVVvWEc0Z0lDQWdJQ0JqYjJ4dmNpQTlJRndpSXpBd01EQXdNRndpTEZ4dUlDQWdJQ0FnYzJsNlpTQTlJR3hwYm1WVWFHbGpheXB0YlZSdlRHbHVaVlZ1YVhRc1hHNGdJQ0FnSUNCc2FXNWxaVzVrSUQwZ1hDSnpjWFZoY21WY0lseHVJQ0FnSUNrc1hHNGdJQ0FnWVhocGN5NTBhV05yY3lBOUlHVnNaVzFsYm5SZmJHbHVaU2hjYmlBZ0lDQWdJR052Ykc5eUlEMGdYQ0lqTURBd01EQXdYQ0lzWEc0Z0lDQWdJQ0J6YVhwbElEMGdiR2x1WlZSb2FXTnJLbTF0Vkc5TWFXNWxWVzVwZEN4Y2JpQWdJQ0FnSUd4cGJtVmxibVFnUFNCY0luTnhkV0Z5WlZ3aVhHNGdJQ0FnS1N4Y2JpQWdJQ0J3WVc1bGJDNWlZV05yWjNKdmRXNWtJRDBnWld4bGJXVnVkRjl5WldOMEtHWnBiR3dnUFNCY0luUnlZVzV6Y0dGeVpXNTBYQ0lwTEZ4dUlDQWdJR3hsWjJWdVpDNTBaWGgwSUQwZ1pXeGxiV1Z1ZEY5MFpYaDBLR1poYldsc2VTQTlJR1p2Ym5SVWVYQmxMQ0J6YVhwbElEMGdabTl1ZEZOcGVtVlRLU3hjYmlBZ0lDQnNaV2RsYm1RdWRHbDBiR1VnUFNCbGJHVnRaVzUwWDNSbGVIUW9abUZ0YVd4NUlEMGdabTl1ZEZSNWNHVXNJSE5wZW1VZ1BTQm1iMjUwVTJsNlpWTXBYRzRnSUNBZ0tWeHVYRzVjYmx4dVptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGd2lZMjkxYm5SZlltRnljR3h2ZEY5a2FXWm1SM0p2ZFhCZlpGUkJSMTkyYzE5RVRWTlBYM0JsWDJKcGJtRnllVWR5YjNWd1hDSXBYRzUzYVdSMGFDQThMU0J3WVc1bGJGTnBlbVVvTUM0NEtTcHRiVlJ2U1c1amFGeHVhR1ZwWjJoMElEd3RJSEJoYm1Wc1UybDZaU2d4TGpVcEttMXRWRzlKYm1Ob1hHNXdibWNvYUdWeVpTaG1hV2RFYVhJc0lIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hDSXVjRzVuWENJcEtTd2djbVZ6SUQwZ05qQXdMQ0IxYm1sMElEMGdYQ0pwYmx3aUxDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc1d2NtbHVkQ2h3S1Z4dVpHVjJMbTltWmlncFhHNXpkbWRzYVhSbEtHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRndpTG5OMloxd2lLU2tzSUNCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzV3Y21sdWRDaHdLVnh1WkdWMkxtOW1aaWdwWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG4jIyMjIyMjI1xuI1AtRVxuZGF0YSA8LSB0ZW1wMiAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgbnVtX3BlKVxuY29sbmFtZXMoZGF0YSkgPC0gYyhcXGdyb3VwXFwsIFxcY291bnRcXClcbnB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgKyBcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC41LCBvdXRsaWVyLnNoYXBlID0gTkEsIGNvbG9yID0gXFxibGFja1xcLCBhbHBoYSA9IDAuNixcbiAgICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCAxMCwgYnkgPSAyKSkgKyBcbiAgbGFicyh4ID0gTlVMTCwgeSA9IFxcIyBvZiBQLUUgbG9vcHMgcGVyIGdlbmVcXCkgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgNCkpICtcbiAgc3RhdF9zdW1tYXJ5KFxuICAgIGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkrXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIGNvbnZQdmFsdWUocHYxMikpLFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSkgK1xuICB0aGVtZShcbiAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgYW5nbGUgPSA0NSwgICAgICAjIFJvdGF0ZSB4LWF4aXMgbGFiZWxzIDQ1IGRlZ3JlZXNcbiAgICAgIGhqdXN0ID0gMSwgICAgICAgIyBBZGp1c3QgaG9yaXpvbnRhbCBqdXN0aWZpY2F0aW9uXG4gICAgICB2anVzdCA9IDEgICAgICAgICMgQWRqdXN0IHZlcnRpY2FsIGp1c3RpZmljYXRpb25cbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgICApXG5cblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxjb3VudF9iYXJwbG90X2RpZmZHcm91cF9kVEFHX3ZzX0RNU09fcGVfYmluYXJ5R3JvdXBcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSgwLjgpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuNSkqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
########
#P-E
data <- temp2 %>% dplyr::select(group, num_pe)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)


p <- ggplot(data, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA, color = \black\, alpha = 0.6,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\, show.legend = FALSE) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  labs(x = NULL, y = \# of P-E loops per gene\) +
  coord_cartesian(ylim = c(0, 4)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  )+
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, convPvalue(pv12)),
           color = \black\, hjust = 0, size = 1) +
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )



fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_pe_binaryGroup\)
width <- panelSize(0.8)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSXlOY2JpTlFMVVZjYm1SaGRHRWdQQzBnZEdWdGNESWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aM0p2ZFhBc0lHNTFiVjl3WlNsY2JtTnZiRzVoYldWektHUmhkR0VwSUR3dElHTW9YRnhuY205MWNGeGNMQ0JjWEdOdmRXNTBYRndwWEc1d2RqRXlJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjWEdkeWIzVndNVnhjTENCY1hHZHliM1Z3TWx4Y0tTd2dOU2xjYmx4dVhHNXdJRHd0SUdkbmNHeHZkQ2hrWVhSaExDQmhaWE1vZUNBOUlHZHliM1Z3TENCNUlEMGdZMjkxYm5Rc0lHWnBiR3dnUFNCbmNtOTFjQ2twSUNzZ1hHNGdJR2RsYjIxZlltOTRjR3h2ZENoM2FXUjBhQ0E5SURBdU5Td2diM1YwYkdsbGNpNXphR0Z3WlNBOUlFNUJMQ0JqYjJ4dmNpQTlJRnhjWW14aFkydGNYQ3dnWVd4d2FHRWdQU0F3TGpZc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHeHBibVYzYVdSMGFDQTlJR3hwYm1WVWFHbGpheUFxSUcxdFZHOU1hVzVsVlc1cGRDd2diR2x1WldWdVpDQTlJRnhjYzNGMVlYSmxYRndzSUhOb2IzY3ViR1ZuWlc1a0lEMGdSa0ZNVTBVcElDc2dkR2hsYldWZlkyeGhjM05wWXlncElDc2dJQ0FnSUNBZ1hHNGdJSE5qWVd4bFgzbGZZMjl1ZEdsdWRXOTFjeWhpY21WaGEzTWdQU0J6WlhFb01Dd2dNVEFzSUdKNUlEMGdNaWtwSUNzZ1hHNGdJR3hoWW5Nb2VDQTlJRTVWVEV3c0lIa2dQU0JjWENNZ2IyWWdVQzFGSUd4dmIzQnpJSEJsY2lCblpXNWxYRndwSUN0Y2JpQWdZMjl2Y21SZlkyRnlkR1Z6YVdGdUtIbHNhVzBnUFNCaktEQXNJRFFwS1NBclhHNGdJSE4wWVhSZmMzVnRiV0Z5ZVNoY2JpQWdJQ0JoWlhNb1ozSnZkWEFnUFNCbmNtOTFjQ2tzSUdaMWJpQTlJRzFsWVc0c1hHNGdJQ0FnWjJWdmJTQTlJRnhjY0c5cGJuUmNYQ3dnYzJoaGNHVWdQU0F5TVN3Z2MybDZaU0E5SURBdU5TeGNiaUFnSUNCbWFXeHNJRDBnWEZ4aWJHRmphMXhjTENCamIyeHZjaUE5SUZ4Y1lteGhZMnRjWEZ4dUlDQXBLMXh1SUNCaGJtNXZkR0YwWlNoY1hIUmxlSFJjWEN3Z2VDQTlJREVzSUhrZ1BTQXpMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNYSEIyTVRJNklGeGNMQ0JqYjI1MlVIWmhiSFZsS0hCMk1USXBLU3hjYmlBZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlERXBJQ3RjYmlBZ2RHaGxiV1VvWEc0Z0lDQWdJQ0JoZUdsekxuUnBkR3hsSUQwZ1pXeGxiV1Z1ZEY5MFpYaDBLRnh1SUNBZ0lDQWdJQ0J6YVhwbElEMGdabTl1ZEZOcGVtVk5MRnh1SUNBZ0lDQWdabUZ0YVd4NUlEMGdabTl1ZEZSNWNHVXNYRzRnSUNBZ0lDQmpiMnh2Y2lBOUlGeGNJekF3TURBd01GeGNYRzRnSUNBZ0tTeGNiaUFnSUNCaGVHbHpMblJsZUhRZ1BTQmxiR1Z0Wlc1MFgzUmxlSFFvWEc0Z0lDQWdJQ0J6YVhwbElEMGdabTl1ZEZOcGVtVk5MRnh1SUNBZ0lDQWdabUZ0YVd4NUlEMGdabTl1ZEZSNWNHVXNYRzRnSUNBZ0lDQmpiMnh2Y2lBOUlGeGNJekF3TURBd01GeGNYRzRnSUNBZ0tTeGNiaUFnSUNCaGVHbHpMblJsZUhRdWVDQTlJR1ZzWlcxbGJuUmZkR1Y0ZENoY2JpQWdJQ0FnSUdGdVoyeGxJRDBnTkRVc0lDQWdJQ0FnSXlCU2IzUmhkR1VnZUMxaGVHbHpJR3hoWW1Wc2N5QTBOU0JrWldkeVpXVnpYRzRnSUNBZ0lDQm9hblZ6ZENBOUlERXNJQ0FnSUNBZ0lDTWdRV1JxZFhOMElHaHZjbWw2YjI1MFlXd2dhblZ6ZEdsbWFXTmhkR2x2Ymx4dUlDQWdJQ0FnZG1wMWMzUWdQU0F4SUNBZ0lDQWdJQ0FqSUVGa2FuVnpkQ0IyWlhKMGFXTmhiQ0JxZFhOMGFXWnBZMkYwYVc5dVhHNGdJQ0FnS1N4Y2JpQWdJQ0JoZUdsekxteHBibVVnUFNCbGJHVnRaVzUwWDJ4cGJtVW9YRzRnSUNBZ0lDQmpiMnh2Y2lBOUlGeGNJekF3TURBd01GeGNMRnh1SUNBZ0lDQWdjMmw2WlNBOUlHeHBibVZVYUdsamF5cHRiVlJ2VEdsdVpWVnVhWFFzWEc0Z0lDQWdJQ0JzYVc1bFpXNWtJRDBnWEZ4emNYVmhjbVZjWEZ4dUlDQWdJQ2tzWEc0Z0lDQWdZWGhwY3k1MGFXTnJjeUE5SUdWc1pXMWxiblJmYkdsdVpTaGNiaUFnSUNBZ0lHTnZiRzl5SUQwZ1hGd2pNREF3TURBd1hGd3NYRzRnSUNBZ0lDQnphWHBsSUQwZ2JHbHVaVlJvYVdOckttMXRWRzlNYVc1bFZXNXBkQ3hjYmlBZ0lDQWdJR3hwYm1WbGJtUWdQU0JjWEhOeGRXRnlaVnhjWEc0Z0lDQWdLU3hjYmlBZ0lDQndZVzVsYkM1aVlXTnJaM0p2ZFc1a0lEMGdaV3hsYldWdWRGOXlaV04wS0dacGJHd2dQU0JjWEhSeVlXNXpjR0Z5Wlc1MFhGd3BMRnh1SUNBZ0lHeGxaMlZ1WkM1MFpYaDBJRDBnWld4bGJXVnVkRjkwWlhoMEtHWmhiV2xzZVNBOUlHWnZiblJVZVhCbExDQnphWHBsSUQwZ1ptOXVkRk5wZW1WVEtTeGNiaUFnSUNCc1pXZGxibVF1ZEdsMGJHVWdQU0JsYkdWdFpXNTBYM1JsZUhRb1ptRnRhV3g1SUQwZ1ptOXVkRlI1Y0dVc0lITnBlbVVnUFNCbWIyNTBVMmw2WlZNcFhHNGdJQ0FnS1Z4dVhHNWNibHh1Wm1sc1pVNWhiV1VnUEMwZ2NHRnpkR1V3S0Z4Y1kyOTFiblJmWW1GeWNHeHZkRjlrYVdabVIzSnZkWEJmWkZSQlIxOTJjMTlFVFZOUFgzQmxYMkpwYm1GeWVVZHliM1Z3WEZ3cFhHNTNhV1IwYUNBOExTQndZVzVsYkZOcGVtVW9NQzQ0S1NwdGJWUnZTVzVqYUZ4dWFHVnBaMmgwSUR3dElIQmhibVZzVTJsNlpTZ3hMalVwS20xdFZHOUpibU5vWEc1d2JtY29hR1Z5WlNobWFXZEVhWElzSUhCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWEZ3dWNHNW5YRndwS1N3Z2NtVnpJRDBnTmpBd0xDQjFibWwwSUQwZ1hGeHBibHhjTENCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzV3Y21sdWRDaHdLVnh1WkdWMkxtOW1aaWdwWEc1emRtZHNhWFJsS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGeGNMbk4yWjF4Y0tTa3NJQ0JvWldsbmFIUWdQU0JvWldsbmFIUXNJSGRwWkhSb0lEMGdkMmxrZEdncFhHNXdjbWx1ZENod0tWeHVaR1YyTG05bVppZ3BYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG4jIyMjIyMjI1xuI1AtRVxuZGF0YSA8LSB0ZW1wMiAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgbnVtX3BlKVxuY29sbmFtZXMoZGF0YSkgPC0gYyhcXGdyb3VwXFwsIFxcY291bnRcXClcbnB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgKyBcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC41LCBvdXRsaWVyLnNoYXBlID0gTkEsIGNvbG9yID0gXFxibGFja1xcLCBhbHBoYSA9IDAuNixcbiAgICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCAxMCwgYnkgPSAyKSkgKyBcbiAgbGFicyh4ID0gTlVMTCwgeSA9IFxcIyBvZiBQLUUgbG9vcHMgcGVyIGdlbmVcXCkgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgNCkpICtcbiAgc3RhdF9zdW1tYXJ5KFxuICAgIGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkrXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIGNvbnZQdmFsdWUocHYxMikpLFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSkgK1xuICB0aGVtZShcbiAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgYW5nbGUgPSA0NSwgICAgICAjIFJvdGF0ZSB4LWF4aXMgbGFiZWxzIDQ1IGRlZ3JlZXNcbiAgICAgIGhqdXN0ID0gMSwgICAgICAgIyBBZGp1c3QgaG9yaXpvbnRhbCBqdXN0aWZpY2F0aW9uXG4gICAgICB2anVzdCA9IDEgICAgICAgICMgQWRqdXN0IHZlcnRpY2FsIGp1c3RpZmljYXRpb25cbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgICApXG5cblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxjb3VudF9iYXJwbG90X2RpZmZHcm91cF9kVEFHX3ZzX0RNU09fcGVfYmluYXJ5R3JvdXBcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSgwLjgpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuNSkqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLUVcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wZSlcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcblxuXG5wIDwtIGdncGxvdChkYXRhLCBhZXMoeCA9IGdyb3VwLCB5ID0gY291bnQsIGZpbGwgPSBncm91cCkpICsgXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BLCBjb2xvciA9IFxcYmxhY2tcXCwgYWxwaGEgPSAwLjYsXG4gICAgICAgICAgICAgICAgIGxpbmV3aWR0aCA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsIHNob3cubGVnZW5kID0gRkFMU0UpICsgdGhlbWVfY2xhc3NpYygpICsgICAgICAgXG4gIHNjYWxlX3lfY29udGludW91cyhicmVha3MgPSBzZXEoMCwgMTAsIGJ5ID0gMikpICsgXG4gIGxhYnMoeCA9IE5VTEwsIHkgPSBcXCMgb2YgUC1FIGxvb3BzIHBlciBnZW5lXFwpICtcbiAgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIDQpKSArXG4gIHN0YXRfc3VtbWFyeShcbiAgICBhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sXG4gICAgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDAuNSxcbiAgICBmaWxsID0gXFxibGFja1xcLCBjb2xvciA9IFxcYmxhY2tcXFxuICApK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBjb252UHZhbHVlKHB2MTIpKSxcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpICtcbiAgdGhlbWUoXG4gICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIGFuZ2xlID0gNDUsICAgICAgIyBSb3RhdGUgeC1heGlzIGxhYmVscyA0NSBkZWdyZWVzXG4gICAgICBoanVzdCA9IDEsICAgICAgICMgQWRqdXN0IGhvcml6b250YWwganVzdGlmaWNhdGlvblxuICAgICAgdmp1c3QgPSAxICAgICAgICAjIEFkanVzdCB2ZXJ0aWNhbCBqdXN0aWZpY2F0aW9uXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcXHRyYW5zcGFyZW50XFwpLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gICAgKVxuXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPX3BlX2JpbmFyeUdyb3VwXFwpXG53aWR0aCA8LSBwYW5lbFNpemUoMC44KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjUpKm1tVG9JbmNoXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
########
#P-E
data <- temp2 %>% dplyr::select(group, num_pe)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)


p <- ggplot(data, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA, color = \black\, alpha = 0.6,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\, show.legend = FALSE) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  labs(x = NULL, y = \# of P-E loops per gene\) +
  coord_cartesian(ylim = c(0, 4)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  )+
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, convPvalue(pv12)),
           color = \black\, hjust = 0, size = 1) +
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )



fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_pe_binaryGroup\)
width <- panelSize(0.8)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-P

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakl5TmNiaU5RTFZOY2JtUmhkR0VnUEMwZ2RHVnRjRElnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWjNKdmRYQXNJRzUxYlY5d2N5bGNibU52Ykc1aGJXVnpLR1JoZEdFcElEd3RJR01vWENKbmNtOTFjRndpTENCY0ltTnZkVzUwWENJcFhHNXdkakV5SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29aR0YwWVN4Y0ltZHliM1Z3TVZ3aUxDQmNJbWR5YjNWd01sd2lLU3dnTlNsY2JseHVYRzV3SUR3dElHZG5jR3h2ZENoa1lYUmhMQ0JoWlhNb2VDQTlJR2R5YjNWd0xDQjVJRDBnWTI5MWJuUXNJR1pwYkd3Z1BTQm5jbTkxY0NrcElDc2dYRzRnSUdkbGIyMWZZbTk0Y0d4dmRDaDNhV1IwYUNBOUlEQXVOU3dnYjNWMGJHbGxjaTV6YUdGd1pTQTlJRTVCTENCamIyeHZjaUE5SUZ3aVlteGhZMnRjSWl3Z1lXeHdhR0VnUFNBd0xqWXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3hwYm1WM2FXUjBhQ0E5SUd4cGJtVlVhR2xqYXlBcUlHMXRWRzlNYVc1bFZXNXBkQ3dnYkdsdVpXVnVaQ0E5SUZ3aWMzRjFZWEpsWENJc0lITm9iM2N1YkdWblpXNWtJRDBnUmtGTVUwVXBJQ3NnZEdobGJXVmZZMnhoYzNOcFl5Z3BJQ3NnSUNBZ0lDQWdYRzRnSUhOallXeGxYM2xmWTI5dWRHbHVkVzkxY3loaWNtVmhhM01nUFNCelpYRW9NQ3dnTVRBc0lHSjVJRDBnTWlrcElDc2dYRzRnSUd4aFluTW9lQ0E5SUU1VlRFd3NJSGtnUFNCY0lpTWdiMllnVUMxVElHeHZiM0J6SUhCbGNpQm5aVzVsWENJcElDdGNiaUFnWTI5dmNtUmZZMkZ5ZEdWemFXRnVLSGxzYVcwZ1BTQmpLREFzSURRcEtTQXJYRzRnSUhOMFlYUmZjM1Z0YldGeWVTaGNiaUFnSUNCaFpYTW9aM0p2ZFhBZ1BTQm5jbTkxY0Nrc0lHWjFiaUE5SUcxbFlXNHNYRzRnSUNBZ1oyVnZiU0E5SUZ3aWNHOXBiblJjSWl3Z2MyaGhjR1VnUFNBeU1Td2djMmw2WlNBOUlEQXVOU3hjYmlBZ0lDQm1hV3hzSUQwZ1hDSmliR0ZqYTF3aUxDQmpiMnh2Y2lBOUlGd2lZbXhoWTJ0Y0lseHVJQ0FwSzF4dUlDQmhibTV2ZEdGMFpTaGNJblJsZUhSY0lpd2dlQ0E5SURFc0lIa2dQU0F6TENCc1lXSmxiQ0E5SUhCaGMzUmxNQ2hjSW5CMk1USTZJRndpTENCamIyNTJVSFpoYkhWbEtIQjJNVElwS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJREVwSUN0Y2JpQWdkR2hsYldVb1hHNGdJQ0FnSUNCaGVHbHpMblJwZEd4bElEMGdaV3hsYldWdWRGOTBaWGgwS0Z4dUlDQWdJQ0FnSUNCemFYcGxJRDBnWm05dWRGTnBlbVZOTEZ4dUlDQWdJQ0FnWm1GdGFXeDVJRDBnWm05dWRGUjVjR1VzWEc0Z0lDQWdJQ0JqYjJ4dmNpQTlJRndpSXpBd01EQXdNRndpWEc0Z0lDQWdLU3hjYmlBZ0lDQmhlR2x6TG5SbGVIUWdQU0JsYkdWdFpXNTBYM1JsZUhRb1hHNGdJQ0FnSUNCemFYcGxJRDBnWm05dWRGTnBlbVZOTEZ4dUlDQWdJQ0FnWm1GdGFXeDVJRDBnWm05dWRGUjVjR1VzWEc0Z0lDQWdJQ0JqYjJ4dmNpQTlJRndpSXpBd01EQXdNRndpWEc0Z0lDQWdLU3hjYmlBZ0lDQmhlR2x6TG5SbGVIUXVlQ0E5SUdWc1pXMWxiblJmZEdWNGRDaGNiaUFnSUNBZ0lHRnVaMnhsSUQwZ05EVXNJQ0FnSUNBZ0l5QlNiM1JoZEdVZ2VDMWhlR2x6SUd4aFltVnNjeUEwTlNCa1pXZHlaV1Z6WEc0Z0lDQWdJQ0JvYW5WemRDQTlJREVzSUNBZ0lDQWdJQ01nUVdScWRYTjBJR2h2Y21sNmIyNTBZV3dnYW5WemRHbG1hV05oZEdsdmJseHVJQ0FnSUNBZ2RtcDFjM1FnUFNBeElDQWdJQ0FnSUNBaklFRmthblZ6ZENCMlpYSjBhV05oYkNCcWRYTjBhV1pwWTJGMGFXOXVYRzRnSUNBZ0tTeGNiaUFnSUNCaGVHbHpMbXhwYm1VZ1BTQmxiR1Z0Wlc1MFgyeHBibVVvWEc0Z0lDQWdJQ0JqYjJ4dmNpQTlJRndpSXpBd01EQXdNRndpTEZ4dUlDQWdJQ0FnYzJsNlpTQTlJR3hwYm1WVWFHbGpheXB0YlZSdlRHbHVaVlZ1YVhRc1hHNGdJQ0FnSUNCc2FXNWxaVzVrSUQwZ1hDSnpjWFZoY21WY0lseHVJQ0FnSUNrc1hHNGdJQ0FnWVhocGN5NTBhV05yY3lBOUlHVnNaVzFsYm5SZmJHbHVaU2hjYmlBZ0lDQWdJR052Ykc5eUlEMGdYQ0lqTURBd01EQXdYQ0lzWEc0Z0lDQWdJQ0J6YVhwbElEMGdiR2x1WlZSb2FXTnJLbTF0Vkc5TWFXNWxWVzVwZEN4Y2JpQWdJQ0FnSUd4cGJtVmxibVFnUFNCY0luTnhkV0Z5WlZ3aVhHNGdJQ0FnS1N4Y2JpQWdJQ0J3WVc1bGJDNWlZV05yWjNKdmRXNWtJRDBnWld4bGJXVnVkRjl5WldOMEtHWnBiR3dnUFNCY0luUnlZVzV6Y0dGeVpXNTBYQ0lwTEZ4dUlDQWdJR3hsWjJWdVpDNTBaWGgwSUQwZ1pXeGxiV1Z1ZEY5MFpYaDBLR1poYldsc2VTQTlJR1p2Ym5SVWVYQmxMQ0J6YVhwbElEMGdabTl1ZEZOcGVtVlRLU3hjYmlBZ0lDQnNaV2RsYm1RdWRHbDBiR1VnUFNCbGJHVnRaVzUwWDNSbGVIUW9abUZ0YVd4NUlEMGdabTl1ZEZSNWNHVXNJSE5wZW1VZ1BTQm1iMjUwVTJsNlpWTXBYRzRnSUNBZ0tWeHVYRzVjYmx4dVptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGd2lZMjkxYm5SZlltRnljR3h2ZEY5a2FXWm1SM0p2ZFhCZlpGUkJSMTkyYzE5RVRWTlBYM0J6WDJKcGJtRnllVWR5YjNWd1hDSXBYRzUzYVdSMGFDQThMU0J3WVc1bGJGTnBlbVVvTUM0NEtTcHRiVlJ2U1c1amFGeHVhR1ZwWjJoMElEd3RJSEJoYm1Wc1UybDZaU2d4TGpVcEttMXRWRzlKYm1Ob1hHNXdibWNvYUdWeVpTaG1hV2RFYVhJc0lIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hDSXVjRzVuWENJcEtTd2djbVZ6SUQwZ05qQXdMQ0IxYm1sMElEMGdYQ0pwYmx3aUxDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc1d2NtbHVkQ2h3S1Z4dVpHVjJMbTltWmlncFhHNXpkbWRzYVhSbEtHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRndpTG5OMloxd2lLU2tzSUNCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzV3Y21sdWRDaHdLVnh1WkdWMkxtOW1aaWdwWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG4jIyMjIyMjI1xuI1AtU1xuZGF0YSA8LSB0ZW1wMiAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgbnVtX3BzKVxuY29sbmFtZXMoZGF0YSkgPC0gYyhcXGdyb3VwXFwsIFxcY291bnRcXClcbnB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgKyBcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC41LCBvdXRsaWVyLnNoYXBlID0gTkEsIGNvbG9yID0gXFxibGFja1xcLCBhbHBoYSA9IDAuNixcbiAgICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCAxMCwgYnkgPSAyKSkgKyBcbiAgbGFicyh4ID0gTlVMTCwgeSA9IFxcIyBvZiBQLVMgbG9vcHMgcGVyIGdlbmVcXCkgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgNCkpICtcbiAgc3RhdF9zdW1tYXJ5KFxuICAgIGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkrXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIGNvbnZQdmFsdWUocHYxMikpLFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSkgK1xuICB0aGVtZShcbiAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgYW5nbGUgPSA0NSwgICAgICAjIFJvdGF0ZSB4LWF4aXMgbGFiZWxzIDQ1IGRlZ3JlZXNcbiAgICAgIGhqdXN0ID0gMSwgICAgICAgIyBBZGp1c3QgaG9yaXpvbnRhbCBqdXN0aWZpY2F0aW9uXG4gICAgICB2anVzdCA9IDEgICAgICAgICMgQWRqdXN0IHZlcnRpY2FsIGp1c3RpZmljYXRpb25cbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgICApXG5cblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxjb3VudF9iYXJwbG90X2RpZmZHcm91cF9kVEFHX3ZzX0RNU09fcHNfYmluYXJ5R3JvdXBcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSgwLjgpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuNSkqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
########
#P-S
data <- temp2 %>% dplyr::select(group, num_ps)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)


p <- ggplot(data, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA, color = \black\, alpha = 0.6,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\, show.legend = FALSE) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  labs(x = NULL, y = \# of P-S loops per gene\) +
  coord_cartesian(ylim = c(0, 4)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  )+
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, convPvalue(pv12)),
           color = \black\, hjust = 0, size = 1) +
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )



fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_ps_binaryGroup\)
width <- panelSize(0.8)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSXlOY2JpTlFMVk5jYm1SaGRHRWdQQzBnZEdWdGNESWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aM0p2ZFhBc0lHNTFiVjl3Y3lsY2JtTnZiRzVoYldWektHUmhkR0VwSUR3dElHTW9YRnhuY205MWNGeGNMQ0JjWEdOdmRXNTBYRndwWEc1d2RqRXlJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjWEdkeWIzVndNVnhjTENCY1hHZHliM1Z3TWx4Y0tTd2dOU2xjYmx4dVhHNXdJRHd0SUdkbmNHeHZkQ2hrWVhSaExDQmhaWE1vZUNBOUlHZHliM1Z3TENCNUlEMGdZMjkxYm5Rc0lHWnBiR3dnUFNCbmNtOTFjQ2twSUNzZ1hHNGdJR2RsYjIxZlltOTRjR3h2ZENoM2FXUjBhQ0E5SURBdU5Td2diM1YwYkdsbGNpNXphR0Z3WlNBOUlFNUJMQ0JqYjJ4dmNpQTlJRnhjWW14aFkydGNYQ3dnWVd4d2FHRWdQU0F3TGpZc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHeHBibVYzYVdSMGFDQTlJR3hwYm1WVWFHbGpheUFxSUcxdFZHOU1hVzVsVlc1cGRDd2diR2x1WldWdVpDQTlJRnhjYzNGMVlYSmxYRndzSUhOb2IzY3ViR1ZuWlc1a0lEMGdSa0ZNVTBVcElDc2dkR2hsYldWZlkyeGhjM05wWXlncElDc2dJQ0FnSUNBZ1hHNGdJSE5qWVd4bFgzbGZZMjl1ZEdsdWRXOTFjeWhpY21WaGEzTWdQU0J6WlhFb01Dd2dNVEFzSUdKNUlEMGdNaWtwSUNzZ1hHNGdJR3hoWW5Nb2VDQTlJRTVWVEV3c0lIa2dQU0JjWENNZ2IyWWdVQzFUSUd4dmIzQnpJSEJsY2lCblpXNWxYRndwSUN0Y2JpQWdZMjl2Y21SZlkyRnlkR1Z6YVdGdUtIbHNhVzBnUFNCaktEQXNJRFFwS1NBclhHNGdJSE4wWVhSZmMzVnRiV0Z5ZVNoY2JpQWdJQ0JoWlhNb1ozSnZkWEFnUFNCbmNtOTFjQ2tzSUdaMWJpQTlJRzFsWVc0c1hHNGdJQ0FnWjJWdmJTQTlJRnhjY0c5cGJuUmNYQ3dnYzJoaGNHVWdQU0F5TVN3Z2MybDZaU0E5SURBdU5TeGNiaUFnSUNCbWFXeHNJRDBnWEZ4aWJHRmphMXhjTENCamIyeHZjaUE5SUZ4Y1lteGhZMnRjWEZ4dUlDQXBLMXh1SUNCaGJtNXZkR0YwWlNoY1hIUmxlSFJjWEN3Z2VDQTlJREVzSUhrZ1BTQXpMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNYSEIyTVRJNklGeGNMQ0JqYjI1MlVIWmhiSFZsS0hCMk1USXBLU3hjYmlBZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlERXBJQ3RjYmlBZ2RHaGxiV1VvWEc0Z0lDQWdJQ0JoZUdsekxuUnBkR3hsSUQwZ1pXeGxiV1Z1ZEY5MFpYaDBLRnh1SUNBZ0lDQWdJQ0J6YVhwbElEMGdabTl1ZEZOcGVtVk5MRnh1SUNBZ0lDQWdabUZ0YVd4NUlEMGdabTl1ZEZSNWNHVXNYRzRnSUNBZ0lDQmpiMnh2Y2lBOUlGeGNJekF3TURBd01GeGNYRzRnSUNBZ0tTeGNiaUFnSUNCaGVHbHpMblJsZUhRZ1BTQmxiR1Z0Wlc1MFgzUmxlSFFvWEc0Z0lDQWdJQ0J6YVhwbElEMGdabTl1ZEZOcGVtVk5MRnh1SUNBZ0lDQWdabUZ0YVd4NUlEMGdabTl1ZEZSNWNHVXNYRzRnSUNBZ0lDQmpiMnh2Y2lBOUlGeGNJekF3TURBd01GeGNYRzRnSUNBZ0tTeGNiaUFnSUNCaGVHbHpMblJsZUhRdWVDQTlJR1ZzWlcxbGJuUmZkR1Y0ZENoY2JpQWdJQ0FnSUdGdVoyeGxJRDBnTkRVc0lDQWdJQ0FnSXlCU2IzUmhkR1VnZUMxaGVHbHpJR3hoWW1Wc2N5QTBOU0JrWldkeVpXVnpYRzRnSUNBZ0lDQm9hblZ6ZENBOUlERXNJQ0FnSUNBZ0lDTWdRV1JxZFhOMElHaHZjbWw2YjI1MFlXd2dhblZ6ZEdsbWFXTmhkR2x2Ymx4dUlDQWdJQ0FnZG1wMWMzUWdQU0F4SUNBZ0lDQWdJQ0FqSUVGa2FuVnpkQ0IyWlhKMGFXTmhiQ0JxZFhOMGFXWnBZMkYwYVc5dVhHNGdJQ0FnS1N4Y2JpQWdJQ0JoZUdsekxteHBibVVnUFNCbGJHVnRaVzUwWDJ4cGJtVW9YRzRnSUNBZ0lDQmpiMnh2Y2lBOUlGeGNJekF3TURBd01GeGNMRnh1SUNBZ0lDQWdjMmw2WlNBOUlHeHBibVZVYUdsamF5cHRiVlJ2VEdsdVpWVnVhWFFzWEc0Z0lDQWdJQ0JzYVc1bFpXNWtJRDBnWEZ4emNYVmhjbVZjWEZ4dUlDQWdJQ2tzWEc0Z0lDQWdZWGhwY3k1MGFXTnJjeUE5SUdWc1pXMWxiblJmYkdsdVpTaGNiaUFnSUNBZ0lHTnZiRzl5SUQwZ1hGd2pNREF3TURBd1hGd3NYRzRnSUNBZ0lDQnphWHBsSUQwZ2JHbHVaVlJvYVdOckttMXRWRzlNYVc1bFZXNXBkQ3hjYmlBZ0lDQWdJR3hwYm1WbGJtUWdQU0JjWEhOeGRXRnlaVnhjWEc0Z0lDQWdLU3hjYmlBZ0lDQndZVzVsYkM1aVlXTnJaM0p2ZFc1a0lEMGdaV3hsYldWdWRGOXlaV04wS0dacGJHd2dQU0JjWEhSeVlXNXpjR0Z5Wlc1MFhGd3BMRnh1SUNBZ0lHeGxaMlZ1WkM1MFpYaDBJRDBnWld4bGJXVnVkRjkwWlhoMEtHWmhiV2xzZVNBOUlHWnZiblJVZVhCbExDQnphWHBsSUQwZ1ptOXVkRk5wZW1WVEtTeGNiaUFnSUNCc1pXZGxibVF1ZEdsMGJHVWdQU0JsYkdWdFpXNTBYM1JsZUhRb1ptRnRhV3g1SUQwZ1ptOXVkRlI1Y0dVc0lITnBlbVVnUFNCbWIyNTBVMmw2WlZNcFhHNGdJQ0FnS1Z4dVhHNWNibHh1Wm1sc1pVNWhiV1VnUEMwZ2NHRnpkR1V3S0Z4Y1kyOTFiblJmWW1GeWNHeHZkRjlrYVdabVIzSnZkWEJmWkZSQlIxOTJjMTlFVFZOUFgzQnpYMkpwYm1GeWVVZHliM1Z3WEZ3cFhHNTNhV1IwYUNBOExTQndZVzVsYkZOcGVtVW9NQzQ0S1NwdGJWUnZTVzVqYUZ4dWFHVnBaMmgwSUR3dElIQmhibVZzVTJsNlpTZ3hMalVwS20xdFZHOUpibU5vWEc1d2JtY29hR1Z5WlNobWFXZEVhWElzSUhCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWEZ3dWNHNW5YRndwS1N3Z2NtVnpJRDBnTmpBd0xDQjFibWwwSUQwZ1hGeHBibHhjTENCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzV3Y21sdWRDaHdLVnh1WkdWMkxtOW1aaWdwWEc1emRtZHNhWFJsS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGeGNMbk4yWjF4Y0tTa3NJQ0JvWldsbmFIUWdQU0JvWldsbmFIUXNJSGRwWkhSb0lEMGdkMmxrZEdncFhHNXdjbWx1ZENod0tWeHVaR1YyTG05bVppZ3BYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG4jIyMjIyMjI1xuI1AtU1xuZGF0YSA8LSB0ZW1wMiAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgbnVtX3BzKVxuY29sbmFtZXMoZGF0YSkgPC0gYyhcXGdyb3VwXFwsIFxcY291bnRcXClcbnB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgKyBcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC41LCBvdXRsaWVyLnNoYXBlID0gTkEsIGNvbG9yID0gXFxibGFja1xcLCBhbHBoYSA9IDAuNixcbiAgICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCAxMCwgYnkgPSAyKSkgKyBcbiAgbGFicyh4ID0gTlVMTCwgeSA9IFxcIyBvZiBQLVMgbG9vcHMgcGVyIGdlbmVcXCkgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgNCkpICtcbiAgc3RhdF9zdW1tYXJ5KFxuICAgIGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkrXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIGNvbnZQdmFsdWUocHYxMikpLFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSkgK1xuICB0aGVtZShcbiAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgYW5nbGUgPSA0NSwgICAgICAjIFJvdGF0ZSB4LWF4aXMgbGFiZWxzIDQ1IGRlZ3JlZXNcbiAgICAgIGhqdXN0ID0gMSwgICAgICAgIyBBZGp1c3QgaG9yaXpvbnRhbCBqdXN0aWZpY2F0aW9uXG4gICAgICB2anVzdCA9IDEgICAgICAgICMgQWRqdXN0IHZlcnRpY2FsIGp1c3RpZmljYXRpb25cbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgICApXG5cblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxjb3VudF9iYXJwbG90X2RpZmZHcm91cF9kVEFHX3ZzX0RNU09fcHNfYmluYXJ5R3JvdXBcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSgwLjgpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuNSkqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLVNcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wcylcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcblxuXG5wIDwtIGdncGxvdChkYXRhLCBhZXMoeCA9IGdyb3VwLCB5ID0gY291bnQsIGZpbGwgPSBncm91cCkpICsgXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BLCBjb2xvciA9IFxcYmxhY2tcXCwgYWxwaGEgPSAwLjYsXG4gICAgICAgICAgICAgICAgIGxpbmV3aWR0aCA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsIHNob3cubGVnZW5kID0gRkFMU0UpICsgdGhlbWVfY2xhc3NpYygpICsgICAgICAgXG4gIHNjYWxlX3lfY29udGludW91cyhicmVha3MgPSBzZXEoMCwgMTAsIGJ5ID0gMikpICsgXG4gIGxhYnMoeCA9IE5VTEwsIHkgPSBcXCMgb2YgUC1TIGxvb3BzIHBlciBnZW5lXFwpICtcbiAgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIDQpKSArXG4gIHN0YXRfc3VtbWFyeShcbiAgICBhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sXG4gICAgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDAuNSxcbiAgICBmaWxsID0gXFxibGFja1xcLCBjb2xvciA9IFxcYmxhY2tcXFxuICApK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBjb252UHZhbHVlKHB2MTIpKSxcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpICtcbiAgdGhlbWUoXG4gICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIGFuZ2xlID0gNDUsICAgICAgIyBSb3RhdGUgeC1heGlzIGxhYmVscyA0NSBkZWdyZWVzXG4gICAgICBoanVzdCA9IDEsICAgICAgICMgQWRqdXN0IGhvcml6b250YWwganVzdGlmaWNhdGlvblxuICAgICAgdmp1c3QgPSAxICAgICAgICAjIEFkanVzdCB2ZXJ0aWNhbCBqdXN0aWZpY2F0aW9uXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcXHRyYW5zcGFyZW50XFwpLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gICAgKVxuXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPX3BzX2JpbmFyeUdyb3VwXFwpXG53aWR0aCA8LSBwYW5lbFNpemUoMC44KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjUpKm1tVG9JbmNoXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
########
#P-S
data <- temp2 %>% dplyr::select(group, num_ps)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)


p <- ggplot(data, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA, color = \black\, alpha = 0.6,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\, show.legend = FALSE) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  labs(x = NULL, y = \# of P-S loops per gene\) +
  coord_cartesian(ylim = c(0, 4)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  )+
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, convPvalue(pv12)),
           color = \black\, hjust = 0, size = 1) +
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )



fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_ps_binaryGroup\)
width <- panelSize(0.8)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-E

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiX3Atbl9lbnNlbWJsTGlzdC50c3ZcIikpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXCJQLVBcIiwgXCJQLUVcIiwgXCJQLVNcIiwgXCJQLVhcIikpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFwiX1wiKSlcblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX2RUQUdfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9kVEFHX0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcIikpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXCJnZW5lXCIgPSBcImVuc2VtYmxfZ2VuZV9pZFwiKSkgJT4lIFxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxuXG5mY0N1dG9mZiA8LSAwLjVcbmRpZmZDdXRvZmYgPC0gMC4yXG4jIFxudGVtcCA8LSB0ZW1wICU+JVxuICBkcGx5cjo6bXV0YXRlKGdyb3VwID0gaWZlbHNlKG1lYW5fZGlmZl9zY29yZSA8IC1kaWZmQ3V0b2ZmLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPCAtZmNDdXRvZmYsIDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPGZjQ3V0b2ZmLCAyLCAzKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKG1lYW5fZGlmZl9zY29yZSA8IGRpZmZDdXRvZmYsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPCAtZmNDdXRvZmYsIDQsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDwgZmNDdXRvZmYsIDUsIDYpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKHNocmlua2VkX2xvZzJGQyA8IC1mY0N1dG9mZiwgNyxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPCBmY0N1dG9mZiwgOCwgOSkpKSkpXG5cblxuZ2VuZS5ncm91cDEgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMSkpJGdlbmVcbmdlbmUuZ3JvdXAyIDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDIpKSRnZW5lXG5nZW5lLmdyb3VwMyA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAzKSkkZ2VuZVxuZ2VuZS5ncm91cDQgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNCkpJGdlbmVcbmdlbmUuZ3JvdXA1IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDUpKSRnZW5lXG5nZW5lLmdyb3VwNiA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA2KSkkZ2VuZVxuZ2VuZS5ncm91cDcgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNykpJGdlbmVcbmdlbmUuZ3JvdXA4IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDgpKSRnZW5lXG5nZW5lLmdyb3VwOSA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA5KSkkZ2VuZVxuXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMSkpLCBoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAxLnRzdlwiKSwgc2VwID0gXCJcXHRcIilcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAyKSksIGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDIudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDMpKSwgaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMy50c3ZcIiksIHNlcCA9IFwiXFx0XCIpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNCkpLCBoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA0LnRzdlwiKSwgc2VwID0gXCJcXHRcIilcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA1KSksIGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDUudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDYpKSwgaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwNi50c3ZcIiksIHNlcCA9IFwiXFx0XCIpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNykpLCBoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA3LnRzdlwiKSwgc2VwID0gXCJcXHRcIilcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA4KSksIGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDkpKSwgaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwOS50c3ZcIiksIHNlcCA9IFwiXFx0XCIpXG5cblxuIyBBZGRpbmcgZ3JvdXAgaW5mb3JtYXRpb24gdG8gZ2VuZUFubm9cbmdlbmVBbm5vRGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIHVubmVzdChnZW5lKSAlPiUgZHBseXI6Om11dGF0ZShcbiAgZ3JvdXAgPSBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAxLCBcImdyb3VwMVwiLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAyLCBcImdyb3VwMlwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwMywgXCJncm91cDNcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA0LCBcImdyb3VwNFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA1LCBcImdyb3VwNVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwNiwgXCJncm91cDZcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA3LCBcImdyb3VwN1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA4LCBcImdyb3VwOFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwOSwgXCJncm91cDlcIiwgTkEpKSkpKSkpKSlcbilcblxuXG5gYGAifQ== -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1,\n                peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n\n\n## Dividing genes into groups\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO),\n            mean_distance = mean(distance),\n            .groups = 'drop')\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nmaxLog2FC = 2\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  drop_na(shrinked_log2FC)\n\n\nfcCutoff <- 0.5\ndiffCutoff <- 0.2\n# \ntemp <- temp %>%\n  dplyr::mutate(group = ifelse(mean_diff_score < -diffCutoff,\n                               ifelse(shrinked_log2FC < -fcCutoff, 1,\n                                      ifelse(shrinked_log2FC <fcCutoff, 2, 3)),\n                               ifelse(mean_diff_score < diffCutoff,\n                                      ifelse(shrinked_log2FC < -fcCutoff, 4,\n                                             ifelse(shrinked_log2FC < fcCutoff, 5, 6)),\n                                      ifelse(shrinked_log2FC < -fcCutoff, 7,\n                                             ifelse(shrinked_log2FC < fcCutoff, 8, 9)))))\n\n\ngene.group1 <- (temp %>% dplyr::filter(group == 1))$gene\ngene.group2 <- (temp %>% dplyr::filter(group == 2))$gene\ngene.group3 <- (temp %>% dplyr::filter(group == 3))$gene\ngene.group4 <- (temp %>% dplyr::filter(group == 4))$gene\ngene.group5 <- (temp %>% dplyr::filter(group == 5))$gene\ngene.group6 <- (temp %>% dplyr::filter(group == 6))$gene\ngene.group7 <- (temp %>% dplyr::filter(group == 7))$gene\ngene.group8 <- (temp %>% dplyr::filter(group == 8))$gene\ngene.group9 <- (temp %>% dplyr::filter(group == 9))$gene\n\nfwrite((temp %>% dplyr::filter(group == 1)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 2)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 3)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group3.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 4)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group4.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 5)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 6)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group6.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 7)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group7.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 8)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 9)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group9.tsv\\), sep = \\\\t\\)\n\n\n# Adding group information to geneAnno\ngeneAnnoData <- geneAnnoData %>% unnest(gene) %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\,\n                        ifelse(gene %in% gene.group3, \\group3\\,\n                               ifelse(gene %in% gene.group4, \\group4\\,\n                                      ifelse(gene %in% gene.group5, \\group5\\,\n                                             ifelse(gene %in% gene.group6, \\group6\\,\n                                                    ifelse(gene %in% gene.group7, \\group7\\,\n                                                           ifelse(gene %in% gene.group8, \\group8\\,\n                                                                  ifelse(gene %in% gene.group9, \\group9\\, NA)))))))))\n)\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)


fcCutoff <- 0.5
diffCutoff <- 0.2
# 
temp <- temp %>%
  dplyr::mutate(group = ifelse(mean_diff_score < -diffCutoff,
                               ifelse(shrinked_log2FC < -fcCutoff, 1,
                                      ifelse(shrinked_log2FC <fcCutoff, 2, 3)),
                               ifelse(mean_diff_score < diffCutoff,
                                      ifelse(shrinked_log2FC < -fcCutoff, 4,
                                             ifelse(shrinked_log2FC < fcCutoff, 5, 6)),
                                      ifelse(shrinked_log2FC < -fcCutoff, 7,
                                             ifelse(shrinked_log2FC < fcCutoff, 8, 9)))))


gene.group1 <- (temp %>% dplyr::filter(group == 1))$gene
gene.group2 <- (temp %>% dplyr::filter(group == 2))$gene
gene.group3 <- (temp %>% dplyr::filter(group == 3))$gene
gene.group4 <- (temp %>% dplyr::filter(group == 4))$gene
gene.group5 <- (temp %>% dplyr::filter(group == 5))$gene
gene.group6 <- (temp %>% dplyr::filter(group == 6))$gene
gene.group7 <- (temp %>% dplyr::filter(group == 7))$gene
gene.group8 <- (temp %>% dplyr::filter(group == 8))$gene
gene.group9 <- (temp %>% dplyr::filter(group == 9))$gene

fwrite((temp %>% dplyr::filter(group == 1)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 2)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 3)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group3.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 4)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group4.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 5)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 6)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group6.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 7)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group7.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 8)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 9)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group9.tsv\), sep = \\t\)


# Adding group information to geneAnno
geneAnnoData <- geneAnnoData %>% unnest(gene) %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\,
                        ifelse(gene %in% gene.group3, \group3\,
                               ifelse(gene %in% gene.group4, \group4\,
                                      ifelse(gene %in% gene.group5, \group5\,
                                             ifelse(gene %in% gene.group6, \group6\,
                                                    ifelse(gene %in% gene.group7, \group7\,
                                                           ifelse(gene %in% gene.group8, \group8\,
                                                                  ifelse(gene %in% gene.group9, \group9\, NA)))))))))
)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSlcblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX2RUQUdfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9kVEFHX0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxuXG5mY0N1dG9mZiA8LSAwLjVcbmRpZmZDdXRvZmYgPC0gMC4yXG4jIFxudGVtcCA8LSB0ZW1wICU+JVxuICBkcGx5cjo6bXV0YXRlKGdyb3VwID0gaWZlbHNlKG1lYW5fZGlmZl9zY29yZSA8IC1kaWZmQ3V0b2ZmLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPCAtZmNDdXRvZmYsIDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPGZjQ3V0b2ZmLCAyLCAzKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKG1lYW5fZGlmZl9zY29yZSA8IGRpZmZDdXRvZmYsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPCAtZmNDdXRvZmYsIDQsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDwgZmNDdXRvZmYsIDUsIDYpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKHNocmlua2VkX2xvZzJGQyA8IC1mY0N1dG9mZiwgNyxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPCBmY0N1dG9mZiwgOCwgOSkpKSkpXG5cblxuZ2VuZS5ncm91cDEgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMSkpJGdlbmVcbmdlbmUuZ3JvdXAyIDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDIpKSRnZW5lXG5nZW5lLmdyb3VwMyA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAzKSkkZ2VuZVxuZ2VuZS5ncm91cDQgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNCkpJGdlbmVcbmdlbmUuZ3JvdXA1IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDUpKSRnZW5lXG5nZW5lLmdyb3VwNiA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA2KSkkZ2VuZVxuZ2VuZS5ncm91cDcgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNykpJGdlbmVcbmdlbmUuZ3JvdXA4IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDgpKSRnZW5lXG5nZW5lLmdyb3VwOSA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA5KSkkZ2VuZVxuXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMSkpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAxLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAyKSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDIudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDMpKSwgaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMy50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNCkpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA0LnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA1KSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDUudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDYpKSwgaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwNi50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNykpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA3LnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA4KSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDkpKSwgaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwOS50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5cblxuIyBBZGRpbmcgZ3JvdXAgaW5mb3JtYXRpb24gdG8gZ2VuZUFubm9cbmdlbmVBbm5vRGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIHVubmVzdChnZW5lKSAlPiUgZHBseXI6Om11dGF0ZShcbiAgZ3JvdXAgPSBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAxLCBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAyLCBcXGdyb3VwMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwMywgXFxncm91cDNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA0LCBcXGdyb3VwNFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA1LCBcXGdyb3VwNVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwNiwgXFxncm91cDZcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA3LCBcXGdyb3VwN1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA4LCBcXGdyb3VwOFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwOSwgXFxncm91cDlcXCwgTkEpKSkpKSkpKSlcbilcblxuXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1,\n                peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n\n\n## Dividing genes into groups\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO),\n            mean_distance = mean(distance),\n            .groups = 'drop')\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nmaxLog2FC = 2\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  drop_na(shrinked_log2FC)\n\n\nfcCutoff <- 0.5\ndiffCutoff <- 0.2\n# \ntemp <- temp %>%\n  dplyr::mutate(group = ifelse(mean_diff_score < -diffCutoff,\n                               ifelse(shrinked_log2FC < -fcCutoff, 1,\n                                      ifelse(shrinked_log2FC <fcCutoff, 2, 3)),\n                               ifelse(mean_diff_score < diffCutoff,\n                                      ifelse(shrinked_log2FC < -fcCutoff, 4,\n                                             ifelse(shrinked_log2FC < fcCutoff, 5, 6)),\n                                      ifelse(shrinked_log2FC < -fcCutoff, 7,\n                                             ifelse(shrinked_log2FC < fcCutoff, 8, 9)))))\n\n\ngene.group1 <- (temp %>% dplyr::filter(group == 1))$gene\ngene.group2 <- (temp %>% dplyr::filter(group == 2))$gene\ngene.group3 <- (temp %>% dplyr::filter(group == 3))$gene\ngene.group4 <- (temp %>% dplyr::filter(group == 4))$gene\ngene.group5 <- (temp %>% dplyr::filter(group == 5))$gene\ngene.group6 <- (temp %>% dplyr::filter(group == 6))$gene\ngene.group7 <- (temp %>% dplyr::filter(group == 7))$gene\ngene.group8 <- (temp %>% dplyr::filter(group == 8))$gene\ngene.group9 <- (temp %>% dplyr::filter(group == 9))$gene\n\nfwrite((temp %>% dplyr::filter(group == 1)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 2)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 3)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group3.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 4)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group4.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 5)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 6)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group6.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 7)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group7.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 8)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 9)), here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group9.tsv\\), sep = \\\\t\\)\n\n\n# Adding group information to geneAnno\ngeneAnnoData <- geneAnnoData %>% unnest(gene) %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\,\n                        ifelse(gene %in% gene.group3, \\group3\\,\n                               ifelse(gene %in% gene.group4, \\group4\\,\n                                      ifelse(gene %in% gene.group5, \\group5\\,\n                                             ifelse(gene %in% gene.group6, \\group6\\,\n                                                    ifelse(gene %in% gene.group7, \\group7\\,\n                                                           ifelse(gene %in% gene.group8, \\group8\\,\n                                                                  ifelse(gene %in% gene.group9, \\group9\\, NA)))))))))\n)\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSlcblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX2RUQUdfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9kVEFHX0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxuXG5mY0N1dG9mZiA8LSAwLjVcbmRpZmZDdXRvZmYgPC0gMC4yXG4jIFxudGVtcCA8LSB0ZW1wICU+JVxuICBkcGx5cjo6bXV0YXRlKGdyb3VwID0gaWZlbHNlKG1lYW5fZGlmZl9zY29yZSA8IC1kaWZmQ3V0b2ZmLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPCAtZmNDdXRvZmYsIDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPGZjQ3V0b2ZmLCAyLCAzKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKG1lYW5fZGlmZl9zY29yZSA8IGRpZmZDdXRvZmYsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPCAtZmNDdXRvZmYsIDQsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDwgZmNDdXRvZmYsIDUsIDYpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKHNocmlua2VkX2xvZzJGQyA8IC1mY0N1dG9mZiwgNyxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPCBmY0N1dG9mZiwgOCwgOSkpKSkpXG5cblxuZ2VuZS5ncm91cDEgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMSkpJGdlbmVcbmdlbmUuZ3JvdXAyIDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDIpKSRnZW5lXG5nZW5lLmdyb3VwMyA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAzKSkkZ2VuZVxuZ2VuZS5ncm91cDQgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNCkpJGdlbmVcbmdlbmUuZ3JvdXA1IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDUpKSRnZW5lXG5nZW5lLmdyb3VwNiA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA2KSkkZ2VuZVxuZ2VuZS5ncm91cDcgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNykpJGdlbmVcbmdlbmUuZ3JvdXA4IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDgpKSRnZW5lXG5nZW5lLmdyb3VwOSA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA5KSkkZ2VuZVxuXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMSkpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAxLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAyKSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDIudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDMpKSwgaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMy50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNCkpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA0LnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA1KSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDUudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDYpKSwgaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwNi50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNykpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA3LnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA4KSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDkpKSwgaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwOS50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5cblxuIyBBZGRpbmcgZ3JvdXAgaW5mb3JtYXRpb24gdG8gZ2VuZUFubm9cbmdlbmVBbm5vRGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIHVubmVzdChnZW5lKSAlPiUgZHBseXI6Om11dGF0ZShcbiAgZ3JvdXAgPSBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAxLCBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAyLCBcXGdyb3VwMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwMywgXFxncm91cDNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA0LCBcXGdyb3VwNFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA1LCBcXGdyb3VwNVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwNiwgXFxncm91cDZcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA3LCBcXGdyb3VwN1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA4LCBcXGdyb3VwOFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwOSwgXFxncm91cDlcXCwgTkEpKSkpKSkpKSlcbilcblxuXG5gYGBcbmBgYCJ9 -->

```r
```r
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)


fcCutoff <- 0.5
diffCutoff <- 0.2
# 
temp <- temp %>%
  dplyr::mutate(group = ifelse(mean_diff_score < -diffCutoff,
                               ifelse(shrinked_log2FC < -fcCutoff, 1,
                                      ifelse(shrinked_log2FC <fcCutoff, 2, 3)),
                               ifelse(mean_diff_score < diffCutoff,
                                      ifelse(shrinked_log2FC < -fcCutoff, 4,
                                             ifelse(shrinked_log2FC < fcCutoff, 5, 6)),
                                      ifelse(shrinked_log2FC < -fcCutoff, 7,
                                             ifelse(shrinked_log2FC < fcCutoff, 8, 9)))))


gene.group1 <- (temp %>% dplyr::filter(group == 1))$gene
gene.group2 <- (temp %>% dplyr::filter(group == 2))$gene
gene.group3 <- (temp %>% dplyr::filter(group == 3))$gene
gene.group4 <- (temp %>% dplyr::filter(group == 4))$gene
gene.group5 <- (temp %>% dplyr::filter(group == 5))$gene
gene.group6 <- (temp %>% dplyr::filter(group == 6))$gene
gene.group7 <- (temp %>% dplyr::filter(group == 7))$gene
gene.group8 <- (temp %>% dplyr::filter(group == 8))$gene
gene.group9 <- (temp %>% dplyr::filter(group == 9))$gene

fwrite((temp %>% dplyr::filter(group == 1)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 2)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 3)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group3.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 4)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group4.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 5)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 6)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group6.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 7)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group7.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 8)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 9)), here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group9.tsv\), sep = \\t\)


# Adding group information to geneAnno
geneAnnoData <- geneAnnoData %>% unnest(gene) %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\,
                        ifelse(gene %in% gene.group3, \group3\,
                               ifelse(gene %in% gene.group4, \group4\,
                                      ifelse(gene %in% gene.group5, \group5\,
                                             ifelse(gene %in% gene.group6, \group6\,
                                                    ifelse(gene %in% gene.group7, \group7\,
                                                           ifelse(gene %in% gene.group8, \group8\,
                                                                  ifelse(gene %in% gene.group9, \group9\, NA)))))))))
)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-S

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuR08xIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuR08yIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuR081IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuR084IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwOCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuXG5HTzEuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzEpXG5HTzIuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzIpXG5HTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzUpXG5HTzQuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzgpXG5cbnN1YnNldDEgPC0gR08xLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcImdyb3VwMVwiKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBnciA9IHNhcHBseShHZW5lUmF0aW8sIGZ1bmN0aW9uKHgpIHtcbiAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuICAgICAgcGFydHMgPC0gdW5saXN0KHN0cnNwbGl0KHgsIFwiL1wiKSlcbiAgICAgICMgQ29udmVydCB0byBudW1lcmljIGFuZCBwZXJmb3JtIHRoZSBkaXZpc2lvblxuICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuICAgIH0pXG4gICkgJT4lIGRwbHlyOjphcnJhbmdlKGRlc2MoZ3IpKVxuc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXCJncm91cDJcIikgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXCIvXCJcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcIi9cIikpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDMgPC0gR08zLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbixHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwiZ3JvdXAzXCIpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGdyID0gc2FwcGx5KEdlbmVSYXRpbywgZnVuY3Rpb24oeCkge1xuICAgICAgIyBTcGxpdCB0aGUgc3RyaW5nIGJ5IFwiL1wiXG4gICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuICAgICAgIyBDb252ZXJ0IHRvIG51bWVyaWMgYW5kIHBlcmZvcm0gdGhlIGRpdmlzaW9uXG4gICAgICBhcy5udW1lcmljKHBhcnRzWzFdKSAvIGFzLm51bWVyaWMocGFydHNbMl0pXG4gICAgfSlcbiAgKSAlPiUgZHBseXI6OmFycmFuZ2UoZGVzYyhncikpXG5cbkdPbGlzdCA8LSBmYWN0b3IoYyhcIkdPOjAwMzMwMDJcIiwgXCJHTzowMDcwMzczXCIsIFwiR086MDA0ODczMFwiLCBcIkdPOjAwMzExMDNcIixcbiAgICAgICAgICAgICAgICAgXCJHTzowMDIyNjEzXCIsIFwiR086MDA1MDc2N1wiLCBcIkdPOjAwMzQ0NzBcIiwgXCJHTzowMDE2MDU1XCIsIFxuICAgICAgICAgICAgICAgICBcIkdPOjAwMDYzOTdcIiwgXCJHTzowMDMwOTAwXCIsIFwiR086MDAwODM4MFwiKSlcblxuZGF0YSA8LSBiaW5kX3Jvd3MoYmluZF9yb3dzKHN1YnNldDEsIHN1YnNldDIpLCBzdWJzZXQzKSAlPiVcbiAgZHBseXI6OmZpbHRlcihJRCAlaW4lIEdPbGlzdClcblxuZGVzY09yZGVyIDwtIHNvcnQodW5pcXVlKGRhdGEkRGVzY3JpcHRpb24pKVtjKDEsIDIsIDUsIDcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAzLCA0LCA2LCA4LCA5LCAxMCwgMTEpXVxuXG5wIDwtIGdncGxvdChkYXRhLCBhZXMoeCA9IGdyb3VwLCB5ID0gZmFjdG9yKERlc2NyaXB0aW9uLCBsZXZlbCA9IGRlc2NPcmRlciksIGNvbG9yID0gcC5hZGp1c3QsIHNpemUgPSBncikpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuICBzY2FsZV9jb2xvcl9ncmFkaWVudChsb3cgPSBcInJlZFwiLCBoaWdoID0gXCJibHVlXCIsIGxpbWl0cyA9IGMoMCwgMC4wNSkpICtcbiAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygwLCAzKSkgK1xuICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuICB0aGVtZShheGlzLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAgIyBTZXQgYXhpcyB0ZXh0IHNpemVcbiAgICAgICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICMgU2V0IGF4aXMgdGl0bGUgc2l6ZSAoaWYgbm90IHJlbW92ZWQpXG4gICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuICAgICAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpKSBcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFwiLi5cIiwgXCJHT1wiLCBcIkdPX2dyb3Vwc1wiKVxuaGVpZ2h0ID0gMlxud2lkdGggPSAzLjVcbnN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIiksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYCJ9 -->\n\n```r\nGO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO5 <- enrichGO(gene = gene.group5, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO8 <- enrichGO(gene = gene.group8, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\n\nGO1.df <- as.data.frame(GO1)\nGO2.df <- as.data.frame(GO2)\nGO3.df <- as.data.frame(GO5)\nGO4.df <- as.data.frame(GO8)\n\nsubset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\group1\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\nsubset2 <- GO2.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \\group2\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\nsubset3 <- GO3.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \\group3\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\n\nGOlist <- factor(c(\\GO:0033002\\, \\GO:0070373\\, \\GO:0048730\\, \\GO:0031103\\,\n                 \\GO:0022613\\, \\GO:0050767\\, \\GO:0034470\\, \\GO:0016055\\, \n                 \\GO:0006397\\, \\GO:0030900\\, \\GO:0008380\\))\n\ndata <- bind_rows(bind_rows(subset1, subset2), subset3) %>%\n  dplyr::filter(ID %in% GOlist)\n\ndescOrder <- sort(unique(data$Description))[c(1, 2, 5, 7,\n                                 3, 4, 6, 8, 9, 10, 11)]\n\np <- ggplot(data, aes(x = group, y = factor(Description, level = descOrder), color = p.adjust, size = gr)) + \n  geom_point() + theme_bw() +\n  scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n  scale_size_continuous(range = c(0, 3)) +\n  labs(x = NULL, y = NULL) +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups\\)\nheight = 2\nwidth = 3.5\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
GO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO5 <- enrichGO(gene = gene.group5, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO8 <- enrichGO(gene = gene.group8, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)

GO1.df <- as.data.frame(GO1)
GO2.df <- as.data.frame(GO2)
GO3.df <- as.data.frame(GO5)
GO4.df <- as.data.frame(GO8)

subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \group1\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset2 <- GO2.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \group2\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset3 <- GO3.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \group3\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

GOlist <- factor(c(\GO:0033002\, \GO:0070373\, \GO:0048730\, \GO:0031103\,
                 \GO:0022613\, \GO:0050767\, \GO:0034470\, \GO:0016055\, 
                 \GO:0006397\, \GO:0030900\, \GO:0008380\))

data <- bind_rows(bind_rows(subset1, subset2), subset3) %>%
  dplyr::filter(ID %in% GOlist)

descOrder <- sort(unique(data$Description))[c(1, 2, 5, 7,
                                 3, 4, 6, 8, 9, 10, 11)]

p <- ggplot(data, aes(x = group, y = factor(Description, level = descOrder), color = p.adjust, size = gr)) + 
  geom_point() + theme_bw() +
  scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
  scale_size_continuous(range = c(0, 3)) +
  labs(x = NULL, y = NULL) +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- here(figDir, \..\, \GO\, \GO_groups\)
height = 2
width = 3.5
svglite(paste0(fileName, \.svg\), height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuR08xIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR08yIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR081IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR084IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwOCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuXG5HTzEuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzEpXG5HTzIuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzIpXG5HTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzUpXG5HTzQuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzgpXG5cbnN1YnNldDEgPC0gR08xLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXGdyb3VwMVxcKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBnciA9IHNhcHBseShHZW5lUmF0aW8sIGZ1bmN0aW9uKHgpIHtcbiAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuICAgICAgcGFydHMgPC0gdW5saXN0KHN0cnNwbGl0KHgsIFxcL1xcKSlcbiAgICAgICMgQ29udmVydCB0byBudW1lcmljIGFuZCBwZXJmb3JtIHRoZSBkaXZpc2lvblxuICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuICAgIH0pXG4gICkgJT4lIGRwbHlyOjphcnJhbmdlKGRlc2MoZ3IpKVxuc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxncm91cDJcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDMgPC0gR08zLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbixHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcZ3JvdXAzXFwpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGdyID0gc2FwcGx5KEdlbmVSYXRpbywgZnVuY3Rpb24oeCkge1xuICAgICAgIyBTcGxpdCB0aGUgc3RyaW5nIGJ5IFxcL1xcXG4gICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuICAgICAgIyBDb252ZXJ0IHRvIG51bWVyaWMgYW5kIHBlcmZvcm0gdGhlIGRpdmlzaW9uXG4gICAgICBhcy5udW1lcmljKHBhcnRzWzFdKSAvIGFzLm51bWVyaWMocGFydHNbMl0pXG4gICAgfSlcbiAgKSAlPiUgZHBseXI6OmFycmFuZ2UoZGVzYyhncikpXG5cbkdPbGlzdCA8LSBmYWN0b3IoYyhcXEdPOjAwMzMwMDJcXCwgXFxHTzowMDcwMzczXFwsIFxcR086MDA0ODczMFxcLCBcXEdPOjAwMzExMDNcXCxcbiAgICAgICAgICAgICAgICAgXFxHTzowMDIyNjEzXFwsIFxcR086MDA1MDc2N1xcLCBcXEdPOjAwMzQ0NzBcXCwgXFxHTzowMDE2MDU1XFwsIFxuICAgICAgICAgICAgICAgICBcXEdPOjAwMDYzOTdcXCwgXFxHTzowMDMwOTAwXFwsIFxcR086MDAwODM4MFxcKSlcblxuZGF0YSA8LSBiaW5kX3Jvd3MoYmluZF9yb3dzKHN1YnNldDEsIHN1YnNldDIpLCBzdWJzZXQzKSAlPiVcbiAgZHBseXI6OmZpbHRlcihJRCAlaW4lIEdPbGlzdClcblxuZGVzY09yZGVyIDwtIHNvcnQodW5pcXVlKGRhdGEkRGVzY3JpcHRpb24pKVtjKDEsIDIsIDUsIDcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAzLCA0LCA2LCA4LCA5LCAxMCwgMTEpXVxuXG5wIDwtIGdncGxvdChkYXRhLCBhZXMoeCA9IGdyb3VwLCB5ID0gZmFjdG9yKERlc2NyaXB0aW9uLCBsZXZlbCA9IGRlc2NPcmRlciksIGNvbG9yID0gcC5hZGp1c3QsIHNpemUgPSBncikpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuICBzY2FsZV9jb2xvcl9ncmFkaWVudChsb3cgPSBcXHJlZFxcLCBoaWdoID0gXFxibHVlXFwsIGxpbWl0cyA9IGMoMCwgMC4wNSkpICtcbiAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygwLCAzKSkgK1xuICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuICB0aGVtZShheGlzLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAgIyBTZXQgYXhpcyB0ZXh0IHNpemVcbiAgICAgICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICMgU2V0IGF4aXMgdGl0bGUgc2l6ZSAoaWYgbm90IHJlbW92ZWQpXG4gICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuICAgICAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpKSBcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc1xcKVxuaGVpZ2h0ID0gMlxud2lkdGggPSAzLjVcbnN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\nGO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO5 <- enrichGO(gene = gene.group5, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO8 <- enrichGO(gene = gene.group8, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\n\nGO1.df <- as.data.frame(GO1)\nGO2.df <- as.data.frame(GO2)\nGO3.df <- as.data.frame(GO5)\nGO4.df <- as.data.frame(GO8)\n\nsubset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\group1\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\nsubset2 <- GO2.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \\group2\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\nsubset3 <- GO3.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \\group3\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\n\nGOlist <- factor(c(\\GO:0033002\\, \\GO:0070373\\, \\GO:0048730\\, \\GO:0031103\\,\n                 \\GO:0022613\\, \\GO:0050767\\, \\GO:0034470\\, \\GO:0016055\\, \n                 \\GO:0006397\\, \\GO:0030900\\, \\GO:0008380\\))\n\ndata <- bind_rows(bind_rows(subset1, subset2), subset3) %>%\n  dplyr::filter(ID %in% GOlist)\n\ndescOrder <- sort(unique(data$Description))[c(1, 2, 5, 7,\n                                 3, 4, 6, 8, 9, 10, 11)]\n\np <- ggplot(data, aes(x = group, y = factor(Description, level = descOrder), color = p.adjust, size = gr)) + \n  geom_point() + theme_bw() +\n  scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n  scale_size_continuous(range = c(0, 3)) +\n  labs(x = NULL, y = NULL) +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups\\)\nheight = 2\nwidth = 3.5\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuR08xIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR08yIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR081IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR084IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwOCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuXG5HTzEuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzEpXG5HTzIuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzIpXG5HTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzUpXG5HTzQuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzgpXG5cbnN1YnNldDEgPC0gR08xLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXGdyb3VwMVxcKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBnciA9IHNhcHBseShHZW5lUmF0aW8sIGZ1bmN0aW9uKHgpIHtcbiAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuICAgICAgcGFydHMgPC0gdW5saXN0KHN0cnNwbGl0KHgsIFxcL1xcKSlcbiAgICAgICMgQ29udmVydCB0byBudW1lcmljIGFuZCBwZXJmb3JtIHRoZSBkaXZpc2lvblxuICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuICAgIH0pXG4gICkgJT4lIGRwbHlyOjphcnJhbmdlKGRlc2MoZ3IpKVxuc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxncm91cDJcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDMgPC0gR08zLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbixHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcZ3JvdXAzXFwpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGdyID0gc2FwcGx5KEdlbmVSYXRpbywgZnVuY3Rpb24oeCkge1xuICAgICAgIyBTcGxpdCB0aGUgc3RyaW5nIGJ5IFxcL1xcXG4gICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuICAgICAgIyBDb252ZXJ0IHRvIG51bWVyaWMgYW5kIHBlcmZvcm0gdGhlIGRpdmlzaW9uXG4gICAgICBhcy5udW1lcmljKHBhcnRzWzFdKSAvIGFzLm51bWVyaWMocGFydHNbMl0pXG4gICAgfSlcbiAgKSAlPiUgZHBseXI6OmFycmFuZ2UoZGVzYyhncikpXG5cbkdPbGlzdCA8LSBmYWN0b3IoYyhcXEdPOjAwMzMwMDJcXCwgXFxHTzowMDcwMzczXFwsIFxcR086MDA0ODczMFxcLCBcXEdPOjAwMzExMDNcXCxcbiAgICAgICAgICAgICAgICAgXFxHTzowMDIyNjEzXFwsIFxcR086MDA1MDc2N1xcLCBcXEdPOjAwMzQ0NzBcXCwgXFxHTzowMDE2MDU1XFwsIFxuICAgICAgICAgICAgICAgICBcXEdPOjAwMDYzOTdcXCwgXFxHTzowMDMwOTAwXFwsIFxcR086MDAwODM4MFxcKSlcblxuZGF0YSA8LSBiaW5kX3Jvd3MoYmluZF9yb3dzKHN1YnNldDEsIHN1YnNldDIpLCBzdWJzZXQzKSAlPiVcbiAgZHBseXI6OmZpbHRlcihJRCAlaW4lIEdPbGlzdClcblxuZGVzY09yZGVyIDwtIHNvcnQodW5pcXVlKGRhdGEkRGVzY3JpcHRpb24pKVtjKDEsIDIsIDUsIDcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAzLCA0LCA2LCA4LCA5LCAxMCwgMTEpXVxuXG5wIDwtIGdncGxvdChkYXRhLCBhZXMoeCA9IGdyb3VwLCB5ID0gZmFjdG9yKERlc2NyaXB0aW9uLCBsZXZlbCA9IGRlc2NPcmRlciksIGNvbG9yID0gcC5hZGp1c3QsIHNpemUgPSBncikpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuICBzY2FsZV9jb2xvcl9ncmFkaWVudChsb3cgPSBcXHJlZFxcLCBoaWdoID0gXFxibHVlXFwsIGxpbWl0cyA9IGMoMCwgMC4wNSkpICtcbiAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygwLCAzKSkgK1xuICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuICB0aGVtZShheGlzLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAgIyBTZXQgYXhpcyB0ZXh0IHNpemVcbiAgICAgICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICMgU2V0IGF4aXMgdGl0bGUgc2l6ZSAoaWYgbm90IHJlbW92ZWQpXG4gICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuICAgICAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpKSBcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc1xcKVxuaGVpZ2h0ID0gMlxud2lkdGggPSAzLjVcbnN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
GO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO5 <- enrichGO(gene = gene.group5, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO8 <- enrichGO(gene = gene.group8, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)

GO1.df <- as.data.frame(GO1)
GO2.df <- as.data.frame(GO2)
GO3.df <- as.data.frame(GO5)
GO4.df <- as.data.frame(GO8)

subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \group1\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset2 <- GO2.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \group2\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset3 <- GO3.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \group3\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

GOlist <- factor(c(\GO:0033002\, \GO:0070373\, \GO:0048730\, \GO:0031103\,
                 \GO:0022613\, \GO:0050767\, \GO:0034470\, \GO:0016055\, 
                 \GO:0006397\, \GO:0030900\, \GO:0008380\))

data <- bind_rows(bind_rows(subset1, subset2), subset3) %>%
  dplyr::filter(ID %in% GOlist)

descOrder <- sort(unique(data$Description))[c(1, 2, 5, 7,
                                 3, 4, 6, 8, 9, 10, 11)]

p <- ggplot(data, aes(x = group, y = factor(Description, level = descOrder), color = p.adjust, size = gr)) + 
  geom_point() + theme_bw() +
  scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
  scale_size_continuous(range = c(0, 3)) +
  labs(x = NULL, y = NULL) +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- here(figDir, \..\, \GO\, \GO_groups\)
height = 2
width = 3.5
svglite(paste0(fileName, \.svg\), height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### dTAG
##### - Splitting genes to groups

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJEYUdWamEybHVaeUJoZG1WeVlXZGxJR1JwYzNSaGJtTmxJRzltSUd4dmIzQnpJSEJsY2lCblpXNWxYRzRqSUhSbGJYQWdhWE1nWVNCMGFXSmliR1VnZDJobGNtVWdaR1ZzZEdFZ2JHOXZjQ0JoYm1RZ2JHOW5NbVpqSUdGeVpTQnRaWEpuWldSY2JuUmxiWEFrWjNKdmRYQWdQQzBnWm1GamRHOXlLSFJsYlhBa1ozSnZkWEFwWEc1Y2JpTmNiblJsYlhBZ1BDMGdkR1Z0Y0NBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0FsYVc0bElHTW9NU3dnTWl3Z05Td2dPQ2twWEc1Y2JseHVaMlYwVUhaaGJGZHBiR052ZUNBOExTQm1kVzVqZEdsdmJpaGtZWFJoTENCbmNtOTFjREVzSUdkeWIzVndNaWw3WEc0Z0lHUnBjM1JoYm1ObE1TQThMU0FvWkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaG5jbTkxY0NBOVBXZHliM1Z3TVNrZ0tTUnRaV0Z1WDJScGMzUmhibU5sWEc0Z0lHUnBjM1JoYm1ObE1pQThMU0FvWkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaG5jbTkxY0NBOVBXZHliM1Z3TWlrZ0tTUnRaV0Z1WDJScGMzUmhibU5sWEc0Z0lIZHBiQ0E4TFNCM2FXeGpiM2d1ZEdWemRDaGthWE4wWVc1alpURXNJR1JwYzNSaGJtTmxNaWxjYmlBZ2NtVjBkWEp1S0hkcGJDUndMblpoYkhWbEtWeHVmVnh1WEc1d2RqRXlJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnTVN3Z01pa3NJRFVwWEc1d2RqRTFJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnTVN3Z05Ta3NJRFVwWEc1d2RqRTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnTVN3Z09Da3NJRFVwWEc1d2RqSTFJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnTWl3Z05Ta3NJRFVwWEc1d2RqSTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnTWl3Z09Da3NJRFVwWEc1d2RqVTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnTlN3Z09Da3NJRFVwWEc1Y2JseHVjQ0E4TFNCblozQnNiM1FvZEdWdGNDd2dZV1Z6S0hnZ1BTQm5jbTkxY0N3Z2VTQTlJRzFsWVc1ZlpHbHpkR0Z1WTJVcEtTQXJJR2RsYjIxZmRtbHZiR2x1S0dGbGN5aG1hV3hzSUQwZ1ozSnZkWEFwTENCemFHOTNMbXhsWjJWdVpDQTlJRVpCVEZORktTQXJYRzRnSUdkbGIyMWZZbTk0Y0d4dmRDaDNhV1IwYUNBOUlEQXVNU3dnYjNWMGJHbGxjaTV6YUdGd1pTQTlJRTVCS1NBcklIUm9aVzFsWDJOc1lYTnphV01vS1NBcklITmpZV3hsWDNsZlkyOXVkR2x1ZFc5MWN5aHNZV0psYkhNZ1BTQnNZV0psYkY5cllsOXRZaWtnSzF4dUlDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ1ozSnZkWEFwTENCbWRXNGdQU0J0WldGdUxDQm5aVzl0SUQwZ1hDSndiMmx1ZEZ3aUxDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNaXdnWm1sc2JDQTlJRndpY21Wa1hDSXNJR052Ykc5eUlEMGdYQ0ppYkdGamExd2lLU0FyWEc0Z0lHRnVibTkwWVhSbEtGd2lkR1Y0ZEZ3aUxDQjRJRDBnTVN3Z2VTQTlJREV3TURBd01EQXNJR3hoWW1Wc0lEMGdjR0Z6ZEdVd0tGd2ljSFl4TWpvZ1hDSXNJSEIyTVRJc0lGd2lYRnh1WENJc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkIyTVRVNklGd2lMQ0J3ZGpFMUxDQmNJbHhjYmx3aUxGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p3ZGpFNE9pQmNJaXdnY0hZeE9Dd2dYQ0pjWEc1Y0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0hZeU5Ub2dYQ0lzSUhCMk1qVXNJRndpWEZ4dVhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5CMk1qZzZJRndpTENCd2RqSTRMQ0JjSWx4Y2Jsd2lMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWENKd2RqVTRPaUJjSWl3Z2NIWTFPQ3dnWENKY1hHNWNJaWtzSUZ4dUlDQWdJQ0FnSUNBZ0lDQmpiMnh2Y2lBOUlGd2lZbXhoWTJ0Y0lpd2dhR3AxYzNRZ1BTQXdMQ0J6YVhwbElEMGdNeWxjYmlBZ1hHNGdJRnh1Wm1sc1pVNWhiV1VnUEMwZ2NHRnpkR1V3S0Z3aWMybDZaVjlpWVhKd2JHOTBYMlJwWm1aSGNtOTFjRjlrVkVGSFgzWnpYMFJOVTA5Y0lpbGNibWhsYVdkb2RDQThMU0F6WEc1M2FXUjBhQ0E4TFNBelhHNXdibWNvYUdWeVpTaG1hV2RFYVhJc0lIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hDSXVjRzVuWENJcEtTd2djbVZ6SUQwZ05qQXdMQ0IxYm1sMElEMGdYQ0pwYmx3aUxDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc1d2NtbHVkQ2h3S1Z4dVpHVjJMbTltWmlncFhHNXpkbWRzYVhSbEtHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRndpTG5OMloxd2lLU2tzSUNCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzV3Y21sdWRDaHdLVnh1WkdWMkxtOW1aaWdwWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG4jIENoZWNraW5nIGF2ZXJhZ2UgZGlzdGFuY2Ugb2YgbG9vcHMgcGVyIGdlbmVcbiMgdGVtcCBpcyBhIHRpYmJsZSB3aGVyZSBkZWx0YSBsb29wIGFuZCBsb2cyZmMgYXJlIG1lcmdlZFxudGVtcCRncm91cCA8LSBmYWN0b3IodGVtcCRncm91cClcblxuI1xudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwICVpbiUgYygxLCAyLCA1LCA4KSlcblxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJG1lYW5fZGlzdGFuY2VcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJG1lYW5fZGlzdGFuY2VcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAxLCAyKSwgNSlcbnB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAxLCA1KSwgNSlcbnB2MTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAxLCA4KSwgNSlcbnB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAyLCA1KSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAyLCA4KSwgNSlcbnB2NTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCA1LCA4KSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGdyb3VwLCB5ID0gbWVhbl9kaXN0YW5jZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgc2NhbGVfeV9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMTAwMDAwMCwgbGFiZWwgPSBwYXN0ZTAoXFxwdjEyOiBcXCwgcHYxMiwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxNTogXFwsIHB2MTUsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTg6IFxcLCBwdjE4LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI1OiBcXCwgcHYyNSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyODogXFwsIHB2MjgsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NTg6IFxcLCBwdjU4LCBcXFxcblxcKSwgXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxzaXplX2JhcnBsb3RfZGlmZkdyb3VwX2RUQUdfdnNfRE1TT1xcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
# Checking average distance of loops per gene
# temp is a tibble where delta loop and log2fc are merged
temp$group <- factor(temp$group)

#
temp <- temp %>% dplyr::filter(group %in% c(1, 2, 5, 8))


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$mean_distance
  distance2 <- (data %>% dplyr::filter(group ==group2) )$mean_distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv12 <- round(getPvalWilcox(temp, 1, 2), 5)
pv15 <- round(getPvalWilcox(temp, 1, 5), 5)
pv18 <- round(getPvalWilcox(temp, 1, 8), 5)
pv25 <- round(getPvalWilcox(temp, 2, 5), 5)
pv28 <- round(getPvalWilcox(temp, 2, 8), 5)
pv58 <- round(getPvalWilcox(temp, 5, 8), 5)


p <- ggplot(temp, aes(x = group, y = mean_distance)) + geom_violin(aes(fill = group), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  annotate(\text\, x = 1, y = 1000000, label = paste0(\pv12: \, pv12, \\n\,
                                                      \pv15: \, pv15, \\n\,
                                                      \pv18: \, pv18, \\n\,
                                                      \pv25: \, pv25, \\n\,
                                                      \pv28: \, pv28, \\n\,
                                                      \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 3)
  
  
fileName <- paste0(\size_barplot_diffGroup_dTAG_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QkRhR1ZqYTJsdVp5QmhkbVZ5WVdkbElHUnBjM1JoYm1ObElHOW1JR3h2YjNCeklIQmxjaUJuWlc1bFhHNGpJSFJsYlhBZ2FYTWdZU0IwYVdKaWJHVWdkMmhsY21VZ1pHVnNkR0VnYkc5dmNDQmhibVFnYkc5bk1tWmpJR0Z5WlNCdFpYSm5aV1JjYm5SbGJYQWtaM0p2ZFhBZ1BDMGdabUZqZEc5eUtIUmxiWEFrWjNKdmRYQXBYRzVjYmlOY2JuUmxiWEFnUEMwZ2RHVnRjQ0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhuY205MWNDQWxhVzRsSUdNb01Td2dNaXdnTlN3Z09Da3BYRzVjYmx4dVoyVjBVSFpoYkZkcGJHTnZlQ0E4TFNCbWRXNWpkR2x2Ymloa1lYUmhMQ0JuY205MWNERXNJR2R5YjNWd01pbDdYRzRnSUdScGMzUmhibU5sTVNBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFdkeWIzVndNU2tnS1NSdFpXRnVYMlJwYzNSaGJtTmxYRzRnSUdScGMzUmhibU5sTWlBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFdkeWIzVndNaWtnS1NSdFpXRnVYMlJwYzNSaGJtTmxYRzRnSUhkcGJDQThMU0IzYVd4amIzZ3VkR1Z6ZENoa2FYTjBZVzVqWlRFc0lHUnBjM1JoYm1ObE1pbGNiaUFnY21WMGRYSnVLSGRwYkNSd0xuWmhiSFZsS1Z4dWZWeHVYRzV3ZGpFeUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dNU3dnTWlrc0lEVXBYRzV3ZGpFMUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dNU3dnTlNrc0lEVXBYRzV3ZGpFNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dNU3dnT0Nrc0lEVXBYRzV3ZGpJMUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dNaXdnTlNrc0lEVXBYRzV3ZGpJNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dNaXdnT0Nrc0lEVXBYRzV3ZGpVNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dOU3dnT0Nrc0lEVXBYRzVjYmx4dWNDQThMU0JuWjNCc2IzUW9kR1Z0Y0N3Z1lXVnpLSGdnUFNCbmNtOTFjQ3dnZVNBOUlHMWxZVzVmWkdsemRHRnVZMlVwS1NBcklHZGxiMjFmZG1sdmJHbHVLR0ZsY3lobWFXeHNJRDBnWjNKdmRYQXBMQ0J6YUc5M0xteGxaMlZ1WkNBOUlFWkJURk5GS1NBclhHNGdJR2RsYjIxZlltOTRjR3h2ZENoM2FXUjBhQ0E5SURBdU1Td2diM1YwYkdsbGNpNXphR0Z3WlNBOUlFNUJLU0FySUhSb1pXMWxYMk5zWVhOemFXTW9LU0FySUhOallXeGxYM2xmWTI5dWRHbHVkVzkxY3loc1lXSmxiSE1nUFNCc1lXSmxiRjlyWWw5dFlpa2dLMXh1SUNCemRHRjBYM04xYlcxaGNua29ZV1Z6S0dkeWIzVndJRDBnWjNKdmRYQXBMQ0JtZFc0Z1BTQnRaV0Z1TENCblpXOXRJRDBnWEZ4d2IybHVkRnhjTENCemFHRndaU0E5SURJeExDQnphWHBsSUQwZ01pd2dabWxzYkNBOUlGeGNjbVZrWEZ3c0lHTnZiRzl5SUQwZ1hGeGliR0ZqYTF4Y0tTQXJYRzRnSUdGdWJtOTBZWFJsS0Z4Y2RHVjRkRnhjTENCNElEMGdNU3dnZVNBOUlERXdNREF3TURBc0lHeGhZbVZzSUQwZ2NHRnpkR1V3S0Z4Y2NIWXhNam9nWEZ3c0lIQjJNVElzSUZ4Y1hGeHVYRndzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQjJNVFU2SUZ4Y0xDQndkakUxTENCY1hGeGNibHhjTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hGeHdkakU0T2lCY1hDd2djSFl4T0N3Z1hGeGNYRzVjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjSFl5TlRvZ1hGd3NJSEIyTWpVc0lGeGNYRnh1WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEIyTWpnNklGeGNMQ0J3ZGpJNExDQmNYRnhjYmx4Y0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYRnh3ZGpVNE9pQmNYQ3dnY0hZMU9Dd2dYRnhjWEc1Y1hDa3NJRnh1SUNBZ0lDQWdJQ0FnSUNCamIyeHZjaUE5SUZ4Y1lteGhZMnRjWEN3Z2FHcDFjM1FnUFNBd0xDQnphWHBsSUQwZ015bGNiaUFnWEc0Z0lGeHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRnhjYzJsNlpWOWlZWEp3Ykc5MFgyUnBabVpIY205MWNGOWtWRUZIWDNaelgwUk5VMDljWENsY2JtaGxhV2RvZENBOExTQXpYRzUzYVdSMGFDQThMU0F6WEc1d2JtY29hR1Z5WlNobWFXZEVhWElzSUhCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWEZ3dWNHNW5YRndwS1N3Z2NtVnpJRDBnTmpBd0xDQjFibWwwSUQwZ1hGeHBibHhjTENCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzV3Y21sdWRDaHdLVnh1WkdWMkxtOW1aaWdwWEc1emRtZHNhWFJsS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGeGNMbk4yWjF4Y0tTa3NJQ0JvWldsbmFIUWdQU0JvWldsbmFIUXNJSGRwWkhSb0lEMGdkMmxrZEdncFhHNXdjbWx1ZENod0tWeHVaR1YyTG05bVppZ3BYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG4jIENoZWNraW5nIGF2ZXJhZ2UgZGlzdGFuY2Ugb2YgbG9vcHMgcGVyIGdlbmVcbiMgdGVtcCBpcyBhIHRpYmJsZSB3aGVyZSBkZWx0YSBsb29wIGFuZCBsb2cyZmMgYXJlIG1lcmdlZFxudGVtcCRncm91cCA8LSBmYWN0b3IodGVtcCRncm91cClcblxuI1xudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwICVpbiUgYygxLCAyLCA1LCA4KSlcblxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJG1lYW5fZGlzdGFuY2VcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJG1lYW5fZGlzdGFuY2VcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAxLCAyKSwgNSlcbnB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAxLCA1KSwgNSlcbnB2MTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAxLCA4KSwgNSlcbnB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAyLCA1KSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAyLCA4KSwgNSlcbnB2NTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCA1LCA4KSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGdyb3VwLCB5ID0gbWVhbl9kaXN0YW5jZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgc2NhbGVfeV9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMTAwMDAwMCwgbGFiZWwgPSBwYXN0ZTAoXFxwdjEyOiBcXCwgcHYxMiwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxNTogXFwsIHB2MTUsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTg6IFxcLCBwdjE4LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI1OiBcXCwgcHYyNSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyODogXFwsIHB2MjgsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NTg6IFxcLCBwdjU4LCBcXFxcblxcKSwgXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxzaXplX2JhcnBsb3RfZGlmZkdyb3VwX2RUQUdfdnNfRE1TT1xcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBDaGVja2luZyBhdmVyYWdlIGRpc3RhbmNlIG9mIGxvb3BzIHBlciBnZW5lXG4jIHRlbXAgaXMgYSB0aWJibGUgd2hlcmUgZGVsdGEgbG9vcCBhbmQgbG9nMmZjIGFyZSBtZXJnZWRcbnRlbXAkZ3JvdXAgPC0gZmFjdG9yKHRlbXAkZ3JvdXApXG5cbiNcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCAlaW4lIGMoMSwgMiwgNSwgOCkpXG5cblxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMSkgKSRtZWFuX2Rpc3RhbmNlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRtZWFuX2Rpc3RhbmNlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgMSwgMiksIDUpXG5wdjE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgMSwgNSksIDUpXG5wdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgMSwgOCksIDUpXG5wdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgMiwgNSksIDUpXG5wdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgMiwgOCksIDUpXG5wdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgNSwgOCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBncm91cCwgeSA9IG1lYW5fZGlzdGFuY2UpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgK1xuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDEwMDAwMDAsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIHB2MTIsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE4OiBcXCwgcHYxOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNTogXFwsIHB2MjUsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjU4OiBcXCwgcHY1OCwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcc2l6ZV9iYXJwbG90X2RpZmZHcm91cF9kVEFHX3ZzX0RNU09cXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
# Checking average distance of loops per gene
# temp is a tibble where delta loop and log2fc are merged
temp$group <- factor(temp$group)

#
temp <- temp %>% dplyr::filter(group %in% c(1, 2, 5, 8))


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$mean_distance
  distance2 <- (data %>% dplyr::filter(group ==group2) )$mean_distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv12 <- round(getPvalWilcox(temp, 1, 2), 5)
pv15 <- round(getPvalWilcox(temp, 1, 5), 5)
pv18 <- round(getPvalWilcox(temp, 1, 8), 5)
pv25 <- round(getPvalWilcox(temp, 2, 5), 5)
pv28 <- round(getPvalWilcox(temp, 2, 8), 5)
pv58 <- round(getPvalWilcox(temp, 5, 8), 5)


p <- ggplot(temp, aes(x = group, y = mean_distance)) + geom_violin(aes(fill = group), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  annotate(\text\, x = 1, y = 1000000, label = paste0(\pv12: \, pv12, \\n\,
                                                      \pv15: \, pv15, \\n\,
                                                      \pv18: \, pv18, \\n\,
                                                      \pv25: \, pv25, \\n\,
                                                      \pv28: \, pv28, \\n\,
                                                      \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 3)
  
  
fileName <- paste0(\size_barplot_diffGroup_dTAG_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### - GO for each group


<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBDb3VudGluZyBudW1iZXIgb2YgbG9vcCBwZXIgZ2VuZXNcbnRlbXBTdW0gPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KHBlYWtJRCwgZ2VuZSwgQW5ubzIpICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JSAgc3VtbWFyaXplKFxuICAgIHBlYWsgPSBsaXN0KHBlYWtJRCksXG4gICAgYW5ubzIgPSBsaXN0KEFubm8yKSxcbiAgICBjb3VudCA9IG4oKSlcblxudGVtcFN1bSA8LSB0ZW1wU3VtICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDEsIFwiZ3JvdXAxXCIsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDIsIFwiZ3JvdXAyXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAzLCBcImdyb3VwM1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDQsIFwiZ3JvdXA0XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDUsIFwiZ3JvdXA1XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA2LCBcImdyb3VwNlwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDcsIFwiZ3JvdXA3XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDgsIFwiZ3JvdXA4XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA5LCBcImdyb3VwOVwiLCBOQSkpKSkpKSkpKVxuKSAlPiVcbiAgZHBseXI6OmZpbHRlcihncm91cCAlaW4lIGMoXCJncm91cDFcIiwgXCJncm91cDJcIiwgXCJncm91cDVcIiwgXCJncm91cDhcIikpXG5cblxuIyBURU1QIFNUQVJUXG4jZ2VuZUxpc3QuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XCIpKVxuI2dlbmVMaXN0Lmdyb3VwMS50ZW1wIDwtIGdlbmVMaXN0Lmdyb3VwMSAlPiUgZHBseXI6OmxlZnRfam9pbih0ZW1wU3VtLCBieSA9IGMoXCJnZW5lXCIpKVxuIyBURU1QIEVORFxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJGNvdW50XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRjb3VudFxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcImdyb3VwMVwiLCBcImdyb3VwMlwiKSwgNSlcbnB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFwiZ3JvdXAxXCIsIFwiZ3JvdXA1XCIpLCA1KVxucHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXCJncm91cDFcIiwgXCJncm91cDhcIiksIDUpXG5wdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcImdyb3VwMlwiLCBcImdyb3VwNVwiKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFwiZ3JvdXAyXCIsIFwiZ3JvdXA4XCIpLCA1KVxucHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXCJncm91cDVcIiwgXCJncm91cDhcIiksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcFN1bSwgYWVzKHggPSBncm91cCwgeSA9IGNvdW50LCBmaWxsID0gZ3JvdXApKSArIFxuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCAxMCwgYnkgPSAyKSwgbGltaXRzID0gYygwLCAxMCkpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcInBvaW50XCIsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCIpICArXG4gIGFubm90YXRlKFwidGV4dFwiLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFwicHYxMjogXCIsIHB2MTIsIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInB2MTU6IFwiLCBwdjE1LCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjE4OiBcIiwgcHYxOCwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHYyNTogXCIsIHB2MjUsIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInB2Mjg6IFwiLCBwdjI4LCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjU4OiBcIiwgcHY1OCwgXCJcXG5cIiksIFxuICAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMSkgKyAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXCJub25lXCIpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwiY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPXCIpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgIn0= -->\n\n```r\n# Counting number of loop per genes\ntempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(\n    peak = list(peakID),\n    anno2 = list(Anno2),\n    count = n())\n\ntempSum <- tempSum %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\,\n                        ifelse(gene %in% gene.group3, \\group3\\,\n                               ifelse(gene %in% gene.group4, \\group4\\,\n                                      ifelse(gene %in% gene.group5, \\group5\\,\n                                             ifelse(gene %in% gene.group6, \\group6\\,\n                                                    ifelse(gene %in% gene.group7, \\group7\\,\n                                                           ifelse(gene %in% gene.group8, \\group8\\,\n                                                                  ifelse(gene %in% gene.group9, \\group9\\, NA)))))))))\n) %>%\n  dplyr::filter(group %in% c(\\group1\\, \\group2\\, \\group5\\, \\group8\\))\n\n\n# TEMP START\n#geneList.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))\n#geneList.group1.temp <- geneList.group1 %>% dplyr::left_join(tempSum, by = c(\\gene\\))\n# TEMP END\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$count\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$count\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\npv12 <- round(getPvalWilcox(tempSum,\\group1\\, \\group2\\), 5)\npv15 <- round(getPvalWilcox(tempSum,\\group1\\, \\group5\\), 5)\npv18 <- round(getPvalWilcox(tempSum,\\group1\\, \\group8\\), 5)\npv25 <- round(getPvalWilcox(tempSum,\\group2\\, \\group5\\), 5)\npv28 <- round(getPvalWilcox(tempSum,\\group2\\, \\group8\\), 5)\npv58 <- round(getPvalWilcox(tempSum,\\group5\\, \\group8\\), 5)\n\n\np <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + \n  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       \n  scale_y_continuous(breaks = seq(0, 10, by = 2), limits = c(0, 10)) + \n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)  +\n  annotate(\\text\\, x = 1, y = 3, label = paste0(\\pv12: \\, pv12, \\\\n\\,\n                                                \\pv15: \\, pv15, \\\\n\\,\n                                                \\pv18: \\, pv18, \\\\n\\,\n                                                \\pv25: \\, pv25, \\\\n\\,\n                                                \\pv28: \\, pv28, \\\\n\\,\n                                                \\pv58: \\, pv58, \\\\n\\), \n           color = \\black\\, hjust = 0, size = 1) +  theme(legend.position = \\none\\)\n\n\nfileName <- paste0(\\count_barplot_diffGroup_dTAG_vs_DMSO\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# Counting number of loop per genes
tempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(
    peak = list(peakID),
    anno2 = list(Anno2),
    count = n())

tempSum <- tempSum %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\,
                        ifelse(gene %in% gene.group3, \group3\,
                               ifelse(gene %in% gene.group4, \group4\,
                                      ifelse(gene %in% gene.group5, \group5\,
                                             ifelse(gene %in% gene.group6, \group6\,
                                                    ifelse(gene %in% gene.group7, \group7\,
                                                           ifelse(gene %in% gene.group8, \group8\,
                                                                  ifelse(gene %in% gene.group9, \group9\, NA)))))))))
) %>%
  dplyr::filter(group %in% c(\group1\, \group2\, \group5\, \group8\))


# TEMP START
#geneList.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))
#geneList.group1.temp <- geneList.group1 %>% dplyr::left_join(tempSum, by = c(\gene\))
# TEMP END

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$count
  distance2 <- (data %>% dplyr::filter(group ==group2) )$count
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


pv12 <- round(getPvalWilcox(tempSum,\group1\, \group2\), 5)
pv15 <- round(getPvalWilcox(tempSum,\group1\, \group5\), 5)
pv18 <- round(getPvalWilcox(tempSum,\group1\, \group8\), 5)
pv25 <- round(getPvalWilcox(tempSum,\group2\, \group5\), 5)
pv28 <- round(getPvalWilcox(tempSum,\group2\, \group8\), 5)
pv58 <- round(getPvalWilcox(tempSum,\group5\, \group8\), 5)


p <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2), limits = c(0, 10)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
                                                \pv15: \, pv15, \\n\,
                                                \pv18: \, pv18, \\n\,
                                                \pv25: \, pv25, \\n\,
                                                \pv28: \, pv28, \\n\,
                                                \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 1) +  theme(legend.position = \none\)


fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBDb3VudGluZyBudW1iZXIgb2YgbG9vcCBwZXIgZ2VuZXNcbnRlbXBTdW0gPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KHBlYWtJRCwgZ2VuZSwgQW5ubzIpICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JSAgc3VtbWFyaXplKFxuICAgIHBlYWsgPSBsaXN0KHBlYWtJRCksXG4gICAgYW5ubzIgPSBsaXN0KEFubm8yKSxcbiAgICBjb3VudCA9IG4oKSlcblxudGVtcFN1bSA8LSB0ZW1wU3VtICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDEsIFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDIsIFxcZ3JvdXAyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAzLCBcXGdyb3VwM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDQsIFxcZ3JvdXA0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDUsIFxcZ3JvdXA1XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA2LCBcXGdyb3VwNlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDcsIFxcZ3JvdXA3XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDgsIFxcZ3JvdXA4XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA5LCBcXGdyb3VwOVxcLCBOQSkpKSkpKSkpKVxuKSAlPiVcbiAgZHBseXI6OmZpbHRlcihncm91cCAlaW4lIGMoXFxncm91cDFcXCwgXFxncm91cDJcXCwgXFxncm91cDVcXCwgXFxncm91cDhcXCkpXG5cblxuIyBURU1QIFNUQVJUXG4jZ2VuZUxpc3QuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKVxuI2dlbmVMaXN0Lmdyb3VwMS50ZW1wIDwtIGdlbmVMaXN0Lmdyb3VwMSAlPiUgZHBseXI6OmxlZnRfam9pbih0ZW1wU3VtLCBieSA9IGMoXFxnZW5lXFwpKVxuIyBURU1QIEVORFxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJGNvdW50XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRjb3VudFxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbnB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG5wdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxucHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcFN1bSwgYWVzKHggPSBncm91cCwgeSA9IGNvdW50LCBmaWxsID0gZ3JvdXApKSArIFxuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCAxMCwgYnkgPSAyKSwgbGltaXRzID0gYygwLCAxMCkpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIHB2MTIsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE4OiBcXCwgcHYxOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNTogXFwsIHB2MjUsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjU4OiBcXCwgcHY1OCwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSkgKyAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n# Counting number of loop per genes\ntempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(\n    peak = list(peakID),\n    anno2 = list(Anno2),\n    count = n())\n\ntempSum <- tempSum %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\,\n                        ifelse(gene %in% gene.group3, \\group3\\,\n                               ifelse(gene %in% gene.group4, \\group4\\,\n                                      ifelse(gene %in% gene.group5, \\group5\\,\n                                             ifelse(gene %in% gene.group6, \\group6\\,\n                                                    ifelse(gene %in% gene.group7, \\group7\\,\n                                                           ifelse(gene %in% gene.group8, \\group8\\,\n                                                                  ifelse(gene %in% gene.group9, \\group9\\, NA)))))))))\n) %>%\n  dplyr::filter(group %in% c(\\group1\\, \\group2\\, \\group5\\, \\group8\\))\n\n\n# TEMP START\n#geneList.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))\n#geneList.group1.temp <- geneList.group1 %>% dplyr::left_join(tempSum, by = c(\\gene\\))\n# TEMP END\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$count\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$count\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\npv12 <- round(getPvalWilcox(tempSum,\\group1\\, \\group2\\), 5)\npv15 <- round(getPvalWilcox(tempSum,\\group1\\, \\group5\\), 5)\npv18 <- round(getPvalWilcox(tempSum,\\group1\\, \\group8\\), 5)\npv25 <- round(getPvalWilcox(tempSum,\\group2\\, \\group5\\), 5)\npv28 <- round(getPvalWilcox(tempSum,\\group2\\, \\group8\\), 5)\npv58 <- round(getPvalWilcox(tempSum,\\group5\\, \\group8\\), 5)\n\n\np <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + \n  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       \n  scale_y_continuous(breaks = seq(0, 10, by = 2), limits = c(0, 10)) + \n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)  +\n  annotate(\\text\\, x = 1, y = 3, label = paste0(\\pv12: \\, pv12, \\\\n\\,\n                                                \\pv15: \\, pv15, \\\\n\\,\n                                                \\pv18: \\, pv18, \\\\n\\,\n                                                \\pv25: \\, pv25, \\\\n\\,\n                                                \\pv28: \\, pv28, \\\\n\\,\n                                                \\pv58: \\, pv58, \\\\n\\), \n           color = \\black\\, hjust = 0, size = 1) +  theme(legend.position = \\none\\)\n\n\nfileName <- paste0(\\count_barplot_diffGroup_dTAG_vs_DMSO\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBDb3VudGluZyBudW1iZXIgb2YgbG9vcCBwZXIgZ2VuZXNcbnRlbXBTdW0gPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KHBlYWtJRCwgZ2VuZSwgQW5ubzIpICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JSAgc3VtbWFyaXplKFxuICAgIHBlYWsgPSBsaXN0KHBlYWtJRCksXG4gICAgYW5ubzIgPSBsaXN0KEFubm8yKSxcbiAgICBjb3VudCA9IG4oKSlcblxudGVtcFN1bSA8LSB0ZW1wU3VtICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDEsIFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDIsIFxcZ3JvdXAyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAzLCBcXGdyb3VwM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDQsIFxcZ3JvdXA0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDUsIFxcZ3JvdXA1XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA2LCBcXGdyb3VwNlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDcsIFxcZ3JvdXA3XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDgsIFxcZ3JvdXA4XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA5LCBcXGdyb3VwOVxcLCBOQSkpKSkpKSkpKVxuKSAlPiVcbiAgZHBseXI6OmZpbHRlcihncm91cCAlaW4lIGMoXFxncm91cDFcXCwgXFxncm91cDJcXCwgXFxncm91cDVcXCwgXFxncm91cDhcXCkpXG5cblxuIyBURU1QIFNUQVJUXG4jZ2VuZUxpc3QuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKVxuI2dlbmVMaXN0Lmdyb3VwMS50ZW1wIDwtIGdlbmVMaXN0Lmdyb3VwMSAlPiUgZHBseXI6OmxlZnRfam9pbih0ZW1wU3VtLCBieSA9IGMoXFxnZW5lXFwpKVxuIyBURU1QIEVORFxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJGNvdW50XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRjb3VudFxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbnB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG5wdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxucHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcFN1bSwgYWVzKHggPSBncm91cCwgeSA9IGNvdW50LCBmaWxsID0gZ3JvdXApKSArIFxuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCAxMCwgYnkgPSAyKSwgbGltaXRzID0gYygwLCAxMCkpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIHB2MTIsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE4OiBcXCwgcHYxOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNTogXFwsIHB2MjUsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjU4OiBcXCwgcHY1OCwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSkgKyAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
# Counting number of loop per genes
tempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(
    peak = list(peakID),
    anno2 = list(Anno2),
    count = n())

tempSum <- tempSum %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\,
                        ifelse(gene %in% gene.group3, \group3\,
                               ifelse(gene %in% gene.group4, \group4\,
                                      ifelse(gene %in% gene.group5, \group5\,
                                             ifelse(gene %in% gene.group6, \group6\,
                                                    ifelse(gene %in% gene.group7, \group7\,
                                                           ifelse(gene %in% gene.group8, \group8\,
                                                                  ifelse(gene %in% gene.group9, \group9\, NA)))))))))
) %>%
  dplyr::filter(group %in% c(\group1\, \group2\, \group5\, \group8\))


# TEMP START
#geneList.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))
#geneList.group1.temp <- geneList.group1 %>% dplyr::left_join(tempSum, by = c(\gene\))
# TEMP END

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$count
  distance2 <- (data %>% dplyr::filter(group ==group2) )$count
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


pv12 <- round(getPvalWilcox(tempSum,\group1\, \group2\), 5)
pv15 <- round(getPvalWilcox(tempSum,\group1\, \group5\), 5)
pv18 <- round(getPvalWilcox(tempSum,\group1\, \group8\), 5)
pv25 <- round(getPvalWilcox(tempSum,\group2\, \group5\), 5)
pv28 <- round(getPvalWilcox(tempSum,\group2\, \group8\), 5)
pv58 <- round(getPvalWilcox(tempSum,\group5\, \group8\), 5)


p <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2), limits = c(0, 10)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
                                                \pv15: \, pv15, \\n\,
                                                \pv18: \, pv18, \\n\,
                                                \pv25: \, pv25, \\n\,
                                                \pv28: \, pv28, \\n\,
                                                \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 1) +  theme(legend.position = \none\)


fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




##### - Average loop size

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakkxeHVkR1Z0Y0RJZ1BDMGdkR1Z0Y0ZOMWJTQWxQaVVnY205M2QybHpaU2dwSUNVK0pTQnRkWFJoZEdVb2RHOTBZV3dnUFNCc1pXNW5kR2dvWVc1dWJ6SXBMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiblZ0WDNCd0lEMGdjM1Z0S0dGdWJtOHlJRDA5SUZ3aVVDMVFYQ0lwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYm5WdFgzQmxJRDBnYzNWdEtHRnVibTh5SUQwOUlGd2lVQzFGWENJcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0J6SUQwZ2MzVnRLR0Z1Ym04eUlEMDlJRndpVUMxVFhDSXBMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiblZ0WDNCNElEMGdjM1Z0S0dGdWJtOHlJRDA5SUZ3aVVDMVlYQ0lwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnY21GMGFXOWZjbVZuSUQwZ0tHNTFiVjl3Y0NBcklHNTFiVjl3WlNrdmRHOTBZV3dzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J5WVhScGIxOXpkSElnUFNCdWRXMWZjSE12ZEc5MFlXd3BYRzVjYm5OaGRtVlNSRk1vZEdWdGNESXNJR2hsY21Vb2NtVnpkV3gwUkdseUxDQmNJbWRsYm1WZmJHOXZjRjlzYVc1ckxuSmtjMXdpS1NsY2JseHVYRzVzYjI5d1ZIbHdaU0E4TFNCMFpXMXdNaUFsUGlVZ1ozSnZkWEJmWW5rb1ozSnZkWEFwSUNVK0pTQnpkVzF0WVhKcGMyVW9iblZ0WDNCd0lEMGdjM1Z0S0c1MWJWOXdjQ2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiblZ0WDNCbElEMGdjM1Z0S0c1MWJWOXdaU2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiblZ0WDNCeklEMGdjM1Z0S0c1MWJWOXdjeWtzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiblZ0WDNCNElEMGdjM1Z0S0c1MWJWOXdlQ2twWEc1Y2JseHViRzl2Y0ZSNWNHVk1iMjVuSUR3dElHeHZiM0JVZVhCbElDVStKU0J3YVhadmRGOXNiMjVuWlhJb0xXZHliM1Z3TENCdVlXMWxjMTkwYnlBOUlGd2lkSGx3WlZ3aUxDQjJZV3gxWlhOZmRHOGdQU0JjSW1OdmRXNTBYQ0lwWEc1Y2JteHZiM0JVZVhCbFRHOXVaeVIwZVhCbElEd3RJR1poWTNSdmNpaHNiMjl3Vkhsd1pVeHZibWNrZEhsd1pTd2diR1YyWld4eklEMGdZeWhjSW01MWJWOXdjRndpTENCY0ltNTFiVjl3WlZ3aUxDQmNJbTUxYlY5d2Mxd2lMQ0JjSW01MWJWOXdlRndpS1NsY2JseHVJeUJRYkc5MGRHbHVaMXh1WjJkd2JHOTBLR3h2YjNCVWVYQmxURzl1Wnl3Z1lXVnpLR1pwYkd3OWRIbHdaU3dnZVQxamIzVnVkQ3dnZUQxbmNtOTFjQ2twSUNzZ1hHNGdJQ0FnWjJWdmJWOWlZWElvY0c5emFYUnBiMjQ5WENKbWFXeHNYQ0lzSUhOMFlYUTlYQ0pwWkdWdWRHbDBlVndpS1NBcklIUm9aVzFsWDJOc1lYTnphV01vS1Z4dVhHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuIyMjIyMjI1xudGVtcDIgPC0gdGVtcFN1bSAlPiUgcm93d2lzZSgpICU+JSBtdXRhdGUodG90YWwgPSBsZW5ndGgoYW5ubzIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BwID0gc3VtKGFubm8yID09IFxcUC1QXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BlID0gc3VtKGFubm8yID09IFxcUC1FXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BzID0gc3VtKGFubm8yID09IFxcUC1TXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3B4ID0gc3VtKGFubm8yID09IFxcUC1YXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcmF0aW9fcmVnID0gKG51bV9wcCArIG51bV9wZSkvdG90YWwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICByYXRpb19zdHIgPSBudW1fcHMvdG90YWwpXG5cbnNhdmVSRFModGVtcDIsIGhlcmUocmVzdWx0RGlyLCBcXGdlbmVfbG9vcF9saW5rLnJkc1xcKSlcblxuXG5sb29wVHlwZSA8LSB0ZW1wMiAlPiUgZ3JvdXBfYnkoZ3JvdXApICU+JSBzdW1tYXJpc2UobnVtX3BwID0gc3VtKG51bV9wcCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BlID0gc3VtKG51bV9wZSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BzID0gc3VtKG51bV9wcyksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3B4ID0gc3VtKG51bV9weCkpXG5cblxubG9vcFR5cGVMb25nIDwtIGxvb3BUeXBlICU+JSBwaXZvdF9sb25nZXIoLWdyb3VwLCBuYW1lc190byA9IFxcdHlwZVxcLCB2YWx1ZXNfdG8gPSBcXGNvdW50XFwpXG5cbmxvb3BUeXBlTG9uZyR0eXBlIDwtIGZhY3Rvcihsb29wVHlwZUxvbmckdHlwZSwgbGV2ZWxzID0gYyhcXG51bV9wcFxcLCBcXG51bV9wZVxcLCBcXG51bV9wc1xcLCBcXG51bV9weFxcKSlcblxuIyBQbG90dGluZ1xuZ2dwbG90KGxvb3BUeXBlTG9uZywgYWVzKGZpbGw9dHlwZSwgeT1jb3VudCwgeD1ncm91cCkpICsgXG4gICAgZ2VvbV9iYXIocG9zaXRpb249XFxmaWxsXFwsIHN0YXQ9XFxpZGVudGl0eVxcKSArIHRoZW1lX2NsYXNzaWMoKVxuXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
#######
temp2 <- tempSum %>% rowwise() %>% mutate(total = length(anno2),
                                 num_pp = sum(anno2 == \P-P\),
                                 num_pe = sum(anno2 == \P-E\),
                                 num_ps = sum(anno2 == \P-S\),
                                 num_px = sum(anno2 == \P-X\),
                                 ratio_reg = (num_pp + num_pe)/total,
                                 ratio_str = num_ps/total)

saveRDS(temp2, here(resultDir, \gene_loop_link.rds\))


loopType <- temp2 %>% group_by(group) %>% summarise(num_pp = sum(num_pp),
                                        num_pe = sum(num_pe),
                                        num_ps = sum(num_ps),
                                        num_px = sum(num_px))


loopTypeLong <- loopType %>% pivot_longer(-group, names_to = \type\, values_to = \count\)

loopTypeLong$type <- factor(loopTypeLong$type, levels = c(\num_pp\, \num_pe\, \num_ps\, \num_px\))

# Plotting
ggplot(loopTypeLong, aes(fill=type, y=count, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSTF4dWRHVnRjRElnUEMwZ2RHVnRjRk4xYlNBbFBpVWdjbTkzZDJselpTZ3BJQ1UrSlNCdGRYUmhkR1VvZEc5MFlXd2dQU0JzWlc1bmRHZ29ZVzV1YnpJcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0J3SUQwZ2MzVnRLR0Z1Ym04eUlEMDlJRnhjVUMxUVhGd3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiblZ0WDNCbElEMGdjM1Z0S0dGdWJtOHlJRDA5SUZ4Y1VDMUZYRndwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYm5WdFgzQnpJRDBnYzNWdEtHRnVibTh5SUQwOUlGeGNVQzFUWEZ3cExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0I0SUQwZ2MzVnRLR0Z1Ym04eUlEMDlJRnhjVUMxWVhGd3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdjbUYwYVc5ZmNtVm5JRDBnS0c1MWJWOXdjQ0FySUc1MWJWOXdaU2t2ZEc5MFlXd3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnlZWFJwYjE5emRISWdQU0J1ZFcxZmNITXZkRzkwWVd3cFhHNWNibk5oZG1WU1JGTW9kR1Z0Y0RJc0lHaGxjbVVvY21WemRXeDBSR2x5TENCY1hHZGxibVZmYkc5dmNGOXNhVzVyTG5Ka2MxeGNLU2xjYmx4dVhHNXNiMjl3Vkhsd1pTQThMU0IwWlcxd01pQWxQaVVnWjNKdmRYQmZZbmtvWjNKdmRYQXBJQ1UrSlNCemRXMXRZWEpwYzJVb2JuVnRYM0J3SUQwZ2MzVnRLRzUxYlY5d2NDa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0JsSUQwZ2MzVnRLRzUxYlY5d1pTa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0J6SUQwZ2MzVnRLRzUxYlY5d2N5a3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0I0SUQwZ2MzVnRLRzUxYlY5d2VDa3BYRzVjYmx4dWJHOXZjRlI1Y0dWTWIyNW5JRHd0SUd4dmIzQlVlWEJsSUNVK0pTQndhWFp2ZEY5c2IyNW5aWElvTFdkeWIzVndMQ0J1WVcxbGMxOTBieUE5SUZ4Y2RIbHdaVnhjTENCMllXeDFaWE5mZEc4Z1BTQmNYR052ZFc1MFhGd3BYRzVjYm14dmIzQlVlWEJsVEc5dVp5UjBlWEJsSUR3dElHWmhZM1J2Y2loc2IyOXdWSGx3WlV4dmJtY2tkSGx3WlN3Z2JHVjJaV3h6SUQwZ1l5aGNYRzUxYlY5d2NGeGNMQ0JjWEc1MWJWOXdaVnhjTENCY1hHNTFiVjl3YzF4Y0xDQmNYRzUxYlY5d2VGeGNLU2xjYmx4dUl5QlFiRzkwZEdsdVoxeHVaMmR3Ykc5MEtHeHZiM0JVZVhCbFRHOXVaeXdnWVdWektHWnBiR3c5ZEhsd1pTd2dlVDFqYjNWdWRDd2dlRDFuY205MWNDa3BJQ3NnWEc0Z0lDQWdaMlZ2YlY5aVlYSW9jRzl6YVhScGIyNDlYRnhtYVd4c1hGd3NJSE4wWVhROVhGeHBaR1Z1ZEdsMGVWeGNLU0FySUhSb1pXMWxYMk5zWVhOemFXTW9LVnh1WEc1Z1lHQmNibUJnWUNKOSAtLT5cblxuYGBgclxuYGBgclxuIyMjIyMjI1xudGVtcDIgPC0gdGVtcFN1bSAlPiUgcm93d2lzZSgpICU+JSBtdXRhdGUodG90YWwgPSBsZW5ndGgoYW5ubzIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BwID0gc3VtKGFubm8yID09IFxcUC1QXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BlID0gc3VtKGFubm8yID09IFxcUC1FXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BzID0gc3VtKGFubm8yID09IFxcUC1TXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3B4ID0gc3VtKGFubm8yID09IFxcUC1YXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcmF0aW9fcmVnID0gKG51bV9wcCArIG51bV9wZSkvdG90YWwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICByYXRpb19zdHIgPSBudW1fcHMvdG90YWwpXG5cbnNhdmVSRFModGVtcDIsIGhlcmUocmVzdWx0RGlyLCBcXGdlbmVfbG9vcF9saW5rLnJkc1xcKSlcblxuXG5sb29wVHlwZSA8LSB0ZW1wMiAlPiUgZ3JvdXBfYnkoZ3JvdXApICU+JSBzdW1tYXJpc2UobnVtX3BwID0gc3VtKG51bV9wcCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BlID0gc3VtKG51bV9wZSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BzID0gc3VtKG51bV9wcyksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3B4ID0gc3VtKG51bV9weCkpXG5cblxubG9vcFR5cGVMb25nIDwtIGxvb3BUeXBlICU+JSBwaXZvdF9sb25nZXIoLWdyb3VwLCBuYW1lc190byA9IFxcdHlwZVxcLCB2YWx1ZXNfdG8gPSBcXGNvdW50XFwpXG5cbmxvb3BUeXBlTG9uZyR0eXBlIDwtIGZhY3Rvcihsb29wVHlwZUxvbmckdHlwZSwgbGV2ZWxzID0gYyhcXG51bV9wcFxcLCBcXG51bV9wZVxcLCBcXG51bV9wc1xcLCBcXG51bV9weFxcKSlcblxuIyBQbG90dGluZ1xuZ2dwbG90KGxvb3BUeXBlTG9uZywgYWVzKGZpbGw9dHlwZSwgeT1jb3VudCwgeD1ncm91cCkpICsgXG4gICAgZ2VvbV9iYXIocG9zaXRpb249XFxmaWxsXFwsIHN0YXQ9XFxpZGVudGl0eVxcKSArIHRoZW1lX2NsYXNzaWMoKVxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjI1xudGVtcDIgPC0gdGVtcFN1bSAlPiUgcm93d2lzZSgpICU+JSBtdXRhdGUodG90YWwgPSBsZW5ndGgoYW5ubzIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BwID0gc3VtKGFubm8yID09IFxcUC1QXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BlID0gc3VtKGFubm8yID09IFxcUC1FXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BzID0gc3VtKGFubm8yID09IFxcUC1TXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3B4ID0gc3VtKGFubm8yID09IFxcUC1YXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcmF0aW9fcmVnID0gKG51bV9wcCArIG51bV9wZSkvdG90YWwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICByYXRpb19zdHIgPSBudW1fcHMvdG90YWwpXG5cbnNhdmVSRFModGVtcDIsIGhlcmUocmVzdWx0RGlyLCBcXGdlbmVfbG9vcF9saW5rLnJkc1xcKSlcblxuXG5sb29wVHlwZSA8LSB0ZW1wMiAlPiUgZ3JvdXBfYnkoZ3JvdXApICU+JSBzdW1tYXJpc2UobnVtX3BwID0gc3VtKG51bV9wcCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BlID0gc3VtKG51bV9wZSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BzID0gc3VtKG51bV9wcyksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3B4ID0gc3VtKG51bV9weCkpXG5cblxubG9vcFR5cGVMb25nIDwtIGxvb3BUeXBlICU+JSBwaXZvdF9sb25nZXIoLWdyb3VwLCBuYW1lc190byA9IFxcdHlwZVxcLCB2YWx1ZXNfdG8gPSBcXGNvdW50XFwpXG5cbmxvb3BUeXBlTG9uZyR0eXBlIDwtIGZhY3Rvcihsb29wVHlwZUxvbmckdHlwZSwgbGV2ZWxzID0gYyhcXG51bV9wcFxcLCBcXG51bV9wZVxcLCBcXG51bV9wc1xcLCBcXG51bV9weFxcKSlcblxuIyBQbG90dGluZ1xuZ2dwbG90KGxvb3BUeXBlTG9uZywgYWVzKGZpbGw9dHlwZSwgeT1jb3VudCwgeD1ncm91cCkpICsgXG4gICAgZ2VvbV9iYXIocG9zaXRpb249XFxmaWxsXFwsIHN0YXQ9XFxpZGVudGl0eVxcKSArIHRoZW1lX2NsYXNzaWMoKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
#######
temp2 <- tempSum %>% rowwise() %>% mutate(total = length(anno2),
                                 num_pp = sum(anno2 == \P-P\),
                                 num_pe = sum(anno2 == \P-E\),
                                 num_ps = sum(anno2 == \P-S\),
                                 num_px = sum(anno2 == \P-X\),
                                 ratio_reg = (num_pp + num_pe)/total,
                                 ratio_str = num_ps/total)

saveRDS(temp2, here(resultDir, \gene_loop_link.rds\))


loopType <- temp2 %>% group_by(group) %>% summarise(num_pp = sum(num_pp),
                                        num_pe = sum(num_pe),
                                        num_ps = sum(num_ps),
                                        num_px = sum(num_px))


loopTypeLong <- loopType %>% pivot_longer(-group, names_to = \type\, values_to = \count\)

loopTypeLong$type <- factor(loopTypeLong$type, levels = c(\num_pp\, \num_pe\, \num_ps\, \num_px\))

# Plotting
ggplot(loopTypeLong, aes(fill=type, y=count, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-N

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakl5TmNiaU5RTFZCY2JtUmhkR0VnUEMwZ2RHVnRjRElnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWjNKdmRYQXNJRzUxYlY5d2NDbGNibU52Ykc1aGJXVnpLR1JoZEdFcElEd3RJR01vWENKbmNtOTFjRndpTENCY0ltTnZkVzUwWENJcFhHNXdkakV5SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29aR0YwWVN4Y0ltZHliM1Z3TVZ3aUxDQmNJbWR5YjNWd01sd2lLU3dnTlNsY2JuQjJNVFVnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaGtZWFJoTEZ3aVozSnZkWEF4WENJc0lGd2laM0p2ZFhBMVhDSXBMQ0ExS1Z4dWNIWXhPQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtHUmhkR0VzWENKbmNtOTFjREZjSWl3Z1hDSm5jbTkxY0RoY0lpa3NJRFVwWEc1d2RqSTFJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjSW1keWIzVndNbHdpTENCY0ltZHliM1Z3TlZ3aUtTd2dOU2xjYm5CMk1qZ2dQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoa1lYUmhMRndpWjNKdmRYQXlYQ0lzSUZ3aVozSnZkWEE0WENJcExDQTFLVnh1Y0hZMU9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYQ0puY205MWNEVmNJaXdnWENKbmNtOTFjRGhjSWlrc0lEVXBYRzVjYm5BZ1BDMGdaMmR3Ykc5MEtHUmhkR0VzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCamIzVnVkQ3dnWm1sc2JDQTlJR2R5YjNWd0tTa2dLMXh1SUNCblpXOXRYMkp2ZUhCc2IzUW9kMmxrZEdnZ1BTQXdMalVzSUc5MWRHeHBaWEl1YzJoaGNHVWdQU0JPUVNrZ0t5QjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0t5QWdJQ0FnSUNCY2JpQWdjMk5oYkdWZmVWOWpiMjUwYVc1MWIzVnpLR0p5WldGcmN5QTlJSE5sY1Nnd0xDQTFMQ0JpZVNBOUlESXBMQ0JzYVcxcGRITWdQU0JqS0RBc0lEVXBLU0FySUZ4dUlDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ1ozSnZkWEFwTENCbWRXNGdQU0J0WldGdUxDQm5aVzl0SUQwZ1hDSndiMmx1ZEZ3aUxDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNaXdnWm1sc2JDQTlJRndpY21Wa1hDSXNJR052Ykc5eUlEMGdYQ0ppYkdGamExd2lLU0FnSzF4dUlDQmhibTV2ZEdGMFpTaGNJblJsZUhSY0lpd2dlQ0E5SURFc0lIa2dQU0F6TENCc1lXSmxiQ0E5SUhCaGMzUmxNQ2hjSW5CMk1USTZJRndpTENCd2RqRXlMQ0JjSWx4Y2Jsd2lMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hDSndkakUxT2lCY0lpd2djSFl4TlN3Z1hDSmNYRzVjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0hZeE9Eb2dYQ0lzSUhCMk1UZ3NJRndpWEZ4dVhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQjJNalU2SUZ3aUxDQndkakkxTENCY0lseGNibHdpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p3ZGpJNE9pQmNJaXdnY0hZeU9Dd2dYQ0pjWEc1Y0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ3aWNIWTFPRG9nWENJc0lIQjJOVGdzSUZ3aVhGeHVYQ0lwTENCY2JpQWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJREVwS3lBZ2RHaGxiV1VvYkdWblpXNWtMbkJ2YzJsMGFXOXVJRDBnWENKdWIyNWxYQ0lwWEc1Y2JseHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRndpWTI5MWJuUmZZbUZ5Y0d4dmRGOWthV1ptUjNKdmRYQmZaRlJCUjE5MmMxOUVUVk5QWDNCd1hDSXBYRzVvWldsbmFIUWdQQzBnTTF4dWQybGtkR2dnUEMwZ00xeHVjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGd2lMbkJ1WjF3aUtTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRndpYVc1Y0lpd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dWNISnBiblFvY0NsY2JtUmxkaTV2Wm1Zb0tWeHVjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjSWk1emRtZGNJaWtwTENBZ2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG4jIyMjIyMjI1xuI1AtUFxuZGF0YSA8LSB0ZW1wMiAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgbnVtX3BwKVxuY29sbmFtZXMoZGF0YSkgPC0gYyhcXGdyb3VwXFwsIFxcY291bnRcXClcbnB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxucHYxNSA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG5wdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbnB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG5wdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcblxucCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IGNvdW50LCBmaWxsID0gZ3JvdXApKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArICAgICAgIFxuICBzY2FsZV95X2NvbnRpbnVvdXMoYnJlYWtzID0gc2VxKDAsIDUsIGJ5ID0gMiksIGxpbWl0cyA9IGMoMCwgNSkpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIHB2MTIsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE4OiBcXCwgcHYxOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNTogXFwsIHB2MjUsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjU4OiBcXCwgcHY1OCwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSkrICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXClcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxjb3VudF9iYXJwbG90X2RpZmZHcm91cF9kVEFHX3ZzX0RNU09fcHBcXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
########
#P-P
data <- temp2 %>% dplyr::select(group, num_pp)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
                                                \pv15: \, pv15, \\n\,
                                                \pv18: \, pv18, \\n\,
                                                \pv25: \, pv25, \\n\,
                                                \pv28: \, pv28, \\n\,
                                                \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 1)+  theme(legend.position = \none\)


fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_pp\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSXlOY2JpTlFMVkJjYm1SaGRHRWdQQzBnZEdWdGNESWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aM0p2ZFhBc0lHNTFiVjl3Y0NsY2JtTnZiRzVoYldWektHUmhkR0VwSUR3dElHTW9YRnhuY205MWNGeGNMQ0JjWEdOdmRXNTBYRndwWEc1d2RqRXlJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjWEdkeWIzVndNVnhjTENCY1hHZHliM1Z3TWx4Y0tTd2dOU2xjYm5CMk1UVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoa1lYUmhMRnhjWjNKdmRYQXhYRndzSUZ4Y1ozSnZkWEExWEZ3cExDQTFLVnh1Y0hZeE9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYRnhuY205MWNERmNYQ3dnWEZ4bmNtOTFjRGhjWENrc0lEVXBYRzV3ZGpJMUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvWkdGMFlTeGNYR2R5YjNWd01seGNMQ0JjWEdkeWIzVndOVnhjS1N3Z05TbGNibkIyTWpnZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGeGNaM0p2ZFhBeVhGd3NJRnhjWjNKdmRYQTRYRndwTENBMUtWeHVjSFkxT0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLR1JoZEdFc1hGeG5jbTkxY0RWY1hDd2dYRnhuY205MWNEaGNYQ2tzSURVcFhHNWNibkFnUEMwZ1oyZHdiRzkwS0dSaGRHRXNJR0ZsY3loNElEMGdaM0p2ZFhBc0lIa2dQU0JqYjNWdWRDd2dabWxzYkNBOUlHZHliM1Z3S1NrZ0sxeHVJQ0JuWlc5dFgySnZlSEJzYjNRb2QybGtkR2dnUFNBd0xqVXNJRzkxZEd4cFpYSXVjMmhoY0dVZ1BTQk9RU2tnS3lCMGFHVnRaVjlqYkdGemMybGpLQ2tnS3lBZ0lDQWdJQ0JjYmlBZ2MyTmhiR1ZmZVY5amIyNTBhVzUxYjNWektHSnlaV0ZyY3lBOUlITmxjU2d3TENBMUxDQmllU0E5SURJcExDQnNhVzFwZEhNZ1BTQmpLREFzSURVcEtTQXJJRnh1SUNCemRHRjBYM04xYlcxaGNua29ZV1Z6S0dkeWIzVndJRDBnWjNKdmRYQXBMQ0JtZFc0Z1BTQnRaV0Z1TENCblpXOXRJRDBnWEZ4d2IybHVkRnhjTENCemFHRndaU0E5SURJeExDQnphWHBsSUQwZ01pd2dabWxzYkNBOUlGeGNjbVZrWEZ3c0lHTnZiRzl5SUQwZ1hGeGliR0ZqYTF4Y0tTQWdLMXh1SUNCaGJtNXZkR0YwWlNoY1hIUmxlSFJjWEN3Z2VDQTlJREVzSUhrZ1BTQXpMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNYSEIyTVRJNklGeGNMQ0J3ZGpFeUxDQmNYRnhjYmx4Y0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWEZ4d2RqRTFPaUJjWEN3Z2NIWXhOU3dnWEZ4Y1hHNWNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjSFl4T0RvZ1hGd3NJSEIyTVRnc0lGeGNYRnh1WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhCMk1qVTZJRnhjTENCd2RqSTFMQ0JjWEZ4Y2JseGNMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hGeHdkakk0T2lCY1hDd2djSFl5T0N3Z1hGeGNYRzVjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRnhjY0hZMU9Eb2dYRndzSUhCMk5UZ3NJRnhjWEZ4dVhGd3BMQ0JjYmlBZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlERXBLeUFnZEdobGJXVW9iR1ZuWlc1a0xuQnZjMmwwYVc5dUlEMGdYRnh1YjI1bFhGd3BYRzVjYmx4dVptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGeGNZMjkxYm5SZlltRnljR3h2ZEY5a2FXWm1SM0p2ZFhCZlpGUkJSMTkyYzE5RVRWTlBYM0J3WEZ3cFhHNW9aV2xuYUhRZ1BDMGdNMXh1ZDJsa2RHZ2dQQzBnTTF4dWNHNW5LR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ4Y0xuQnVaMXhjS1Nrc0lISmxjeUE5SURZd01Dd2dkVzVwZENBOUlGeGNhVzVjWEN3Z2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dWMzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNYQzV6ZG1kY1hDa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1WUdCZ1hHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLVBcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wcClcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbnB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG5wdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxucHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE1OiBcXCwgcHYxNSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxODogXFwsIHB2MTgsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgcHYyOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY1ODogXFwsIHB2NTgsIFxcXFxuXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpKyAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPX3BwXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLVBcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wcClcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbnB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG5wdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxucHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE1OiBcXCwgcHYxNSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxODogXFwsIHB2MTgsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgcHYyOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY1ODogXFwsIHB2NTgsIFxcXFxuXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpKyAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPX3BwXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
########
#P-P
data <- temp2 %>% dplyr::select(group, num_pp)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
                                                \pv15: \, pv15, \\n\,
                                                \pv18: \, pv18, \\n\,
                                                \pv25: \, pv25, \\n\,
                                                \pv28: \, pv28, \\n\,
                                                \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 1)+  theme(legend.position = \none\)


fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_pp\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Counting loop types

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakl5TmNiaU5RTFVWY2JtUmhkR0VnUEMwZ2RHVnRjRElnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWjNKdmRYQXNJRzUxYlY5d1pTbGNibU52Ykc1aGJXVnpLR1JoZEdFcElEd3RJR01vWENKbmNtOTFjRndpTENCY0ltTnZkVzUwWENJcFhHNXdkakV5SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29aR0YwWVN4Y0ltZHliM1Z3TVZ3aUxDQmNJbWR5YjNWd01sd2lLU3dnTlNsY2JuQjJNVFVnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaGtZWFJoTEZ3aVozSnZkWEF4WENJc0lGd2laM0p2ZFhBMVhDSXBMQ0ExS1Z4dWNIWXhPQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtHUmhkR0VzWENKbmNtOTFjREZjSWl3Z1hDSm5jbTkxY0RoY0lpa3NJRFVwWEc1d2RqSTFJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjSW1keWIzVndNbHdpTENCY0ltZHliM1Z3TlZ3aUtTd2dOU2xjYm5CMk1qZ2dQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoa1lYUmhMRndpWjNKdmRYQXlYQ0lzSUZ3aVozSnZkWEE0WENJcExDQTFLVnh1Y0hZMU9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYQ0puY205MWNEVmNJaXdnWENKbmNtOTFjRGhjSWlrc0lEVXBYRzVjYm5BZ1BDMGdaMmR3Ykc5MEtHUmhkR0VzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCamIzVnVkQ3dnWm1sc2JDQTlJR2R5YjNWd0tTa2dLMXh1SUNCblpXOXRYMkp2ZUhCc2IzUW9kMmxrZEdnZ1BTQXdMalVzSUc5MWRHeHBaWEl1YzJoaGNHVWdQU0JPUVNrZ0t5QjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0t5QWdJQ0FnSUNCY2JpQWdjMk5oYkdWZmVWOWpiMjUwYVc1MWIzVnpLR0p5WldGcmN5QTlJSE5sY1Nnd0xDQTFMQ0JpZVNBOUlESXBMQ0JzYVcxcGRITWdQU0JqS0RBc0lEVXBLU0FySUZ4dUlDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ1ozSnZkWEFwTENCbWRXNGdQU0J0WldGdUxDQm5aVzl0SUQwZ1hDSndiMmx1ZEZ3aUxDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNaXdnWm1sc2JDQTlJRndpY21Wa1hDSXNJR052Ykc5eUlEMGdYQ0ppYkdGamExd2lLU0FnSzF4dUlDQmhibTV2ZEdGMFpTaGNJblJsZUhSY0lpd2dlQ0E5SURFc0lIa2dQU0F6TENCc1lXSmxiQ0E5SUhCaGMzUmxNQ2hjSW5CMk1USTZJRndpTENCd2RqRXlMQ0JjSWx4Y2Jsd2lMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hDSndkakUxT2lCY0lpd2djSFl4TlN3Z1hDSmNYRzVjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0hZeE9Eb2dYQ0lzSUhCMk1UZ3NJRndpWEZ4dVhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQjJNalU2SUZ3aUxDQndkakkxTENCY0lseGNibHdpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p3ZGpJNE9pQmNJaXdnY0hZeU9Dd2dYQ0pjWEc1Y0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ3aWNIWTFPRG9nWENJc0lIQjJOVGdzSUZ3aVhGeHVYQ0lwTENCY2JpQWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJREVwS3lBZ2RHaGxiV1VvYkdWblpXNWtMbkJ2YzJsMGFXOXVJRDBnWENKdWIyNWxYQ0lwWEc1Y2JseHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRndpWTI5MWJuUmZZbUZ5Y0d4dmRGOWthV1ptUjNKdmRYQmZaRlJCUjE5MmMxOUVUVk5QWDNCbFhDSXBYRzVvWldsbmFIUWdQQzBnTTF4dWQybGtkR2dnUEMwZ00xeHVjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGd2lMbkJ1WjF3aUtTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRndpYVc1Y0lpd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dWNISnBiblFvY0NsY2JtUmxkaTV2Wm1Zb0tWeHVjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjSWk1emRtZGNJaWtwTENBZ2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG4jIyMjIyMjI1xuI1AtRVxuZGF0YSA8LSB0ZW1wMiAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgbnVtX3BlKVxuY29sbmFtZXMoZGF0YSkgPC0gYyhcXGdyb3VwXFwsIFxcY291bnRcXClcbnB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxucHYxNSA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG5wdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbnB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG5wdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcblxucCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IGNvdW50LCBmaWxsID0gZ3JvdXApKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArICAgICAgIFxuICBzY2FsZV95X2NvbnRpbnVvdXMoYnJlYWtzID0gc2VxKDAsIDUsIGJ5ID0gMiksIGxpbWl0cyA9IGMoMCwgNSkpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIHB2MTIsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE4OiBcXCwgcHYxOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNTogXFwsIHB2MjUsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjU4OiBcXCwgcHY1OCwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSkrICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXClcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxjb3VudF9iYXJwbG90X2RpZmZHcm91cF9kVEFHX3ZzX0RNU09fcGVcXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
########
#P-E
data <- temp2 %>% dplyr::select(group, num_pe)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
                                                \pv15: \, pv15, \\n\,
                                                \pv18: \, pv18, \\n\,
                                                \pv25: \, pv25, \\n\,
                                                \pv28: \, pv28, \\n\,
                                                \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 1)+  theme(legend.position = \none\)


fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_pe\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSXlOY2JpTlFMVVZjYm1SaGRHRWdQQzBnZEdWdGNESWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aM0p2ZFhBc0lHNTFiVjl3WlNsY2JtTnZiRzVoYldWektHUmhkR0VwSUR3dElHTW9YRnhuY205MWNGeGNMQ0JjWEdOdmRXNTBYRndwWEc1d2RqRXlJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjWEdkeWIzVndNVnhjTENCY1hHZHliM1Z3TWx4Y0tTd2dOU2xjYm5CMk1UVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoa1lYUmhMRnhjWjNKdmRYQXhYRndzSUZ4Y1ozSnZkWEExWEZ3cExDQTFLVnh1Y0hZeE9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYRnhuY205MWNERmNYQ3dnWEZ4bmNtOTFjRGhjWENrc0lEVXBYRzV3ZGpJMUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvWkdGMFlTeGNYR2R5YjNWd01seGNMQ0JjWEdkeWIzVndOVnhjS1N3Z05TbGNibkIyTWpnZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGeGNaM0p2ZFhBeVhGd3NJRnhjWjNKdmRYQTRYRndwTENBMUtWeHVjSFkxT0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLR1JoZEdFc1hGeG5jbTkxY0RWY1hDd2dYRnhuY205MWNEaGNYQ2tzSURVcFhHNWNibkFnUEMwZ1oyZHdiRzkwS0dSaGRHRXNJR0ZsY3loNElEMGdaM0p2ZFhBc0lIa2dQU0JqYjNWdWRDd2dabWxzYkNBOUlHZHliM1Z3S1NrZ0sxeHVJQ0JuWlc5dFgySnZlSEJzYjNRb2QybGtkR2dnUFNBd0xqVXNJRzkxZEd4cFpYSXVjMmhoY0dVZ1BTQk9RU2tnS3lCMGFHVnRaVjlqYkdGemMybGpLQ2tnS3lBZ0lDQWdJQ0JjYmlBZ2MyTmhiR1ZmZVY5amIyNTBhVzUxYjNWektHSnlaV0ZyY3lBOUlITmxjU2d3TENBMUxDQmllU0E5SURJcExDQnNhVzFwZEhNZ1BTQmpLREFzSURVcEtTQXJJRnh1SUNCemRHRjBYM04xYlcxaGNua29ZV1Z6S0dkeWIzVndJRDBnWjNKdmRYQXBMQ0JtZFc0Z1BTQnRaV0Z1TENCblpXOXRJRDBnWEZ4d2IybHVkRnhjTENCemFHRndaU0E5SURJeExDQnphWHBsSUQwZ01pd2dabWxzYkNBOUlGeGNjbVZrWEZ3c0lHTnZiRzl5SUQwZ1hGeGliR0ZqYTF4Y0tTQWdLMXh1SUNCaGJtNXZkR0YwWlNoY1hIUmxlSFJjWEN3Z2VDQTlJREVzSUhrZ1BTQXpMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNYSEIyTVRJNklGeGNMQ0J3ZGpFeUxDQmNYRnhjYmx4Y0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWEZ4d2RqRTFPaUJjWEN3Z2NIWXhOU3dnWEZ4Y1hHNWNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjSFl4T0RvZ1hGd3NJSEIyTVRnc0lGeGNYRnh1WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhCMk1qVTZJRnhjTENCd2RqSTFMQ0JjWEZ4Y2JseGNMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hGeHdkakk0T2lCY1hDd2djSFl5T0N3Z1hGeGNYRzVjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRnhjY0hZMU9Eb2dYRndzSUhCMk5UZ3NJRnhjWEZ4dVhGd3BMQ0JjYmlBZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlERXBLeUFnZEdobGJXVW9iR1ZuWlc1a0xuQnZjMmwwYVc5dUlEMGdYRnh1YjI1bFhGd3BYRzVjYmx4dVptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGeGNZMjkxYm5SZlltRnljR3h2ZEY5a2FXWm1SM0p2ZFhCZlpGUkJSMTkyYzE5RVRWTlBYM0JsWEZ3cFhHNW9aV2xuYUhRZ1BDMGdNMXh1ZDJsa2RHZ2dQQzBnTTF4dWNHNW5LR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ4Y0xuQnVaMXhjS1Nrc0lISmxjeUE5SURZd01Dd2dkVzVwZENBOUlGeGNhVzVjWEN3Z2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dWMzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNYQzV6ZG1kY1hDa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1WUdCZ1hHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLUVcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wZSlcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbnB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG5wdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxucHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE1OiBcXCwgcHYxNSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxODogXFwsIHB2MTgsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgcHYyOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY1ODogXFwsIHB2NTgsIFxcXFxuXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpKyAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPX3BlXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLUVcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wZSlcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbnB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG5wdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxucHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE1OiBcXCwgcHYxNSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxODogXFwsIHB2MTgsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgcHYyOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY1ODogXFwsIHB2NTgsIFxcXFxuXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpKyAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPX3BlXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
########
#P-E
data <- temp2 %>% dplyr::select(group, num_pe)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
                                                \pv15: \, pv15, \\n\,
                                                \pv18: \, pv18, \\n\,
                                                \pv25: \, pv25, \\n\,
                                                \pv28: \, pv28, \\n\,
                                                \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 1)+  theme(legend.position = \none\)


fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_pe\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-P

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakl5TmNiaU5RTFZOY2JtUmhkR0VnUEMwZ2RHVnRjRElnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWjNKdmRYQXNJRzUxYlY5d2N5bGNibU52Ykc1aGJXVnpLR1JoZEdFcElEd3RJR01vWENKbmNtOTFjRndpTENCY0ltTnZkVzUwWENJcFhHNXdkakV5SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29aR0YwWVN4Y0ltZHliM1Z3TVZ3aUxDQmNJbWR5YjNWd01sd2lLU3dnTlNsY2JuQjJNVFVnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaGtZWFJoTEZ3aVozSnZkWEF4WENJc0lGd2laM0p2ZFhBMVhDSXBMQ0ExS1Z4dWNIWXhPQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtHUmhkR0VzWENKbmNtOTFjREZjSWl3Z1hDSm5jbTkxY0RoY0lpa3NJRFVwWEc1d2RqSTFJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjSW1keWIzVndNbHdpTENCY0ltZHliM1Z3TlZ3aUtTd2dOU2xjYm5CMk1qZ2dQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoa1lYUmhMRndpWjNKdmRYQXlYQ0lzSUZ3aVozSnZkWEE0WENJcExDQTFLVnh1Y0hZMU9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYQ0puY205MWNEVmNJaXdnWENKbmNtOTFjRGhjSWlrc0lEVXBYRzVjYm5BZ1BDMGdaMmR3Ykc5MEtHUmhkR0VzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCamIzVnVkQ3dnWm1sc2JDQTlJR2R5YjNWd0tTa2dLMXh1SUNCblpXOXRYMkp2ZUhCc2IzUW9kMmxrZEdnZ1BTQXdMalVzSUc5MWRHeHBaWEl1YzJoaGNHVWdQU0JPUVNrZ0t5QjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0t5QWdJQ0FnSUNCY2JpQWdjMk5oYkdWZmVWOWpiMjUwYVc1MWIzVnpLR0p5WldGcmN5QTlJSE5sY1Nnd0xDQTFMQ0JpZVNBOUlESXBMQ0JzYVcxcGRITWdQU0JqS0RBc0lEVXBLU0FySUZ4dUlDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ1ozSnZkWEFwTENCbWRXNGdQU0J0WldGdUxDQm5aVzl0SUQwZ1hDSndiMmx1ZEZ3aUxDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNaXdnWm1sc2JDQTlJRndpY21Wa1hDSXNJR052Ykc5eUlEMGdYQ0ppYkdGamExd2lLU0FnSzF4dUlDQmhibTV2ZEdGMFpTaGNJblJsZUhSY0lpd2dlQ0E5SURFc0lIa2dQU0F6TENCc1lXSmxiQ0E5SUhCaGMzUmxNQ2hjSW5CMk1USTZJRndpTENCd2RqRXlMQ0JjSWx4Y2Jsd2lMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hDSndkakUxT2lCY0lpd2djSFl4TlN3Z1hDSmNYRzVjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0hZeE9Eb2dYQ0lzSUhCMk1UZ3NJRndpWEZ4dVhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQjJNalU2SUZ3aUxDQndkakkxTENCY0lseGNibHdpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p3ZGpJNE9pQmNJaXdnY0hZeU9Dd2dYQ0pjWEc1Y0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ3aWNIWTFPRG9nWENJc0lIQjJOVGdzSUZ3aVhGeHVYQ0lwTENCY2JpQWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJREVwS3lBZ2RHaGxiV1VvYkdWblpXNWtMbkJ2YzJsMGFXOXVJRDBnWENKdWIyNWxYQ0lwWEc1Y2JseHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRndpWTI5MWJuUmZZbUZ5Y0d4dmRGOWthV1ptUjNKdmRYQmZaRlJCUjE5MmMxOUVUVk5QWDNCelhDSXBYRzVvWldsbmFIUWdQQzBnTTF4dWQybGtkR2dnUEMwZ00xeHVjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGd2lMbkJ1WjF3aUtTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRndpYVc1Y0lpd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dWNISnBiblFvY0NsY2JtUmxkaTV2Wm1Zb0tWeHVjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjSWk1emRtZGNJaWtwTENBZ2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG4jIyMjIyMjI1xuI1AtU1xuZGF0YSA8LSB0ZW1wMiAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgbnVtX3BzKVxuY29sbmFtZXMoZGF0YSkgPC0gYyhcXGdyb3VwXFwsIFxcY291bnRcXClcbnB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxucHYxNSA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG5wdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbnB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG5wdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcblxucCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IGNvdW50LCBmaWxsID0gZ3JvdXApKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArICAgICAgIFxuICBzY2FsZV95X2NvbnRpbnVvdXMoYnJlYWtzID0gc2VxKDAsIDUsIGJ5ID0gMiksIGxpbWl0cyA9IGMoMCwgNSkpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIHB2MTIsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE4OiBcXCwgcHYxOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNTogXFwsIHB2MjUsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjU4OiBcXCwgcHY1OCwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSkrICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXClcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxjb3VudF9iYXJwbG90X2RpZmZHcm91cF9kVEFHX3ZzX0RNU09fcHNcXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
########
#P-S
data <- temp2 %>% dplyr::select(group, num_ps)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
                                                \pv15: \, pv15, \\n\,
                                                \pv18: \, pv18, \\n\,
                                                \pv25: \, pv25, \\n\,
                                                \pv28: \, pv28, \\n\,
                                                \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 1)+  theme(legend.position = \none\)


fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_ps\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSXlOY2JpTlFMVk5jYm1SaGRHRWdQQzBnZEdWdGNESWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aM0p2ZFhBc0lHNTFiVjl3Y3lsY2JtTnZiRzVoYldWektHUmhkR0VwSUR3dElHTW9YRnhuY205MWNGeGNMQ0JjWEdOdmRXNTBYRndwWEc1d2RqRXlJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjWEdkeWIzVndNVnhjTENCY1hHZHliM1Z3TWx4Y0tTd2dOU2xjYm5CMk1UVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoa1lYUmhMRnhjWjNKdmRYQXhYRndzSUZ4Y1ozSnZkWEExWEZ3cExDQTFLVnh1Y0hZeE9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYRnhuY205MWNERmNYQ3dnWEZ4bmNtOTFjRGhjWENrc0lEVXBYRzV3ZGpJMUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvWkdGMFlTeGNYR2R5YjNWd01seGNMQ0JjWEdkeWIzVndOVnhjS1N3Z05TbGNibkIyTWpnZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGeGNaM0p2ZFhBeVhGd3NJRnhjWjNKdmRYQTRYRndwTENBMUtWeHVjSFkxT0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLR1JoZEdFc1hGeG5jbTkxY0RWY1hDd2dYRnhuY205MWNEaGNYQ2tzSURVcFhHNWNibkFnUEMwZ1oyZHdiRzkwS0dSaGRHRXNJR0ZsY3loNElEMGdaM0p2ZFhBc0lIa2dQU0JqYjNWdWRDd2dabWxzYkNBOUlHZHliM1Z3S1NrZ0sxeHVJQ0JuWlc5dFgySnZlSEJzYjNRb2QybGtkR2dnUFNBd0xqVXNJRzkxZEd4cFpYSXVjMmhoY0dVZ1BTQk9RU2tnS3lCMGFHVnRaVjlqYkdGemMybGpLQ2tnS3lBZ0lDQWdJQ0JjYmlBZ2MyTmhiR1ZmZVY5amIyNTBhVzUxYjNWektHSnlaV0ZyY3lBOUlITmxjU2d3TENBMUxDQmllU0E5SURJcExDQnNhVzFwZEhNZ1BTQmpLREFzSURVcEtTQXJJRnh1SUNCemRHRjBYM04xYlcxaGNua29ZV1Z6S0dkeWIzVndJRDBnWjNKdmRYQXBMQ0JtZFc0Z1BTQnRaV0Z1TENCblpXOXRJRDBnWEZ4d2IybHVkRnhjTENCemFHRndaU0E5SURJeExDQnphWHBsSUQwZ01pd2dabWxzYkNBOUlGeGNjbVZrWEZ3c0lHTnZiRzl5SUQwZ1hGeGliR0ZqYTF4Y0tTQWdLMXh1SUNCaGJtNXZkR0YwWlNoY1hIUmxlSFJjWEN3Z2VDQTlJREVzSUhrZ1BTQXpMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNYSEIyTVRJNklGeGNMQ0J3ZGpFeUxDQmNYRnhjYmx4Y0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWEZ4d2RqRTFPaUJjWEN3Z2NIWXhOU3dnWEZ4Y1hHNWNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjSFl4T0RvZ1hGd3NJSEIyTVRnc0lGeGNYRnh1WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhCMk1qVTZJRnhjTENCd2RqSTFMQ0JjWEZ4Y2JseGNMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hGeHdkakk0T2lCY1hDd2djSFl5T0N3Z1hGeGNYRzVjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRnhjY0hZMU9Eb2dYRndzSUhCMk5UZ3NJRnhjWEZ4dVhGd3BMQ0JjYmlBZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlERXBLeUFnZEdobGJXVW9iR1ZuWlc1a0xuQnZjMmwwYVc5dUlEMGdYRnh1YjI1bFhGd3BYRzVjYmx4dVptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGeGNZMjkxYm5SZlltRnljR3h2ZEY5a2FXWm1SM0p2ZFhCZlpGUkJSMTkyYzE5RVRWTlBYM0J6WEZ3cFhHNW9aV2xuYUhRZ1BDMGdNMXh1ZDJsa2RHZ2dQQzBnTTF4dWNHNW5LR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ4Y0xuQnVaMXhjS1Nrc0lISmxjeUE5SURZd01Dd2dkVzVwZENBOUlGeGNhVzVjWEN3Z2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dWMzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNYQzV6ZG1kY1hDa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1WUdCZ1hHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLVNcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wcylcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbnB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG5wdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxucHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE1OiBcXCwgcHYxNSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxODogXFwsIHB2MTgsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgcHYyOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY1ODogXFwsIHB2NTgsIFxcXFxuXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpKyAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPX3BzXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLVNcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wcylcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbnB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG5wdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxucHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE1OiBcXCwgcHYxNSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxODogXFwsIHB2MTgsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgcHYyOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY1ODogXFwsIHB2NTgsIFxcXFxuXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpKyAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPX3BzXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
########
#P-S
data <- temp2 %>% dplyr::select(group, num_ps)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
                                                \pv15: \, pv15, \\n\,
                                                \pv18: \, pv18, \\n\,
                                                \pv25: \, pv25, \\n\,
                                                \pv28: \, pv28, \\n\,
                                                \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 1)+  theme(legend.position = \none\)


fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_ps\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-E

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakl5TmNiaU5RTFZoY2JtUmhkR0VnUEMwZ2RHVnRjRElnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWjNKdmRYQXNJRzUxYlY5d2VDbGNibU52Ykc1aGJXVnpLR1JoZEdFcElEd3RJR01vWENKbmNtOTFjRndpTENCY0ltTnZkVzUwWENJcFhHNXdkakV5SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29aR0YwWVN4Y0ltZHliM1Z3TVZ3aUxDQmNJbWR5YjNWd01sd2lLU3dnTlNsY2JuQjJNVFVnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaGtZWFJoTEZ3aVozSnZkWEF4WENJc0lGd2laM0p2ZFhBMVhDSXBMQ0ExS1Z4dWNIWXhPQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtHUmhkR0VzWENKbmNtOTFjREZjSWl3Z1hDSm5jbTkxY0RoY0lpa3NJRFVwWEc1d2RqSTFJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjSW1keWIzVndNbHdpTENCY0ltZHliM1Z3TlZ3aUtTd2dOU2xjYm5CMk1qZ2dQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoa1lYUmhMRndpWjNKdmRYQXlYQ0lzSUZ3aVozSnZkWEE0WENJcExDQTFLVnh1Y0hZMU9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYQ0puY205MWNEVmNJaXdnWENKbmNtOTFjRGhjSWlrc0lEVXBYRzVjYm5BZ1BDMGdaMmR3Ykc5MEtHUmhkR0VzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCamIzVnVkQ3dnWm1sc2JDQTlJR2R5YjNWd0tTa2dLMXh1SUNCblpXOXRYMkp2ZUhCc2IzUW9kMmxrZEdnZ1BTQXdMalVzSUc5MWRHeHBaWEl1YzJoaGNHVWdQU0JPUVNrZ0t5QjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0t5QWdJQ0FnSUNCY2JpQWdjMk5oYkdWZmVWOWpiMjUwYVc1MWIzVnpLR0p5WldGcmN5QTlJSE5sY1Nnd0xDQTFMQ0JpZVNBOUlESXBMQ0JzYVcxcGRITWdQU0JqS0RBc0lEVXBLU0FySUZ4dUlDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ1ozSnZkWEFwTENCbWRXNGdQU0J0WldGdUxDQm5aVzl0SUQwZ1hDSndiMmx1ZEZ3aUxDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNaXdnWm1sc2JDQTlJRndpY21Wa1hDSXNJR052Ykc5eUlEMGdYQ0ppYkdGamExd2lLU0FnSzF4dUlDQmhibTV2ZEdGMFpTaGNJblJsZUhSY0lpd2dlQ0E5SURFc0lIa2dQU0F6TENCc1lXSmxiQ0E5SUhCaGMzUmxNQ2hjSW5CMk1USTZJRndpTENCd2RqRXlMQ0JjSWx4Y2Jsd2lMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hDSndkakUxT2lCY0lpd2djSFl4TlN3Z1hDSmNYRzVjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0hZeE9Eb2dYQ0lzSUhCMk1UZ3NJRndpWEZ4dVhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQjJNalU2SUZ3aUxDQndkakkxTENCY0lseGNibHdpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p3ZGpJNE9pQmNJaXdnY0hZeU9Dd2dYQ0pjWEc1Y0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ3aWNIWTFPRG9nWENJc0lIQjJOVGdzSUZ3aVhGeHVYQ0lwTENCY2JpQWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJREVwS3lBZ2RHaGxiV1VvYkdWblpXNWtMbkJ2YzJsMGFXOXVJRDBnWENKdWIyNWxYQ0lwWEc1Y2JseHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRndpWTI5MWJuUmZZbUZ5Y0d4dmRGOWthV1ptUjNKdmRYQmZaRlJCUjE5MmMxOUVUVk5QWDNCNFhDSXBYRzVvWldsbmFIUWdQQzBnTTF4dWQybGtkR2dnUEMwZ00xeHVjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGd2lMbkJ1WjF3aUtTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRndpYVc1Y0lpd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dWNISnBiblFvY0NsY2JtUmxkaTV2Wm1Zb0tWeHVjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjSWk1emRtZGNJaWtwTENBZ2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG4jIyMjIyMjI1xuI1AtWFxuZGF0YSA8LSB0ZW1wMiAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgbnVtX3B4KVxuY29sbmFtZXMoZGF0YSkgPC0gYyhcXGdyb3VwXFwsIFxcY291bnRcXClcbnB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxucHYxNSA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG5wdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbnB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG5wdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcblxucCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IGNvdW50LCBmaWxsID0gZ3JvdXApKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArICAgICAgIFxuICBzY2FsZV95X2NvbnRpbnVvdXMoYnJlYWtzID0gc2VxKDAsIDUsIGJ5ID0gMiksIGxpbWl0cyA9IGMoMCwgNSkpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIHB2MTIsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE4OiBcXCwgcHYxOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNTogXFwsIHB2MjUsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjU4OiBcXCwgcHY1OCwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSkrICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXClcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxjb3VudF9iYXJwbG90X2RpZmZHcm91cF9kVEFHX3ZzX0RNU09fcHhcXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
########
#P-X
data <- temp2 %>% dplyr::select(group, num_px)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
                                                \pv15: \, pv15, \\n\,
                                                \pv18: \, pv18, \\n\,
                                                \pv25: \, pv25, \\n\,
                                                \pv28: \, pv28, \\n\,
                                                \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 1)+  theme(legend.position = \none\)


fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_px\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSXlOY2JpTlFMVmhjYm1SaGRHRWdQQzBnZEdWdGNESWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aM0p2ZFhBc0lHNTFiVjl3ZUNsY2JtTnZiRzVoYldWektHUmhkR0VwSUR3dElHTW9YRnhuY205MWNGeGNMQ0JjWEdOdmRXNTBYRndwWEc1d2RqRXlJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjWEdkeWIzVndNVnhjTENCY1hHZHliM1Z3TWx4Y0tTd2dOU2xjYm5CMk1UVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoa1lYUmhMRnhjWjNKdmRYQXhYRndzSUZ4Y1ozSnZkWEExWEZ3cExDQTFLVnh1Y0hZeE9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYRnhuY205MWNERmNYQ3dnWEZ4bmNtOTFjRGhjWENrc0lEVXBYRzV3ZGpJMUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvWkdGMFlTeGNYR2R5YjNWd01seGNMQ0JjWEdkeWIzVndOVnhjS1N3Z05TbGNibkIyTWpnZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGeGNaM0p2ZFhBeVhGd3NJRnhjWjNKdmRYQTRYRndwTENBMUtWeHVjSFkxT0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLR1JoZEdFc1hGeG5jbTkxY0RWY1hDd2dYRnhuY205MWNEaGNYQ2tzSURVcFhHNWNibkFnUEMwZ1oyZHdiRzkwS0dSaGRHRXNJR0ZsY3loNElEMGdaM0p2ZFhBc0lIa2dQU0JqYjNWdWRDd2dabWxzYkNBOUlHZHliM1Z3S1NrZ0sxeHVJQ0JuWlc5dFgySnZlSEJzYjNRb2QybGtkR2dnUFNBd0xqVXNJRzkxZEd4cFpYSXVjMmhoY0dVZ1BTQk9RU2tnS3lCMGFHVnRaVjlqYkdGemMybGpLQ2tnS3lBZ0lDQWdJQ0JjYmlBZ2MyTmhiR1ZmZVY5amIyNTBhVzUxYjNWektHSnlaV0ZyY3lBOUlITmxjU2d3TENBMUxDQmllU0E5SURJcExDQnNhVzFwZEhNZ1BTQmpLREFzSURVcEtTQXJJRnh1SUNCemRHRjBYM04xYlcxaGNua29ZV1Z6S0dkeWIzVndJRDBnWjNKdmRYQXBMQ0JtZFc0Z1BTQnRaV0Z1TENCblpXOXRJRDBnWEZ4d2IybHVkRnhjTENCemFHRndaU0E5SURJeExDQnphWHBsSUQwZ01pd2dabWxzYkNBOUlGeGNjbVZrWEZ3c0lHTnZiRzl5SUQwZ1hGeGliR0ZqYTF4Y0tTQWdLMXh1SUNCaGJtNXZkR0YwWlNoY1hIUmxlSFJjWEN3Z2VDQTlJREVzSUhrZ1BTQXpMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNYSEIyTVRJNklGeGNMQ0J3ZGpFeUxDQmNYRnhjYmx4Y0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWEZ4d2RqRTFPaUJjWEN3Z2NIWXhOU3dnWEZ4Y1hHNWNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjSFl4T0RvZ1hGd3NJSEIyTVRnc0lGeGNYRnh1WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhCMk1qVTZJRnhjTENCd2RqSTFMQ0JjWEZ4Y2JseGNMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hGeHdkakk0T2lCY1hDd2djSFl5T0N3Z1hGeGNYRzVjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRnhjY0hZMU9Eb2dYRndzSUhCMk5UZ3NJRnhjWEZ4dVhGd3BMQ0JjYmlBZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlERXBLeUFnZEdobGJXVW9iR1ZuWlc1a0xuQnZjMmwwYVc5dUlEMGdYRnh1YjI1bFhGd3BYRzVjYmx4dVptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGeGNZMjkxYm5SZlltRnljR3h2ZEY5a2FXWm1SM0p2ZFhCZlpGUkJSMTkyYzE5RVRWTlBYM0I0WEZ3cFhHNW9aV2xuYUhRZ1BDMGdNMXh1ZDJsa2RHZ2dQQzBnTTF4dWNHNW5LR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ4Y0xuQnVaMXhjS1Nrc0lISmxjeUE5SURZd01Dd2dkVzVwZENBOUlGeGNhVzVjWEN3Z2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dWMzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNYQzV6ZG1kY1hDa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1WUdCZ1hHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLVhcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9weClcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbnB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG5wdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxucHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE1OiBcXCwgcHYxNSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxODogXFwsIHB2MTgsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgcHYyOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY1ODogXFwsIHB2NTgsIFxcXFxuXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpKyAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPX3B4XFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLVhcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9weClcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG5wdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbnB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxucHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG5wdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxucHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE1OiBcXCwgcHYxNSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxODogXFwsIHB2MTgsIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgcHYyOCwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY1ODogXFwsIHB2NTgsIFxcXFxuXFwpLCBcbiAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpKyAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfZFRBR192c19ETVNPX3B4XFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
########
#P-X
data <- temp2 %>% dplyr::select(group, num_px)
colnames(data) <- c(\group\, \count\)
pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
                                                \pv15: \, pv15, \\n\,
                                                \pv18: \, pv18, \\n\,
                                                \pv25: \, pv25, \\n\,
                                                \pv28: \, pv28, \\n\,
                                                \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 1)+  theme(legend.position = \none\)


fileName <- paste0(\count_barplot_diffGroup_dTAG_vs_DMSO_px\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-S

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiX3Atbl9lbnNlbWJsTGlzdC50c3ZcIikpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXCJQLVBcIiwgXCJQLUVcIiwgXCJQLVNcIiwgXCJQLVhcIikpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFwiX1wiKSlcblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX0E0ODVfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9BNDg1X0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZGlmZl9HMS5BNDg1LnNlbGVjdGVkMl9HMS4yaS5BNDg1X3ZzX0cxLjJpLkRNU08udHN2XCIpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFwiZ2VuZVwiID0gXCJlbnNlbWJsX2dlbmVfaWRcIikpICU+JSBcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cblxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuMlxuIyBcbnRlbXAgPC0gdGVtcCAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IGlmZWxzZShtZWFuX2RpZmZfc2NvcmUgPCAtZGlmZkN1dG9mZixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDwgLWZjQ3V0b2ZmLCAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDxmY0N1dG9mZiwgMiwgMykpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShtZWFuX2RpZmZfc2NvcmUgPCBkaWZmQ3V0b2ZmLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDwgLWZjQ3V0b2ZmLCA0LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKHNocmlua2VkX2xvZzJGQyA8IGZjQ3V0b2ZmLCA1LCA2KSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPCAtZmNDdXRvZmYsIDcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDwgZmNDdXRvZmYsIDgsIDkpKSkpKVxuXG5cbmdlbmUuZ3JvdXAxIDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDEpKSRnZW5lXG5nZW5lLmdyb3VwMiA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAyKSkkZ2VuZVxuZ2VuZS5ncm91cDMgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMykpJGdlbmVcbmdlbmUuZ3JvdXA0IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDQpKSRnZW5lXG5nZW5lLmdyb3VwNSA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA1KSkkZ2VuZVxuZ2VuZS5ncm91cDYgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNikpJGdlbmVcbmdlbmUuZ3JvdXA3IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDcpKSRnZW5lXG5nZW5lLmdyb3VwOCA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA4KSkkZ2VuZVxuZ2VuZS5ncm91cDkgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gOSkpJGdlbmVcblxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDEpKSwgaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwMS50c3ZcIiksIHNlcCA9IFwiXFx0XCIpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMikpLCBoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAyLnRzdlwiKSwgc2VwID0gXCJcXHRcIilcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAzKSksIGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDMudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDQpKSwgaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwNC50c3ZcIiksIHNlcCA9IFwiXFx0XCIpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNSkpLCBoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlwiKSwgc2VwID0gXCJcXHRcIilcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA2KSksIGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDYudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDcpKSwgaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwNy50c3ZcIiksIHNlcCA9IFwiXFx0XCIpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gOCkpLCBoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA4LnRzdlwiKSwgc2VwID0gXCJcXHRcIilcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA5KSksIGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDkudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuXG5cbiMgQWRkaW5nIGdyb3VwIGluZm9ybWF0aW9uIHRvIGdlbmVBbm5vXG5nZW5lQW5ub0RhdGEgPC0gZ2VuZUFubm9EYXRhICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwMSwgXCJncm91cDFcIixcbiAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwMiwgXCJncm91cDJcIixcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDMsIFwiZ3JvdXAzXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwNCwgXCJncm91cDRcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwNSwgXCJncm91cDVcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDYsIFwiZ3JvdXA2XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwNywgXCJncm91cDdcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwOCwgXCJncm91cDhcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDksIFwiZ3JvdXA5XCIsIE5BKSkpKSkpKSkpXG4pXG5cblxuYGBgIn0= -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1,\n                peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n\n\n## Dividing genes into groups\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO),\n            mean_distance = mean(distance),\n            .groups = 'drop')\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  drop_na(shrinked_log2FC)\n\n\nfcCutoff <- 0.5\ndiffCutoff <- 0.2\n# \ntemp <- temp %>%\n  dplyr::mutate(group = ifelse(mean_diff_score < -diffCutoff,\n                               ifelse(shrinked_log2FC < -fcCutoff, 1,\n                                      ifelse(shrinked_log2FC <fcCutoff, 2, 3)),\n                               ifelse(mean_diff_score < diffCutoff,\n                                      ifelse(shrinked_log2FC < -fcCutoff, 4,\n                                             ifelse(shrinked_log2FC < fcCutoff, 5, 6)),\n                                      ifelse(shrinked_log2FC < -fcCutoff, 7,\n                                             ifelse(shrinked_log2FC < fcCutoff, 8, 9)))))\n\n\ngene.group1 <- (temp %>% dplyr::filter(group == 1))$gene\ngene.group2 <- (temp %>% dplyr::filter(group == 2))$gene\ngene.group3 <- (temp %>% dplyr::filter(group == 3))$gene\ngene.group4 <- (temp %>% dplyr::filter(group == 4))$gene\ngene.group5 <- (temp %>% dplyr::filter(group == 5))$gene\ngene.group6 <- (temp %>% dplyr::filter(group == 6))$gene\ngene.group7 <- (temp %>% dplyr::filter(group == 7))$gene\ngene.group8 <- (temp %>% dplyr::filter(group == 8))$gene\ngene.group9 <- (temp %>% dplyr::filter(group == 9))$gene\n\nfwrite((temp %>% dplyr::filter(group == 1)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group1.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 2)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group2.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 3)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group3.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 4)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group4.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 5)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group5.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 6)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group6.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 7)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group7.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 8)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group8.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 9)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group9.tsv\\), sep = \\\\t\\)\n\n\n# Adding group information to geneAnno\ngeneAnnoData <- geneAnnoData %>% unnest(gene) %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\,\n                        ifelse(gene %in% gene.group3, \\group3\\,\n                               ifelse(gene %in% gene.group4, \\group4\\,\n                                      ifelse(gene %in% gene.group5, \\group5\\,\n                                             ifelse(gene %in% gene.group6, \\group6\\,\n                                                    ifelse(gene %in% gene.group7, \\group7\\,\n                                                           ifelse(gene %in% gene.group8, \\group8\\,\n                                                                  ifelse(gene %in% gene.group9, \\group9\\, NA)))))))))\n)\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)


temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)


fcCutoff <- 0.5
diffCutoff <- 0.2
# 
temp <- temp %>%
  dplyr::mutate(group = ifelse(mean_diff_score < -diffCutoff,
                               ifelse(shrinked_log2FC < -fcCutoff, 1,
                                      ifelse(shrinked_log2FC <fcCutoff, 2, 3)),
                               ifelse(mean_diff_score < diffCutoff,
                                      ifelse(shrinked_log2FC < -fcCutoff, 4,
                                             ifelse(shrinked_log2FC < fcCutoff, 5, 6)),
                                      ifelse(shrinked_log2FC < -fcCutoff, 7,
                                             ifelse(shrinked_log2FC < fcCutoff, 8, 9)))))


gene.group1 <- (temp %>% dplyr::filter(group == 1))$gene
gene.group2 <- (temp %>% dplyr::filter(group == 2))$gene
gene.group3 <- (temp %>% dplyr::filter(group == 3))$gene
gene.group4 <- (temp %>% dplyr::filter(group == 4))$gene
gene.group5 <- (temp %>% dplyr::filter(group == 5))$gene
gene.group6 <- (temp %>% dplyr::filter(group == 6))$gene
gene.group7 <- (temp %>% dplyr::filter(group == 7))$gene
gene.group8 <- (temp %>% dplyr::filter(group == 8))$gene
gene.group9 <- (temp %>% dplyr::filter(group == 9))$gene

fwrite((temp %>% dplyr::filter(group == 1)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group1.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 2)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group2.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 3)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group3.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 4)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group4.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 5)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group5.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 6)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group6.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 7)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group7.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 8)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group8.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 9)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group9.tsv\), sep = \\t\)


# Adding group information to geneAnno
geneAnnoData <- geneAnnoData %>% unnest(gene) %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\,
                        ifelse(gene %in% gene.group3, \group3\,
                               ifelse(gene %in% gene.group4, \group4\,
                                      ifelse(gene %in% gene.group5, \group5\,
                                             ifelse(gene %in% gene.group6, \group6\,
                                                    ifelse(gene %in% gene.group7, \group7\,
                                                           ifelse(gene %in% gene.group8, \group8\,
                                                                  ifelse(gene %in% gene.group9, \group9\, NA)))))))))
)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSlcblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX0E0ODVfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9BNDg1X0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5BNDg1LnNlbGVjdGVkMl9HMS4yaS5BNDg1X3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cblxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuMlxuIyBcbnRlbXAgPC0gdGVtcCAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IGlmZWxzZShtZWFuX2RpZmZfc2NvcmUgPCAtZGlmZkN1dG9mZixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDwgLWZjQ3V0b2ZmLCAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDxmY0N1dG9mZiwgMiwgMykpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShtZWFuX2RpZmZfc2NvcmUgPCBkaWZmQ3V0b2ZmLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDwgLWZjQ3V0b2ZmLCA0LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKHNocmlua2VkX2xvZzJGQyA8IGZjQ3V0b2ZmLCA1LCA2KSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPCAtZmNDdXRvZmYsIDcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDwgZmNDdXRvZmYsIDgsIDkpKSkpKVxuXG5cbmdlbmUuZ3JvdXAxIDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDEpKSRnZW5lXG5nZW5lLmdyb3VwMiA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAyKSkkZ2VuZVxuZ2VuZS5ncm91cDMgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMykpJGdlbmVcbmdlbmUuZ3JvdXA0IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDQpKSRnZW5lXG5nZW5lLmdyb3VwNSA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA1KSkkZ2VuZVxuZ2VuZS5ncm91cDYgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNikpJGdlbmVcbmdlbmUuZ3JvdXA3IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDcpKSRnZW5lXG5nZW5lLmdyb3VwOCA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA4KSkkZ2VuZVxuZ2VuZS5ncm91cDkgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gOSkpJGdlbmVcblxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDEpKSwgaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwMS50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMikpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAyLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAzKSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDMudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDQpKSwgaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwNC50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNSkpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA2KSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDYudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDcpKSwgaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwNy50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gOCkpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA4LnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA5KSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDkudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG5cbiMgQWRkaW5nIGdyb3VwIGluZm9ybWF0aW9uIHRvIGdlbmVBbm5vXG5nZW5lQW5ub0RhdGEgPC0gZ2VuZUFubm9EYXRhICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwMSwgXFxncm91cDFcXCxcbiAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwMiwgXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDMsIFxcZ3JvdXAzXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwNCwgXFxncm91cDRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwNSwgXFxncm91cDVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDYsIFxcZ3JvdXA2XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwNywgXFxncm91cDdcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwOCwgXFxncm91cDhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDksIFxcZ3JvdXA5XFwsIE5BKSkpKSkpKSkpXG4pXG5cblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1,\n                peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n\n\n## Dividing genes into groups\ntemp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_A485_DMSO),\n            mean_distance = mean(distance),\n            .groups = 'drop')\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  drop_na(shrinked_log2FC)\n\n\nfcCutoff <- 0.5\ndiffCutoff <- 0.2\n# \ntemp <- temp %>%\n  dplyr::mutate(group = ifelse(mean_diff_score < -diffCutoff,\n                               ifelse(shrinked_log2FC < -fcCutoff, 1,\n                                      ifelse(shrinked_log2FC <fcCutoff, 2, 3)),\n                               ifelse(mean_diff_score < diffCutoff,\n                                      ifelse(shrinked_log2FC < -fcCutoff, 4,\n                                             ifelse(shrinked_log2FC < fcCutoff, 5, 6)),\n                                      ifelse(shrinked_log2FC < -fcCutoff, 7,\n                                             ifelse(shrinked_log2FC < fcCutoff, 8, 9)))))\n\n\ngene.group1 <- (temp %>% dplyr::filter(group == 1))$gene\ngene.group2 <- (temp %>% dplyr::filter(group == 2))$gene\ngene.group3 <- (temp %>% dplyr::filter(group == 3))$gene\ngene.group4 <- (temp %>% dplyr::filter(group == 4))$gene\ngene.group5 <- (temp %>% dplyr::filter(group == 5))$gene\ngene.group6 <- (temp %>% dplyr::filter(group == 6))$gene\ngene.group7 <- (temp %>% dplyr::filter(group == 7))$gene\ngene.group8 <- (temp %>% dplyr::filter(group == 8))$gene\ngene.group9 <- (temp %>% dplyr::filter(group == 9))$gene\n\nfwrite((temp %>% dplyr::filter(group == 1)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group1.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 2)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group2.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 3)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group3.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 4)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group4.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 5)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group5.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 6)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group6.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 7)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group7.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 8)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group8.tsv\\), sep = \\\\t\\)\nfwrite((temp %>% dplyr::filter(group == 9)), here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group9.tsv\\), sep = \\\\t\\)\n\n\n# Adding group information to geneAnno\ngeneAnnoData <- geneAnnoData %>% unnest(gene) %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\,\n                        ifelse(gene %in% gene.group3, \\group3\\,\n                               ifelse(gene %in% gene.group4, \\group4\\,\n                                      ifelse(gene %in% gene.group5, \\group5\\,\n                                             ifelse(gene %in% gene.group6, \\group6\\,\n                                                    ifelse(gene %in% gene.group7, \\group7\\,\n                                                           ifelse(gene %in% gene.group8, \\group8\\,\n                                                                  ifelse(gene %in% gene.group9, \\group9\\, NA)))))))))\n)\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSlcblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX0E0ODVfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9BNDg1X0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5BNDg1LnNlbGVjdGVkMl9HMS4yaS5BNDg1X3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cblxuZmNDdXRvZmYgPC0gMC41XG5kaWZmQ3V0b2ZmIDwtIDAuMlxuIyBcbnRlbXAgPC0gdGVtcCAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IGlmZWxzZShtZWFuX2RpZmZfc2NvcmUgPCAtZGlmZkN1dG9mZixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDwgLWZjQ3V0b2ZmLCAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDxmY0N1dG9mZiwgMiwgMykpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShtZWFuX2RpZmZfc2NvcmUgPCBkaWZmQ3V0b2ZmLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDwgLWZjQ3V0b2ZmLCA0LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKHNocmlua2VkX2xvZzJGQyA8IGZjQ3V0b2ZmLCA1LCA2KSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShzaHJpbmtlZF9sb2cyRkMgPCAtZmNDdXRvZmYsIDcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2Uoc2hyaW5rZWRfbG9nMkZDIDwgZmNDdXRvZmYsIDgsIDkpKSkpKVxuXG5cbmdlbmUuZ3JvdXAxIDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDEpKSRnZW5lXG5nZW5lLmdyb3VwMiA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAyKSkkZ2VuZVxuZ2VuZS5ncm91cDMgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMykpJGdlbmVcbmdlbmUuZ3JvdXA0IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDQpKSRnZW5lXG5nZW5lLmdyb3VwNSA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA1KSkkZ2VuZVxuZ2VuZS5ncm91cDYgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNikpJGdlbmVcbmdlbmUuZ3JvdXA3IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDcpKSRnZW5lXG5nZW5lLmdyb3VwOCA8LSAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA4KSkkZ2VuZVxuZ2VuZS5ncm91cDkgPC0gKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gOSkpJGdlbmVcblxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDEpKSwgaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwMS50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gMikpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAyLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSAzKSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDMudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDQpKSwgaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwNC50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gNSkpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA2KSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDYudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuZndyaXRlKCh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IDcpKSwgaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwNy50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gOCkpLCBoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA4LnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZSgodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSA5KSksIGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDkudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG5cbiMgQWRkaW5nIGdyb3VwIGluZm9ybWF0aW9uIHRvIGdlbmVBbm5vXG5nZW5lQW5ub0RhdGEgPC0gZ2VuZUFubm9EYXRhICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwMSwgXFxncm91cDFcXCxcbiAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwMiwgXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDMsIFxcZ3JvdXAzXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwNCwgXFxncm91cDRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwNSwgXFxncm91cDVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDYsIFxcZ3JvdXA2XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwNywgXFxncm91cDdcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBnZW5lLmdyb3VwOCwgXFxncm91cDhcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDksIFxcZ3JvdXA5XFwsIE5BKSkpKSkpKSkpXG4pXG5cblxuYGBgXG5gYGAifQ== -->

```r
```r
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)


temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)


fcCutoff <- 0.5
diffCutoff <- 0.2
# 
temp <- temp %>%
  dplyr::mutate(group = ifelse(mean_diff_score < -diffCutoff,
                               ifelse(shrinked_log2FC < -fcCutoff, 1,
                                      ifelse(shrinked_log2FC <fcCutoff, 2, 3)),
                               ifelse(mean_diff_score < diffCutoff,
                                      ifelse(shrinked_log2FC < -fcCutoff, 4,
                                             ifelse(shrinked_log2FC < fcCutoff, 5, 6)),
                                      ifelse(shrinked_log2FC < -fcCutoff, 7,
                                             ifelse(shrinked_log2FC < fcCutoff, 8, 9)))))


gene.group1 <- (temp %>% dplyr::filter(group == 1))$gene
gene.group2 <- (temp %>% dplyr::filter(group == 2))$gene
gene.group3 <- (temp %>% dplyr::filter(group == 3))$gene
gene.group4 <- (temp %>% dplyr::filter(group == 4))$gene
gene.group5 <- (temp %>% dplyr::filter(group == 5))$gene
gene.group6 <- (temp %>% dplyr::filter(group == 6))$gene
gene.group7 <- (temp %>% dplyr::filter(group == 7))$gene
gene.group8 <- (temp %>% dplyr::filter(group == 8))$gene
gene.group9 <- (temp %>% dplyr::filter(group == 9))$gene

fwrite((temp %>% dplyr::filter(group == 1)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group1.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 2)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group2.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 3)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group3.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 4)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group4.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 5)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group5.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 6)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group6.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 7)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group7.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 8)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group8.tsv\), sep = \\t\)
fwrite((temp %>% dplyr::filter(group == 9)), here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group9.tsv\), sep = \\t\)


# Adding group information to geneAnno
geneAnnoData <- geneAnnoData %>% unnest(gene) %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\,
                        ifelse(gene %in% gene.group3, \group3\,
                               ifelse(gene %in% gene.group4, \group4\,
                                      ifelse(gene %in% gene.group5, \group5\,
                                             ifelse(gene %in% gene.group6, \group6\,
                                                    ifelse(gene %in% gene.group7, \group7\,
                                                           ifelse(gene %in% gene.group8, \group8\,
                                                                  ifelse(gene %in% gene.group9, \group9\, NA)))))))))
)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-X

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuR08xIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuR08yIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuR08zIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuR080IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuR081IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuR082IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuR083IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuR084IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwOCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuR085IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwOSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuXG5kb3RwbG90KEdPMSwgc2hvd0NhdGVnb3J5ID0gMTApXG5cbiMgXG4jIEdPMS5kZiA8LSBhcy5kYXRhLmZyYW1lKEdPMSlcbiMgR08yLmRmIDwtIGFzLmRhdGEuZnJhbWUoR08yKVxuIyBHTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzUpXG4jIEdPNC5kZiA8LSBhcy5kYXRhLmZyYW1lKEdPOClcbiMgXG4jIHN1YnNldDEgPC0gR08xLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcImdyb3VwMVwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXCJncm91cDJcIikgJT4lXG4jICAgZHBseXI6Om11dGF0ZShcbiMgICAgIGdyID0gc2FwcGx5KEdlbmVSYXRpbywgZnVuY3Rpb24oeCkge1xuIyAgICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXCIvXCJcbiMgICAgICAgcGFydHMgPC0gdW5saXN0KHN0cnNwbGl0KHgsIFwiL1wiKSlcbiMgICAgICAgIyBDb252ZXJ0IHRvIG51bWVyaWMgYW5kIHBlcmZvcm0gdGhlIGRpdmlzaW9uXG4jICAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiMgICAgIH0pXG4jICAgKSAlPiUgZHBseXI6OmFycmFuZ2UoZGVzYyhncikpXG4jIHN1YnNldDMgPC0gR08zLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbixHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwiZ3JvdXAzXCIpICU+JVxuIyAgIGRwbHlyOjptdXRhdGUoXG4jICAgICBnciA9IHNhcHBseShHZW5lUmF0aW8sIGZ1bmN0aW9uKHgpIHtcbiMgICAgICAgIyBTcGxpdCB0aGUgc3RyaW5nIGJ5IFwiL1wiXG4jICAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcIi9cIikpXG4jICAgICAgICMgQ29udmVydCB0byBudW1lcmljIGFuZCBwZXJmb3JtIHRoZSBkaXZpc2lvblxuIyAgICAgICBhcy5udW1lcmljKHBhcnRzWzFdKSAvIGFzLm51bWVyaWMocGFydHNbMl0pXG4jICAgICB9KVxuIyAgICkgJT4lIGRwbHlyOjphcnJhbmdlKGRlc2MoZ3IpKVxuIyBcbiMgR09saXN0IDwtIGZhY3RvcihjKFwiR086MDAzMzAwMlwiLCBcIkdPOjAwNzAzNzNcIiwgXCJHTzowMDQ4NzMwXCIsIFwiR086MDAzMTEwM1wiLFxuIyAgICAgICAgICAgICAgICAgIFwiR086MDAyMjYxM1wiLCBcIkdPOjAwNTA3NjdcIiwgXCJHTzowMDM0NDcwXCIsIFwiR086MDAxNjA1NVwiLCBcbiMgICAgICAgICAgICAgICAgICBcIkdPOjAwMDYzOTdcIiwgXCJHTzowMDMwOTAwXCIsIFwiR086MDAwODM4MFwiKSlcbiMgXG4jIGRhdGEgPC0gYmluZF9yb3dzKGJpbmRfcm93cyhzdWJzZXQxLCBzdWJzZXQyKSwgc3Vic2V0MykgJT4lXG4jICAgZHBseXI6OmZpbHRlcihJRCAlaW4lIEdPbGlzdClcbiMgXG4jIGRlc2NPcmRlciA8LSBzb3J0KHVuaXF1ZShkYXRhJERlc2NyaXB0aW9uKSlbYygxLCAyLCA1LCA3LFxuIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAzLCA0LCA2LCA4LCA5LCAxMCwgMTEpXVxuIyBcbiMgcCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IGZhY3RvcihEZXNjcmlwdGlvbiwgbGV2ZWwgPSBkZXNjT3JkZXIpLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuIyAgIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuIyAgIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFwicmVkXCIsIGhpZ2ggPSBcImJsdWVcIiwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuIyAgIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiMgICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFwiLi5cIiwgXCJHT1wiLCBcIkdPX2dyb3Vwc1wiKVxuIyBoZWlnaHQgPSAyXG4jIHdpZHRoID0gMy41XG4jIHN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIiksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5gYGAifQ== -->\n\n```r\nGO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO3 <- enrichGO(gene = gene.group3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO4 <- enrichGO(gene = gene.group4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO5 <- enrichGO(gene = gene.group5, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO6 <- enrichGO(gene = gene.group6, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO7 <- enrichGO(gene = gene.group7, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO8 <- enrichGO(gene = gene.group8, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO9 <- enrichGO(gene = gene.group9, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\n\ndotplot(GO1, showCategory = 10)\n\n# \n# GO1.df <- as.data.frame(GO1)\n# GO2.df <- as.data.frame(GO2)\n# GO3.df <- as.data.frame(GO5)\n# GO4.df <- as.data.frame(GO8)\n# \n# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\group1\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset2 <- GO2.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \\group2\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset3 <- GO3.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \\group3\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# \n# GOlist <- factor(c(\\GO:0033002\\, \\GO:0070373\\, \\GO:0048730\\, \\GO:0031103\\,\n#                  \\GO:0022613\\, \\GO:0050767\\, \\GO:0034470\\, \\GO:0016055\\, \n#                  \\GO:0006397\\, \\GO:0030900\\, \\GO:0008380\\))\n# \n# data <- bind_rows(bind_rows(subset1, subset2), subset3) %>%\n#   dplyr::filter(ID %in% GOlist)\n# \n# descOrder <- sort(unique(data$Description))[c(1, 2, 5, 7,\n#                                  3, 4, 6, 8, 9, 10, 11)]\n# \n# p <- ggplot(data, aes(x = group, y = factor(Description, level = descOrder), color = p.adjust, size = gr)) + \n#   geom_point() + theme_bw() +\n#   scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n#   scale_size_continuous(range = c(0, 3)) +\n#   labs(x = NULL, y = NULL) +\n#   theme(axis.text = element_text(size = 6),  # Set axis text size\n#         axis.title = element_text(size = 6), # Set axis title size (if not removed)\n#         legend.text = element_text(size = 6), # Set legend text size\n#         legend.title = element_text(size = 6)) \n# \n# fileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups\\)\n# height = 2\n# width = 3.5\n# svglite(paste0(fileName, \\.svg\\), height = height, width = width)\n# print(p)\n# dev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
GO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO3 <- enrichGO(gene = gene.group3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO4 <- enrichGO(gene = gene.group4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO5 <- enrichGO(gene = gene.group5, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO6 <- enrichGO(gene = gene.group6, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO7 <- enrichGO(gene = gene.group7, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO8 <- enrichGO(gene = gene.group8, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO9 <- enrichGO(gene = gene.group9, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)

dotplot(GO1, showCategory = 10)

# 
# GO1.df <- as.data.frame(GO1)
# GO2.df <- as.data.frame(GO2)
# GO3.df <- as.data.frame(GO5)
# GO4.df <- as.data.frame(GO8)
# 
# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \group1\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \group2\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset3 <- GO3.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \group3\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# GOlist <- factor(c(\GO:0033002\, \GO:0070373\, \GO:0048730\, \GO:0031103\,
#                  \GO:0022613\, \GO:0050767\, \GO:0034470\, \GO:0016055\, 
#                  \GO:0006397\, \GO:0030900\, \GO:0008380\))
# 
# data <- bind_rows(bind_rows(subset1, subset2), subset3) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# descOrder <- sort(unique(data$Description))[c(1, 2, 5, 7,
#                                  3, 4, 6, 8, 9, 10, 11)]
# 
# p <- ggplot(data, aes(x = group, y = factor(Description, level = descOrder), color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, \..\, \GO\, \GO_groups\)
# height = 2
# width = 3.5
# svglite(paste0(fileName, \.svg\), height = height, width = width)
# print(p)
# dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuR08xIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR08yIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR08zIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR080IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR081IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR082IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR083IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR084IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwOCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR085IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwOSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuXG5kb3RwbG90KEdPMSwgc2hvd0NhdGVnb3J5ID0gMTApXG5cbiMgXG4jIEdPMS5kZiA8LSBhcy5kYXRhLmZyYW1lKEdPMSlcbiMgR08yLmRmIDwtIGFzLmRhdGEuZnJhbWUoR08yKVxuIyBHTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzUpXG4jIEdPNC5kZiA8LSBhcy5kYXRhLmZyYW1lKEdPOClcbiMgXG4jIHN1YnNldDEgPC0gR08xLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXGdyb3VwMVxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxncm91cDJcXCkgJT4lXG4jICAgZHBseXI6Om11dGF0ZShcbiMgICAgIGdyID0gc2FwcGx5KEdlbmVSYXRpbywgZnVuY3Rpb24oeCkge1xuIyAgICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiMgICAgICAgcGFydHMgPC0gdW5saXN0KHN0cnNwbGl0KHgsIFxcL1xcKSlcbiMgICAgICAgIyBDb252ZXJ0IHRvIG51bWVyaWMgYW5kIHBlcmZvcm0gdGhlIGRpdmlzaW9uXG4jICAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiMgICAgIH0pXG4jICAgKSAlPiUgZHBseXI6OmFycmFuZ2UoZGVzYyhncikpXG4jIHN1YnNldDMgPC0gR08zLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbixHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcZ3JvdXAzXFwpICU+JVxuIyAgIGRwbHlyOjptdXRhdGUoXG4jICAgICBnciA9IHNhcHBseShHZW5lUmF0aW8sIGZ1bmN0aW9uKHgpIHtcbiMgICAgICAgIyBTcGxpdCB0aGUgc3RyaW5nIGJ5IFxcL1xcXG4jICAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4jICAgICAgICMgQ29udmVydCB0byBudW1lcmljIGFuZCBwZXJmb3JtIHRoZSBkaXZpc2lvblxuIyAgICAgICBhcy5udW1lcmljKHBhcnRzWzFdKSAvIGFzLm51bWVyaWMocGFydHNbMl0pXG4jICAgICB9KVxuIyAgICkgJT4lIGRwbHlyOjphcnJhbmdlKGRlc2MoZ3IpKVxuIyBcbiMgR09saXN0IDwtIGZhY3RvcihjKFxcR086MDAzMzAwMlxcLCBcXEdPOjAwNzAzNzNcXCwgXFxHTzowMDQ4NzMwXFwsIFxcR086MDAzMTEwM1xcLFxuIyAgICAgICAgICAgICAgICAgIFxcR086MDAyMjYxM1xcLCBcXEdPOjAwNTA3NjdcXCwgXFxHTzowMDM0NDcwXFwsIFxcR086MDAxNjA1NVxcLCBcbiMgICAgICAgICAgICAgICAgICBcXEdPOjAwMDYzOTdcXCwgXFxHTzowMDMwOTAwXFwsIFxcR086MDAwODM4MFxcKSlcbiMgXG4jIGRhdGEgPC0gYmluZF9yb3dzKGJpbmRfcm93cyhzdWJzZXQxLCBzdWJzZXQyKSwgc3Vic2V0MykgJT4lXG4jICAgZHBseXI6OmZpbHRlcihJRCAlaW4lIEdPbGlzdClcbiMgXG4jIGRlc2NPcmRlciA8LSBzb3J0KHVuaXF1ZShkYXRhJERlc2NyaXB0aW9uKSlbYygxLCAyLCA1LCA3LFxuIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAzLCA0LCA2LCA4LCA5LCAxMCwgMTEpXVxuIyBcbiMgcCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IGZhY3RvcihEZXNjcmlwdGlvbiwgbGV2ZWwgPSBkZXNjT3JkZXIpLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuIyAgIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuIyAgIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFxccmVkXFwsIGhpZ2ggPSBcXGJsdWVcXCwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuIyAgIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiMgICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc1xcKVxuIyBoZWlnaHQgPSAyXG4jIHdpZHRoID0gMy41XG4jIHN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\nGO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO3 <- enrichGO(gene = gene.group3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO4 <- enrichGO(gene = gene.group4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO5 <- enrichGO(gene = gene.group5, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO6 <- enrichGO(gene = gene.group6, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO7 <- enrichGO(gene = gene.group7, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO8 <- enrichGO(gene = gene.group8, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO9 <- enrichGO(gene = gene.group9, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\n\ndotplot(GO1, showCategory = 10)\n\n# \n# GO1.df <- as.data.frame(GO1)\n# GO2.df <- as.data.frame(GO2)\n# GO3.df <- as.data.frame(GO5)\n# GO4.df <- as.data.frame(GO8)\n# \n# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\group1\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset2 <- GO2.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \\group2\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset3 <- GO3.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \\group3\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# \n# GOlist <- factor(c(\\GO:0033002\\, \\GO:0070373\\, \\GO:0048730\\, \\GO:0031103\\,\n#                  \\GO:0022613\\, \\GO:0050767\\, \\GO:0034470\\, \\GO:0016055\\, \n#                  \\GO:0006397\\, \\GO:0030900\\, \\GO:0008380\\))\n# \n# data <- bind_rows(bind_rows(subset1, subset2), subset3) %>%\n#   dplyr::filter(ID %in% GOlist)\n# \n# descOrder <- sort(unique(data$Description))[c(1, 2, 5, 7,\n#                                  3, 4, 6, 8, 9, 10, 11)]\n# \n# p <- ggplot(data, aes(x = group, y = factor(Description, level = descOrder), color = p.adjust, size = gr)) + \n#   geom_point() + theme_bw() +\n#   scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n#   scale_size_continuous(range = c(0, 3)) +\n#   labs(x = NULL, y = NULL) +\n#   theme(axis.text = element_text(size = 6),  # Set axis text size\n#         axis.title = element_text(size = 6), # Set axis title size (if not removed)\n#         legend.text = element_text(size = 6), # Set legend text size\n#         legend.title = element_text(size = 6)) \n# \n# fileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups\\)\n# height = 2\n# width = 3.5\n# svglite(paste0(fileName, \\.svg\\), height = height, width = width)\n# print(p)\n# dev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuR08xIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR08yIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR08zIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR080IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR081IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR082IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR083IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwNywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR084IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwOCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR085IDwtIGVucmljaEdPKGdlbmUgPSBnZW5lLmdyb3VwOSwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuXG5kb3RwbG90KEdPMSwgc2hvd0NhdGVnb3J5ID0gMTApXG5cbiMgXG4jIEdPMS5kZiA8LSBhcy5kYXRhLmZyYW1lKEdPMSlcbiMgR08yLmRmIDwtIGFzLmRhdGEuZnJhbWUoR08yKVxuIyBHTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShHTzUpXG4jIEdPNC5kZiA8LSBhcy5kYXRhLmZyYW1lKEdPOClcbiMgXG4jIHN1YnNldDEgPC0gR08xLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXGdyb3VwMVxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxncm91cDJcXCkgJT4lXG4jICAgZHBseXI6Om11dGF0ZShcbiMgICAgIGdyID0gc2FwcGx5KEdlbmVSYXRpbywgZnVuY3Rpb24oeCkge1xuIyAgICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiMgICAgICAgcGFydHMgPC0gdW5saXN0KHN0cnNwbGl0KHgsIFxcL1xcKSlcbiMgICAgICAgIyBDb252ZXJ0IHRvIG51bWVyaWMgYW5kIHBlcmZvcm0gdGhlIGRpdmlzaW9uXG4jICAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiMgICAgIH0pXG4jICAgKSAlPiUgZHBseXI6OmFycmFuZ2UoZGVzYyhncikpXG4jIHN1YnNldDMgPC0gR08zLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbixHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcZ3JvdXAzXFwpICU+JVxuIyAgIGRwbHlyOjptdXRhdGUoXG4jICAgICBnciA9IHNhcHBseShHZW5lUmF0aW8sIGZ1bmN0aW9uKHgpIHtcbiMgICAgICAgIyBTcGxpdCB0aGUgc3RyaW5nIGJ5IFxcL1xcXG4jICAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4jICAgICAgICMgQ29udmVydCB0byBudW1lcmljIGFuZCBwZXJmb3JtIHRoZSBkaXZpc2lvblxuIyAgICAgICBhcy5udW1lcmljKHBhcnRzWzFdKSAvIGFzLm51bWVyaWMocGFydHNbMl0pXG4jICAgICB9KVxuIyAgICkgJT4lIGRwbHlyOjphcnJhbmdlKGRlc2MoZ3IpKVxuIyBcbiMgR09saXN0IDwtIGZhY3RvcihjKFxcR086MDAzMzAwMlxcLCBcXEdPOjAwNzAzNzNcXCwgXFxHTzowMDQ4NzMwXFwsIFxcR086MDAzMTEwM1xcLFxuIyAgICAgICAgICAgICAgICAgIFxcR086MDAyMjYxM1xcLCBcXEdPOjAwNTA3NjdcXCwgXFxHTzowMDM0NDcwXFwsIFxcR086MDAxNjA1NVxcLCBcbiMgICAgICAgICAgICAgICAgICBcXEdPOjAwMDYzOTdcXCwgXFxHTzowMDMwOTAwXFwsIFxcR086MDAwODM4MFxcKSlcbiMgXG4jIGRhdGEgPC0gYmluZF9yb3dzKGJpbmRfcm93cyhzdWJzZXQxLCBzdWJzZXQyKSwgc3Vic2V0MykgJT4lXG4jICAgZHBseXI6OmZpbHRlcihJRCAlaW4lIEdPbGlzdClcbiMgXG4jIGRlc2NPcmRlciA8LSBzb3J0KHVuaXF1ZShkYXRhJERlc2NyaXB0aW9uKSlbYygxLCAyLCA1LCA3LFxuIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAzLCA0LCA2LCA4LCA5LCAxMCwgMTEpXVxuIyBcbiMgcCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IGZhY3RvcihEZXNjcmlwdGlvbiwgbGV2ZWwgPSBkZXNjT3JkZXIpLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuIyAgIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuIyAgIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFxccmVkXFwsIGhpZ2ggPSBcXGJsdWVcXCwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuIyAgIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiMgICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc1xcKVxuIyBoZWlnaHQgPSAyXG4jIHdpZHRoID0gMy41XG4jIHN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
GO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO3 <- enrichGO(gene = gene.group3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO4 <- enrichGO(gene = gene.group4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO5 <- enrichGO(gene = gene.group5, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO6 <- enrichGO(gene = gene.group6, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO7 <- enrichGO(gene = gene.group7, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO8 <- enrichGO(gene = gene.group8, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO9 <- enrichGO(gene = gene.group9, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)

dotplot(GO1, showCategory = 10)

# 
# GO1.df <- as.data.frame(GO1)
# GO2.df <- as.data.frame(GO2)
# GO3.df <- as.data.frame(GO5)
# GO4.df <- as.data.frame(GO8)
# 
# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \group1\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \group2\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset3 <- GO3.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = \group3\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# GOlist <- factor(c(\GO:0033002\, \GO:0070373\, \GO:0048730\, \GO:0031103\,
#                  \GO:0022613\, \GO:0050767\, \GO:0034470\, \GO:0016055\, 
#                  \GO:0006397\, \GO:0030900\, \GO:0008380\))
# 
# data <- bind_rows(bind_rows(subset1, subset2), subset3) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# descOrder <- sort(unique(data$Description))[c(1, 2, 5, 7,
#                                  3, 4, 6, 8, 9, 10, 11)]
# 
# p <- ggplot(data, aes(x = group, y = factor(Description, level = descOrder), color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, \..\, \GO\, \GO_groups\)
# height = 2
# width = 3.5
# svglite(paste0(fileName, \.svg\), height = height, width = width)
# print(p)
# dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### A485
##### - Splitting genes to groups

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJEYUdWamEybHVaeUJoZG1WeVlXZGxJR1JwYzNSaGJtTmxJRzltSUd4dmIzQnpJSEJsY2lCblpXNWxYRzRqSUhSbGJYQWdhWE1nWVNCMGFXSmliR1VnZDJobGNtVWdaR1ZzZEdFZ2JHOXZjQ0JoYm1RZ2JHOW5NbVpqSUdGeVpTQnRaWEpuWldSY2JuUmxiWEFrWjNKdmRYQWdQQzBnWm1GamRHOXlLSFJsYlhBa1ozSnZkWEFwWEc1Y2JseHVJeUJjYmlNZ1oyVjBVSFpoYkZkcGJHTnZlQ0E4TFNCbWRXNWpkR2x2Ymloa1lYUmhMQ0JuY205MWNERXNJR2R5YjNWd01pbDdYRzRqSUNBZ1pHbHpkR0Z1WTJVeElEd3RJQ2hrWVhSaElDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHZHliM1Z3SUQwOVozSnZkWEF4S1NBcEpHMWxZVzVmWkdsemRHRnVZMlZjYmlNZ0lDQmthWE4wWVc1alpUSWdQQzBnS0dSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9aM0p2ZFhBZ1BUMW5jbTkxY0RJcElDa2tiV1ZoYmw5a2FYTjBZVzVqWlZ4dUl5QWdJSGRwYkNBOExTQjNhV3hqYjNndWRHVnpkQ2hrYVhOMFlXNWpaVEVzSUdScGMzUmhibU5sTWlsY2JpTWdJQ0J5WlhSMWNtNG9kMmxzSkhBdWRtRnNkV1VwWEc0aklIMWNiaU1nWEc0aklIQjJNVElnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaDBaVzF3TENBeExDQXlLU3dnTlNsY2JpTWdjSFl4TlNBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBc0lERXNJRFVwTENBMUtWeHVJeUJ3ZGpFNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dNU3dnT0Nrc0lEVXBYRzRqSUhCMk1qVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMQ0F5TENBMUtTd2dOU2xjYmlNZ2NIWXlPQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEFzSURJc0lEZ3BMQ0ExS1Z4dUl5QndkalU0SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0N3Z05Td2dPQ2tzSURVcFhHNWNibHh1Y0NBOExTQm5aM0JzYjNRb2RHVnRjQ3dnWVdWektIZ2dQU0JuY205MWNDd2dlU0E5SUcxbFlXNWZaR2x6ZEdGdVkyVXBLU0FySUdkbGIyMWZkbWx2YkdsdUtHRmxjeWhtYVd4c0lEMGdaM0p2ZFhBcExDQnphRzkzTG14bFoyVnVaQ0E5SUVaQlRGTkZLU0FyWEc0Z0lHZGxiMjFmWW05NGNHeHZkQ2gzYVdSMGFDQTlJREF1TVN3Z2IzVjBiR2xsY2k1emFHRndaU0E5SUU1QktTQXJJSFJvWlcxbFgyTnNZWE56YVdNb0tTQXJJSE5qWVd4bFgzbGZZMjl1ZEdsdWRXOTFjeWhzWVdKbGJITWdQU0JzWVdKbGJGOXJZbDl0WWlrZ0sxeHVJQ0J6ZEdGMFgzTjFiVzFoY25rb1lXVnpLR2R5YjNWd0lEMGdaM0p2ZFhBcExDQm1kVzRnUFNCdFpXRnVMQ0JuWlc5dElEMGdYQ0p3YjJsdWRGd2lMQ0J6YUdGd1pTQTlJREl4TENCemFYcGxJRDBnTWl3Z1ptbHNiQ0E5SUZ3aWNtVmtYQ0lzSUdOdmJHOXlJRDBnWENKaWJHRmphMXdpS1Z4dUlDQWpJR0Z1Ym05MFlYUmxLRndpZEdWNGRGd2lMQ0I0SUQwZ01Td2dlU0E5SURFd01EQXdNREFzSUd4aFltVnNJRDBnY0dGemRHVXdLRndpY0hZeE1qb2dYQ0lzSUhCMk1USXNJRndpWEZ4dVhDSXNYRzRnSUNNZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ3aWNIWXhOVG9nWENJc0lIQjJNVFVzSUZ3aVhGeHVYQ0lzWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGd2ljSFl4T0RvZ1hDSXNJSEIyTVRnc0lGd2lYRnh1WENJc1hHNGdJQ01nSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0hZeU5Ub2dYQ0lzSUhCMk1qVXNJRndpWEZ4dVhDSXNYRzRnSUNNZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ3aWNIWXlPRG9nWENJc0lIQjJNamdzSUZ3aVhGeHVYQ0lzWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGd2ljSFkxT0RvZ1hDSXNJSEIyTlRnc0lGd2lYRnh1WENJcExDQmNiaUFnSXlBZ0lDQWdJQ0FnSUNCamIyeHZjaUE5SUZ3aVlteGhZMnRjSWl3Z2FHcDFjM1FnUFNBd0xDQnphWHBsSUQwZ015bGNiaUFnSXlCY2JpQWdYRzVtYVd4bFRtRnRaU0E4TFNCd1lYTjBaVEFvWENKemFYcGxYMkpoY25Cc2IzUmZaR2xtWmtkeWIzVndYMEUwT0RWZmRuTmZSRTFUVDF3aUtWeHVhR1ZwWjJoMElEd3RJRE5jYm5kcFpIUm9JRHd0SURSY2JuQnVaeWhvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY0lpNXdibWRjSWlrcExDQnlaWE1nUFNBMk1EQXNJSFZ1YVhRZ1BTQmNJbWx1WENJc0lHaGxhV2RvZENBOUlHaGxhV2RvZEN3Z2QybGtkR2dnUFNCM2FXUjBhQ2xjYm5CeWFXNTBLSEFwWEc1a1pYWXViMlptS0NsY2JuTjJaMnhwZEdVb2FHVnlaU2htYVdkRWFYSXNJSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYQ0l1YzNablhDSXBLU3dnSUdobGFXZG9kQ0E5SUdobGFXZG9kQ3dnZDJsa2RHZ2dQU0IzYVdSMGFDbGNibkJ5YVc1MEtIQXBYRzVrWlhZdWIyWm1LQ2xjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbiMgQ2hlY2tpbmcgYXZlcmFnZSBkaXN0YW5jZSBvZiBsb29wcyBwZXIgZ2VuZVxuIyB0ZW1wIGlzIGEgdGliYmxlIHdoZXJlIGRlbHRhIGxvb3AgYW5kIGxvZzJmYyBhcmUgbWVyZ2VkXG50ZW1wJGdyb3VwIDwtIGZhY3Rvcih0ZW1wJGdyb3VwKVxuXG5cbiMgXG4jIGdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuIyAgIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMSkgKSRtZWFuX2Rpc3RhbmNlXG4jICAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJG1lYW5fZGlzdGFuY2VcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxuIyBwdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgMSwgMiksIDUpXG4jIHB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAxLCA1KSwgNSlcbiMgcHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIDEsIDgpLCA1KVxuIyBwdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgMiwgNSksIDUpXG4jIHB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAyLCA4KSwgNSlcbiMgcHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIDUsIDgpLCA1KVxuXG5cbnAgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gZ3JvdXAsIHkgPSBtZWFuX2Rpc3RhbmNlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAxMDAwMDAwLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTg6IFxcLCBwdjE4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NTg6IFxcLCBwdjU4LCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gICMgXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcc2l6ZV9iYXJwbG90X2RpZmZHcm91cF9BNDg1X3ZzX0RNU09cXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSA0XG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
# Checking average distance of loops per gene
# temp is a tibble where delta loop and log2fc are merged
temp$group <- factor(temp$group)


# 
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group ==group1) )$mean_distance
#   distance2 <- (data %>% dplyr::filter(group ==group2) )$mean_distance
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# pv12 <- round(getPvalWilcox(temp, 1, 2), 5)
# pv15 <- round(getPvalWilcox(temp, 1, 5), 5)
# pv18 <- round(getPvalWilcox(temp, 1, 8), 5)
# pv25 <- round(getPvalWilcox(temp, 2, 5), 5)
# pv28 <- round(getPvalWilcox(temp, 2, 8), 5)
# pv58 <- round(getPvalWilcox(temp, 5, 8), 5)


p <- ggplot(temp, aes(x = group, y = mean_distance)) + geom_violin(aes(fill = group), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)
  # annotate(\text\, x = 1, y = 1000000, label = paste0(\pv12: \, pv12, \\n\,
  #                                                     \pv15: \, pv15, \\n\,
  #                                                     \pv18: \, pv18, \\n\,
  #                                                     \pv25: \, pv25, \\n\,
  #                                                     \pv28: \, pv28, \\n\,
  #                                                     \pv58: \, pv58, \\n\), 
  #          color = \black\, hjust = 0, size = 3)
  # 
  
fileName <- paste0(\size_barplot_diffGroup_A485_vs_DMSO\)
height <- 3
width <- 4
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QkRhR1ZqYTJsdVp5QmhkbVZ5WVdkbElHUnBjM1JoYm1ObElHOW1JR3h2YjNCeklIQmxjaUJuWlc1bFhHNGpJSFJsYlhBZ2FYTWdZU0IwYVdKaWJHVWdkMmhsY21VZ1pHVnNkR0VnYkc5dmNDQmhibVFnYkc5bk1tWmpJR0Z5WlNCdFpYSm5aV1JjYm5SbGJYQWtaM0p2ZFhBZ1BDMGdabUZqZEc5eUtIUmxiWEFrWjNKdmRYQXBYRzVjYmx4dUl5QmNiaU1nWjJWMFVIWmhiRmRwYkdOdmVDQThMU0JtZFc1amRHbHZiaWhrWVhSaExDQm5jbTkxY0RFc0lHZHliM1Z3TWlsN1hHNGpJQ0FnWkdsemRHRnVZMlV4SUR3dElDaGtZWFJoSUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0dkeWIzVndJRDA5WjNKdmRYQXhLU0FwSkcxbFlXNWZaR2x6ZEdGdVkyVmNiaU1nSUNCa2FYTjBZVzVqWlRJZ1BDMGdLR1JoZEdFZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1ozSnZkWEFnUFQxbmNtOTFjRElwSUNra2JXVmhibDlrYVhOMFlXNWpaVnh1SXlBZ0lIZHBiQ0E4TFNCM2FXeGpiM2d1ZEdWemRDaGthWE4wWVc1alpURXNJR1JwYzNSaGJtTmxNaWxjYmlNZ0lDQnlaWFIxY200b2QybHNKSEF1ZG1Gc2RXVXBYRzRqSUgxY2JpTWdYRzRqSUhCMk1USWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMQ0F4TENBeUtTd2dOU2xjYmlNZ2NIWXhOU0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEFzSURFc0lEVXBMQ0ExS1Z4dUl5QndkakU0SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0N3Z01Td2dPQ2tzSURVcFhHNGpJSEIyTWpVZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xDQXlMQ0ExS1N3Z05TbGNiaU1nY0hZeU9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXNJRElzSURncExDQTFLVnh1SXlCd2RqVTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnTlN3Z09Da3NJRFVwWEc1Y2JseHVjQ0E4TFNCblozQnNiM1FvZEdWdGNDd2dZV1Z6S0hnZ1BTQm5jbTkxY0N3Z2VTQTlJRzFsWVc1ZlpHbHpkR0Z1WTJVcEtTQXJJR2RsYjIxZmRtbHZiR2x1S0dGbGN5aG1hV3hzSUQwZ1ozSnZkWEFwTENCemFHOTNMbXhsWjJWdVpDQTlJRVpCVEZORktTQXJYRzRnSUdkbGIyMWZZbTk0Y0d4dmRDaDNhV1IwYUNBOUlEQXVNU3dnYjNWMGJHbGxjaTV6YUdGd1pTQTlJRTVCS1NBcklIUm9aVzFsWDJOc1lYTnphV01vS1NBcklITmpZV3hsWDNsZlkyOXVkR2x1ZFc5MWN5aHNZV0psYkhNZ1BTQnNZV0psYkY5cllsOXRZaWtnSzF4dUlDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ1ozSnZkWEFwTENCbWRXNGdQU0J0WldGdUxDQm5aVzl0SUQwZ1hGeHdiMmx1ZEZ4Y0xDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNaXdnWm1sc2JDQTlJRnhjY21Wa1hGd3NJR052Ykc5eUlEMGdYRnhpYkdGamExeGNLVnh1SUNBaklHRnVibTkwWVhSbEtGeGNkR1Y0ZEZ4Y0xDQjRJRDBnTVN3Z2VTQTlJREV3TURBd01EQXNJR3hoWW1Wc0lEMGdjR0Z6ZEdVd0tGeGNjSFl4TWpvZ1hGd3NJSEIyTVRJc0lGeGNYRnh1WEZ3c1hHNGdJQ01nSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRnhjY0hZeE5Ub2dYRndzSUhCMk1UVXNJRnhjWEZ4dVhGd3NYRzRnSUNNZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ4Y2NIWXhPRG9nWEZ3c0lIQjJNVGdzSUZ4Y1hGeHVYRndzWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjSFl5TlRvZ1hGd3NJSEIyTWpVc0lGeGNYRnh1WEZ3c1hHNGdJQ01nSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRnhjY0hZeU9Eb2dYRndzSUhCMk1qZ3NJRnhjWEZ4dVhGd3NYRzRnSUNNZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ4Y2NIWTFPRG9nWEZ3c0lIQjJOVGdzSUZ4Y1hGeHVYRndwTENCY2JpQWdJeUFnSUNBZ0lDQWdJQ0JqYjJ4dmNpQTlJRnhjWW14aFkydGNYQ3dnYUdwMWMzUWdQU0F3TENCemFYcGxJRDBnTXlsY2JpQWdJeUJjYmlBZ1hHNW1hV3hsVG1GdFpTQThMU0J3WVhOMFpUQW9YRnh6YVhwbFgySmhjbkJzYjNSZlpHbG1aa2R5YjNWd1gwRTBPRFZmZG5OZlJFMVRUMXhjS1Z4dWFHVnBaMmgwSUR3dElETmNibmRwWkhSb0lEd3RJRFJjYm5CdVp5aG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjWEM1d2JtZGNYQ2twTENCeVpYTWdQU0EyTURBc0lIVnVhWFFnUFNCY1hHbHVYRndzSUdobGFXZG9kQ0E5SUdobGFXZG9kQ3dnZDJsa2RHZ2dQU0IzYVdSMGFDbGNibkJ5YVc1MEtIQXBYRzVrWlhZdWIyWm1LQ2xjYm5OMloyeHBkR1VvYUdWeVpTaG1hV2RFYVhJc0lIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hGd3VjM1puWEZ3cEtTd2dJR2hsYVdkb2RDQTlJR2hsYVdkb2RDd2dkMmxrZEdnZ1BTQjNhV1IwYUNsY2JuQnlhVzUwS0hBcFhHNWtaWFl1YjJabUtDbGNibUJnWUZ4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG5gYGByXG4jIENoZWNraW5nIGF2ZXJhZ2UgZGlzdGFuY2Ugb2YgbG9vcHMgcGVyIGdlbmVcbiMgdGVtcCBpcyBhIHRpYmJsZSB3aGVyZSBkZWx0YSBsb29wIGFuZCBsb2cyZmMgYXJlIG1lcmdlZFxudGVtcCRncm91cCA8LSBmYWN0b3IodGVtcCRncm91cClcblxuXG4jIFxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDEpICkkbWVhbl9kaXN0YW5jZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRtZWFuX2Rpc3RhbmNlXG4jICAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuIyAgIHJldHVybih3aWwkcC52YWx1ZSlcbiMgfVxuIyBcbiMgcHYxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIDEsIDIpLCA1KVxuIyBwdjE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgMSwgNSksIDUpXG4jIHB2MTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAxLCA4KSwgNSlcbiMgcHYyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIDIsIDUpLCA1KVxuIyBwdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgMiwgOCksIDUpXG4jIHB2NTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCA1LCA4KSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGdyb3VwLCB5ID0gbWVhbl9kaXN0YW5jZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgc2NhbGVfeV9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpXG4gICMgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMTAwMDAwMCwgbGFiZWwgPSBwYXN0ZTAoXFxwdjEyOiBcXCwgcHYxMiwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE1OiBcXCwgcHYxNSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE4OiBcXCwgcHYxOCwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI1OiBcXCwgcHYyNSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgcHYyOCwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjU4OiBcXCwgcHY1OCwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICAjIFxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXHNpemVfYmFycGxvdF9kaWZmR3JvdXBfQTQ4NV92c19ETVNPXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gNFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBDaGVja2luZyBhdmVyYWdlIGRpc3RhbmNlIG9mIGxvb3BzIHBlciBnZW5lXG4jIHRlbXAgaXMgYSB0aWJibGUgd2hlcmUgZGVsdGEgbG9vcCBhbmQgbG9nMmZjIGFyZSBtZXJnZWRcbnRlbXAkZ3JvdXAgPC0gZmFjdG9yKHRlbXAkZ3JvdXApXG5cblxuIyBcbiMgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJG1lYW5fZGlzdGFuY2VcbiMgICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDIpICkkbWVhbl9kaXN0YW5jZVxuIyAgIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiMgICByZXR1cm4od2lsJHAudmFsdWUpXG4jIH1cbiMgXG4jIHB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAxLCAyKSwgNSlcbiMgcHYxNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIDEsIDUpLCA1KVxuIyBwdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgMSwgOCksIDUpXG4jIHB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCAyLCA1KSwgNSlcbiMgcHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIDIsIDgpLCA1KVxuIyBwdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgNSwgOCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBncm91cCwgeSA9IG1lYW5fZGlzdGFuY2UpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgK1xuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKVxuICAjIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDEwMDAwMDAsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIHB2MTIsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxNTogXFwsIHB2MTUsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxODogXFwsIHB2MTgsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNTogXFwsIHB2MjUsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyODogXFwsIHB2MjgsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY1ODogXFwsIHB2NTgsIFxcXFxuXFwpLCBcbiAgIyAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgIyBcbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxzaXplX2JhcnBsb3RfZGlmZkdyb3VwX0E0ODVfdnNfRE1TT1xcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDRcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
# Checking average distance of loops per gene
# temp is a tibble where delta loop and log2fc are merged
temp$group <- factor(temp$group)


# 
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group ==group1) )$mean_distance
#   distance2 <- (data %>% dplyr::filter(group ==group2) )$mean_distance
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# pv12 <- round(getPvalWilcox(temp, 1, 2), 5)
# pv15 <- round(getPvalWilcox(temp, 1, 5), 5)
# pv18 <- round(getPvalWilcox(temp, 1, 8), 5)
# pv25 <- round(getPvalWilcox(temp, 2, 5), 5)
# pv28 <- round(getPvalWilcox(temp, 2, 8), 5)
# pv58 <- round(getPvalWilcox(temp, 5, 8), 5)


p <- ggplot(temp, aes(x = group, y = mean_distance)) + geom_violin(aes(fill = group), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)
  # annotate(\text\, x = 1, y = 1000000, label = paste0(\pv12: \, pv12, \\n\,
  #                                                     \pv15: \, pv15, \\n\,
  #                                                     \pv18: \, pv18, \\n\,
  #                                                     \pv25: \, pv25, \\n\,
  #                                                     \pv28: \, pv28, \\n\,
  #                                                     \pv58: \, pv58, \\n\), 
  #          color = \black\, hjust = 0, size = 3)
  # 
  
fileName <- paste0(\size_barplot_diffGroup_A485_vs_DMSO\)
height <- 3
width <- 4
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### - GO for each group


<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBDb3VudGluZyBudW1iZXIgb2YgbG9vcCBwZXIgZ2VuZXNcbnRlbXBTdW0gPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KHBlYWtJRCwgZ2VuZSwgQW5ubzIpICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JSAgc3VtbWFyaXplKFxuICAgIHBlYWsgPSBsaXN0KHBlYWtJRCksXG4gICAgYW5ubzIgPSBsaXN0KEFubm8yKSxcbiAgICBjb3VudCA9IG4oKSlcblxudGVtcFN1bSA8LSB0ZW1wU3VtICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDEsIFwiZ3JvdXAxXCIsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDIsIFwiZ3JvdXAyXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAzLCBcImdyb3VwM1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDQsIFwiZ3JvdXA0XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDUsIFwiZ3JvdXA1XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA2LCBcImdyb3VwNlwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDcsIFwiZ3JvdXA3XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDgsIFwiZ3JvdXA4XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA5LCBcImdyb3VwOVwiLCBOQSkpKSkpKSkpKVxuKSAlPiUgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG4jIFxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDEpICkkY291bnRcbiMgICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDIpICkkY291bnRcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxuIyBcbiMgcHYxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXCJncm91cDFcIiwgXCJncm91cDJcIiksIDUpXG4jIHB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFwiZ3JvdXAxXCIsIFwiZ3JvdXA1XCIpLCA1KVxuIyBwdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcImdyb3VwMVwiLCBcImdyb3VwOFwiKSwgNSlcbiMgcHYyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXCJncm91cDJcIiwgXCJncm91cDVcIiksIDUpXG4jIHB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFwiZ3JvdXAyXCIsIFwiZ3JvdXA4XCIpLCA1KVxuIyBwdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcImdyb3VwNVwiLCBcImdyb3VwOFwiKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wU3VtLCBhZXMoeCA9IGdyb3VwLCB5ID0gY291bnQsIGZpbGwgPSBncm91cCkpICsgXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArICAgICAgIFxuICBzY2FsZV95X2NvbnRpbnVvdXMoYnJlYWtzID0gc2VxKDAsIDEwLCBieSA9IDIpKSArIFxuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgMTApKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcInBvaW50XCIsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCIpICtcbiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXCJub25lXCIpXG4gICMgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAxLCB5ID0gMywgbGFiZWwgPSBwYXN0ZTAoXCJwdjEyOiBcIiwgcHYxMiwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjE1OiBcIiwgcHYxNSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjE4OiBcIiwgcHYxOCwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjI1OiBcIiwgcHYyNSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjI4OiBcIiwgcHYyOCwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjU4OiBcIiwgcHY1OCwgXCJcXG5cIiksIFxuICAjICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAxKSArICBcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJjb3VudF9iYXJwbG90X2RpZmZHcm91cF9BNDg1X3ZzX0RNU09cIilcbmhlaWdodCA8LSAzXG53aWR0aCA8LSA0XG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGAifQ== -->\n\n```r\n# Counting number of loop per genes\ntempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(\n    peak = list(peakID),\n    anno2 = list(Anno2),\n    count = n())\n\ntempSum <- tempSum %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\,\n                        ifelse(gene %in% gene.group3, \\group3\\,\n                               ifelse(gene %in% gene.group4, \\group4\\,\n                                      ifelse(gene %in% gene.group5, \\group5\\,\n                                             ifelse(gene %in% gene.group6, \\group6\\,\n                                                    ifelse(gene %in% gene.group7, \\group7\\,\n                                                           ifelse(gene %in% gene.group8, \\group8\\,\n                                                                  ifelse(gene %in% gene.group9, \\group9\\, NA)))))))))\n) %>% dplyr::filter(!is.na(group))\n\n# \n# getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(group ==group1) )$count\n#   distance2 <- (data %>% dplyr::filter(group ==group2) )$count\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n# \n# \n# pv12 <- round(getPvalWilcox(tempSum,\\group1\\, \\group2\\), 5)\n# pv15 <- round(getPvalWilcox(tempSum,\\group1\\, \\group5\\), 5)\n# pv18 <- round(getPvalWilcox(tempSum,\\group1\\, \\group8\\), 5)\n# pv25 <- round(getPvalWilcox(tempSum,\\group2\\, \\group5\\), 5)\n# pv28 <- round(getPvalWilcox(tempSum,\\group2\\, \\group8\\), 5)\n# pv58 <- round(getPvalWilcox(tempSum,\\group5\\, \\group8\\), 5)\n\n\np <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + \n  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       \n  scale_y_continuous(breaks = seq(0, 10, by = 2)) + \n  coord_cartesian(ylim = c(0, 10)) +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme(legend.position = \\none\\)\n  # annotate(\\text\\, x = 1, y = 3, label = paste0(\\pv12: \\, pv12, \\\\n\\,\n  #                                               \\pv15: \\, pv15, \\\\n\\,\n  #                                               \\pv18: \\, pv18, \\\\n\\,\n  #                                               \\pv25: \\, pv25, \\\\n\\,\n  #                                               \\pv28: \\, pv28, \\\\n\\,\n  #                                               \\pv58: \\, pv58, \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 1) +  \n\n\nfileName <- paste0(\\count_barplot_diffGroup_A485_vs_DMSO\\)\nheight <- 3\nwidth <- 4\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# Counting number of loop per genes
tempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(
    peak = list(peakID),
    anno2 = list(Anno2),
    count = n())

tempSum <- tempSum %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\,
                        ifelse(gene %in% gene.group3, \group3\,
                               ifelse(gene %in% gene.group4, \group4\,
                                      ifelse(gene %in% gene.group5, \group5\,
                                             ifelse(gene %in% gene.group6, \group6\,
                                                    ifelse(gene %in% gene.group7, \group7\,
                                                           ifelse(gene %in% gene.group8, \group8\,
                                                                  ifelse(gene %in% gene.group9, \group9\, NA)))))))))
) %>% dplyr::filter(!is.na(group))

# 
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group ==group1) )$count
#   distance2 <- (data %>% dplyr::filter(group ==group2) )$count
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# 
# pv12 <- round(getPvalWilcox(tempSum,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(tempSum,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(tempSum,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(tempSum,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(tempSum,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(tempSum,\group5\, \group8\), 5)


p <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  coord_cartesian(ylim = c(0, 10)) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  theme(legend.position = \none\)
  # annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
  #                                               \pv15: \, pv15, \\n\,
  #                                               \pv18: \, pv18, \\n\,
  #                                               \pv25: \, pv25, \\n\,
  #                                               \pv28: \, pv28, \\n\,
  #                                               \pv58: \, pv58, \\n\), 
  #          color = \black\, hjust = 0, size = 1) +  


fileName <- paste0(\count_barplot_diffGroup_A485_vs_DMSO\)
height <- 3
width <- 4
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBDb3VudGluZyBudW1iZXIgb2YgbG9vcCBwZXIgZ2VuZXNcbnRlbXBTdW0gPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KHBlYWtJRCwgZ2VuZSwgQW5ubzIpICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JSAgc3VtbWFyaXplKFxuICAgIHBlYWsgPSBsaXN0KHBlYWtJRCksXG4gICAgYW5ubzIgPSBsaXN0KEFubm8yKSxcbiAgICBjb3VudCA9IG4oKSlcblxudGVtcFN1bSA8LSB0ZW1wU3VtICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDEsIFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDIsIFxcZ3JvdXAyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAzLCBcXGdyb3VwM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDQsIFxcZ3JvdXA0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDUsIFxcZ3JvdXA1XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA2LCBcXGdyb3VwNlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDcsIFxcZ3JvdXA3XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDgsIFxcZ3JvdXA4XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA5LCBcXGdyb3VwOVxcLCBOQSkpKSkpKSkpKVxuKSAlPiUgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG4jIFxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDEpICkkY291bnRcbiMgICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDIpICkkY291bnRcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxuIyBcbiMgcHYxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXFxncm91cDFcXCwgXFxncm91cDJcXCksIDUpXG4jIHB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHYyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXFxncm91cDJcXCwgXFxncm91cDVcXCksIDUpXG4jIHB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxuIyBwdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wU3VtLCBhZXMoeCA9IGdyb3VwLCB5ID0gY291bnQsIGZpbGwgPSBncm91cCkpICsgXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArICAgICAgIFxuICBzY2FsZV95X2NvbnRpbnVvdXMoYnJlYWtzID0gc2VxKDAsIDEwLCBieSA9IDIpKSArIFxuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgMTApKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG4gICMgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMywgbGFiZWwgPSBwYXN0ZTAoXFxwdjEyOiBcXCwgcHYxMiwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE1OiBcXCwgcHYxNSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE4OiBcXCwgcHYxOCwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI1OiBcXCwgcHYyNSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgcHYyOCwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjU4OiBcXCwgcHY1OCwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAxKSArICBcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxjb3VudF9iYXJwbG90X2RpZmZHcm91cF9BNDg1X3ZzX0RNU09cXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSA0XG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\n# Counting number of loop per genes\ntempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(\n    peak = list(peakID),\n    anno2 = list(Anno2),\n    count = n())\n\ntempSum <- tempSum %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\,\n                        ifelse(gene %in% gene.group3, \\group3\\,\n                               ifelse(gene %in% gene.group4, \\group4\\,\n                                      ifelse(gene %in% gene.group5, \\group5\\,\n                                             ifelse(gene %in% gene.group6, \\group6\\,\n                                                    ifelse(gene %in% gene.group7, \\group7\\,\n                                                           ifelse(gene %in% gene.group8, \\group8\\,\n                                                                  ifelse(gene %in% gene.group9, \\group9\\, NA)))))))))\n) %>% dplyr::filter(!is.na(group))\n\n# \n# getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(group ==group1) )$count\n#   distance2 <- (data %>% dplyr::filter(group ==group2) )$count\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n# \n# \n# pv12 <- round(getPvalWilcox(tempSum,\\group1\\, \\group2\\), 5)\n# pv15 <- round(getPvalWilcox(tempSum,\\group1\\, \\group5\\), 5)\n# pv18 <- round(getPvalWilcox(tempSum,\\group1\\, \\group8\\), 5)\n# pv25 <- round(getPvalWilcox(tempSum,\\group2\\, \\group5\\), 5)\n# pv28 <- round(getPvalWilcox(tempSum,\\group2\\, \\group8\\), 5)\n# pv58 <- round(getPvalWilcox(tempSum,\\group5\\, \\group8\\), 5)\n\n\np <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + \n  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       \n  scale_y_continuous(breaks = seq(0, 10, by = 2)) + \n  coord_cartesian(ylim = c(0, 10)) +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme(legend.position = \\none\\)\n  # annotate(\\text\\, x = 1, y = 3, label = paste0(\\pv12: \\, pv12, \\\\n\\,\n  #                                               \\pv15: \\, pv15, \\\\n\\,\n  #                                               \\pv18: \\, pv18, \\\\n\\,\n  #                                               \\pv25: \\, pv25, \\\\n\\,\n  #                                               \\pv28: \\, pv28, \\\\n\\,\n  #                                               \\pv58: \\, pv58, \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 1) +  \n\n\nfileName <- paste0(\\count_barplot_diffGroup_A485_vs_DMSO\\)\nheight <- 3\nwidth <- 4\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBDb3VudGluZyBudW1iZXIgb2YgbG9vcCBwZXIgZ2VuZXNcbnRlbXBTdW0gPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KHBlYWtJRCwgZ2VuZSwgQW5ubzIpICU+JSB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JSAgc3VtbWFyaXplKFxuICAgIHBlYWsgPSBsaXN0KHBlYWtJRCksXG4gICAgYW5ubzIgPSBsaXN0KEFubm8yKSxcbiAgICBjb3VudCA9IG4oKSlcblxudGVtcFN1bSA8LSB0ZW1wU3VtICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDEsIFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDIsIFxcZ3JvdXAyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXAzLCBcXGdyb3VwM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDQsIFxcZ3JvdXA0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDUsIFxcZ3JvdXA1XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA2LCBcXGdyb3VwNlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDcsIFxcZ3JvdXA3XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgZ2VuZS5ncm91cDgsIFxcZ3JvdXA4XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIGdlbmUuZ3JvdXA5LCBcXGdyb3VwOVxcLCBOQSkpKSkpKSkpKVxuKSAlPiUgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG4jIFxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDEpICkkY291bnRcbiMgICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDIpICkkY291bnRcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxuIyBcbiMgcHYxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXFxncm91cDFcXCwgXFxncm91cDJcXCksIDUpXG4jIHB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHYyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBTdW0sXFxncm91cDJcXCwgXFxncm91cDVcXCksIDUpXG4jIHB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wU3VtLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxuIyBwdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFN1bSxcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wU3VtLCBhZXMoeCA9IGdyb3VwLCB5ID0gY291bnQsIGZpbGwgPSBncm91cCkpICsgXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArICAgICAgIFxuICBzY2FsZV95X2NvbnRpbnVvdXMoYnJlYWtzID0gc2VxKDAsIDEwLCBieSA9IDIpKSArIFxuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgMTApKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG4gICMgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMywgbGFiZWwgPSBwYXN0ZTAoXFxwdjEyOiBcXCwgcHYxMiwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE1OiBcXCwgcHYxNSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE4OiBcXCwgcHYxOCwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI1OiBcXCwgcHYyNSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgcHYyOCwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjU4OiBcXCwgcHY1OCwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAxKSArICBcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxjb3VudF9iYXJwbG90X2RpZmZHcm91cF9BNDg1X3ZzX0RNU09cXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSA0XG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
# Counting number of loop per genes
tempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(
    peak = list(peakID),
    anno2 = list(Anno2),
    count = n())

tempSum <- tempSum %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\,
                        ifelse(gene %in% gene.group3, \group3\,
                               ifelse(gene %in% gene.group4, \group4\,
                                      ifelse(gene %in% gene.group5, \group5\,
                                             ifelse(gene %in% gene.group6, \group6\,
                                                    ifelse(gene %in% gene.group7, \group7\,
                                                           ifelse(gene %in% gene.group8, \group8\,
                                                                  ifelse(gene %in% gene.group9, \group9\, NA)))))))))
) %>% dplyr::filter(!is.na(group))

# 
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group ==group1) )$count
#   distance2 <- (data %>% dplyr::filter(group ==group2) )$count
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# 
# pv12 <- round(getPvalWilcox(tempSum,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(tempSum,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(tempSum,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(tempSum,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(tempSum,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(tempSum,\group5\, \group8\), 5)


p <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  coord_cartesian(ylim = c(0, 10)) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  theme(legend.position = \none\)
  # annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
  #                                               \pv15: \, pv15, \\n\,
  #                                               \pv18: \, pv18, \\n\,
  #                                               \pv25: \, pv25, \\n\,
  #                                               \pv28: \, pv28, \\n\,
  #                                               \pv58: \, pv58, \\n\), 
  #          color = \black\, hjust = 0, size = 1) +  


fileName <- paste0(\count_barplot_diffGroup_A485_vs_DMSO\)
height <- 3
width <- 4
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




##### - Average loop size

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakkxeHVkR1Z0Y0RJZ1BDMGdkR1Z0Y0ZOMWJTQWxQaVVnY205M2QybHpaU2dwSUNVK0pTQnRkWFJoZEdVb2RHOTBZV3dnUFNCc1pXNW5kR2dvWVc1dWJ6SXBMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiblZ0WDNCd0lEMGdjM1Z0S0dGdWJtOHlJRDA5SUZ3aVVDMVFYQ0lwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYm5WdFgzQmxJRDBnYzNWdEtHRnVibTh5SUQwOUlGd2lVQzFGWENJcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0J6SUQwZ2MzVnRLR0Z1Ym04eUlEMDlJRndpVUMxVFhDSXBMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiblZ0WDNCNElEMGdjM1Z0S0dGdWJtOHlJRDA5SUZ3aVVDMVlYQ0lwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnY21GMGFXOWZjbVZuSUQwZ0tHNTFiVjl3Y0NBcklHNTFiVjl3WlNrdmRHOTBZV3dzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J5WVhScGIxOXpkSElnUFNCdWRXMWZjSE12ZEc5MFlXd3BYRzVjYm5OaGRtVlNSRk1vZEdWdGNESXNJR2hsY21Vb2NtVnpkV3gwUkdseUxDQmNJbWRsYm1WZmJHOXZjRjlzYVc1clgwRTBPRFV1Y21SelhDSXBLVnh1WEc1Y2JteHZiM0JVZVhCbElEd3RJSFJsYlhBeUlDVStKU0JuY205MWNGOWllU2huY205MWNDa2dKVDRsSUhOMWJXMWhjbWx6WlNodWRXMWZjSEFnUFNCemRXMG9iblZ0WDNCd0tTeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCdWRXMWZjR1VnUFNCemRXMG9iblZ0WDNCbEtTeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCdWRXMWZjSE1nUFNCemRXMG9iblZ0WDNCektTeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCdWRXMWZjSGdnUFNCemRXMG9iblZ0WDNCNEtTbGNibHh1WEc1c2IyOXdWSGx3WlV4dmJtY2dQQzBnYkc5dmNGUjVjR1VnSlQ0bElIQnBkbTkwWDJ4dmJtZGxjaWd0WjNKdmRYQXNJRzVoYldWelgzUnZJRDBnWENKMGVYQmxYQ0lzSUhaaGJIVmxjMTkwYnlBOUlGd2lZMjkxYm5SY0lpbGNibHh1Ykc5dmNGUjVjR1ZNYjI1bkpIUjVjR1VnUEMwZ1ptRmpkRzl5S0d4dmIzQlVlWEJsVEc5dVp5UjBlWEJsTENCc1pYWmxiSE1nUFNCaktGd2liblZ0WDNCd1hDSXNJRndpYm5WdFgzQmxYQ0lzSUZ3aWJuVnRYM0J6WENJc0lGd2liblZ0WDNCNFhDSXBLVnh1WEc0aklGQnNiM1IwYVc1blhHNW5aM0JzYjNRb2JHOXZjRlI1Y0dWTWIyNW5MQ0JoWlhNb1ptbHNiRDEwZVhCbExDQjVQV052ZFc1MExDQjRQV2R5YjNWd0tTa2dLeUJjYmlBZ0lDQm5aVzl0WDJKaGNpaHdiM05wZEdsdmJqMWNJbVpwYkd4Y0lpd2djM1JoZEQxY0ltbGtaVzUwYVhSNVhDSXBJQ3NnZEdobGJXVmZZMnhoYzNOcFl5Z3BYRzVjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbiMjIyMjIyNcbnRlbXAyIDwtIHRlbXBTdW0gJT4lIHJvd3dpc2UoKSAlPiUgbXV0YXRlKHRvdGFsID0gbGVuZ3RoKGFubm8yKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG51bV9wcCA9IHN1bShhbm5vMiA9PSBcXFAtUFxcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG51bV9wZSA9IHN1bShhbm5vMiA9PSBcXFAtRVxcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG51bV9wcyA9IHN1bShhbm5vMiA9PSBcXFAtU1xcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG51bV9weCA9IHN1bShhbm5vMiA9PSBcXFAtWFxcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHJhdGlvX3JlZyA9IChudW1fcHAgKyBudW1fcGUpL3RvdGFsLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcmF0aW9fc3RyID0gbnVtX3BzL3RvdGFsKVxuXG5zYXZlUkRTKHRlbXAyLCBoZXJlKHJlc3VsdERpciwgXFxnZW5lX2xvb3BfbGlua19BNDg1LnJkc1xcKSlcblxuXG5sb29wVHlwZSA8LSB0ZW1wMiAlPiUgZ3JvdXBfYnkoZ3JvdXApICU+JSBzdW1tYXJpc2UobnVtX3BwID0gc3VtKG51bV9wcCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BlID0gc3VtKG51bV9wZSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BzID0gc3VtKG51bV9wcyksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3B4ID0gc3VtKG51bV9weCkpXG5cblxubG9vcFR5cGVMb25nIDwtIGxvb3BUeXBlICU+JSBwaXZvdF9sb25nZXIoLWdyb3VwLCBuYW1lc190byA9IFxcdHlwZVxcLCB2YWx1ZXNfdG8gPSBcXGNvdW50XFwpXG5cbmxvb3BUeXBlTG9uZyR0eXBlIDwtIGZhY3Rvcihsb29wVHlwZUxvbmckdHlwZSwgbGV2ZWxzID0gYyhcXG51bV9wcFxcLCBcXG51bV9wZVxcLCBcXG51bV9wc1xcLCBcXG51bV9weFxcKSlcblxuIyBQbG90dGluZ1xuZ2dwbG90KGxvb3BUeXBlTG9uZywgYWVzKGZpbGw9dHlwZSwgeT1jb3VudCwgeD1ncm91cCkpICsgXG4gICAgZ2VvbV9iYXIocG9zaXRpb249XFxmaWxsXFwsIHN0YXQ9XFxpZGVudGl0eVxcKSArIHRoZW1lX2NsYXNzaWMoKVxuXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
#######
temp2 <- tempSum %>% rowwise() %>% mutate(total = length(anno2),
                                 num_pp = sum(anno2 == \P-P\),
                                 num_pe = sum(anno2 == \P-E\),
                                 num_ps = sum(anno2 == \P-S\),
                                 num_px = sum(anno2 == \P-X\),
                                 ratio_reg = (num_pp + num_pe)/total,
                                 ratio_str = num_ps/total)

saveRDS(temp2, here(resultDir, \gene_loop_link_A485.rds\))


loopType <- temp2 %>% group_by(group) %>% summarise(num_pp = sum(num_pp),
                                        num_pe = sum(num_pe),
                                        num_ps = sum(num_ps),
                                        num_px = sum(num_px))


loopTypeLong <- loopType %>% pivot_longer(-group, names_to = \type\, values_to = \count\)

loopTypeLong$type <- factor(loopTypeLong$type, levels = c(\num_pp\, \num_pe\, \num_ps\, \num_px\))

# Plotting
ggplot(loopTypeLong, aes(fill=type, y=count, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSTF4dWRHVnRjRElnUEMwZ2RHVnRjRk4xYlNBbFBpVWdjbTkzZDJselpTZ3BJQ1UrSlNCdGRYUmhkR1VvZEc5MFlXd2dQU0JzWlc1bmRHZ29ZVzV1YnpJcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0J3SUQwZ2MzVnRLR0Z1Ym04eUlEMDlJRnhjVUMxUVhGd3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiblZ0WDNCbElEMGdjM1Z0S0dGdWJtOHlJRDA5SUZ4Y1VDMUZYRndwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYm5WdFgzQnpJRDBnYzNWdEtHRnVibTh5SUQwOUlGeGNVQzFUWEZ3cExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JuVnRYM0I0SUQwZ2MzVnRLR0Z1Ym04eUlEMDlJRnhjVUMxWVhGd3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdjbUYwYVc5ZmNtVm5JRDBnS0c1MWJWOXdjQ0FySUc1MWJWOXdaU2t2ZEc5MFlXd3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnlZWFJwYjE5emRISWdQU0J1ZFcxZmNITXZkRzkwWVd3cFhHNWNibk5oZG1WU1JGTW9kR1Z0Y0RJc0lHaGxjbVVvY21WemRXeDBSR2x5TENCY1hHZGxibVZmYkc5dmNGOXNhVzVyWDBFME9EVXVjbVJ6WEZ3cEtWeHVYRzVjYm14dmIzQlVlWEJsSUR3dElIUmxiWEF5SUNVK0pTQm5jbTkxY0Y5aWVTaG5jbTkxY0NrZ0pUNGxJSE4xYlcxaGNtbHpaU2h1ZFcxZmNIQWdQU0J6ZFcwb2JuVnRYM0J3S1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J1ZFcxZmNHVWdQU0J6ZFcwb2JuVnRYM0JsS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J1ZFcxZmNITWdQU0J6ZFcwb2JuVnRYM0J6S1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J1ZFcxZmNIZ2dQU0J6ZFcwb2JuVnRYM0I0S1NsY2JseHVYRzVzYjI5d1ZIbHdaVXh2Ym1jZ1BDMGdiRzl2Y0ZSNWNHVWdKVDRsSUhCcGRtOTBYMnh2Ym1kbGNpZ3RaM0p2ZFhBc0lHNWhiV1Z6WDNSdklEMGdYRngwZVhCbFhGd3NJSFpoYkhWbGMxOTBieUE5SUZ4Y1kyOTFiblJjWENsY2JseHViRzl2Y0ZSNWNHVk1iMjVuSkhSNWNHVWdQQzBnWm1GamRHOXlLR3h2YjNCVWVYQmxURzl1WnlSMGVYQmxMQ0JzWlhabGJITWdQU0JqS0Z4Y2JuVnRYM0J3WEZ3c0lGeGNiblZ0WDNCbFhGd3NJRnhjYm5WdFgzQnpYRndzSUZ4Y2JuVnRYM0I0WEZ3cEtWeHVYRzRqSUZCc2IzUjBhVzVuWEc1blozQnNiM1FvYkc5dmNGUjVjR1ZNYjI1bkxDQmhaWE1vWm1sc2JEMTBlWEJsTENCNVBXTnZkVzUwTENCNFBXZHliM1Z3S1NrZ0t5QmNiaUFnSUNCblpXOXRYMkpoY2lod2IzTnBkR2x2YmoxY1hHWnBiR3hjWEN3Z2MzUmhkRDFjWEdsa1pXNTBhWFI1WEZ3cElDc2dkR2hsYldWZlkyeGhjM05wWXlncFhHNWNibUJnWUZ4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG5gYGByXG4jIyMjIyMjXG50ZW1wMiA8LSB0ZW1wU3VtICU+JSByb3d3aXNlKCkgJT4lIG11dGF0ZSh0b3RhbCA9IGxlbmd0aChhbm5vMiksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHAgPSBzdW0oYW5ubzIgPT0gXFxQLVBcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcGUgPSBzdW0oYW5ubzIgPT0gXFxQLUVcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHMgPSBzdW0oYW5ubzIgPT0gXFxQLVNcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHggPSBzdW0oYW5ubzIgPT0gXFxQLVhcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICByYXRpb19yZWcgPSAobnVtX3BwICsgbnVtX3BlKS90b3RhbCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHJhdGlvX3N0ciA9IG51bV9wcy90b3RhbClcblxuc2F2ZVJEUyh0ZW1wMiwgaGVyZShyZXN1bHREaXIsIFxcZ2VuZV9sb29wX2xpbmtfQTQ4NS5yZHNcXCkpXG5cblxubG9vcFR5cGUgPC0gdGVtcDIgJT4lIGdyb3VwX2J5KGdyb3VwKSAlPiUgc3VtbWFyaXNlKG51bV9wcCA9IHN1bShudW1fcHApLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG51bV9wZSA9IHN1bShudW1fcGUpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG51bV9wcyA9IHN1bShudW1fcHMpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG51bV9weCA9IHN1bShudW1fcHgpKVxuXG5cbmxvb3BUeXBlTG9uZyA8LSBsb29wVHlwZSAlPiUgcGl2b3RfbG9uZ2VyKC1ncm91cCwgbmFtZXNfdG8gPSBcXHR5cGVcXCwgdmFsdWVzX3RvID0gXFxjb3VudFxcKVxuXG5sb29wVHlwZUxvbmckdHlwZSA8LSBmYWN0b3IobG9vcFR5cGVMb25nJHR5cGUsIGxldmVscyA9IGMoXFxudW1fcHBcXCwgXFxudW1fcGVcXCwgXFxudW1fcHNcXCwgXFxudW1fcHhcXCkpXG5cbiMgUGxvdHRpbmdcbmdncGxvdChsb29wVHlwZUxvbmcsIGFlcyhmaWxsPXR5cGUsIHk9Y291bnQsIHg9Z3JvdXApKSArIFxuICAgIGdlb21fYmFyKHBvc2l0aW9uPVxcZmlsbFxcLCBzdGF0PVxcaWRlbnRpdHlcXCkgKyB0aGVtZV9jbGFzc2ljKClcblxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjI1xudGVtcDIgPC0gdGVtcFN1bSAlPiUgcm93d2lzZSgpICU+JSBtdXRhdGUodG90YWwgPSBsZW5ndGgoYW5ubzIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BwID0gc3VtKGFubm8yID09IFxcUC1QXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BlID0gc3VtKGFubm8yID09IFxcUC1FXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3BzID0gc3VtKGFubm8yID09IFxcUC1TXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbnVtX3B4ID0gc3VtKGFubm8yID09IFxcUC1YXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcmF0aW9fcmVnID0gKG51bV9wcCArIG51bV9wZSkvdG90YWwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICByYXRpb19zdHIgPSBudW1fcHMvdG90YWwpXG5cbnNhdmVSRFModGVtcDIsIGhlcmUocmVzdWx0RGlyLCBcXGdlbmVfbG9vcF9saW5rX0E0ODUucmRzXFwpKVxuXG5cbmxvb3BUeXBlIDwtIHRlbXAyICU+JSBncm91cF9ieShncm91cCkgJT4lIHN1bW1hcmlzZShudW1fcHAgPSBzdW0obnVtX3BwKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcGUgPSBzdW0obnVtX3BlKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHMgPSBzdW0obnVtX3BzKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBudW1fcHggPSBzdW0obnVtX3B4KSlcblxuXG5sb29wVHlwZUxvbmcgPC0gbG9vcFR5cGUgJT4lIHBpdm90X2xvbmdlcigtZ3JvdXAsIG5hbWVzX3RvID0gXFx0eXBlXFwsIHZhbHVlc190byA9IFxcY291bnRcXClcblxubG9vcFR5cGVMb25nJHR5cGUgPC0gZmFjdG9yKGxvb3BUeXBlTG9uZyR0eXBlLCBsZXZlbHMgPSBjKFxcbnVtX3BwXFwsIFxcbnVtX3BlXFwsIFxcbnVtX3BzXFwsIFxcbnVtX3B4XFwpKVxuXG4jIFBsb3R0aW5nXG5nZ3Bsb3QobG9vcFR5cGVMb25nLCBhZXMoZmlsbD10eXBlLCB5PWNvdW50LCB4PWdyb3VwKSkgKyBcbiAgICBnZW9tX2Jhcihwb3NpdGlvbj1cXGZpbGxcXCwgc3RhdD1cXGlkZW50aXR5XFwpICsgdGhlbWVfY2xhc3NpYygpXG5cbmBgYFxuYGBgIn0= -->

```r
```r
#######
temp2 <- tempSum %>% rowwise() %>% mutate(total = length(anno2),
                                 num_pp = sum(anno2 == \P-P\),
                                 num_pe = sum(anno2 == \P-E\),
                                 num_ps = sum(anno2 == \P-S\),
                                 num_px = sum(anno2 == \P-X\),
                                 ratio_reg = (num_pp + num_pe)/total,
                                 ratio_str = num_ps/total)

saveRDS(temp2, here(resultDir, \gene_loop_link_A485.rds\))


loopType <- temp2 %>% group_by(group) %>% summarise(num_pp = sum(num_pp),
                                        num_pe = sum(num_pe),
                                        num_ps = sum(num_ps),
                                        num_px = sum(num_px))


loopTypeLong <- loopType %>% pivot_longer(-group, names_to = \type\, values_to = \count\)

loopTypeLong$type <- factor(loopTypeLong$type, levels = c(\num_pp\, \num_pe\, \num_ps\, \num_px\))

# Plotting
ggplot(loopTypeLong, aes(fill=type, y=count, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-N

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakl5TmNiaU5RTFZCY2JtUmhkR0VnUEMwZ2RHVnRjRElnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWjNKdmRYQXNJRzUxYlY5d2NDbGNibU52Ykc1aGJXVnpLR1JoZEdFcElEd3RJR01vWENKbmNtOTFjRndpTENCY0ltTnZkVzUwWENJcFhHNGpJSEIyTVRJZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGd2laM0p2ZFhBeFhDSXNJRndpWjNKdmRYQXlYQ0lwTENBMUtWeHVJeUJ3ZGpFMUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvWkdGMFlTeGNJbWR5YjNWd01Wd2lMQ0JjSW1keWIzVndOVndpS1N3Z05TbGNiaU1nY0hZeE9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYQ0puY205MWNERmNJaXdnWENKbmNtOTFjRGhjSWlrc0lEVXBYRzRqSUhCMk1qVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoa1lYUmhMRndpWjNKdmRYQXlYQ0lzSUZ3aVozSnZkWEExWENJcExDQTFLVnh1SXlCd2RqSTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjSW1keWIzVndNbHdpTENCY0ltZHliM1Z3T0Z3aUtTd2dOU2xjYmlNZ2NIWTFPQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtHUmhkR0VzWENKbmNtOTFjRFZjSWl3Z1hDSm5jbTkxY0RoY0lpa3NJRFVwWEc1Y2JuQWdQQzBnWjJkd2JHOTBLR1JoZEdFc0lHRmxjeWg0SUQwZ1ozSnZkWEFzSUhrZ1BTQmpiM1Z1ZEN3Z1ptbHNiQ0E5SUdkeWIzVndLU2tnSzF4dUlDQm5aVzl0WDJKdmVIQnNiM1FvZDJsa2RHZ2dQU0F3TGpVc0lHOTFkR3hwWlhJdWMyaGhjR1VnUFNCT1FTa2dLeUIwYUdWdFpWOWpiR0Z6YzJsaktDa2dLeUFnSUNBZ0lDQmNiaUFnYzJOaGJHVmZlVjlqYjI1MGFXNTFiM1Z6S0dKeVpXRnJjeUE5SUhObGNTZ3dMQ0ExTENCaWVTQTlJRElwTENCc2FXMXBkSE1nUFNCaktEQXNJRFVwS1NBcklGeHVJQ0J6ZEdGMFgzTjFiVzFoY25rb1lXVnpLR2R5YjNWd0lEMGdaM0p2ZFhBcExDQm1kVzRnUFNCdFpXRnVMQ0JuWlc5dElEMGdYQ0p3YjJsdWRGd2lMQ0J6YUdGd1pTQTlJREl4TENCemFYcGxJRDBnTWl3Z1ptbHNiQ0E5SUZ3aWNtVmtYQ0lzSUdOdmJHOXlJRDBnWENKaWJHRmphMXdpS1NBZ0sxeHVJQ0IwYUdWdFpTaHNaV2RsYm1RdWNHOXphWFJwYjI0Z1BTQmNJbTV2Ym1WY0lpbGNiaUFnSXlCaGJtNXZkR0YwWlNoY0luUmxlSFJjSWl3Z2VDQTlJREVzSUhrZ1BTQXpMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNJbkIyTVRJNklGd2lMQ0J3ZGpFeUxDQmNJbHhjYmx3aUxGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQjJNVFU2SUZ3aUxDQndkakUxTENCY0lseGNibHdpTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5CMk1UZzZJRndpTENCd2RqRTRMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkIyTWpVNklGd2lMQ0J3ZGpJMUxDQmNJbHhjYmx3aUxGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQjJNamc2SUZ3aUxDQndkakk0TENCY0lseGNibHdpTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5CMk5UZzZJRndpTENCd2RqVTRMQ0JjSWx4Y2Jsd2lLU3dnWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJREVwWEc1Y2JseHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRndpWTI5MWJuUmZZbUZ5Y0d4dmRGOWthV1ptUjNKdmRYQmZRVFE0TlY5MmMxOUVUVk5QWDNCd1hDSXBYRzVvWldsbmFIUWdQQzBnTTF4dWQybGtkR2dnUEMwZ00xeHVjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGd2lMbkJ1WjF3aUtTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRndpYVc1Y0lpd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dWNISnBiblFvY0NsY2JtUmxkaTV2Wm1Zb0tWeHVjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjSWk1emRtZGNJaWtwTENBZ2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG4jIyMjIyMjI1xuI1AtUFxuZGF0YSA8LSB0ZW1wMiAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgbnVtX3BwKVxuY29sbmFtZXMoZGF0YSkgPC0gYyhcXGdyb3VwXFwsIFxcY291bnRcXClcbiMgcHYxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDJcXCksIDUpXG4jIHB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHYyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDJcXCwgXFxncm91cDVcXCksIDUpXG4jIHB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxuIyBwdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcblxucCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IGNvdW50LCBmaWxsID0gZ3JvdXApKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArICAgICAgIFxuICBzY2FsZV95X2NvbnRpbnVvdXMoYnJlYWtzID0gc2VxKDAsIDUsIGJ5ID0gMiksIGxpbWl0cyA9IGMoMCwgNSkpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICArXG4gIHRoZW1lKGxlZ2VuZC5wb3NpdGlvbiA9IFxcbm9uZVxcKVxuICAjIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIHB2MTIsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxNTogXFwsIHB2MTUsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxODogXFwsIHB2MTgsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNTogXFwsIHB2MjUsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyODogXFwsIHB2MjgsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY1ODogXFwsIHB2NTgsIFxcXFxuXFwpLCBcbiAgIyAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSlcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxjb3VudF9iYXJwbG90X2RpZmZHcm91cF9BNDg1X3ZzX0RNU09fcHBcXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
########
#P-P
data <- temp2 %>% dplyr::select(group, num_pp)
colnames(data) <- c(\group\, \count\)
# pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  theme(legend.position = \none\)
  # annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
  #                                               \pv15: \, pv15, \\n\,
  #                                               \pv18: \, pv18, \\n\,
  #                                               \pv25: \, pv25, \\n\,
  #                                               \pv28: \, pv28, \\n\,
  #                                               \pv58: \, pv58, \\n\), 
  #          color = \black\, hjust = 0, size = 1)


fileName <- paste0(\count_barplot_diffGroup_A485_vs_DMSO_pp\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSXlOY2JpTlFMVkJjYm1SaGRHRWdQQzBnZEdWdGNESWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aM0p2ZFhBc0lHNTFiVjl3Y0NsY2JtTnZiRzVoYldWektHUmhkR0VwSUR3dElHTW9YRnhuY205MWNGeGNMQ0JjWEdOdmRXNTBYRndwWEc0aklIQjJNVElnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaGtZWFJoTEZ4Y1ozSnZkWEF4WEZ3c0lGeGNaM0p2ZFhBeVhGd3BMQ0ExS1Z4dUl5QndkakUxSUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29aR0YwWVN4Y1hHZHliM1Z3TVZ4Y0xDQmNYR2R5YjNWd05WeGNLU3dnTlNsY2JpTWdjSFl4T0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLR1JoZEdFc1hGeG5jbTkxY0RGY1hDd2dYRnhuY205MWNEaGNYQ2tzSURVcFhHNGpJSEIyTWpVZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGeGNaM0p2ZFhBeVhGd3NJRnhjWjNKdmRYQTFYRndwTENBMUtWeHVJeUJ3ZGpJNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvWkdGMFlTeGNYR2R5YjNWd01seGNMQ0JjWEdkeWIzVndPRnhjS1N3Z05TbGNiaU1nY0hZMU9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYRnhuY205MWNEVmNYQ3dnWEZ4bmNtOTFjRGhjWENrc0lEVXBYRzVjYm5BZ1BDMGdaMmR3Ykc5MEtHUmhkR0VzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCamIzVnVkQ3dnWm1sc2JDQTlJR2R5YjNWd0tTa2dLMXh1SUNCblpXOXRYMkp2ZUhCc2IzUW9kMmxrZEdnZ1BTQXdMalVzSUc5MWRHeHBaWEl1YzJoaGNHVWdQU0JPUVNrZ0t5QjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0t5QWdJQ0FnSUNCY2JpQWdjMk5oYkdWZmVWOWpiMjUwYVc1MWIzVnpLR0p5WldGcmN5QTlJSE5sY1Nnd0xDQTFMQ0JpZVNBOUlESXBMQ0JzYVcxcGRITWdQU0JqS0RBc0lEVXBLU0FySUZ4dUlDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ1ozSnZkWEFwTENCbWRXNGdQU0J0WldGdUxDQm5aVzl0SUQwZ1hGeHdiMmx1ZEZ4Y0xDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNaXdnWm1sc2JDQTlJRnhjY21Wa1hGd3NJR052Ykc5eUlEMGdYRnhpYkdGamExeGNLU0FnSzF4dUlDQjBhR1Z0WlNoc1pXZGxibVF1Y0c5emFYUnBiMjRnUFNCY1hHNXZibVZjWENsY2JpQWdJeUJoYm01dmRHRjBaU2hjWEhSbGVIUmNYQ3dnZUNBOUlERXNJSGtnUFNBekxDQnNZV0psYkNBOUlIQmhjM1JsTUNoY1hIQjJNVEk2SUZ4Y0xDQndkakV5TENCY1hGeGNibHhjTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhCMk1UVTZJRnhjTENCd2RqRTFMQ0JjWEZ4Y2JseGNMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEIyTVRnNklGeGNMQ0J3ZGpFNExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQjJNalU2SUZ4Y0xDQndkakkxTENCY1hGeGNibHhjTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhCMk1qZzZJRnhjTENCd2RqSTRMQ0JjWEZ4Y2JseGNMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEIyTlRnNklGeGNMQ0J3ZGpVNExDQmNYRnhjYmx4Y0tTd2dYRzRnSUNNZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlERXBYRzVjYmx4dVptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGeGNZMjkxYm5SZlltRnljR3h2ZEY5a2FXWm1SM0p2ZFhCZlFUUTROVjkyYzE5RVRWTlBYM0J3WEZ3cFhHNW9aV2xuYUhRZ1BDMGdNMXh1ZDJsa2RHZ2dQQzBnTTF4dWNHNW5LR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ4Y0xuQnVaMXhjS1Nrc0lISmxjeUE5SURZd01Dd2dkVzVwZENBOUlGeGNhVzVjWEN3Z2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dWMzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNYQzV6ZG1kY1hDa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1WUdCZ1hHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLVBcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wcClcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG4jIHB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuIyBwdjE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiMgcHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4jIHB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTg6IFxcLCBwdjE4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NTg6IFxcLCBwdjU4LCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfQTQ4NV92c19ETVNPX3BwXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLVBcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wcClcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG4jIHB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuIyBwdjE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiMgcHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4jIHB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTg6IFxcLCBwdjE4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NTg6IFxcLCBwdjU4LCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfQTQ4NV92c19ETVNPX3BwXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
########
#P-P
data <- temp2 %>% dplyr::select(group, num_pp)
colnames(data) <- c(\group\, \count\)
# pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  theme(legend.position = \none\)
  # annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
  #                                               \pv15: \, pv15, \\n\,
  #                                               \pv18: \, pv18, \\n\,
  #                                               \pv25: \, pv25, \\n\,
  #                                               \pv28: \, pv28, \\n\,
  #                                               \pv58: \, pv58, \\n\), 
  #          color = \black\, hjust = 0, size = 1)


fileName <- paste0(\count_barplot_diffGroup_A485_vs_DMSO_pp\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Counting loop types

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakl5TmNiaU5RTFVWY2JtUmhkR0VnUEMwZ2RHVnRjRElnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWjNKdmRYQXNJRzUxYlY5d1pTbGNibU52Ykc1aGJXVnpLR1JoZEdFcElEd3RJR01vWENKbmNtOTFjRndpTENCY0ltTnZkVzUwWENJcFhHNGpJSEIyTVRJZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGd2laM0p2ZFhBeFhDSXNJRndpWjNKdmRYQXlYQ0lwTENBMUtWeHVJeUJ3ZGpFMUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvWkdGMFlTeGNJbWR5YjNWd01Wd2lMQ0JjSW1keWIzVndOVndpS1N3Z05TbGNiaU1nY0hZeE9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYQ0puY205MWNERmNJaXdnWENKbmNtOTFjRGhjSWlrc0lEVXBYRzRqSUhCMk1qVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoa1lYUmhMRndpWjNKdmRYQXlYQ0lzSUZ3aVozSnZkWEExWENJcExDQTFLVnh1SXlCd2RqSTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjSW1keWIzVndNbHdpTENCY0ltZHliM1Z3T0Z3aUtTd2dOU2xjYmlNZ2NIWTFPQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtHUmhkR0VzWENKbmNtOTFjRFZjSWl3Z1hDSm5jbTkxY0RoY0lpa3NJRFVwWEc1Y2JuQWdQQzBnWjJkd2JHOTBLR1JoZEdFc0lHRmxjeWg0SUQwZ1ozSnZkWEFzSUhrZ1BTQmpiM1Z1ZEN3Z1ptbHNiQ0E5SUdkeWIzVndLU2tnSzF4dUlDQm5aVzl0WDJKdmVIQnNiM1FvZDJsa2RHZ2dQU0F3TGpVc0lHOTFkR3hwWlhJdWMyaGhjR1VnUFNCT1FTa2dLeUIwYUdWdFpWOWpiR0Z6YzJsaktDa2dLeUFnSUNBZ0lDQmNiaUFnYzJOaGJHVmZlVjlqYjI1MGFXNTFiM1Z6S0dKeVpXRnJjeUE5SUhObGNTZ3dMQ0ExTENCaWVTQTlJRElwTENCc2FXMXBkSE1nUFNCaktEQXNJRFVwS1NBcklGeHVJQ0J6ZEdGMFgzTjFiVzFoY25rb1lXVnpLR2R5YjNWd0lEMGdaM0p2ZFhBcExDQm1kVzRnUFNCdFpXRnVMQ0JuWlc5dElEMGdYQ0p3YjJsdWRGd2lMQ0J6YUdGd1pTQTlJREl4TENCemFYcGxJRDBnTWl3Z1ptbHNiQ0E5SUZ3aWNtVmtYQ0lzSUdOdmJHOXlJRDBnWENKaWJHRmphMXdpS1NBZ0sxeHVJQ0IwYUdWdFpTaHNaV2RsYm1RdWNHOXphWFJwYjI0Z1BTQmNJbTV2Ym1WY0lpbGNiaUFnSXlCaGJtNXZkR0YwWlNoY0luUmxlSFJjSWl3Z2VDQTlJREVzSUhrZ1BTQXpMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNJbkIyTVRJNklGd2lMQ0J3ZGpFeUxDQmNJbHhjYmx3aUxGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQjJNVFU2SUZ3aUxDQndkakUxTENCY0lseGNibHdpTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5CMk1UZzZJRndpTENCd2RqRTRMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkIyTWpVNklGd2lMQ0J3ZGpJMUxDQmNJbHhjYmx3aUxGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQjJNamc2SUZ3aUxDQndkakk0TENCY0lseGNibHdpTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5CMk5UZzZJRndpTENCd2RqVTRMQ0JjSWx4Y2Jsd2lLU3dnWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJREVwWEc1Y2JseHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRndpWTI5MWJuUmZZbUZ5Y0d4dmRGOWthV1ptUjNKdmRYQmZRVFE0TlY5MmMxOUVUVk5QWDNCbFhDSXBYRzVvWldsbmFIUWdQQzBnTTF4dWQybGtkR2dnUEMwZ00xeHVjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGd2lMbkJ1WjF3aUtTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRndpYVc1Y0lpd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dWNISnBiblFvY0NsY2JtUmxkaTV2Wm1Zb0tWeHVjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjSWk1emRtZGNJaWtwTENBZ2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG4jIyMjIyMjI1xuI1AtRVxuZGF0YSA8LSB0ZW1wMiAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgbnVtX3BlKVxuY29sbmFtZXMoZGF0YSkgPC0gYyhcXGdyb3VwXFwsIFxcY291bnRcXClcbiMgcHYxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDJcXCksIDUpXG4jIHB2MTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHYyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDJcXCwgXFxncm91cDVcXCksIDUpXG4jIHB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA4XFwpLCA1KVxuIyBwdjU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcblxucCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IGNvdW50LCBmaWxsID0gZ3JvdXApKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArICAgICAgIFxuICBzY2FsZV95X2NvbnRpbnVvdXMoYnJlYWtzID0gc2VxKDAsIDUsIGJ5ID0gMiksIGxpbWl0cyA9IGMoMCwgNSkpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICArXG4gIHRoZW1lKGxlZ2VuZC5wb3NpdGlvbiA9IFxcbm9uZVxcKVxuICAjIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDMsIGxhYmVsID0gcGFzdGUwKFxccHYxMjogXFwsIHB2MTIsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxNTogXFwsIHB2MTUsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYxODogXFwsIHB2MTgsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNTogXFwsIHB2MjUsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyODogXFwsIHB2MjgsIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY1ODogXFwsIHB2NTgsIFxcXFxuXFwpLCBcbiAgIyAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMSlcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxjb3VudF9iYXJwbG90X2RpZmZHcm91cF9BNDg1X3ZzX0RNU09fcGVcXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
########
#P-E
data <- temp2 %>% dplyr::select(group, num_pe)
colnames(data) <- c(\group\, \count\)
# pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  theme(legend.position = \none\)
  # annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
  #                                               \pv15: \, pv15, \\n\,
  #                                               \pv18: \, pv18, \\n\,
  #                                               \pv25: \, pv25, \\n\,
  #                                               \pv28: \, pv28, \\n\,
  #                                               \pv58: \, pv58, \\n\), 
  #          color = \black\, hjust = 0, size = 1)


fileName <- paste0(\count_barplot_diffGroup_A485_vs_DMSO_pe\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSXlOY2JpTlFMVVZjYm1SaGRHRWdQQzBnZEdWdGNESWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aM0p2ZFhBc0lHNTFiVjl3WlNsY2JtTnZiRzVoYldWektHUmhkR0VwSUR3dElHTW9YRnhuY205MWNGeGNMQ0JjWEdOdmRXNTBYRndwWEc0aklIQjJNVElnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaGtZWFJoTEZ4Y1ozSnZkWEF4WEZ3c0lGeGNaM0p2ZFhBeVhGd3BMQ0ExS1Z4dUl5QndkakUxSUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29aR0YwWVN4Y1hHZHliM1Z3TVZ4Y0xDQmNYR2R5YjNWd05WeGNLU3dnTlNsY2JpTWdjSFl4T0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLR1JoZEdFc1hGeG5jbTkxY0RGY1hDd2dYRnhuY205MWNEaGNYQ2tzSURVcFhHNGpJSEIyTWpVZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGeGNaM0p2ZFhBeVhGd3NJRnhjWjNKdmRYQTFYRndwTENBMUtWeHVJeUJ3ZGpJNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvWkdGMFlTeGNYR2R5YjNWd01seGNMQ0JjWEdkeWIzVndPRnhjS1N3Z05TbGNiaU1nY0hZMU9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYRnhuY205MWNEVmNYQ3dnWEZ4bmNtOTFjRGhjWENrc0lEVXBYRzVjYm5BZ1BDMGdaMmR3Ykc5MEtHUmhkR0VzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCamIzVnVkQ3dnWm1sc2JDQTlJR2R5YjNWd0tTa2dLMXh1SUNCblpXOXRYMkp2ZUhCc2IzUW9kMmxrZEdnZ1BTQXdMalVzSUc5MWRHeHBaWEl1YzJoaGNHVWdQU0JPUVNrZ0t5QjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0t5QWdJQ0FnSUNCY2JpQWdjMk5oYkdWZmVWOWpiMjUwYVc1MWIzVnpLR0p5WldGcmN5QTlJSE5sY1Nnd0xDQTFMQ0JpZVNBOUlESXBMQ0JzYVcxcGRITWdQU0JqS0RBc0lEVXBLU0FySUZ4dUlDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ1ozSnZkWEFwTENCbWRXNGdQU0J0WldGdUxDQm5aVzl0SUQwZ1hGeHdiMmx1ZEZ4Y0xDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNaXdnWm1sc2JDQTlJRnhjY21Wa1hGd3NJR052Ykc5eUlEMGdYRnhpYkdGamExeGNLU0FnSzF4dUlDQjBhR1Z0WlNoc1pXZGxibVF1Y0c5emFYUnBiMjRnUFNCY1hHNXZibVZjWENsY2JpQWdJeUJoYm01dmRHRjBaU2hjWEhSbGVIUmNYQ3dnZUNBOUlERXNJSGtnUFNBekxDQnNZV0psYkNBOUlIQmhjM1JsTUNoY1hIQjJNVEk2SUZ4Y0xDQndkakV5TENCY1hGeGNibHhjTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhCMk1UVTZJRnhjTENCd2RqRTFMQ0JjWEZ4Y2JseGNMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEIyTVRnNklGeGNMQ0J3ZGpFNExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQjJNalU2SUZ4Y0xDQndkakkxTENCY1hGeGNibHhjTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhCMk1qZzZJRnhjTENCd2RqSTRMQ0JjWEZ4Y2JseGNMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEIyTlRnNklGeGNMQ0J3ZGpVNExDQmNYRnhjYmx4Y0tTd2dYRzRnSUNNZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlERXBYRzVjYmx4dVptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGeGNZMjkxYm5SZlltRnljR3h2ZEY5a2FXWm1SM0p2ZFhCZlFUUTROVjkyYzE5RVRWTlBYM0JsWEZ3cFhHNW9aV2xuYUhRZ1BDMGdNMXh1ZDJsa2RHZ2dQQzBnTTF4dWNHNW5LR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ4Y0xuQnVaMXhjS1Nrc0lISmxjeUE5SURZd01Dd2dkVzVwZENBOUlGeGNhVzVjWEN3Z2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dWMzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNYQzV6ZG1kY1hDa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1WUdCZ1hHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLUVcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wZSlcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG4jIHB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuIyBwdjE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiMgcHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4jIHB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTg6IFxcLCBwdjE4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NTg6IFxcLCBwdjU4LCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfQTQ4NV92c19ETVNPX3BlXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLUVcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wZSlcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG4jIHB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuIyBwdjE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiMgcHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4jIHB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTg6IFxcLCBwdjE4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NTg6IFxcLCBwdjU4LCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfQTQ4NV92c19ETVNPX3BlXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
########
#P-E
data <- temp2 %>% dplyr::select(group, num_pe)
colnames(data) <- c(\group\, \count\)
# pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  theme(legend.position = \none\)
  # annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
  #                                               \pv15: \, pv15, \\n\,
  #                                               \pv18: \, pv18, \\n\,
  #                                               \pv25: \, pv25, \\n\,
  #                                               \pv28: \, pv28, \\n\,
  #                                               \pv58: \, pv58, \\n\), 
  #          color = \black\, hjust = 0, size = 1)


fileName <- paste0(\count_barplot_diffGroup_A485_vs_DMSO_pe\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-P

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakl5TmNiaU5RTFZOY2JtUmhkR0VnUEMwZ2RHVnRjRElnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWjNKdmRYQXNJRzUxYlY5d2N5bGNibU52Ykc1aGJXVnpLR1JoZEdFcElEd3RJR01vWENKbmNtOTFjRndpTENCY0ltTnZkVzUwWENJcFhHNGpJSEIyTVRJZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGd2laM0p2ZFhBeFhDSXNJRndpWjNKdmRYQXlYQ0lwTENBMUtWeHVJeUJ3ZGpFMUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvWkdGMFlTeGNJbWR5YjNWd01Wd2lMQ0JjSW1keWIzVndOVndpS1N3Z05TbGNiaU1nY0hZeE9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYQ0puY205MWNERmNJaXdnWENKbmNtOTFjRGhjSWlrc0lEVXBYRzRqSUhCMk1qVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoa1lYUmhMRndpWjNKdmRYQXlYQ0lzSUZ3aVozSnZkWEExWENJcExDQTFLVnh1SXlCd2RqSTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjSW1keWIzVndNbHdpTENCY0ltZHliM1Z3T0Z3aUtTd2dOU2xjYmlNZ2NIWTFPQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtHUmhkR0VzWENKbmNtOTFjRFZjSWl3Z1hDSm5jbTkxY0RoY0lpa3NJRFVwWEc1Y2JuQWdQQzBnWjJkd2JHOTBLR1JoZEdFc0lHRmxjeWg0SUQwZ1ozSnZkWEFzSUhrZ1BTQmpiM1Z1ZEN3Z1ptbHNiQ0E5SUdkeWIzVndLU2tnSzF4dUlDQm5aVzl0WDJKdmVIQnNiM1FvZDJsa2RHZ2dQU0F3TGpVc0lHOTFkR3hwWlhJdWMyaGhjR1VnUFNCT1FTa2dLeUIwYUdWdFpWOWpiR0Z6YzJsaktDa2dLeUFnSUNBZ0lDQmNiaUFnYzJOaGJHVmZlVjlqYjI1MGFXNTFiM1Z6S0dKeVpXRnJjeUE5SUhObGNTZ3dMQ0ExTENCaWVTQTlJRElwTENCc2FXMXBkSE1nUFNCaktEQXNJRFVwS1NBcklGeHVJQ0J6ZEdGMFgzTjFiVzFoY25rb1lXVnpLR2R5YjNWd0lEMGdaM0p2ZFhBcExDQm1kVzRnUFNCdFpXRnVMQ0JuWlc5dElEMGdYQ0p3YjJsdWRGd2lMQ0J6YUdGd1pTQTlJREl4TENCemFYcGxJRDBnTWl3Z1ptbHNiQ0E5SUZ3aWNtVmtYQ0lzSUdOdmJHOXlJRDBnWENKaWJHRmphMXdpS1NBZ0sxeHVJQ0IwYUdWdFpTaHNaV2RsYm1RdWNHOXphWFJwYjI0Z1BTQmNJbTV2Ym1WY0lpbGNiaUFnSXlCaGJtNXZkR0YwWlNoY0luUmxlSFJjSWl3Z2VDQTlJREVzSUhrZ1BTQXpMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNJbkIyTVRJNklGd2lMQ0J3ZGpFeUxDQmNJbHhjYmx3aUxGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQjJNVFU2SUZ3aUxDQndkakUxTENCY0lseGNibHdpTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5CMk1UZzZJRndpTENCd2RqRTRMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkIyTWpVNklGd2lMQ0J3ZGpJMUxDQmNJbHhjYmx3aUxGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQjJNamc2SUZ3aUxDQndkakk0TENCY0lseGNibHdpTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5CMk5UZzZJRndpTENCd2RqVTRMQ0JjSWx4Y2Jsd2lLU3dnWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJREVwS3lBZ1hHNWNibHh1Wm1sc1pVNWhiV1VnUEMwZ2NHRnpkR1V3S0Z3aVkyOTFiblJmWW1GeWNHeHZkRjlrYVdabVIzSnZkWEJmUVRRNE5WOTJjMTlFVFZOUFgzQnpYQ0lwWEc1b1pXbG5hSFFnUEMwZ00xeHVkMmxrZEdnZ1BDMGdNMXh1Y0c1bktHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRndpTG5CdVoxd2lLU2tzSUhKbGN5QTlJRFl3TUN3Z2RXNXBkQ0E5SUZ3aWFXNWNJaXdnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1YzNabmJHbDBaU2hvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY0lpNXpkbWRjSWlrcExDQWdhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dWNISnBiblFvY0NsY2JtUmxkaTV2Wm1Zb0tWeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuIyMjIyMjIyNcbiNQLVNcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wcylcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG4jIHB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuIyBwdjE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiMgcHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4jIHB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTg6IFxcLCBwdjE4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NTg6IFxcLCBwdjU4LCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpKyAgXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfQTQ4NV92c19ETVNPX3BzXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
########
#P-S
data <- temp2 %>% dplyr::select(group, num_ps)
colnames(data) <- c(\group\, \count\)
# pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  theme(legend.position = \none\)
  # annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
  #                                               \pv15: \, pv15, \\n\,
  #                                               \pv18: \, pv18, \\n\,
  #                                               \pv25: \, pv25, \\n\,
  #                                               \pv28: \, pv28, \\n\,
  #                                               \pv58: \, pv58, \\n\), 
  #          color = \black\, hjust = 0, size = 1)+  


fileName <- paste0(\count_barplot_diffGroup_A485_vs_DMSO_ps\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSXlOY2JpTlFMVk5jYm1SaGRHRWdQQzBnZEdWdGNESWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aM0p2ZFhBc0lHNTFiVjl3Y3lsY2JtTnZiRzVoYldWektHUmhkR0VwSUR3dElHTW9YRnhuY205MWNGeGNMQ0JjWEdOdmRXNTBYRndwWEc0aklIQjJNVElnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaGtZWFJoTEZ4Y1ozSnZkWEF4WEZ3c0lGeGNaM0p2ZFhBeVhGd3BMQ0ExS1Z4dUl5QndkakUxSUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29aR0YwWVN4Y1hHZHliM1Z3TVZ4Y0xDQmNYR2R5YjNWd05WeGNLU3dnTlNsY2JpTWdjSFl4T0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLR1JoZEdFc1hGeG5jbTkxY0RGY1hDd2dYRnhuY205MWNEaGNYQ2tzSURVcFhHNGpJSEIyTWpVZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGeGNaM0p2ZFhBeVhGd3NJRnhjWjNKdmRYQTFYRndwTENBMUtWeHVJeUJ3ZGpJNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvWkdGMFlTeGNYR2R5YjNWd01seGNMQ0JjWEdkeWIzVndPRnhjS1N3Z05TbGNiaU1nY0hZMU9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYRnhuY205MWNEVmNYQ3dnWEZ4bmNtOTFjRGhjWENrc0lEVXBYRzVjYm5BZ1BDMGdaMmR3Ykc5MEtHUmhkR0VzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCamIzVnVkQ3dnWm1sc2JDQTlJR2R5YjNWd0tTa2dLMXh1SUNCblpXOXRYMkp2ZUhCc2IzUW9kMmxrZEdnZ1BTQXdMalVzSUc5MWRHeHBaWEl1YzJoaGNHVWdQU0JPUVNrZ0t5QjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0t5QWdJQ0FnSUNCY2JpQWdjMk5oYkdWZmVWOWpiMjUwYVc1MWIzVnpLR0p5WldGcmN5QTlJSE5sY1Nnd0xDQTFMQ0JpZVNBOUlESXBMQ0JzYVcxcGRITWdQU0JqS0RBc0lEVXBLU0FySUZ4dUlDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ1ozSnZkWEFwTENCbWRXNGdQU0J0WldGdUxDQm5aVzl0SUQwZ1hGeHdiMmx1ZEZ4Y0xDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNaXdnWm1sc2JDQTlJRnhjY21Wa1hGd3NJR052Ykc5eUlEMGdYRnhpYkdGamExeGNLU0FnSzF4dUlDQjBhR1Z0WlNoc1pXZGxibVF1Y0c5emFYUnBiMjRnUFNCY1hHNXZibVZjWENsY2JpQWdJeUJoYm01dmRHRjBaU2hjWEhSbGVIUmNYQ3dnZUNBOUlERXNJSGtnUFNBekxDQnNZV0psYkNBOUlIQmhjM1JsTUNoY1hIQjJNVEk2SUZ4Y0xDQndkakV5TENCY1hGeGNibHhjTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhCMk1UVTZJRnhjTENCd2RqRTFMQ0JjWEZ4Y2JseGNMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEIyTVRnNklGeGNMQ0J3ZGpFNExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQjJNalU2SUZ4Y0xDQndkakkxTENCY1hGeGNibHhjTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhCMk1qZzZJRnhjTENCd2RqSTRMQ0JjWEZ4Y2JseGNMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEIyTlRnNklGeGNMQ0J3ZGpVNExDQmNYRnhjYmx4Y0tTd2dYRzRnSUNNZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlERXBLeUFnWEc1Y2JseHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRnhjWTI5MWJuUmZZbUZ5Y0d4dmRGOWthV1ptUjNKdmRYQmZRVFE0TlY5MmMxOUVUVk5QWDNCelhGd3BYRzVvWldsbmFIUWdQQzBnTTF4dWQybGtkR2dnUEMwZ00xeHVjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGeGNMbkJ1WjF4Y0tTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRnhjYVc1Y1hDd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dWNISnBiblFvY0NsY2JtUmxkaTV2Wm1Zb0tWeHVjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjWEM1emRtZGNYQ2twTENBZ2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbiMjIyMjIyMjXG4jUC1TXG5kYXRhIDwtIHRlbXAyICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBudW1fcHMpXG5jb2xuYW1lcyhkYXRhKSA8LSBjKFxcZ3JvdXBcXCwgXFxjb3VudFxcKVxuIyBwdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiMgcHYxNSA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4jIHB2MTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuIyBwdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiMgcHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4jIHB2NTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuXG5wIDwtIGdncGxvdChkYXRhLCBhZXMoeCA9IGdyb3VwLCB5ID0gY291bnQsIGZpbGwgPSBncm91cCkpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC41LCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgICAgICAgXG4gIHNjYWxlX3lfY29udGludW91cyhicmVha3MgPSBzZXEoMCwgNSwgYnkgPSAyKSwgbGltaXRzID0gYygwLCA1KSkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgICtcbiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG4gICMgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMywgbGFiZWwgPSBwYXN0ZTAoXFxwdjEyOiBcXCwgcHYxMiwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE1OiBcXCwgcHYxNSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE4OiBcXCwgcHYxOCwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI1OiBcXCwgcHYyNSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgcHYyOCwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjU4OiBcXCwgcHY1OCwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAxKSsgIFxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGNvdW50X2JhcnBsb3RfZGlmZkdyb3VwX0E0ODVfdnNfRE1TT19wc1xcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLVNcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9wcylcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG4jIHB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuIyBwdjE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiMgcHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4jIHB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTg6IFxcLCBwdjE4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NTg6IFxcLCBwdjU4LCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpKyAgXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfQTQ4NV92c19ETVNPX3BzXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
########
#P-S
data <- temp2 %>% dplyr::select(group, num_ps)
colnames(data) <- c(\group\, \count\)
# pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  theme(legend.position = \none\)
  # annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
  #                                               \pv15: \, pv15, \\n\,
  #                                               \pv18: \, pv18, \\n\,
  #                                               \pv25: \, pv25, \\n\,
  #                                               \pv28: \, pv28, \\n\,
  #                                               \pv58: \, pv58, \\n\), 
  #          color = \black\, hjust = 0, size = 1)+  


fileName <- paste0(\count_barplot_diffGroup_A485_vs_DMSO_ps\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-E

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakl5TmNiaU5RTFZoY2JtUmhkR0VnUEMwZ2RHVnRjRElnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWjNKdmRYQXNJRzUxYlY5d2VDbGNibU52Ykc1aGJXVnpLR1JoZEdFcElEd3RJR01vWENKbmNtOTFjRndpTENCY0ltTnZkVzUwWENJcFhHNGpJSEIyTVRJZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGd2laM0p2ZFhBeFhDSXNJRndpWjNKdmRYQXlYQ0lwTENBMUtWeHVJeUJ3ZGpFMUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvWkdGMFlTeGNJbWR5YjNWd01Wd2lMQ0JjSW1keWIzVndOVndpS1N3Z05TbGNiaU1nY0hZeE9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYQ0puY205MWNERmNJaXdnWENKbmNtOTFjRGhjSWlrc0lEVXBYRzRqSUhCMk1qVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoa1lYUmhMRndpWjNKdmRYQXlYQ0lzSUZ3aVozSnZkWEExWENJcExDQTFLVnh1SXlCd2RqSTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb1pHRjBZU3hjSW1keWIzVndNbHdpTENCY0ltZHliM1Z3T0Z3aUtTd2dOU2xjYmlNZ2NIWTFPQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtHUmhkR0VzWENKbmNtOTFjRFZjSWl3Z1hDSm5jbTkxY0RoY0lpa3NJRFVwWEc1Y2JuQWdQQzBnWjJkd2JHOTBLR1JoZEdFc0lHRmxjeWg0SUQwZ1ozSnZkWEFzSUhrZ1BTQmpiM1Z1ZEN3Z1ptbHNiQ0E5SUdkeWIzVndLU2tnSzF4dUlDQm5aVzl0WDJKdmVIQnNiM1FvZDJsa2RHZ2dQU0F3TGpVc0lHOTFkR3hwWlhJdWMyaGhjR1VnUFNCT1FTa2dLeUIwYUdWdFpWOWpiR0Z6YzJsaktDa2dLeUFnSUNBZ0lDQmNiaUFnYzJOaGJHVmZlVjlqYjI1MGFXNTFiM1Z6S0dKeVpXRnJjeUE5SUhObGNTZ3dMQ0ExTENCaWVTQTlJRElwTENCc2FXMXBkSE1nUFNCaktEQXNJRFVwS1NBcklGeHVJQ0J6ZEdGMFgzTjFiVzFoY25rb1lXVnpLR2R5YjNWd0lEMGdaM0p2ZFhBcExDQm1kVzRnUFNCdFpXRnVMQ0JuWlc5dElEMGdYQ0p3YjJsdWRGd2lMQ0J6YUdGd1pTQTlJREl4TENCemFYcGxJRDBnTWl3Z1ptbHNiQ0E5SUZ3aWNtVmtYQ0lzSUdOdmJHOXlJRDBnWENKaWJHRmphMXdpS1NBZ0sxeHVJQ0IwYUdWdFpTaHNaV2RsYm1RdWNHOXphWFJwYjI0Z1BTQmNJbTV2Ym1WY0lpbGNiaUFnSXlCaGJtNXZkR0YwWlNoY0luUmxlSFJjSWl3Z2VDQTlJREVzSUhrZ1BTQXpMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNJbkIyTVRJNklGd2lMQ0J3ZGpFeUxDQmNJbHhjYmx3aUxGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQjJNVFU2SUZ3aUxDQndkakUxTENCY0lseGNibHdpTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5CMk1UZzZJRndpTENCd2RqRTRMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkIyTWpVNklGd2lMQ0J3ZGpJMUxDQmNJbHhjYmx3aUxGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQjJNamc2SUZ3aUxDQndkakk0TENCY0lseGNibHdpTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5CMk5UZzZJRndpTENCd2RqVTRMQ0JjSWx4Y2Jsd2lLU3dnWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJREVwS3lBZ1hHNWNibHh1Wm1sc1pVNWhiV1VnUEMwZ2NHRnpkR1V3S0Z3aVkyOTFiblJmWW1GeWNHeHZkRjlrYVdabVIzSnZkWEJmUVRRNE5WOTJjMTlFVFZOUFgzQjRYQ0lwWEc1b1pXbG5hSFFnUEMwZ00xeHVkMmxrZEdnZ1BDMGdNMXh1Y0c1bktHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRndpTG5CdVoxd2lLU2tzSUhKbGN5QTlJRFl3TUN3Z2RXNXBkQ0E5SUZ3aWFXNWNJaXdnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1YzNabmJHbDBaU2hvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY0lpNXpkbWRjSWlrcExDQWdhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dWNISnBiblFvY0NsY2JtUmxkaTV2Wm1Zb0tWeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuIyMjIyMjIyNcbiNQLVhcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9weClcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG4jIHB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuIyBwdjE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiMgcHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4jIHB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTg6IFxcLCBwdjE4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NTg6IFxcLCBwdjU4LCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpKyAgXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfQTQ4NV92c19ETVNPX3B4XFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
########
#P-X
data <- temp2 %>% dplyr::select(group, num_px)
colnames(data) <- c(\group\, \count\)
# pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  theme(legend.position = \none\)
  # annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
  #                                               \pv15: \, pv15, \\n\,
  #                                               \pv18: \, pv18, \\n\,
  #                                               \pv25: \, pv25, \\n\,
  #                                               \pv28: \, pv28, \\n\,
  #                                               \pv58: \, pv58, \\n\), 
  #          color = \black\, hjust = 0, size = 1)+  


fileName <- paste0(\count_barplot_diffGroup_A485_vs_DMSO_px\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSXlOY2JpTlFMVmhjYm1SaGRHRWdQQzBnZEdWdGNESWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aM0p2ZFhBc0lHNTFiVjl3ZUNsY2JtTnZiRzVoYldWektHUmhkR0VwSUR3dElHTW9YRnhuY205MWNGeGNMQ0JjWEdOdmRXNTBYRndwWEc0aklIQjJNVElnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaGtZWFJoTEZ4Y1ozSnZkWEF4WEZ3c0lGeGNaM0p2ZFhBeVhGd3BMQ0ExS1Z4dUl5QndkakUxSUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29aR0YwWVN4Y1hHZHliM1Z3TVZ4Y0xDQmNYR2R5YjNWd05WeGNLU3dnTlNsY2JpTWdjSFl4T0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLR1JoZEdFc1hGeG5jbTkxY0RGY1hDd2dYRnhuY205MWNEaGNYQ2tzSURVcFhHNGpJSEIyTWpVZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2hrWVhSaExGeGNaM0p2ZFhBeVhGd3NJRnhjWjNKdmRYQTFYRndwTENBMUtWeHVJeUJ3ZGpJNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvWkdGMFlTeGNYR2R5YjNWd01seGNMQ0JjWEdkeWIzVndPRnhjS1N3Z05TbGNiaU1nY0hZMU9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0dSaGRHRXNYRnhuY205MWNEVmNYQ3dnWEZ4bmNtOTFjRGhjWENrc0lEVXBYRzVjYm5BZ1BDMGdaMmR3Ykc5MEtHUmhkR0VzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCamIzVnVkQ3dnWm1sc2JDQTlJR2R5YjNWd0tTa2dLMXh1SUNCblpXOXRYMkp2ZUhCc2IzUW9kMmxrZEdnZ1BTQXdMalVzSUc5MWRHeHBaWEl1YzJoaGNHVWdQU0JPUVNrZ0t5QjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0t5QWdJQ0FnSUNCY2JpQWdjMk5oYkdWZmVWOWpiMjUwYVc1MWIzVnpLR0p5WldGcmN5QTlJSE5sY1Nnd0xDQTFMQ0JpZVNBOUlESXBMQ0JzYVcxcGRITWdQU0JqS0RBc0lEVXBLU0FySUZ4dUlDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ1ozSnZkWEFwTENCbWRXNGdQU0J0WldGdUxDQm5aVzl0SUQwZ1hGeHdiMmx1ZEZ4Y0xDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNaXdnWm1sc2JDQTlJRnhjY21Wa1hGd3NJR052Ykc5eUlEMGdYRnhpYkdGamExeGNLU0FnSzF4dUlDQjBhR1Z0WlNoc1pXZGxibVF1Y0c5emFYUnBiMjRnUFNCY1hHNXZibVZjWENsY2JpQWdJeUJoYm01dmRHRjBaU2hjWEhSbGVIUmNYQ3dnZUNBOUlERXNJSGtnUFNBekxDQnNZV0psYkNBOUlIQmhjM1JsTUNoY1hIQjJNVEk2SUZ4Y0xDQndkakV5TENCY1hGeGNibHhjTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhCMk1UVTZJRnhjTENCd2RqRTFMQ0JjWEZ4Y2JseGNMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEIyTVRnNklGeGNMQ0J3ZGpFNExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQjJNalU2SUZ4Y0xDQndkakkxTENCY1hGeGNibHhjTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhCMk1qZzZJRnhjTENCd2RqSTRMQ0JjWEZ4Y2JseGNMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEIyTlRnNklGeGNMQ0J3ZGpVNExDQmNYRnhjYmx4Y0tTd2dYRzRnSUNNZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlERXBLeUFnWEc1Y2JseHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRnhjWTI5MWJuUmZZbUZ5Y0d4dmRGOWthV1ptUjNKdmRYQmZRVFE0TlY5MmMxOUVUVk5QWDNCNFhGd3BYRzVvWldsbmFIUWdQQzBnTTF4dWQybGtkR2dnUEMwZ00xeHVjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGeGNMbkJ1WjF4Y0tTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRnhjYVc1Y1hDd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dWNISnBiblFvY0NsY2JtUmxkaTV2Wm1Zb0tWeHVjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjWEM1emRtZGNYQ2twTENBZ2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbiMjIyMjIyMjXG4jUC1YXG5kYXRhIDwtIHRlbXAyICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBudW1fcHgpXG5jb2xuYW1lcyhkYXRhKSA8LSBjKFxcZ3JvdXBcXCwgXFxjb3VudFxcKVxuIyBwdjEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiMgcHYxNSA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4jIHB2MTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuIyBwdjI1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiMgcHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4jIHB2NTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuXG5wIDwtIGdncGxvdChkYXRhLCBhZXMoeCA9IGdyb3VwLCB5ID0gY291bnQsIGZpbGwgPSBncm91cCkpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC41LCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgICAgICAgXG4gIHNjYWxlX3lfY29udGludW91cyhicmVha3MgPSBzZXEoMCwgNSwgYnkgPSAyKSwgbGltaXRzID0gYygwLCA1KSkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgICtcbiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gXFxub25lXFwpXG4gICMgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMywgbGFiZWwgPSBwYXN0ZTAoXFxwdjEyOiBcXCwgcHYxMiwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE1OiBcXCwgcHYxNSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjE4OiBcXCwgcHYxOCwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI1OiBcXCwgcHYyNSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgcHYyOCwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjU4OiBcXCwgcHY1OCwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAxKSsgIFxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGNvdW50X2JhcnBsb3RfZGlmZkdyb3VwX0E0ODVfdnNfRE1TT19weFxcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjIyNcbiNQLVhcbmRhdGEgPC0gdGVtcDIgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIG51bV9weClcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxncm91cFxcLCBcXGNvdW50XFwpXG4jIHB2MTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuIyBwdjE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiMgcHYxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4jIHB2MjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveChkYXRhLFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuIyBwdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3goZGF0YSxcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiMgcHY1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KGRhdGEsXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBjb3VudCwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjUsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyAgICAgICBcbiAgc2NhbGVfeV9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA1LCBieSA9IDIpLCBsaW1pdHMgPSBjKDAsIDUpKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSAgK1xuICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAzLCBsYWJlbCA9IHBhc3RlMChcXHB2MTI6IFxcLCBwdjEyLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTU6IFxcLCBwdjE1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MTg6IFxcLCBwdjE4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjU6IFxcLCBwdjI1LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBwdjI4LCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NTg6IFxcLCBwdjU4LCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDEpKyAgXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcY291bnRfYmFycGxvdF9kaWZmR3JvdXBfQTQ4NV92c19ETVNPX3B4XFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
########
#P-X
data <- temp2 %>% dplyr::select(group, num_px)
colnames(data) <- c(\group\, \count\)
# pv12 <- round(getPvalWilcox(data,\group1\, \group2\), 5)
# pv15 <- round(getPvalWilcox(data,\group1\, \group5\), 5)
# pv18 <- round(getPvalWilcox(data,\group1\, \group8\), 5)
# pv25 <- round(getPvalWilcox(data,\group2\, \group5\), 5)
# pv28 <- round(getPvalWilcox(data,\group2\, \group8\), 5)
# pv58 <- round(getPvalWilcox(data,\group5\, \group8\), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  theme(legend.position = \none\)
  # annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
  #                                               \pv15: \, pv15, \\n\,
  #                                               \pv18: \, pv18, \\n\,
  #                                               \pv25: \, pv25, \\n\,
  #                                               \pv28: \, pv28, \\n\,
  #                                               \pv58: \, pv58, \\n\), 
  #          color = \black\, hjust = 0, size = 1)+  


fileName <- paste0(\count_barplot_diffGroup_A485_vs_DMSO_px\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-S

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuXG5hbHBoYSA8LSAwLjA1XG5mY0N1dG9mZiA8LSAwLjVcbmRpZmYuUFJPLkcxLmRUQUcgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZGlmZl9HMUcyLmRUQUdfRzEuZFRBR192c19HMS5ETVNPX1BST3NlcS50c3ZcIikpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHBhZGogPCBhbHBoYSwgYWJzKHNocmlua2VkX2xvZzJGQykgPiBmY0N1dG9mZilcbmRpZmYuUFJPLkcyLmRUQUcgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZGlmZl9HMUcyLmRUQUdfRzIuZFRBR192c19HMi5ETVNPX1BST3NlcS50c3ZcIikpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHBhZGogPCBhbHBoYSwgYWJzKHNocmlua2VkX2xvZzJGQykgPiBmY0N1dG9mZilcbmRpZmYuUk5BLkcxLmRUQUcgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcIikpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHBhZGogPCBhbHBoYSwgYWJzKHNocmlua2VkX2xvZzJGQykgPiBmY0N1dG9mZilcbmRpZmYuUk5BLkcxLmRUQUcubm9GQ2N1dG9mZiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlwiKSkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocGFkaiA8IGFscGhhKVxuIyMjIyMjIyMjIyMjXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiX3Atbl9lbnNlbWJsTGlzdC50c3ZcIikpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXCJQLVBcIiwgXCJQLUVcIiwgXCJQLVNcIiwgXCJQLVhcIikpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFwiX1wiKSlcblxuXG5cbiMgdGVtcDIgY29udGFpbnMgZ2VuZXMgZnJvbSBncm91cCAxLCAyLCA1LCA4IGFuZCBsb29wIGNvdW50c1xuI2NhbGN1bGF0aW5nIGRpZmYgc2NvcmUgYW5kIGxvZzJmYyBkaXN0cmlidXRpb24gYmFzZWQgb24gcC1uIG51bWJlcnNcbnJlc3VsdERpciA8LSBoZXJlKFwiLi4vLi4vcmVzdWx0XCIpXG5cbnRlbXAyIDwtIHJlYWRSRFMoaGVyZShyZXN1bHREaXIsIFwiZ2VuZV9sb29wX2xpbmsucmRzXCIpKVxuXG5cbnBuT3ZlcjggPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsID49IDgpKSRnZW5lXG5wbk92ZXI2IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA2LCB0b3RhbCA8IDgpKSRnZW5lXG5wbk92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA0LCB0b3RhbCA8IDYpKSRnZW5lXG5wbk92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSAyLCB0b3RhbCA8IDQpKSRnZW5lXG5wbk92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA8IDIpKSRnZW5lXG5cblxuXG4jIyBEaXZpZGluZyBnZW5lcyBpbnRvIGdyb3Vwc1xudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZl9kVEFHX0RNU08sIGRpc3RhbmNlLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmZfZFRBR19ETVNPKSxcbiAgICAgICAgICAgIG1lYW5fZGlzdGFuY2UgPSBtZWFuKGRpc3RhbmNlKSxcbiAgICAgICAgICAgIC5ncm91cHMgPSAnZHJvcCcpXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XCIpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxubWF4TG9nMkZDID0gMlxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFwiZ2VuZVwiID0gXCJlbnNlbWJsX2dlbmVfaWRcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShmbGFnID0gaWZlbHNlKGdlbmUgJWluJSBkaWZmLlJOQS5HMS5kVEFHJGVuc2VtYmxfZ2VuZV9pZCwgXCIyRE9XTlwiLCBcIjBOT1wiKSxcbiAgICAgICAgICAgICAgICBtYXhGbGFnID0gKGFicyhzaHJpbmtlZF9sb2cyRkMpID4gbWF4TG9nMkZDKSxcbiAgICAgICAgICAgICAgICBsb2cyZmNNYXggPSBwbWF4KHBtaW4oc2hyaW5rZWRfbG9nMkZDLCBtYXhMb2cyRkMpLCAtbWF4TG9nMkZDKSkgJT4lIFxuICBkcGx5cjo6YXJyYW5nZShmbGFnKSAlPiVcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShcbiAgcG5PdmVyID0gaWZlbHNlKGdlbmUgJWluJSBwbk92ZXI4LCBcInBuT3ZlcjhcIixcbiAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcG5PdmVyNiwgXCJwbk92ZXI2XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwbk92ZXI0LCBcInBuT3ZlcjRcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwbk92ZXIyLCBcInBuT3ZlcjJcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcG5PdmVyMCwgXCJwbk92ZXIwXCIsIE5BKSkpKSkpICU+JVxuICBkcm9wX25hKHBuT3ZlcilcbmBgYCJ9 -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n############\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1,\n                peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n\n\n# temp2 contains genes from group 1, 2, 5, 8 and loop counts\n#calculating diff score and log2fc distribution based on p-n numbers\nresultDir <- here(\\../../result\\)\n\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\n\npnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene\npnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene\npnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene\npnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene\npnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene\n\n\n\n## Dividing genes into groups\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO),\n            mean_distance = mean(distance),\n            .groups = 'drop')\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nmaxLog2FC = 2\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \\2DOWN\\, \\0NO\\),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag) %>%\n  drop_na(shrinked_log2FC)\n\ntemp <- temp %>% dplyr::mutate(\n  pnOver = ifelse(gene %in% pnOver8, \\pnOver8\\,\n                  ifelse(gene %in% pnOver6, \\pnOver6\\,\n                         ifelse(gene %in% pnOver4, \\pnOver4\\,\n                                ifelse(gene %in% pnOver2, \\pnOver2\\,\n                                       ifelse(gene %in% pnOver0, \\pnOver0\\, NA)))))) %>%\n  drop_na(pnOver)\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\

alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
############
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))



# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers
resultDir <- here(\../../result\)

temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))


pnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene
pnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene
pnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene
pnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene
pnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \2DOWN\, \0NO\),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  pnOver = ifelse(gene %in% pnOver8, \pnOver8\,
                  ifelse(gene %in% pnOver6, \pnOver6\,
                         ifelse(gene %in% pnOver4, \pnOver4\,
                                ifelse(gene %in% pnOver2, \pnOver2\,
                                       ifelse(gene %in% pnOver0, \pnOver0\, NA)))))) %>%
  drop_na(pnOver)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5hbHBoYSA8LSAwLjA1XG5mY0N1dG9mZiA8LSAwLjVcbmRpZmYuUFJPLkcxLmRUQUcgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMUcyLmRUQUdfRzEuZFRBR192c19HMS5ETVNPX1BST3NlcS50c3ZcXCkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHBhZGogPCBhbHBoYSwgYWJzKHNocmlua2VkX2xvZzJGQykgPiBmY0N1dG9mZilcbmRpZmYuUFJPLkcyLmRUQUcgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMUcyLmRUQUdfRzIuZFRBR192c19HMi5ETVNPX1BST3NlcS50c3ZcXCkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHBhZGogPCBhbHBoYSwgYWJzKHNocmlua2VkX2xvZzJGQykgPiBmY0N1dG9mZilcbmRpZmYuUk5BLkcxLmRUQUcgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHBhZGogPCBhbHBoYSwgYWJzKHNocmlua2VkX2xvZzJGQykgPiBmY0N1dG9mZilcbmRpZmYuUk5BLkcxLmRUQUcubm9GQ2N1dG9mZiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocGFkaiA8IGFscGhhKVxuIyMjIyMjIyMjIyMjXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSlcblxuXG5cbiMgdGVtcDIgY29udGFpbnMgZ2VuZXMgZnJvbSBncm91cCAxLCAyLCA1LCA4IGFuZCBsb29wIGNvdW50c1xuI2NhbGN1bGF0aW5nIGRpZmYgc2NvcmUgYW5kIGxvZzJmYyBkaXN0cmlidXRpb24gYmFzZWQgb24gcC1uIG51bWJlcnNcbnJlc3VsdERpciA8LSBoZXJlKFxcLi4vLi4vcmVzdWx0XFwpXG5cbnRlbXAyIDwtIHJlYWRSRFMoaGVyZShyZXN1bHREaXIsIFxcZ2VuZV9sb29wX2xpbmsucmRzXFwpKVxuXG5cbnBuT3ZlcjggPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsID49IDgpKSRnZW5lXG5wbk92ZXI2IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA2LCB0b3RhbCA8IDgpKSRnZW5lXG5wbk92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA0LCB0b3RhbCA8IDYpKSRnZW5lXG5wbk92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSAyLCB0b3RhbCA8IDQpKSRnZW5lXG5wbk92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA8IDIpKSRnZW5lXG5cblxuXG4jIyBEaXZpZGluZyBnZW5lcyBpbnRvIGdyb3Vwc1xudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZl9kVEFHX0RNU08sIGRpc3RhbmNlLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmZfZFRBR19ETVNPKSxcbiAgICAgICAgICAgIG1lYW5fZGlzdGFuY2UgPSBtZWFuKGRpc3RhbmNlKSxcbiAgICAgICAgICAgIC5ncm91cHMgPSAnZHJvcCcpXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxubWF4TG9nMkZDID0gMlxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHBseXI6Om11dGF0ZShmbGFnID0gaWZlbHNlKGdlbmUgJWluJSBkaWZmLlJOQS5HMS5kVEFHJGVuc2VtYmxfZ2VuZV9pZCwgXFwyRE9XTlxcLCBcXDBOT1xcKSxcbiAgICAgICAgICAgICAgICBtYXhGbGFnID0gKGFicyhzaHJpbmtlZF9sb2cyRkMpID4gbWF4TG9nMkZDKSxcbiAgICAgICAgICAgICAgICBsb2cyZmNNYXggPSBwbWF4KHBtaW4oc2hyaW5rZWRfbG9nMkZDLCBtYXhMb2cyRkMpLCAtbWF4TG9nMkZDKSkgJT4lIFxuICBkcGx5cjo6YXJyYW5nZShmbGFnKSAlPiVcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShcbiAgcG5PdmVyID0gaWZlbHNlKGdlbmUgJWluJSBwbk92ZXI4LCBcXHBuT3ZlcjhcXCxcbiAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcG5PdmVyNiwgXFxwbk92ZXI2XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwbk92ZXI0LCBcXHBuT3ZlcjRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwbk92ZXIyLCBcXHBuT3ZlcjJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcG5PdmVyMCwgXFxwbk92ZXIwXFwsIE5BKSkpKSkpICU+JVxuICBkcm9wX25hKHBuT3ZlcilcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.PRO.G1.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.PRO.G2.dTAG <- fread(here(refDir, \\diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\n############\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1,\n                peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n\n\n# temp2 contains genes from group 1, 2, 5, 8 and loop counts\n#calculating diff score and log2fc distribution based on p-n numbers\nresultDir <- here(\\../../result\\)\n\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\n\npnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene\npnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene\npnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene\npnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene\npnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene\n\n\n\n## Dividing genes into groups\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO),\n            mean_distance = mean(distance),\n            .groups = 'drop')\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nmaxLog2FC = 2\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \\2DOWN\\, \\0NO\\),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag) %>%\n  drop_na(shrinked_log2FC)\n\ntemp <- temp %>% dplyr::mutate(\n  pnOver = ifelse(gene %in% pnOver8, \\pnOver8\\,\n                  ifelse(gene %in% pnOver6, \\pnOver6\\,\n                         ifelse(gene %in% pnOver4, \\pnOver4\\,\n                                ifelse(gene %in% pnOver2, \\pnOver2\\,\n                                       ifelse(gene %in% pnOver0, \\pnOver0\\, NA)))))) %>%\n  drop_na(pnOver)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5hbHBoYSA8LSAwLjA1XG5mY0N1dG9mZiA8LSAwLjVcbmRpZmYuUFJPLkcxLmRUQUcgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMUcyLmRUQUdfRzEuZFRBR192c19HMS5ETVNPX1BST3NlcS50c3ZcXCkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHBhZGogPCBhbHBoYSwgYWJzKHNocmlua2VkX2xvZzJGQykgPiBmY0N1dG9mZilcbmRpZmYuUFJPLkcyLmRUQUcgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMUcyLmRUQUdfRzIuZFRBR192c19HMi5ETVNPX1BST3NlcS50c3ZcXCkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHBhZGogPCBhbHBoYSwgYWJzKHNocmlua2VkX2xvZzJGQykgPiBmY0N1dG9mZilcbmRpZmYuUk5BLkcxLmRUQUcgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHBhZGogPCBhbHBoYSwgYWJzKHNocmlua2VkX2xvZzJGQykgPiBmY0N1dG9mZilcbmRpZmYuUk5BLkcxLmRUQUcubm9GQ2N1dG9mZiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocGFkaiA8IGFscGhhKVxuIyMjIyMjIyMjIyMjXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSlcblxuXG5cbiMgdGVtcDIgY29udGFpbnMgZ2VuZXMgZnJvbSBncm91cCAxLCAyLCA1LCA4IGFuZCBsb29wIGNvdW50c1xuI2NhbGN1bGF0aW5nIGRpZmYgc2NvcmUgYW5kIGxvZzJmYyBkaXN0cmlidXRpb24gYmFzZWQgb24gcC1uIG51bWJlcnNcbnJlc3VsdERpciA8LSBoZXJlKFxcLi4vLi4vcmVzdWx0XFwpXG5cbnRlbXAyIDwtIHJlYWRSRFMoaGVyZShyZXN1bHREaXIsIFxcZ2VuZV9sb29wX2xpbmsucmRzXFwpKVxuXG5cbnBuT3ZlcjggPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsID49IDgpKSRnZW5lXG5wbk92ZXI2IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA2LCB0b3RhbCA8IDgpKSRnZW5lXG5wbk92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA0LCB0b3RhbCA8IDYpKSRnZW5lXG5wbk92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSAyLCB0b3RhbCA8IDQpKSRnZW5lXG5wbk92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA8IDIpKSRnZW5lXG5cblxuXG4jIyBEaXZpZGluZyBnZW5lcyBpbnRvIGdyb3Vwc1xudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZl9kVEFHX0RNU08sIGRpc3RhbmNlLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmZfZFRBR19ETVNPKSxcbiAgICAgICAgICAgIG1lYW5fZGlzdGFuY2UgPSBtZWFuKGRpc3RhbmNlKSxcbiAgICAgICAgICAgIC5ncm91cHMgPSAnZHJvcCcpXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxubWF4TG9nMkZDID0gMlxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHBseXI6Om11dGF0ZShmbGFnID0gaWZlbHNlKGdlbmUgJWluJSBkaWZmLlJOQS5HMS5kVEFHJGVuc2VtYmxfZ2VuZV9pZCwgXFwyRE9XTlxcLCBcXDBOT1xcKSxcbiAgICAgICAgICAgICAgICBtYXhGbGFnID0gKGFicyhzaHJpbmtlZF9sb2cyRkMpID4gbWF4TG9nMkZDKSxcbiAgICAgICAgICAgICAgICBsb2cyZmNNYXggPSBwbWF4KHBtaW4oc2hyaW5rZWRfbG9nMkZDLCBtYXhMb2cyRkMpLCAtbWF4TG9nMkZDKSkgJT4lIFxuICBkcGx5cjo6YXJyYW5nZShmbGFnKSAlPiVcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShcbiAgcG5PdmVyID0gaWZlbHNlKGdlbmUgJWluJSBwbk92ZXI4LCBcXHBuT3ZlcjhcXCxcbiAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcG5PdmVyNiwgXFxwbk92ZXI2XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwbk92ZXI0LCBcXHBuT3ZlcjRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwbk92ZXIyLCBcXHBuT3ZlcjJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcG5PdmVyMCwgXFxwbk92ZXIwXFwsIE5BKSkpKSkpICU+JVxuICBkcm9wX25hKHBuT3ZlcilcbmBgYFxuYGBgIn0= -->

```r
```r
name <- \chromo_cons_annoHierarchy\

alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, \diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
############
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))



# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers
resultDir <- here(\../../result\)

temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))


pnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene
pnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene
pnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene
pnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene
pnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \2DOWN\, \0NO\),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  pnOver = ifelse(gene %in% pnOver8, \pnOver8\,
                  ifelse(gene %in% pnOver6, \pnOver6\,
                         ifelse(gene %in% pnOver4, \pnOver4\,
                                ifelse(gene %in% pnOver2, \pnOver2\,
                                       ifelse(gene %in% pnOver0, \pnOver0\, NA)))))) %>%
  drop_na(pnOver)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Loop number per gene: P-X

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuR09maWdEaXIgPC0gaGVyZShmaWdEaXIsIFwiLi4vR09cIilcbmdldEdPKFwicG5PdmVyOFwiLCBHT2ZpZ0RpciwgcG5PdmVyOClcbmdldEdPKFwicG5PdmVyNlwiLCBHT2ZpZ0RpciwgcG5PdmVyNilcbmdldEdPKFwicG5PdmVyNFwiLCBHT2ZpZ0RpciwgcG5PdmVyNClcbmdldEdPKFwicG5PdmVyMlwiLCBHT2ZpZ0RpciwgcG5PdmVyMilcbmdldEdPKFwicG5PdmVyMFwiLCBHT2ZpZ0RpciwgcG5PdmVyMClcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5HTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcG5PdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKSlcbkdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwbk92ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFwiRU5TRU1CTFwiLCBvbnQgPSBcIkJQXCIpKVxuR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBuT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIikpXG5HTzYuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcG5PdmVyNiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKSlcbkdPOC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwbk92ZXI4LCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFwiRU5TRU1CTFwiLCBvbnQgPSBcIkJQXCIpKVxuXG5cbnN1YnNldDAgPC0gR08wLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcInBuT3ZlcjBcIikgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXCIvXCJcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcIi9cIikpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDIgPC0gR08yLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcInBuT3ZlcjJcIikgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXCIvXCJcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcIi9cIikpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDQgPC0gR080LmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcInBuT3ZlcjRcIikgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXCIvXCJcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcIi9cIikpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDYgPC0gR082LmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcInBuT3ZlcjZcIikgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXCIvXCJcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcIi9cIikpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDggPC0gR084LmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcInBuT3ZlcjhcIikgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXCIvXCJcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcIi9cIikpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcblxuXG5HT2xpc3QgPC0gZmFjdG9yKGMoXCJHTzowMDA2Mzk3XCIsIFwiR086MDAwODM4MFwiLCBcIkdPOjAwMjI2MTNcIiwgXCJHTzowMDM0NDcwXCIsXG4gICAgICAgICAgICAgICAgICAgXCJHTzowMDE2MDU1XCIsIFwiR086MDAwNzM4OVwiLCBcIkdPOjAwNDg1NjJcIiwgXCJHTzowMDQ1MTY1XCIsIFxuICAgICAgICAgICAgICAgICAgIFwiR086MDA3MjAwMVwiLCBcIkdPOjAwMDc1MTdcIiwgXCJHTzowMDQ4NzA1XCIpKVxuXG5kYXRhIDwtIGJpbmRfcm93cyhiaW5kX3Jvd3MoYmluZF9yb3dzKHN1YnNldDAsIHN1YnNldDIpLCBzdWJzZXQ0KSwgc3Vic2V0OCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoSUQgJWluJSBHT2xpc3QpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBEZXNjcmlwdGlvbiwgY29sb3IgPSBwLmFkanVzdCwgc2l6ZSA9IGdyKSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArXG4gIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFwicmVkXCIsIGhpZ2ggPSBcImJsdWVcIiwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuICBzY2FsZV9zaXplX2NvbnRpbnVvdXMocmFuZ2UgPSBjKDAsIDMpKSArXG4gIGxhYnMoeCA9IE5VTEwsIHkgPSBOVUxMKSArXG4gIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuICAgICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgYXhpcyB0aXRsZSBzaXplIChpZiBub3QgcmVtb3ZlZClcbiAgICAgICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBsZWdlbmQgdGV4dCBzaXplXG4gICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgXCIuLlwiLCBcIkdPXCIsIFwiR09fZ3JvdXBzX3BuXCIpXG5oZWlnaHQgPSAyXG53aWR0aCA9IDMuM1xuc3ZnbGl0ZShwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgIn0= -->\n\n```r\nGOfigDir <- here(figDir, \\../GO\\)\ngetGO(\\pnOver8\\, GOfigDir, pnOver8)\ngetGO(\\pnOver6\\, GOfigDir, pnOver6)\ngetGO(\\pnOver4\\, GOfigDir, pnOver4)\ngetGO(\\pnOver2\\, GOfigDir, pnOver2)\ngetGO(\\pnOver0\\, GOfigDir, pnOver0)\n\n#####################\nGO0.df <- as.data.frame(enrichGO(gene = pnOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO2.df <- as.data.frame(enrichGO(gene = pnOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO4.df <- as.data.frame(enrichGO(gene = pnOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO6.df <- as.data.frame(enrichGO(gene = pnOver6, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO8.df <- as.data.frame(enrichGO(gene = pnOver8, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n\n\nsubset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver0\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\nsubset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver2\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\nsubset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver4\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\nsubset6 <- GO6.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver6\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\nsubset8 <- GO8.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver8\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\n\n\nGOlist <- factor(c(\\GO:0006397\\, \\GO:0008380\\, \\GO:0022613\\, \\GO:0034470\\,\n                   \\GO:0016055\\, \\GO:0007389\\, \\GO:0048562\\, \\GO:0045165\\, \n                   \\GO:0072001\\, \\GO:0007517\\, \\GO:0048705\\))\n\ndata <- bind_rows(bind_rows(bind_rows(subset0, subset2), subset4), subset8) %>%\n  dplyr::filter(ID %in% GOlist)\n\np <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + \n  geom_point() + theme_bw() +\n  scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n  scale_size_continuous(range = c(0, 3)) +\n  labs(x = NULL, y = NULL) +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pn\\)\nheight = 2\nwidth = 3.3\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
GOfigDir <- here(figDir, \../GO\)
getGO(\pnOver8\, GOfigDir, pnOver8)
getGO(\pnOver6\, GOfigDir, pnOver6)
getGO(\pnOver4\, GOfigDir, pnOver4)
getGO(\pnOver2\, GOfigDir, pnOver2)
getGO(\pnOver0\, GOfigDir, pnOver0)

#####################
GO0.df <- as.data.frame(enrichGO(gene = pnOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO2.df <- as.data.frame(enrichGO(gene = pnOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO4.df <- as.data.frame(enrichGO(gene = pnOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO6.df <- as.data.frame(enrichGO(gene = pnOver6, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO8.df <- as.data.frame(enrichGO(gene = pnOver8, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))


subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver0\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver2\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver4\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset6 <- GO6.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver6\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset8 <- GO8.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver8\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))


GOlist <- factor(c(\GO:0006397\, \GO:0008380\, \GO:0022613\, \GO:0034470\,
                   \GO:0016055\, \GO:0007389\, \GO:0048562\, \GO:0045165\, 
                   \GO:0072001\, \GO:0007517\, \GO:0048705\))

data <- bind_rows(bind_rows(bind_rows(subset0, subset2), subset4), subset8) %>%
  dplyr::filter(ID %in% GOlist)

p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
  geom_point() + theme_bw() +
  scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
  scale_size_continuous(range = c(0, 3)) +
  labs(x = NULL, y = NULL) +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- here(figDir, \..\, \GO\, \GO_groups_pn\)
height = 2
width = 3.3
svglite(paste0(fileName, \.svg\), height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuR09maWdEaXIgPC0gaGVyZShmaWdEaXIsIFxcLi4vR09cXClcbmdldEdPKFxccG5PdmVyOFxcLCBHT2ZpZ0RpciwgcG5PdmVyOClcbmdldEdPKFxccG5PdmVyNlxcLCBHT2ZpZ0RpciwgcG5PdmVyNilcbmdldEdPKFxccG5PdmVyNFxcLCBHT2ZpZ0RpciwgcG5PdmVyNClcbmdldEdPKFxccG5PdmVyMlxcLCBHT2ZpZ0RpciwgcG5PdmVyMilcbmdldEdPKFxccG5PdmVyMFxcLCBHT2ZpZ0RpciwgcG5PdmVyMClcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5HTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcG5PdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbkdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwbk92ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpKVxuR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBuT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG5HTzYuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcG5PdmVyNiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbkdPOC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwbk92ZXI4LCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpKVxuXG5cbnN1YnNldDAgPC0gR08wLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXHBuT3ZlcjBcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDIgPC0gR08yLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXHBuT3ZlcjJcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDQgPC0gR080LmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXHBuT3ZlcjRcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDYgPC0gR082LmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXHBuT3ZlcjZcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDggPC0gR084LmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXHBuT3ZlcjhcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcblxuXG5HT2xpc3QgPC0gZmFjdG9yKGMoXFxHTzowMDA2Mzk3XFwsIFxcR086MDAwODM4MFxcLCBcXEdPOjAwMjI2MTNcXCwgXFxHTzowMDM0NDcwXFwsXG4gICAgICAgICAgICAgICAgICAgXFxHTzowMDE2MDU1XFwsIFxcR086MDAwNzM4OVxcLCBcXEdPOjAwNDg1NjJcXCwgXFxHTzowMDQ1MTY1XFwsIFxuICAgICAgICAgICAgICAgICAgIFxcR086MDA3MjAwMVxcLCBcXEdPOjAwMDc1MTdcXCwgXFxHTzowMDQ4NzA1XFwpKVxuXG5kYXRhIDwtIGJpbmRfcm93cyhiaW5kX3Jvd3MoYmluZF9yb3dzKHN1YnNldDAsIHN1YnNldDIpLCBzdWJzZXQ0KSwgc3Vic2V0OCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoSUQgJWluJSBHT2xpc3QpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBEZXNjcmlwdGlvbiwgY29sb3IgPSBwLmFkanVzdCwgc2l6ZSA9IGdyKSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArXG4gIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFxccmVkXFwsIGhpZ2ggPSBcXGJsdWVcXCwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuICBzY2FsZV9zaXplX2NvbnRpbnVvdXMocmFuZ2UgPSBjKDAsIDMpKSArXG4gIGxhYnMoeCA9IE5VTEwsIHkgPSBOVUxMKSArXG4gIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuICAgICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgYXhpcyB0aXRsZSBzaXplIChpZiBub3QgcmVtb3ZlZClcbiAgICAgICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBsZWdlbmQgdGV4dCBzaXplXG4gICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgXFwuLlxcLCBcXEdPXFwsIFxcR09fZ3JvdXBzX3BuXFwpXG5oZWlnaHQgPSAyXG53aWR0aCA9IDMuM1xuc3ZnbGl0ZShwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\nGOfigDir <- here(figDir, \\../GO\\)\ngetGO(\\pnOver8\\, GOfigDir, pnOver8)\ngetGO(\\pnOver6\\, GOfigDir, pnOver6)\ngetGO(\\pnOver4\\, GOfigDir, pnOver4)\ngetGO(\\pnOver2\\, GOfigDir, pnOver2)\ngetGO(\\pnOver0\\, GOfigDir, pnOver0)\n\n#####################\nGO0.df <- as.data.frame(enrichGO(gene = pnOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO2.df <- as.data.frame(enrichGO(gene = pnOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO4.df <- as.data.frame(enrichGO(gene = pnOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO6.df <- as.data.frame(enrichGO(gene = pnOver6, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO8.df <- as.data.frame(enrichGO(gene = pnOver8, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n\n\nsubset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver0\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\nsubset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver2\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\nsubset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver4\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\nsubset6 <- GO6.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver6\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\nsubset8 <- GO8.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver8\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\n\n\nGOlist <- factor(c(\\GO:0006397\\, \\GO:0008380\\, \\GO:0022613\\, \\GO:0034470\\,\n                   \\GO:0016055\\, \\GO:0007389\\, \\GO:0048562\\, \\GO:0045165\\, \n                   \\GO:0072001\\, \\GO:0007517\\, \\GO:0048705\\))\n\ndata <- bind_rows(bind_rows(bind_rows(subset0, subset2), subset4), subset8) %>%\n  dplyr::filter(ID %in% GOlist)\n\np <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + \n  geom_point() + theme_bw() +\n  scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n  scale_size_continuous(range = c(0, 3)) +\n  labs(x = NULL, y = NULL) +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pn\\)\nheight = 2\nwidth = 3.3\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuR09maWdEaXIgPC0gaGVyZShmaWdEaXIsIFxcLi4vR09cXClcbmdldEdPKFxccG5PdmVyOFxcLCBHT2ZpZ0RpciwgcG5PdmVyOClcbmdldEdPKFxccG5PdmVyNlxcLCBHT2ZpZ0RpciwgcG5PdmVyNilcbmdldEdPKFxccG5PdmVyNFxcLCBHT2ZpZ0RpciwgcG5PdmVyNClcbmdldEdPKFxccG5PdmVyMlxcLCBHT2ZpZ0RpciwgcG5PdmVyMilcbmdldEdPKFxccG5PdmVyMFxcLCBHT2ZpZ0RpciwgcG5PdmVyMClcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5HTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcG5PdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbkdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwbk92ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpKVxuR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBuT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG5HTzYuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcG5PdmVyNiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbkdPOC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwbk92ZXI4LCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpKVxuXG5cbnN1YnNldDAgPC0gR08wLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXHBuT3ZlcjBcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDIgPC0gR08yLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXHBuT3ZlcjJcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDQgPC0gR080LmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXHBuT3ZlcjRcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDYgPC0gR082LmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXHBuT3ZlcjZcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbnN1YnNldDggPC0gR084LmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXHBuT3ZlcjhcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcblxuXG5HT2xpc3QgPC0gZmFjdG9yKGMoXFxHTzowMDA2Mzk3XFwsIFxcR086MDAwODM4MFxcLCBcXEdPOjAwMjI2MTNcXCwgXFxHTzowMDM0NDcwXFwsXG4gICAgICAgICAgICAgICAgICAgXFxHTzowMDE2MDU1XFwsIFxcR086MDAwNzM4OVxcLCBcXEdPOjAwNDg1NjJcXCwgXFxHTzowMDQ1MTY1XFwsIFxuICAgICAgICAgICAgICAgICAgIFxcR086MDA3MjAwMVxcLCBcXEdPOjAwMDc1MTdcXCwgXFxHTzowMDQ4NzA1XFwpKVxuXG5kYXRhIDwtIGJpbmRfcm93cyhiaW5kX3Jvd3MoYmluZF9yb3dzKHN1YnNldDAsIHN1YnNldDIpLCBzdWJzZXQ0KSwgc3Vic2V0OCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoSUQgJWluJSBHT2xpc3QpXG5cbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBEZXNjcmlwdGlvbiwgY29sb3IgPSBwLmFkanVzdCwgc2l6ZSA9IGdyKSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArXG4gIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFxccmVkXFwsIGhpZ2ggPSBcXGJsdWVcXCwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuICBzY2FsZV9zaXplX2NvbnRpbnVvdXMocmFuZ2UgPSBjKDAsIDMpKSArXG4gIGxhYnMoeCA9IE5VTEwsIHkgPSBOVUxMKSArXG4gIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuICAgICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgYXhpcyB0aXRsZSBzaXplIChpZiBub3QgcmVtb3ZlZClcbiAgICAgICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBsZWdlbmQgdGV4dCBzaXplXG4gICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgXFwuLlxcLCBcXEdPXFwsIFxcR09fZ3JvdXBzX3BuXFwpXG5oZWlnaHQgPSAyXG53aWR0aCA9IDMuM1xuc3ZnbGl0ZShwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
GOfigDir <- here(figDir, \../GO\)
getGO(\pnOver8\, GOfigDir, pnOver8)
getGO(\pnOver6\, GOfigDir, pnOver6)
getGO(\pnOver4\, GOfigDir, pnOver4)
getGO(\pnOver2\, GOfigDir, pnOver2)
getGO(\pnOver0\, GOfigDir, pnOver0)

#####################
GO0.df <- as.data.frame(enrichGO(gene = pnOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO2.df <- as.data.frame(enrichGO(gene = pnOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO4.df <- as.data.frame(enrichGO(gene = pnOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO6.df <- as.data.frame(enrichGO(gene = pnOver6, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO8.df <- as.data.frame(enrichGO(gene = pnOver8, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))


subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver0\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver2\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver4\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset6 <- GO6.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver6\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset8 <- GO8.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver8\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))


GOlist <- factor(c(\GO:0006397\, \GO:0008380\, \GO:0022613\, \GO:0034470\,
                   \GO:0016055\, \GO:0007389\, \GO:0048562\, \GO:0045165\, 
                   \GO:0072001\, \GO:0007517\, \GO:0048705\))

data <- bind_rows(bind_rows(bind_rows(subset0, subset2), subset4), subset8) %>%
  dplyr::filter(ID %in% GOlist)

p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
  geom_point() + theme_bw() +
  scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
  scale_size_continuous(range = c(0, 3)) +
  labs(x = NULL, y = NULL) +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- here(figDir, \..\, \GO\, \GO_groups_pn\)
height = 2
width = 3.3
svglite(paste0(fileName, \.svg\), height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



### dTAG
#### Grouping with P-N number
##### Grouping

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVaMlYwVUhaaGJGZHBiR052ZUNBOExTQm1kVzVqZEdsdmJpaGtZWFJoTENCbmNtOTFjREVzSUdkeWIzVndNaWw3WEc0Z0lHUnBjM1JoYm1ObE1TQThMU0FvWkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHdiazkyWlhJZ1BUMW5jbTkxY0RFcElDa2tiV1ZoYmw5a2FXWm1YM05qYjNKbFhHNGdJR1JwYzNSaGJtTmxNaUE4TFNBb1pHRjBZU0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWh3Yms5MlpYSWdQVDFuY205MWNESXBJQ2trYldWaGJsOWthV1ptWDNOamIzSmxYRzRnSUhkcGJDQThMU0IzYVd4amIzZ3VkR1Z6ZENoa2FYTjBZVzVqWlRFc0lHUnBjM1JoYm1ObE1pbGNiaUFnY21WMGRYSnVLSGRwYkNSd0xuWmhiSFZsS1Z4dWZWeHVYRzV3ZGpBeUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dYQ0p3Yms5MlpYSXdYQ0lzSUZ3aWNHNVBkbVZ5TWx3aUtTd2dOU2xjYm5CMk1qUWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMQ0JjSW5CdVQzWmxjakpjSWl3Z1hDSndiazkyWlhJMFhDSXBMQ0ExS1Z4dWNIWTBOaUE4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEFzSUZ3aWNHNVBkbVZ5TkZ3aUxDQmNJbkJ1VDNabGNqWmNJaWtzSURVcFhHNXdkakE0SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0N3Z1hDSndiazkyWlhJd1hDSXNJRndpY0c1UGRtVnlPRndpS1N3Z05TbGNibkIyTWpnZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xDQmNJbkJ1VDNabGNqSmNJaXdnWENKd2JrOTJaWEk0WENJcExDQTFLVnh1Y0hZME9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXNJRndpY0c1UGRtVnlORndpTENCY0luQnVUM1psY2poY0lpa3NJRFVwWEc1d2RqWTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnWENKd2JrOTJaWEkyWENJc0lGd2ljRzVQZG1WeU9Gd2lLU3dnTlNsY2JseHVYRzV3SUR3dElHZG5jR3h2ZENoMFpXMXdMQ0JoWlhNb2VDQTlJSEJ1VDNabGNpd2dlU0E5SUcxbFlXNWZaR2xtWmw5elkyOXlaU2twSUNzZ1oyVnZiVjkyYVc5c2FXNG9ZV1Z6S0dacGJHd2dQU0J3Yms5MlpYSXBMQ0J6YUc5M0xteGxaMlZ1WkNBOUlFWkJURk5GS1NBclhHNGdJR2RsYjIxZlltOTRjR3h2ZENoM2FXUjBhQ0E5SURBdU1Td2diM1YwYkdsbGNpNXphR0Z3WlNBOUlFNUJLU0FySUhSb1pXMWxYMk5zWVhOemFXTW9LU0FySUZ4dUlDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ2NHNVBkbVZ5S1N3Z1puVnVJRDBnYldWaGJpd2daMlZ2YlNBOUlGd2ljRzlwYm5SY0lpd2djMmhoY0dVZ1BTQXlNU3dnYzJsNlpTQTlJRElzSUdacGJHd2dQU0JjSW5KbFpGd2lMQ0JqYjJ4dmNpQTlJRndpWW14aFkydGNJaWtnSzF4dUlDQm5aVzl0WDJoc2FXNWxLSGxwYm5SbGNtTmxjSFFnUFNBd0xqSXBLMXh1SUNCaGJtNXZkR0YwWlNoY0luUmxlSFJjSWl3Z2VDQTlJREVzSUhrZ1BTQXdMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNJbkIyTURJNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCMk1ESXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hDSndkakkwT2lCY0lpd2dZMjl1ZGxCMllXeDFaU2h3ZGpJMEtTd2dYQ0pjWEc1Y0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ3aWNIWTBOam9nWENJc0lHTnZiblpRZG1Gc2RXVW9jSFkwTmlrc0lGd2lYRnh1WENJc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5CMk5qZzZJRndpTENCamIyNTJVSFpoYkhWbEtIQjJOamdwTENCY0lseGNibHdpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p3ZGpRNE9pQmNJaXdnWTI5dWRsQjJZV3gxWlNod2RqUTRLU3dnWENKY1hHNWNJaXhjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGd2ljSFl5T0RvZ1hDSXNJR052Ym5aUWRtRnNkV1VvY0hZeU9Da3NJRndpWEZ4dVhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQjJNRGc2SUZ3aUxDQmpiMjUyVUhaaGJIVmxLSEIyTURncExDQmNJbHhjYmx3aUtTd2dYRzRnSUNBZ0lDQWdJQ0FnSUdOdmJHOXlJRDBnWENKaWJHRmphMXdpTENCb2FuVnpkQ0E5SURBc0lITnBlbVVnUFNBektWeHVYRzRnSUZ4dVptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGd2laR2xtWmxOamIzSmxYMkpoY25Cc2IzUmZjRzVIY205MWNGOWtWRUZIWDNaelgwUk5VMDljSWlsY2JtaGxhV2RvZENBOExTQXpYRzUzYVdSMGFDQThMU0F6WEc1d2JtY29hR1Z5WlNobWFXZEVhWElzSUhCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWENJdWNHNW5YQ0lwS1N3Z2NtVnpJRDBnTmpBd0xDQjFibWwwSUQwZ1hDSnBibHdpTENCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzV3Y21sdWRDaHdLVnh1WkdWMkxtOW1aaWdwWEc1emRtZHNhWFJsS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGd2lMbk4yWjF3aUtTa3NJQ0JvWldsbmFIUWdQU0JvWldsbmFIUXNJSGRwWkhSb0lEMGdkMmxrZEdncFhHNXdjbWx1ZENod0tWeHVaR1YyTG05bVppZ3BYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocG5PdmVyID09Z3JvdXAxKSApJG1lYW5fZGlmZl9zY29yZVxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocG5PdmVyID09Z3JvdXAyKSApJG1lYW5fZGlmZl9zY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxucHYwMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjJcXCksIDUpXG5wdjI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwbk92ZXIyXFwsIFxccG5PdmVyNFxcKSwgNSlcbnB2NDYgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI2XFwpLCA1KVxucHYwOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjhcXCksIDUpXG5wdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwbk92ZXIyXFwsIFxccG5PdmVyOFxcKSwgNSlcbnB2NDggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI4XFwpLCA1KVxucHY2OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyNlxcLCBcXHBuT3ZlcjhcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBwbk92ZXIsIHkgPSBtZWFuX2RpZmZfc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcG5PdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBuT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMC4yKStcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMCwgbGFiZWwgPSBwYXN0ZTAoXFxwdjAyOiBcXCwgY29udlB2YWx1ZShwdjAyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNDogXFwsIGNvbnZQdmFsdWUocHYyNCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NDY6IFxcLCBjb252UHZhbHVlKHB2NDYpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjY4OiBcXCwgY29udlB2YWx1ZShwdjY4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY0ODogXFwsIGNvbnZQdmFsdWUocHY0OCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBjb252UHZhbHVlKHB2MjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjA4OiBcXCwgY29udlB2YWx1ZShwdjA4KSwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXGRpZmZTY29yZV9iYXJwbG90X3BuR3JvdXBfZFRBR192c19ETVNPXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv02 <- round(getPvalWilcox(temp, \pnOver0\, \pnOver2\), 5)
pv24 <- round(getPvalWilcox(temp, \pnOver2\, \pnOver4\), 5)
pv46 <- round(getPvalWilcox(temp, \pnOver4\, \pnOver6\), 5)
pv08 <- round(getPvalWilcox(temp, \pnOver0\, \pnOver8\), 5)
pv28 <- round(getPvalWilcox(temp, \pnOver2\, \pnOver8\), 5)
pv48 <- round(getPvalWilcox(temp, \pnOver4\, \pnOver8\), 5)
pv68 <- round(getPvalWilcox(temp, \pnOver6\, \pnOver8\), 5)


p <- ggplot(temp, aes(x = pnOver, y = mean_diff_score)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0.2)+
  annotate(\text\, x = 1, y = 0, label = paste0(\pv02: \, convPvalue(pv02), \\n\,
                                                \pv24: \, convPvalue(pv24), \\n\,
                                                \pv46: \, convPvalue(pv46), \\n\,
                                                \pv68: \, convPvalue(pv68), \\n\,
                                                \pv48: \, convPvalue(pv48), \\n\,
                                                \pv28: \, convPvalue(pv28), \\n\,
                                                \pv08: \, convPvalue(pv08), \\n\), 
           color = \black\, hjust = 0, size = 3)

  
fileName <- paste0(\diffScore_barplot_pnGroup_dTAG_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVoyVjBVSFpoYkZkcGJHTnZlQ0E4TFNCbWRXNWpkR2x2Ymloa1lYUmhMQ0JuY205MWNERXNJR2R5YjNWd01pbDdYRzRnSUdScGMzUmhibU5sTVNBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lod2JrOTJaWElnUFQxbmNtOTFjREVwSUNra2JXVmhibDlrYVdabVgzTmpiM0psWEc0Z0lHUnBjM1JoYm1ObE1pQThMU0FvWkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHdiazkyWlhJZ1BUMW5jbTkxY0RJcElDa2tiV1ZoYmw5a2FXWm1YM05qYjNKbFhHNGdJSGRwYkNBOExTQjNhV3hqYjNndWRHVnpkQ2hrYVhOMFlXNWpaVEVzSUdScGMzUmhibU5sTWlsY2JpQWdjbVYwZFhKdUtIZHBiQ1J3TG5aaGJIVmxLVnh1ZlZ4dVhHNXdkakF5SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0N3Z1hGeHdiazkyWlhJd1hGd3NJRnhjY0c1UGRtVnlNbHhjS1N3Z05TbGNibkIyTWpRZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xDQmNYSEJ1VDNabGNqSmNYQ3dnWEZ4d2JrOTJaWEkwWEZ3cExDQTFLVnh1Y0hZME5pQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXNJRnhjY0c1UGRtVnlORnhjTENCY1hIQnVUM1psY2paY1hDa3NJRFVwWEc1d2RqQTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnWEZ4d2JrOTJaWEl3WEZ3c0lGeGNjRzVQZG1WeU9GeGNLU3dnTlNsY2JuQjJNamdnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaDBaVzF3TENCY1hIQnVUM1psY2pKY1hDd2dYRnh3Yms5MlpYSTRYRndwTENBMUtWeHVjSFkwT0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBc0lGeGNjRzVQZG1WeU5GeGNMQ0JjWEhCdVQzWmxjamhjWENrc0lEVXBYRzV3ZGpZNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dYRnh3Yms5MlpYSTJYRndzSUZ4Y2NHNVBkbVZ5T0Z4Y0tTd2dOU2xjYmx4dVhHNXdJRHd0SUdkbmNHeHZkQ2gwWlcxd0xDQmhaWE1vZUNBOUlIQnVUM1psY2l3Z2VTQTlJRzFsWVc1ZlpHbG1abDl6WTI5eVpTa3BJQ3NnWjJWdmJWOTJhVzlzYVc0b1lXVnpLR1pwYkd3Z1BTQndiazkyWlhJcExDQnphRzkzTG14bFoyVnVaQ0E5SUVaQlRGTkZLU0FyWEc0Z0lHZGxiMjFmWW05NGNHeHZkQ2gzYVdSMGFDQTlJREF1TVN3Z2IzVjBiR2xsY2k1emFHRndaU0E5SUU1QktTQXJJSFJvWlcxbFgyTnNZWE56YVdNb0tTQXJJRnh1SUNCemRHRjBYM04xYlcxaGNua29ZV1Z6S0dkeWIzVndJRDBnY0c1UGRtVnlLU3dnWm5WdUlEMGdiV1ZoYml3Z1oyVnZiU0E5SUZ4Y2NHOXBiblJjWEN3Z2MyaGhjR1VnUFNBeU1Td2djMmw2WlNBOUlESXNJR1pwYkd3Z1BTQmNYSEpsWkZ4Y0xDQmpiMnh2Y2lBOUlGeGNZbXhoWTJ0Y1hDa2dLMXh1SUNCblpXOXRYMmhzYVc1bEtIbHBiblJsY21ObGNIUWdQU0F3TGpJcEsxeHVJQ0JoYm01dmRHRjBaU2hjWEhSbGVIUmNYQ3dnZUNBOUlERXNJSGtnUFNBd0xDQnNZV0psYkNBOUlIQmhjM1JsTUNoY1hIQjJNREk2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEIyTURJcExDQmNYRnhjYmx4Y0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWEZ4d2RqSTBPaUJjWEN3Z1kyOXVkbEIyWVd4MVpTaHdkakkwS1N3Z1hGeGNYRzVjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRnhjY0hZME5qb2dYRndzSUdOdmJuWlFkbUZzZFdVb2NIWTBOaWtzSUZ4Y1hGeHVYRndzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEIyTmpnNklGeGNMQ0JqYjI1MlVIWmhiSFZsS0hCMk5qZ3BMQ0JjWEZ4Y2JseGNMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hGeHdkalE0T2lCY1hDd2dZMjl1ZGxCMllXeDFaU2h3ZGpRNEtTd2dYRnhjWEc1Y1hDeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ4Y2NIWXlPRG9nWEZ3c0lHTnZiblpRZG1Gc2RXVW9jSFl5T0Nrc0lGeGNYRnh1WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhCMk1EZzZJRnhjTENCamIyNTJVSFpoYkhWbEtIQjJNRGdwTENCY1hGeGNibHhjS1N3Z1hHNGdJQ0FnSUNBZ0lDQWdJR052Ykc5eUlEMGdYRnhpYkdGamExeGNMQ0JvYW5WemRDQTlJREFzSUhOcGVtVWdQU0F6S1Z4dVhHNGdJRnh1Wm1sc1pVNWhiV1VnUEMwZ2NHRnpkR1V3S0Z4Y1pHbG1abE5qYjNKbFgySmhjbkJzYjNSZmNHNUhjbTkxY0Y5a1ZFRkhYM1p6WDBSTlUwOWNYQ2xjYm1obGFXZG9kQ0E4TFNBelhHNTNhV1IwYUNBOExTQXpYRzV3Ym1jb2FHVnlaU2htYVdkRWFYSXNJSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYRnd1Y0c1blhGd3BLU3dnY21WeklEMGdOakF3TENCMWJtbDBJRDBnWEZ4cGJseGNMQ0JvWldsbmFIUWdQU0JvWldsbmFIUXNJSGRwWkhSb0lEMGdkMmxrZEdncFhHNXdjbWx1ZENod0tWeHVaR1YyTG05bVppZ3BYRzV6ZG1kc2FYUmxLR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ4Y0xuTjJaMXhjS1Nrc0lDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc1d2NtbHVkQ2h3S1Z4dVpHVjJMbTltWmlncFhHNWdZR0JjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbmBgYHJcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocG5PdmVyID09Z3JvdXAxKSApJG1lYW5fZGlmZl9zY29yZVxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocG5PdmVyID09Z3JvdXAyKSApJG1lYW5fZGlmZl9zY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxucHYwMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjJcXCksIDUpXG5wdjI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwbk92ZXIyXFwsIFxccG5PdmVyNFxcKSwgNSlcbnB2NDYgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI2XFwpLCA1KVxucHYwOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjhcXCksIDUpXG5wdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwbk92ZXIyXFwsIFxccG5PdmVyOFxcKSwgNSlcbnB2NDggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI4XFwpLCA1KVxucHY2OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyNlxcLCBcXHBuT3ZlcjhcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBwbk92ZXIsIHkgPSBtZWFuX2RpZmZfc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcG5PdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBuT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMC4yKStcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMCwgbGFiZWwgPSBwYXN0ZTAoXFxwdjAyOiBcXCwgY29udlB2YWx1ZShwdjAyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNDogXFwsIGNvbnZQdmFsdWUocHYyNCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NDY6IFxcLCBjb252UHZhbHVlKHB2NDYpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjY4OiBcXCwgY29udlB2YWx1ZShwdjY4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY0ODogXFwsIGNvbnZQdmFsdWUocHY0OCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBjb252UHZhbHVlKHB2MjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjA4OiBcXCwgY29udlB2YWx1ZShwdjA4KSwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXGRpZmZTY29yZV9iYXJwbG90X3BuR3JvdXBfZFRBR192c19ETVNPXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wdjAyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwbk92ZXIwXFwsIFxccG5PdmVyMlxcKSwgNSlcbnB2MjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI0XFwpLCA1KVxucHY0NiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyNFxcLCBcXHBuT3ZlcjZcXCksIDUpXG5wdjA4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwbk92ZXIwXFwsIFxccG5PdmVyOFxcKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI4XFwpLCA1KVxucHY0OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyNFxcLCBcXHBuT3ZlcjhcXCksIDUpXG5wdjY4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwbk92ZXI2XFwsIFxccG5PdmVyOFxcKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBuT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwbk92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLjIpK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHB2MDI6IFxcLCBjb252UHZhbHVlKHB2MDIpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI0OiBcXCwgY29udlB2YWx1ZShwdjI0KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY0NjogXFwsIGNvbnZQdmFsdWUocHY0NiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Njg6IFxcLCBjb252UHZhbHVlKHB2NjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjQ4OiBcXCwgY29udlB2YWx1ZShwdjQ4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyODogXFwsIGNvbnZQdmFsdWUocHYyOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MDg6IFxcLCBjb252UHZhbHVlKHB2MDgpLCBcXFxcblxcKSwgXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcZGlmZlNjb3JlX2JhcnBsb3RfcG5Hcm91cF9kVEFHX3ZzX0RNU09cXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv02 <- round(getPvalWilcox(temp, \pnOver0\, \pnOver2\), 5)
pv24 <- round(getPvalWilcox(temp, \pnOver2\, \pnOver4\), 5)
pv46 <- round(getPvalWilcox(temp, \pnOver4\, \pnOver6\), 5)
pv08 <- round(getPvalWilcox(temp, \pnOver0\, \pnOver8\), 5)
pv28 <- round(getPvalWilcox(temp, \pnOver2\, \pnOver8\), 5)
pv48 <- round(getPvalWilcox(temp, \pnOver4\, \pnOver8\), 5)
pv68 <- round(getPvalWilcox(temp, \pnOver6\, \pnOver8\), 5)


p <- ggplot(temp, aes(x = pnOver, y = mean_diff_score)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0.2)+
  annotate(\text\, x = 1, y = 0, label = paste0(\pv02: \, convPvalue(pv02), \\n\,
                                                \pv24: \, convPvalue(pv24), \\n\,
                                                \pv46: \, convPvalue(pv46), \\n\,
                                                \pv68: \, convPvalue(pv68), \\n\,
                                                \pv48: \, convPvalue(pv48), \\n\,
                                                \pv28: \, convPvalue(pv28), \\n\,
                                                \pv08: \, convPvalue(pv08), \\n\), 
           color = \black\, hjust = 0, size = 3)

  
fileName <- paste0(\diffScore_barplot_pnGroup_dTAG_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### GO for each group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuI1xuIGdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocG5PdmVyID09Z3JvdXAxKSApJGxvZzJGb2xkQ2hhbmdlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnRlbXBEb3duIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPCAwKVxuIFxucHYwMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjBcIiwgXCJwbk92ZXIyXCIpLCA1KVxucHYwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjBcIiwgXCJwbk92ZXI0XCIpLCA1KVxucHYwNiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjBcIiwgXCJwbk92ZXI2XCIpLCA1KVxucHYwOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjBcIiwgXCJwbk92ZXI4XCIpLCA1KVxucHYyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjJcIiwgXCJwbk92ZXI0XCIpLCA1KVxucHYyNiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjJcIiwgXCJwbk92ZXI2XCIpLCA1KVxucHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjJcIiwgXCJwbk92ZXI4XCIpLCA1KVxucHY0NiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjRcIiwgXCJwbk92ZXI2XCIpLCA1KVxucHY0OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjRcIiwgXCJwbk92ZXI4XCIpLCA1KVxucHY2OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjZcIiwgXCJwbk92ZXI4XCIpLCA1KVxuXG5cblxuXG5wIDwtIGdncGxvdCh0ZW1wRG93biwgYWVzKHggPSBwbk92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwbk92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcInJlZFwiLCBjb2xvciA9IFwiYmxhY2tcIikgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKStcbiAgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAxLCB5ID0gLTAuNSwgbGFiZWwgPSBwYXN0ZTAoXCJwdjAyOiBcIiwgY29udlB2YWx1ZShwdjAyKSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHYwNDogXCIsIGNvbnZQdmFsdWUocHYwNCksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInB2MDY6IFwiLCBjb252UHZhbHVlKHB2MDYpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjA4OiBcIiwgY29udlB2YWx1ZShwdjA4KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHYyNDogXCIsIGNvbnZQdmFsdWUocHYyNCksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInB2MjY6IFwiLCBjb252UHZhbHVlKHB2MjYpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjI4OiBcIiwgY29udlB2YWx1ZShwdjI4KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHY0NjogXCIsIGNvbnZQdmFsdWUocHY0NiksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInB2NDg6IFwiLCBjb252UHZhbHVlKHB2NDgpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjY4OiBcIiwgY29udlB2YWx1ZShwdjY4KSwgXCJcXG5cIiksIFxuICAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMykgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTEsIDApKVxuXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFwibG9nMkZDX2JhcnBsb3RfcG5Hcm91cF9kVEFHX3ZzX0RNU09fZG93blwiKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcblxuXG5cbnRlbXBVcCA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGxvZzJGb2xkQ2hhbmdlID4gMClcbiBcbnB2MDIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFwicG5PdmVyMFwiLCBcInBuT3ZlcjJcIiksIDUpXG5wdjA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBuT3ZlcjBcIiwgXCJwbk92ZXI0XCIpLCA1KVxucHYwNiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXCJwbk92ZXIwXCIsIFwicG5PdmVyNlwiKSwgNSlcbnB2MDggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFwicG5PdmVyMFwiLCBcInBuT3ZlcjhcIiksIDUpXG5wdjI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBuT3ZlcjJcIiwgXCJwbk92ZXI0XCIpLCA1KVxucHYyNiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXCJwbk92ZXIyXCIsIFwicG5PdmVyNlwiKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFwicG5PdmVyMlwiLCBcInBuT3ZlcjhcIiksIDUpXG5wdjQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBuT3ZlcjRcIiwgXCJwbk92ZXI2XCIpLCA1KVxucHY0OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXCJwbk92ZXI0XCIsIFwicG5PdmVyOFwiKSwgNSlcbnB2NjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFwicG5PdmVyNlwiLCBcInBuT3ZlcjhcIiksIDUpXG5cblxuXG5cbnAgPC0gZ2dwbG90KHRlbXBVcCwgYWVzKHggPSBwbk92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwbk92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcInJlZFwiLCBjb2xvciA9IFwiYmxhY2tcIikgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKStcbiAgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAxLCB5ID0gMC41LCBsYWJlbCA9IHBhc3RlMChcInB2MDI6IFwiLCBjb252UHZhbHVlKHB2MDIpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjA0OiBcIiwgY29udlB2YWx1ZShwdjA0KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHYwNjogXCIsIGNvbnZQdmFsdWUocHYwNiksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInB2MDg6IFwiLCBjb252UHZhbHVlKHB2MDgpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjI0OiBcIiwgY29udlB2YWx1ZShwdjI0KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHYyNjogXCIsIGNvbnZQdmFsdWUocHYyNiksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInB2Mjg6IFwiLCBjb252UHZhbHVlKHB2MjgpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjQ2OiBcIiwgY29udlB2YWx1ZShwdjQ2KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHY0ODogXCIsIGNvbnZQdmFsdWUocHY0OCksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInB2Njg6IFwiLCBjb252UHZhbHVlKHB2NjgpLCBcIlxcblwiKSwgXG4gICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygwLCAxKSlcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcImxvZzJGQ19iYXJwbG90X3BuR3JvdXBfZFRBR192c19ETVNPX3VwXCIpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgIn0= -->\n\n```r\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \npv02 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver2\\), 5)\npv04 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver4\\), 5)\npv06 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver6\\), 5)\npv08 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver8\\), 5)\npv24 <- round(getPvalWilcox(tempDown, \\pnOver2\\, \\pnOver4\\), 5)\npv26 <- round(getPvalWilcox(tempDown, \\pnOver2\\, \\pnOver6\\), 5)\npv28 <- round(getPvalWilcox(tempDown, \\pnOver2\\, \\pnOver8\\), 5)\npv46 <- round(getPvalWilcox(tempDown, \\pnOver4\\, \\pnOver6\\), 5)\npv48 <- round(getPvalWilcox(tempDown, \\pnOver4\\, \\pnOver8\\), 5)\npv68 <- round(getPvalWilcox(tempDown, \\pnOver6\\, \\pnOver8\\), 5)\n\n\n\n\np <- ggplot(tempDown, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = pnOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\pv02: \\, convPvalue(pv02), \\\\n\\,\n                                                   \\pv04: \\, convPvalue(pv04), \\\\n\\,\n                                                   \\pv06: \\, convPvalue(pv06), \\\\n\\,\n                                                   \\pv08: \\, convPvalue(pv08), \\\\n\\,\n                                                   \\pv24: \\, convPvalue(pv24), \\\\n\\,\n                                                   \\pv26: \\, convPvalue(pv26), \\\\n\\,\n                                                   \\pv28: \\, convPvalue(pv28), \\\\n\\,\n                                                   \\pv46: \\, convPvalue(pv46), \\\\n\\,\n                                                   \\pv48: \\, convPvalue(pv48), \\\\n\\,\n                                                   \\pv68: \\, convPvalue(pv68), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))\n\n  \nfileName <- paste0(\\log2FC_barplot_pnGroup_dTAG_vs_DMSO_down\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \npv02 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver2\\), 5)\npv04 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver4\\), 5)\npv06 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver6\\), 5)\npv08 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver8\\), 5)\npv24 <- round(getPvalWilcox(tempUp, \\pnOver2\\, \\pnOver4\\), 5)\npv26 <- round(getPvalWilcox(tempUp, \\pnOver2\\, \\pnOver6\\), 5)\npv28 <- round(getPvalWilcox(tempUp, \\pnOver2\\, \\pnOver8\\), 5)\npv46 <- round(getPvalWilcox(tempUp, \\pnOver4\\, \\pnOver6\\), 5)\npv48 <- round(getPvalWilcox(tempUp, \\pnOver4\\, \\pnOver8\\), 5)\npv68 <- round(getPvalWilcox(tempUp, \\pnOver6\\, \\pnOver8\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = pnOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\pv02: \\, convPvalue(pv02), \\\\n\\,\n                                                   \\pv04: \\, convPvalue(pv04), \\\\n\\,\n                                                   \\pv06: \\, convPvalue(pv06), \\\\n\\,\n                                                   \\pv08: \\, convPvalue(pv08), \\\\n\\,\n                                                   \\pv24: \\, convPvalue(pv24), \\\\n\\,\n                                                   \\pv26: \\, convPvalue(pv26), \\\\n\\,\n                                                   \\pv28: \\, convPvalue(pv28), \\\\n\\,\n                                                   \\pv46: \\, convPvalue(pv46), \\\\n\\,\n                                                   \\pv48: \\, convPvalue(pv48), \\\\n\\,\n                                                   \\pv68: \\, convPvalue(pv68), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_pnGroup_dTAG_vs_DMSO_up\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
#
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$log2FoldChange
  distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$log2FoldChange
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
 
pv02 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver2\), 5)
pv04 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver4\), 5)
pv06 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver6\), 5)
pv08 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver8\), 5)
pv24 <- round(getPvalWilcox(tempDown, \pnOver2\, \pnOver4\), 5)
pv26 <- round(getPvalWilcox(tempDown, \pnOver2\, \pnOver6\), 5)
pv28 <- round(getPvalWilcox(tempDown, \pnOver2\, \pnOver8\), 5)
pv46 <- round(getPvalWilcox(tempDown, \pnOver4\, \pnOver6\), 5)
pv48 <- round(getPvalWilcox(tempDown, \pnOver4\, \pnOver8\), 5)
pv68 <- round(getPvalWilcox(tempDown, \pnOver6\, \pnOver8\), 5)




p <- ggplot(tempDown, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)+
  annotate(\text\, x = 1, y = -0.5, label = paste0(\pv02: \, convPvalue(pv02), \\n\,
                                                   \pv04: \, convPvalue(pv04), \\n\,
                                                   \pv06: \, convPvalue(pv06), \\n\,
                                                   \pv08: \, convPvalue(pv08), \\n\,
                                                   \pv24: \, convPvalue(pv24), \\n\,
                                                   \pv26: \, convPvalue(pv26), \\n\,
                                                   \pv28: \, convPvalue(pv28), \\n\,
                                                   \pv46: \, convPvalue(pv46), \\n\,
                                                   \pv48: \, convPvalue(pv48), \\n\,
                                                   \pv68: \, convPvalue(pv68), \\n\), 
           color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0(\log2FC_barplot_pnGroup_dTAG_vs_DMSO_down\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
pv02 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver2\), 5)
pv04 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver4\), 5)
pv06 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver6\), 5)
pv08 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver8\), 5)
pv24 <- round(getPvalWilcox(tempUp, \pnOver2\, \pnOver4\), 5)
pv26 <- round(getPvalWilcox(tempUp, \pnOver2\, \pnOver6\), 5)
pv28 <- round(getPvalWilcox(tempUp, \pnOver2\, \pnOver8\), 5)
pv46 <- round(getPvalWilcox(tempUp, \pnOver4\, \pnOver6\), 5)
pv48 <- round(getPvalWilcox(tempUp, \pnOver4\, \pnOver8\), 5)
pv68 <- round(getPvalWilcox(tempUp, \pnOver6\, \pnOver8\), 5)




p <- ggplot(tempUp, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)+
  annotate(\text\, x = 1, y = 0.5, label = paste0(\pv02: \, convPvalue(pv02), \\n\,
                                                   \pv04: \, convPvalue(pv04), \\n\,
                                                   \pv06: \, convPvalue(pv06), \\n\,
                                                   \pv08: \, convPvalue(pv08), \\n\,
                                                   \pv24: \, convPvalue(pv24), \\n\,
                                                   \pv26: \, convPvalue(pv26), \\n\,
                                                   \pv28: \, convPvalue(pv28), \\n\,
                                                   \pv46: \, convPvalue(pv46), \\n\,
                                                   \pv48: \, convPvalue(pv48), \\n\,
                                                   \pv68: \, convPvalue(pv68), \\n\), 
           color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_pnGroup_dTAG_vs_DMSO_up\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuI1xuIGdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocG5PdmVyID09Z3JvdXAxKSApJGxvZzJGb2xkQ2hhbmdlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnRlbXBEb3duIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPCAwKVxuIFxucHYwMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXIyXFwpLCA1KVxucHYwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI0XFwpLCA1KVxucHYwNiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI2XFwpLCA1KVxucHYwOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI4XFwpLCA1KVxucHYyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI0XFwpLCA1KVxucHYyNiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI2XFwpLCA1KVxucHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI4XFwpLCA1KVxucHY0NiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI2XFwpLCA1KVxucHY0OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI4XFwpLCA1KVxucHY2OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjZcXCwgXFxwbk92ZXI4XFwpLCA1KVxuXG5cblxuXG5wIDwtIGdncGxvdCh0ZW1wRG93biwgYWVzKHggPSBwbk92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwbk92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKStcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gLTAuNSwgbGFiZWwgPSBwYXN0ZTAoXFxwdjAyOiBcXCwgY29udlB2YWx1ZShwdjAyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYwNDogXFwsIGNvbnZQdmFsdWUocHYwNCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MDY6IFxcLCBjb252UHZhbHVlKHB2MDYpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjA4OiBcXCwgY29udlB2YWx1ZShwdjA4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNDogXFwsIGNvbnZQdmFsdWUocHYyNCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjY6IFxcLCBjb252UHZhbHVlKHB2MjYpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgY29udlB2YWx1ZShwdjI4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY0NjogXFwsIGNvbnZQdmFsdWUocHY0NiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NDg6IFxcLCBjb252UHZhbHVlKHB2NDgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjY4OiBcXCwgY29udlB2YWx1ZShwdjY4KSwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTEsIDApKVxuXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcbG9nMkZDX2JhcnBsb3RfcG5Hcm91cF9kVEFHX3ZzX0RNU09fZG93blxcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcblxuXG5cbnRlbXBVcCA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGxvZzJGb2xkQ2hhbmdlID4gMClcbiBcbnB2MDIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjJcXCksIDUpXG5wdjA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI0XFwpLCA1KVxucHYwNiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwbk92ZXIwXFwsIFxccG5PdmVyNlxcKSwgNSlcbnB2MDggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjhcXCksIDUpXG5wdjI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI0XFwpLCA1KVxucHYyNiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwbk92ZXIyXFwsIFxccG5PdmVyNlxcKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccG5PdmVyMlxcLCBcXHBuT3ZlcjhcXCksIDUpXG5wdjQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI2XFwpLCA1KVxucHY0OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwbk92ZXI0XFwsIFxccG5PdmVyOFxcKSwgNSlcbnB2NjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccG5PdmVyNlxcLCBcXHBuT3ZlcjhcXCksIDUpXG5cblxuXG5cbnAgPC0gZ2dwbG90KHRlbXBVcCwgYWVzKHggPSBwbk92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwbk92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKStcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMC41LCBsYWJlbCA9IHBhc3RlMChcXHB2MDI6IFxcLCBjb252UHZhbHVlKHB2MDIpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjA0OiBcXCwgY29udlB2YWx1ZShwdjA0KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYwNjogXFwsIGNvbnZQdmFsdWUocHYwNiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MDg6IFxcLCBjb252UHZhbHVlKHB2MDgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI0OiBcXCwgY29udlB2YWx1ZShwdjI0KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNjogXFwsIGNvbnZQdmFsdWUocHYyNiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBjb252UHZhbHVlKHB2MjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjQ2OiBcXCwgY29udlB2YWx1ZShwdjQ2KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY0ODogXFwsIGNvbnZQdmFsdWUocHY0OCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Njg6IFxcLCBjb252UHZhbHVlKHB2NjgpLCBcXFxcblxcKSwgXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygwLCAxKSlcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXGxvZzJGQ19iYXJwbG90X3BuR3JvdXBfZFRBR192c19ETVNPX3VwXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \npv02 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver2\\), 5)\npv04 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver4\\), 5)\npv06 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver6\\), 5)\npv08 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver8\\), 5)\npv24 <- round(getPvalWilcox(tempDown, \\pnOver2\\, \\pnOver4\\), 5)\npv26 <- round(getPvalWilcox(tempDown, \\pnOver2\\, \\pnOver6\\), 5)\npv28 <- round(getPvalWilcox(tempDown, \\pnOver2\\, \\pnOver8\\), 5)\npv46 <- round(getPvalWilcox(tempDown, \\pnOver4\\, \\pnOver6\\), 5)\npv48 <- round(getPvalWilcox(tempDown, \\pnOver4\\, \\pnOver8\\), 5)\npv68 <- round(getPvalWilcox(tempDown, \\pnOver6\\, \\pnOver8\\), 5)\n\n\n\n\np <- ggplot(tempDown, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = pnOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\pv02: \\, convPvalue(pv02), \\\\n\\,\n                                                   \\pv04: \\, convPvalue(pv04), \\\\n\\,\n                                                   \\pv06: \\, convPvalue(pv06), \\\\n\\,\n                                                   \\pv08: \\, convPvalue(pv08), \\\\n\\,\n                                                   \\pv24: \\, convPvalue(pv24), \\\\n\\,\n                                                   \\pv26: \\, convPvalue(pv26), \\\\n\\,\n                                                   \\pv28: \\, convPvalue(pv28), \\\\n\\,\n                                                   \\pv46: \\, convPvalue(pv46), \\\\n\\,\n                                                   \\pv48: \\, convPvalue(pv48), \\\\n\\,\n                                                   \\pv68: \\, convPvalue(pv68), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))\n\n  \nfileName <- paste0(\\log2FC_barplot_pnGroup_dTAG_vs_DMSO_down\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \npv02 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver2\\), 5)\npv04 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver4\\), 5)\npv06 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver6\\), 5)\npv08 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver8\\), 5)\npv24 <- round(getPvalWilcox(tempUp, \\pnOver2\\, \\pnOver4\\), 5)\npv26 <- round(getPvalWilcox(tempUp, \\pnOver2\\, \\pnOver6\\), 5)\npv28 <- round(getPvalWilcox(tempUp, \\pnOver2\\, \\pnOver8\\), 5)\npv46 <- round(getPvalWilcox(tempUp, \\pnOver4\\, \\pnOver6\\), 5)\npv48 <- round(getPvalWilcox(tempUp, \\pnOver4\\, \\pnOver8\\), 5)\npv68 <- round(getPvalWilcox(tempUp, \\pnOver6\\, \\pnOver8\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = pnOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\pv02: \\, convPvalue(pv02), \\\\n\\,\n                                                   \\pv04: \\, convPvalue(pv04), \\\\n\\,\n                                                   \\pv06: \\, convPvalue(pv06), \\\\n\\,\n                                                   \\pv08: \\, convPvalue(pv08), \\\\n\\,\n                                                   \\pv24: \\, convPvalue(pv24), \\\\n\\,\n                                                   \\pv26: \\, convPvalue(pv26), \\\\n\\,\n                                                   \\pv28: \\, convPvalue(pv28), \\\\n\\,\n                                                   \\pv46: \\, convPvalue(pv46), \\\\n\\,\n                                                   \\pv48: \\, convPvalue(pv48), \\\\n\\,\n                                                   \\pv68: \\, convPvalue(pv68), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_pnGroup_dTAG_vs_DMSO_up\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuI1xuIGdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocG5PdmVyID09Z3JvdXAxKSApJGxvZzJGb2xkQ2hhbmdlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnRlbXBEb3duIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPCAwKVxuIFxucHYwMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXIyXFwpLCA1KVxucHYwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI0XFwpLCA1KVxucHYwNiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI2XFwpLCA1KVxucHYwOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI4XFwpLCA1KVxucHYyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI0XFwpLCA1KVxucHYyNiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI2XFwpLCA1KVxucHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI4XFwpLCA1KVxucHY0NiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI2XFwpLCA1KVxucHY0OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI4XFwpLCA1KVxucHY2OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjZcXCwgXFxwbk92ZXI4XFwpLCA1KVxuXG5cblxuXG5wIDwtIGdncGxvdCh0ZW1wRG93biwgYWVzKHggPSBwbk92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwbk92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKStcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gLTAuNSwgbGFiZWwgPSBwYXN0ZTAoXFxwdjAyOiBcXCwgY29udlB2YWx1ZShwdjAyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYwNDogXFwsIGNvbnZQdmFsdWUocHYwNCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MDY6IFxcLCBjb252UHZhbHVlKHB2MDYpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjA4OiBcXCwgY29udlB2YWx1ZShwdjA4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNDogXFwsIGNvbnZQdmFsdWUocHYyNCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjY6IFxcLCBjb252UHZhbHVlKHB2MjYpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgY29udlB2YWx1ZShwdjI4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY0NjogXFwsIGNvbnZQdmFsdWUocHY0NiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NDg6IFxcLCBjb252UHZhbHVlKHB2NDgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjY4OiBcXCwgY29udlB2YWx1ZShwdjY4KSwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTEsIDApKVxuXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcbG9nMkZDX2JhcnBsb3RfcG5Hcm91cF9kVEFHX3ZzX0RNU09fZG93blxcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcblxuXG5cbnRlbXBVcCA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGxvZzJGb2xkQ2hhbmdlID4gMClcbiBcbnB2MDIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjJcXCksIDUpXG5wdjA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI0XFwpLCA1KVxucHYwNiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwbk92ZXIwXFwsIFxccG5PdmVyNlxcKSwgNSlcbnB2MDggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjhcXCksIDUpXG5wdjI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI0XFwpLCA1KVxucHYyNiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwbk92ZXIyXFwsIFxccG5PdmVyNlxcKSwgNSlcbnB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccG5PdmVyMlxcLCBcXHBuT3ZlcjhcXCksIDUpXG5wdjQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI2XFwpLCA1KVxucHY0OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwbk92ZXI0XFwsIFxccG5PdmVyOFxcKSwgNSlcbnB2NjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccG5PdmVyNlxcLCBcXHBuT3ZlcjhcXCksIDUpXG5cblxuXG5cbnAgPC0gZ2dwbG90KHRlbXBVcCwgYWVzKHggPSBwbk92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwbk92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKStcbiAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMC41LCBsYWJlbCA9IHBhc3RlMChcXHB2MDI6IFxcLCBjb252UHZhbHVlKHB2MDIpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjA0OiBcXCwgY29udlB2YWx1ZShwdjA0KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYwNjogXFwsIGNvbnZQdmFsdWUocHYwNiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MDg6IFxcLCBjb252UHZhbHVlKHB2MDgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI0OiBcXCwgY29udlB2YWx1ZShwdjI0KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNjogXFwsIGNvbnZQdmFsdWUocHYyNiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBjb252UHZhbHVlKHB2MjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjQ2OiBcXCwgY29udlB2YWx1ZShwdjQ2KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY0ODogXFwsIGNvbnZQdmFsdWUocHY0OCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Njg6IFxcLCBjb252UHZhbHVlKHB2NjgpLCBcXFxcblxcKSwgXG4gICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygwLCAxKSlcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXGxvZzJGQ19iYXJwbG90X3BuR3JvdXBfZFRBR192c19ETVNPX3VwXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
#
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$log2FoldChange
  distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$log2FoldChange
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
 
pv02 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver2\), 5)
pv04 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver4\), 5)
pv06 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver6\), 5)
pv08 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver8\), 5)
pv24 <- round(getPvalWilcox(tempDown, \pnOver2\, \pnOver4\), 5)
pv26 <- round(getPvalWilcox(tempDown, \pnOver2\, \pnOver6\), 5)
pv28 <- round(getPvalWilcox(tempDown, \pnOver2\, \pnOver8\), 5)
pv46 <- round(getPvalWilcox(tempDown, \pnOver4\, \pnOver6\), 5)
pv48 <- round(getPvalWilcox(tempDown, \pnOver4\, \pnOver8\), 5)
pv68 <- round(getPvalWilcox(tempDown, \pnOver6\, \pnOver8\), 5)




p <- ggplot(tempDown, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)+
  annotate(\text\, x = 1, y = -0.5, label = paste0(\pv02: \, convPvalue(pv02), \\n\,
                                                   \pv04: \, convPvalue(pv04), \\n\,
                                                   \pv06: \, convPvalue(pv06), \\n\,
                                                   \pv08: \, convPvalue(pv08), \\n\,
                                                   \pv24: \, convPvalue(pv24), \\n\,
                                                   \pv26: \, convPvalue(pv26), \\n\,
                                                   \pv28: \, convPvalue(pv28), \\n\,
                                                   \pv46: \, convPvalue(pv46), \\n\,
                                                   \pv48: \, convPvalue(pv48), \\n\,
                                                   \pv68: \, convPvalue(pv68), \\n\), 
           color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0(\log2FC_barplot_pnGroup_dTAG_vs_DMSO_down\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
pv02 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver2\), 5)
pv04 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver4\), 5)
pv06 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver6\), 5)
pv08 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver8\), 5)
pv24 <- round(getPvalWilcox(tempUp, \pnOver2\, \pnOver4\), 5)
pv26 <- round(getPvalWilcox(tempUp, \pnOver2\, \pnOver6\), 5)
pv28 <- round(getPvalWilcox(tempUp, \pnOver2\, \pnOver8\), 5)
pv46 <- round(getPvalWilcox(tempUp, \pnOver4\, \pnOver6\), 5)
pv48 <- round(getPvalWilcox(tempUp, \pnOver4\, \pnOver8\), 5)
pv68 <- round(getPvalWilcox(tempUp, \pnOver6\, \pnOver8\), 5)




p <- ggplot(tempUp, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)+
  annotate(\text\, x = 1, y = 0.5, label = paste0(\pv02: \, convPvalue(pv02), \\n\,
                                                   \pv04: \, convPvalue(pv04), \\n\,
                                                   \pv06: \, convPvalue(pv06), \\n\,
                                                   \pv08: \, convPvalue(pv08), \\n\,
                                                   \pv24: \, convPvalue(pv24), \\n\,
                                                   \pv26: \, convPvalue(pv26), \\n\,
                                                   \pv28: \, convPvalue(pv28), \\n\,
                                                   \pv46: \, convPvalue(pv46), \\n\,
                                                   \pv48: \, convPvalue(pv48), \\n\,
                                                   \pv68: \, convPvalue(pv68), \\n\), 
           color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_pnGroup_dTAG_vs_DMSO_up\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



##### loop score

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUIwWlcxd01pQmpiMjUwWVdsdWN5Qm5aVzVsY3lCbWNtOXRJR2R5YjNWd0lERXNJRElzSURVc0lEZ2dZVzVrSUd4dmIzQWdZMjkxYm5SelhHNGpZMkZzWTNWc1lYUnBibWNnWkdsbVppQnpZMjl5WlNCaGJtUWdiRzluTW1aaklHUnBjM1J5YVdKMWRHbHZiaUJpWVhObFpDQnZiaUJ3TFc0Z2JuVnRZbVZ5YzF4dVhHNXdjMDkyWlhJMElEd3RJQ2gwWlcxd01pQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHVkVzFmY0hNZ1BqMGdOQ2twSkdkbGJtVmNibkJ6VDNabGNqTWdQQzBnS0hSbGJYQXlJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRzUxYlY5d2N5QStQU0F6TENCdWRXMWZjSE1nUENBMEtTa2taMlZ1WlZ4dWNITlBkbVZ5TWlBOExTQW9kR1Z0Y0RJZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb2JuVnRYM0J6SUQ0OUlESXNJRzUxYlY5d2N5QThJRE1wS1NSblpXNWxYRzV3YzA5MlpYSXhJRHd0SUNoMFpXMXdNaUFsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWh1ZFcxZmNITWdQajBnTVN3Z2JuVnRYM0J6SUR3Z01pa3BKR2RsYm1WY2JuQnpUM1psY2pBZ1BDMGdLSFJsYlhBeUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHNTFiVjl3Y3lBOElERXBLU1JuWlc1bFhHNWNibHh1WEc0akl5QkVhWFpwWkdsdVp5Qm5aVzVsY3lCcGJuUnZJR2R5YjNWd2MxeHVkR1Z0Y0NBOExTQm5aVzVsUVc1dWIwUmhkR0VnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWkdsbVpsOWtWRUZIWDBSTlUwOHNJR1JwYzNSaGJtTmxMQ0JuWlc1bEtTQWxQaVVnWEc0Z0lIVnVibVZ6ZENoblpXNWxLU0FsUGlVZ1ozSnZkWEJmWW5rb1oyVnVaU2tnSlQ0bFhHNGdJSE4xYlcxaGNtbDZaU2h0WldGdVgyUnBabVpmYzJOdmNtVWdQU0J0WldGdUtHUnBabVpmWkZSQlIxOUVUVk5QS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJRzFsWVc1ZlpHbHpkR0Z1WTJVZ1BTQnRaV0Z1S0dScGMzUmhibU5sS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQzVuY205MWNITWdQU0FuWkhKdmNDY3BYRzVjYm1ScFptWXVVazVCSUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNJbVJwWm1aZlJ6RXVaRlJCUjE5SE1TNHlhUzVrVkVGSFgzWnpYMGN4TGpKcExrUk5VMDh1ZEhOMlhDSXBLU0FsUGlWY2JpQWdaSEJzZVhJNk9uTmxiR1ZqZENobGJuTmxiV0pzWDJkbGJtVmZhV1FzSUd4dlp6SkdiMnhrUTJoaGJtZGxMQ0J6YUhKcGJtdGxaRjlzYjJjeVJrTXNJSEJoWkdvc0lHVjRkR1Z5Ym1Gc1gyZGxibVZmYm1GdFpTbGNibHh1YldGNFRHOW5Na1pESUQwZ01seHVYRzUwWlcxd0lEd3RJR3hsWm5SZmFtOXBiaWgwWlcxd0xDQmthV1ptTGxKT1FTd2dZbmtnUFNCaktGd2laMlZ1WlZ3aUlEMGdYQ0psYm5ObGJXSnNYMmRsYm1WZmFXUmNJaWtwSUNVK0pTQmNiaUFnWkhCc2VYSTZPbTExZEdGMFpTaG1iR0ZuSUQwZ2FXWmxiSE5sS0dkbGJtVWdKV2x1SlNCa2FXWm1MbEpPUVM1SE1TNWtWRUZISkdWdWMyVnRZbXhmWjJWdVpWOXBaQ3dnWENJeVJFOVhUbHdpTENCY0lqQk9UMXdpS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCdFlYaEdiR0ZuSUQwZ0tHRmljeWh6YUhKcGJtdGxaRjlzYjJjeVJrTXBJRDRnYldGNFRHOW5Na1pES1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCc2IyY3labU5OWVhnZ1BTQndiV0Y0S0hCdGFXNG9jMmh5YVc1clpXUmZiRzluTWtaRExDQnRZWGhNYjJjeVJrTXBMQ0F0YldGNFRHOW5Na1pES1NrZ0pUNGxJRnh1SUNCa2NHeDVjam82WVhKeVlXNW5aU2htYkdGbktTQWxQaVZjYmlBZ1pISnZjRjl1WVNoemFISnBibXRsWkY5c2IyY3lSa01wWEc1Y2JuUmxiWEFnUEMwZ2RHVnRjQ0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hjYmlBZ2NITlBkbVZ5SUQwZ2FXWmxiSE5sS0dkbGJtVWdKV2x1SlNCd2MwOTJaWEkwTENCY0luQnpUM1psY2pSY0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaG5aVzVsSUNWcGJpVWdjSE5QZG1WeU15d2dYQ0p3YzA5MlpYSXpYQ0lzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3YzA5MlpYSXlMQ0JjSW5CelQzWmxjakpjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3YzA5MlpYSXhMQ0JjSW5CelQzWmxjakZjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaG5aVzVsSUNWcGJpVWdjSE5QZG1WeU1Dd2dYQ0p3YzA5MlpYSXdYQ0lzSUU1QktTa3BLU2twSUNVK0pWeHVJQ0JrY205d1gyNWhLSEJ6VDNabGNpbGNibHh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbiMgdGVtcDIgY29udGFpbnMgZ2VuZXMgZnJvbSBncm91cCAxLCAyLCA1LCA4IGFuZCBsb29wIGNvdW50c1xuI2NhbGN1bGF0aW5nIGRpZmYgc2NvcmUgYW5kIGxvZzJmYyBkaXN0cmlidXRpb24gYmFzZWQgb24gcC1uIG51bWJlcnNcblxucHNPdmVyNCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDQpKSRnZW5lXG5wc092ZXIzIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMywgbnVtX3BzIDwgNCkpJGdlbmVcbnBzT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAyLCBudW1fcHMgPCAzKSkkZ2VuZVxucHNPdmVyMSA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDEsIG51bV9wcyA8IDIpKSRnZW5lXG5wc092ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPCAxKSkkZ2VuZVxuXG5cblxuIyMgRGl2aWRpbmcgZ2VuZXMgaW50byBncm91cHNcbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmZfZFRBR19ETVNPLCBkaXN0YW5jZSwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmX2RUQUdfRE1TTyksXG4gICAgICAgICAgICBtZWFuX2Rpc3RhbmNlID0gbWVhbihkaXN0YW5jZSksXG4gICAgICAgICAgICAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibF9nZW5lX2lkLCBsb2cyRm9sZENoYW5nZSwgc2hyaW5rZWRfbG9nMkZDLCBwYWRqLCBleHRlcm5hbF9nZW5lX25hbWUpXG5cbm1heExvZzJGQyA9IDJcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcXGdlbmVcXCA9IFxcZW5zZW1ibF9nZW5lX2lkXFwpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoZmxhZyA9IGlmZWxzZShnZW5lICVpbiUgZGlmZi5STkEuRzEuZFRBRyRlbnNlbWJsX2dlbmVfaWQsIFxcMkRPV05cXCwgXFwwTk9cXCksXG4gICAgICAgICAgICAgICAgbWF4RmxhZyA9IChhYnMoc2hyaW5rZWRfbG9nMkZDKSA+IG1heExvZzJGQyksXG4gICAgICAgICAgICAgICAgbG9nMmZjTWF4ID0gcG1heChwbWluKHNocmlua2VkX2xvZzJGQywgbWF4TG9nMkZDKSwgLW1heExvZzJGQykpICU+JSBcbiAgZHBseXI6OmFycmFuZ2UoZmxhZykgJT4lXG4gIGRyb3BfbmEoc2hyaW5rZWRfbG9nMkZDKVxuXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBzT3ZlciA9IGlmZWxzZShnZW5lICVpbiUgcHNPdmVyNCwgXFxwc092ZXI0XFwsXG4gICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjMsIFxccHNPdmVyM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMiwgXFxwc092ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMSwgXFxwc092ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjAsIFxccHNPdmVyMFxcLCBOQSkpKSkpKSAlPiVcbiAgZHJvcF9uYShwc092ZXIpXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \2DOWN\, \0NO\),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  psOver = ifelse(gene %in% psOver4, \psOver4\,
                  ifelse(gene %in% psOver3, \psOver3\,
                         ifelse(gene %in% psOver2, \psOver2\,
                                ifelse(gene %in% psOver1, \psOver1\,
                                       ifelse(gene %in% psOver0, \psOver0\, NA)))))) %>%
  drop_na(psOver)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QjBaVzF3TWlCamIyNTBZV2x1Y3lCblpXNWxjeUJtY205dElHZHliM1Z3SURFc0lESXNJRFVzSURnZ1lXNWtJR3h2YjNBZ1kyOTFiblJ6WEc0alkyRnNZM1ZzWVhScGJtY2daR2xtWmlCelkyOXlaU0JoYm1RZ2JHOW5NbVpqSUdScGMzUnlhV0oxZEdsdmJpQmlZWE5sWkNCdmJpQndMVzRnYm5WdFltVnljMXh1WEc1d2MwOTJaWEkwSUR3dElDaDBaVzF3TWlBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lodWRXMWZjSE1nUGowZ05Da3BKR2RsYm1WY2JuQnpUM1psY2pNZ1BDMGdLSFJsYlhBeUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHNTFiVjl3Y3lBK1BTQXpMQ0J1ZFcxZmNITWdQQ0EwS1Nra1oyVnVaVnh1Y0hOUGRtVnlNaUE4TFNBb2RHVnRjRElnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvYm5WdFgzQnpJRDQ5SURJc0lHNTFiVjl3Y3lBOElETXBLU1JuWlc1bFhHNXdjMDkyWlhJeElEd3RJQ2gwWlcxd01pQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHVkVzFmY0hNZ1BqMGdNU3dnYm5WdFgzQnpJRHdnTWlrcEpHZGxibVZjYm5CelQzWmxjakFnUEMwZ0tIUmxiWEF5SUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0c1MWJWOXdjeUE4SURFcEtTUm5aVzVsWEc1Y2JseHVYRzRqSXlCRWFYWnBaR2x1WnlCblpXNWxjeUJwYm5SdklHZHliM1Z3YzF4dWRHVnRjQ0E4TFNCblpXNWxRVzV1YjBSaGRHRWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aR2xtWmw5a1ZFRkhYMFJOVTA4c0lHUnBjM1JoYm1ObExDQm5aVzVsS1NBbFBpVWdYRzRnSUhWdWJtVnpkQ2huWlc1bEtTQWxQaVVnWjNKdmRYQmZZbmtvWjJWdVpTa2dKVDRsWEc0Z0lITjFiVzFoY21sNlpTaHRaV0Z1WDJScFptWmZjMk52Y21VZ1BTQnRaV0Z1S0dScFptWmZaRlJCUjE5RVRWTlBLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lHMWxZVzVmWkdsemRHRnVZMlVnUFNCdFpXRnVLR1JwYzNSaGJtTmxLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDNW5jbTkxY0hNZ1BTQW5aSEp2Y0NjcFhHNWNibVJwWm1ZdVVrNUJJRHd0SUdaeVpXRmtLR2hsY21Vb2NtVm1SR2x5TENCY1hHUnBabVpmUnpFdVpGUkJSMTlITVM0eWFTNWtWRUZIWDNaelgwY3hMakpwTGtSTlUwOHVkSE4yWEZ3cEtTQWxQaVZjYmlBZ1pIQnNlWEk2T25ObGJHVmpkQ2hsYm5ObGJXSnNYMmRsYm1WZmFXUXNJR3h2WnpKR2IyeGtRMmhoYm1kbExDQnphSEpwYm10bFpGOXNiMmN5UmtNc0lIQmhaR29zSUdWNGRHVnlibUZzWDJkbGJtVmZibUZ0WlNsY2JseHViV0Y0VEc5bk1rWkRJRDBnTWx4dVhHNTBaVzF3SUR3dElHeGxablJmYW05cGJpaDBaVzF3TENCa2FXWm1MbEpPUVN3Z1lua2dQU0JqS0Z4Y1oyVnVaVnhjSUQwZ1hGeGxibk5sYldKc1gyZGxibVZmYVdSY1hDa3BJQ1UrSlNCY2JpQWdaSEJzZVhJNk9tMTFkR0YwWlNobWJHRm5JRDBnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0JrYVdabUxsSk9RUzVITVM1a1ZFRkhKR1Z1YzJWdFlteGZaMlZ1WlY5cFpDd2dYRnd5UkU5WFRseGNMQ0JjWERCT1QxeGNLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J0WVhoR2JHRm5JRDBnS0dGaWN5aHphSEpwYm10bFpGOXNiMmN5UmtNcElENGdiV0Y0VEc5bk1rWkRLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JzYjJjeVptTk5ZWGdnUFNCd2JXRjRLSEJ0YVc0b2MyaHlhVzVyWldSZmJHOW5Na1pETENCdFlYaE1iMmN5UmtNcExDQXRiV0Y0VEc5bk1rWkRLU2tnSlQ0bElGeHVJQ0JrY0d4NWNqbzZZWEp5WVc1blpTaG1iR0ZuS1NBbFBpVmNiaUFnWkhKdmNGOXVZU2h6YUhKcGJtdGxaRjlzYjJjeVJrTXBYRzVjYm5SbGJYQWdQQzBnZEdWdGNDQWxQaVVnWkhCc2VYSTZPbTExZEdGMFpTaGNiaUFnY0hOUGRtVnlJRDBnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3YzA5MlpYSTBMQ0JjWEhCelQzWmxjalJjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNoblpXNWxJQ1ZwYmlVZ2NITlBkbVZ5TXl3Z1hGeHdjMDkyWlhJelhGd3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHZGxibVVnSldsdUpTQndjMDkyWlhJeUxDQmNYSEJ6VDNabGNqSmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHZGxibVVnSldsdUpTQndjMDkyWlhJeExDQmNYSEJ6VDNabGNqRmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNoblpXNWxJQ1ZwYmlVZ2NITlBkbVZ5TUN3Z1hGeHdjMDkyWlhJd1hGd3NJRTVCS1NrcEtTa3BJQ1UrSlZ4dUlDQmtjbTl3WDI1aEtIQnpUM1psY2lsY2JseHVZR0JnWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5gYGByXG4jIHRlbXAyIGNvbnRhaW5zIGdlbmVzIGZyb20gZ3JvdXAgMSwgMiwgNSwgOCBhbmQgbG9vcCBjb3VudHNcbiNjYWxjdWxhdGluZyBkaWZmIHNjb3JlIGFuZCBsb2cyZmMgZGlzdHJpYnV0aW9uIGJhc2VkIG9uIHAtbiBudW1iZXJzXG5cbnBzT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSA0KSkkZ2VuZVxucHNPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDMsIG51bV9wcyA8IDQpKSRnZW5lXG5wc092ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMiwgbnVtX3BzIDwgMykpJGdlbmVcbnBzT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAxLCBudW1fcHMgPCAyKSkkZ2VuZVxucHNPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzIDwgMSkpJGdlbmVcblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX2RUQUdfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9kVEFHX0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGZsYWcgPSBpZmVsc2UoZ2VuZSAlaW4lIGRpZmYuUk5BLkcxLmRUQUckZW5zZW1ibF9nZW5lX2lkLCBcXDJET1dOXFwsIFxcME5PXFwpLFxuICAgICAgICAgICAgICAgIG1heEZsYWcgPSAoYWJzKHNocmlua2VkX2xvZzJGQykgPiBtYXhMb2cyRkMpLFxuICAgICAgICAgICAgICAgIGxvZzJmY01heCA9IHBtYXgocG1pbihzaHJpbmtlZF9sb2cyRkMsIG1heExvZzJGQyksIC1tYXhMb2cyRkMpKSAlPiUgXG4gIGRwbHlyOjphcnJhbmdlKGZsYWcpICU+JVxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6bXV0YXRlKFxuICBwc092ZXIgPSBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjQsIFxccHNPdmVyNFxcLFxuICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIzLCBcXHBzT3ZlcjNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjIsIFxccHNPdmVyMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjEsIFxccHNPdmVyMVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIwLCBcXHBzT3ZlcjBcXCwgTkEpKSkpKSkgJT4lXG4gIGRyb3BfbmEocHNPdmVyKVxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyB0ZW1wMiBjb250YWlucyBnZW5lcyBmcm9tIGdyb3VwIDEsIDIsIDUsIDggYW5kIGxvb3AgY291bnRzXG4jY2FsY3VsYXRpbmcgZGlmZiBzY29yZSBhbmQgbG9nMmZjIGRpc3RyaWJ1dGlvbiBiYXNlZCBvbiBwLW4gbnVtYmVyc1xuXG5wc092ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gNCkpJGdlbmVcbnBzT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAzLCBudW1fcHMgPCA0KSkkZ2VuZVxucHNPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDIsIG51bV9wcyA8IDMpKSRnZW5lXG5wc092ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMSwgbnVtX3BzIDwgMikpJGdlbmVcbnBzT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA8IDEpKSRnZW5lXG5cblxuXG4jIyBEaXZpZGluZyBnZW5lcyBpbnRvIGdyb3Vwc1xudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZl9kVEFHX0RNU08sIGRpc3RhbmNlLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmZfZFRBR19ETVNPKSxcbiAgICAgICAgICAgIG1lYW5fZGlzdGFuY2UgPSBtZWFuKGRpc3RhbmNlKSxcbiAgICAgICAgICAgIC5ncm91cHMgPSAnZHJvcCcpXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxubWF4TG9nMkZDID0gMlxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHBseXI6Om11dGF0ZShmbGFnID0gaWZlbHNlKGdlbmUgJWluJSBkaWZmLlJOQS5HMS5kVEFHJGVuc2VtYmxfZ2VuZV9pZCwgXFwyRE9XTlxcLCBcXDBOT1xcKSxcbiAgICAgICAgICAgICAgICBtYXhGbGFnID0gKGFicyhzaHJpbmtlZF9sb2cyRkMpID4gbWF4TG9nMkZDKSxcbiAgICAgICAgICAgICAgICBsb2cyZmNNYXggPSBwbWF4KHBtaW4oc2hyaW5rZWRfbG9nMkZDLCBtYXhMb2cyRkMpLCAtbWF4TG9nMkZDKSkgJT4lIFxuICBkcGx5cjo6YXJyYW5nZShmbGFnKSAlPiVcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShcbiAgcHNPdmVyID0gaWZlbHNlKGdlbmUgJWluJSBwc092ZXI0LCBcXHBzT3ZlcjRcXCxcbiAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMywgXFxwc092ZXIzXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIyLCBcXHBzT3ZlcjJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIxLCBcXHBzT3ZlcjFcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMCwgXFxwc092ZXIwXFwsIE5BKSkpKSkpICU+JVxuICBkcm9wX25hKHBzT3ZlcilcblxuYGBgXG5gYGAifQ== -->

```r
```r
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \2DOWN\, \0NO\),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  psOver = ifelse(gene %in% psOver4, \psOver4\,
                  ifelse(gene %in% psOver3, \psOver3\,
                         ifelse(gene %in% psOver2, \psOver2\,
                                ifelse(gene %in% psOver1, \psOver1\,
                                       ifelse(gene %in% psOver0, \psOver0\, NA)))))) %>%
  drop_na(psOver)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### log2FC

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuR09maWdEaXIgPC0gaGVyZShmaWdEaXIsIFwiLi4vR09cIilcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5HTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiLCByZWFkYWJsZSA9IFRSVUUpKVxuR08xLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjEsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIiwgcmVhZGFibGUgPSBUUlVFKSlcbkdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFwiRU5TRU1CTFwiLCBvbnQgPSBcIkJQXCIsIHJlYWRhYmxlID0gVFJVRSkpXG5HTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiLCByZWFkYWJsZSA9IFRSVUUpKVxuR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIiwgcmVhZGFibGUgPSBUUlVFKSlcblxuZndyaXRlKEdPMC5kZiwgaGVyZShcIkdPX1BTX2dyb3VwMC50c3ZcIiksIHNlcCA9IFwiXFx0XCIpXG5md3JpdGUoR08xLmRmLCBoZXJlKFwiR09fUFNfZ3JvdXAxLnRzdlwiKSwgc2VwID0gXCJcXHRcIilcbmZ3cml0ZShHTzIuZGYsIGhlcmUoXCJHT19QU19ncm91cDIudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuZndyaXRlKEdPMy5kZiwgaGVyZShcIkdPX1BTX2dyb3VwMy50c3ZcIiksIHNlcCA9IFwiXFx0XCIpXG5md3JpdGUoR080LmRmLCBoZXJlKFwiR09fUFNfZ3JvdXA0LnRzdlwiKSwgc2VwID0gXCJcXHRcIilcblxuR08wLmRmIDwtIGZyZWFkKGhlcmUoXCJHT19QU19ncm91cDAudHN2XCIpKVxuR08xLmRmIDwtIGZyZWFkKGhlcmUoXCJHT19QU19ncm91cDEudHN2XCIpKVxuR08yLmRmIDwtIGZyZWFkKGhlcmUoXCJHT19QU19ncm91cDIudHN2XCIpKVxuR08zLmRmIDwtIGZyZWFkKGhlcmUoXCJHT19QU19ncm91cDMudHN2XCIpKVxuR080LmRmIDwtIGZyZWFkKGhlcmUoXCJHT19QU19ncm91cDQudHN2XCIpKVxuXG5zdWJzZXQwIDwtIEdPMC5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXCJHcm91cCAwXCIpICU+JVxuICBkcGx5cjo6YXJyYW5nZShwLmFkanVzdClcbnN1YnNldDEgPC0gR08xLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcIkdyb3VwIDFcIikgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwiR3JvdXAgMlwiKSAlPiVcbiAgZHBseXI6OmFycmFuZ2UocC5hZGp1c3QpXG5zdWJzZXQzIDwtIEdPMy5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXCJHcm91cCAzXCIpICU+JVxuICBkcGx5cjo6YXJyYW5nZShwLmFkanVzdClcbnN1YnNldDQgPC0gR080LmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcIkdyb3VwIDRcIikgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuXG5zdWJzZXQwJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MCRHZW5lUmF0aW8sIFwiL1wiKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5zdWJzZXQxJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MSRHZW5lUmF0aW8sIFwiL1wiKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5zdWJzZXQyJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MiRHZW5lUmF0aW8sIFwiL1wiKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5zdWJzZXQzJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MyRHZW5lUmF0aW8sIFwiL1wiKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5zdWJzZXQ0JEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0NCRHZW5lUmF0aW8sIFwiL1wiKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5cblxuR09saXN0IDwtIGZhY3RvcihjKFwiR086MDAwODM4MFwiLCBcIkdPOjAwMDYzOTdcIiwgXCJHTzowMDM0NDcwXCIsIFwiR086MDAyMjYxM1wiLCBcIkdPOjAwMTYwNTVcIixcbiAgICAgICAgICAgICAgICAgICBcIkdPOjAwNjExMzhcIiwgXCJHTzowMDYwNTYyXCIsIFwiR086MDAwNzM4OVwiLCBcIkdPOjAwNjA0ODVcIiwgXCJHTzowMDQ4NjM4XCIsIFwiR086MDA0NTY2NFwiKSlcblxuZGF0YSA8LSBiaW5kX3Jvd3MoYmluZF9yb3dzKGJpbmRfcm93cyhiaW5kX3Jvd3Moc3Vic2V0MCwgc3Vic2V0MSksIHN1YnNldDIpLCBzdWJzZXQzKSwgc3Vic2V0NCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoSUQgJWluJSBHT2xpc3QpXG5cbmRlc2NPcmRlciA8LSBzb3J0KHVuaXF1ZShkYXRhJERlc2NyaXB0aW9uKSlbcmV2KGMoMTAsIDQsIDUsIDksIDExLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAyLCA2LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAzLCAxLCA4LCA3KSldXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiUgZHBseXI6Om11dGF0ZShwVmFsdWVMb2cgPSBtaW4oLWxvZzEwKHAuYWRqdXN0KSwgcFZhbHVlTG9nTWF4KSlcbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBmYWN0b3IoRGVzY3JpcHRpb24sIGxldmVscyA9IGRlc2NPcmRlciksIHNpemUgPSBwVmFsdWVMb2csIGZpbGwgPSBHZW5lUmF0aW8pKSArIFxuICBnZW9tX3BvaW50KHNoYXBlID0gMjEsICAgICAgICAjIEVuc3VyZXMgYSBwb2ludCB3aXRoIGFuIG91dGxpbmVcbiAgICAgICAgICAgICBzdHJva2UgPSAxKnB0VG9NTSkgKyBcbiAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygwLjUsIDIpKSArICAjIFNldCBtaW4gYW5kIG1heCBwb2ludCBzaXplcyBoZXJlXG4gIHNjYWxlX2ZpbGxfZ3JhZGllbnQobG93ID0gXCJ3aGl0ZVwiLCBoaWdoID0gXCIjQ0IzMzNBXCIsXG4gICAgICAgICAgICAgICAgICAgICAgIyBsaW1pdHMgPSBjKDAsIDEpLFxuICAgICAgICAgICAgICAgICAgICAgIG9vYiA9IHNjYWxlczo6c3F1aXNoLCAjIERlZmluZSBncmFkaWVudCBjb2xvcnNcbiAgICAgICAgICAgICAgICAgICAgICBndWlkZSA9IGd1aWRlX2NvbG9yYmFyKFxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyd2lkdGggPSAxLjUvNS4wOCwgICMgQWRqdXN0IHdpZHRoIG9mIHRoZSBjb2xvciBiYXJcbiAgICAgICAgICAgICAgICAgICAgICAgIGJhcmhlaWdodCA9IDE1LzUuMDggICAjIEFkanVzdCBoZWlnaHQgb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgIClcbiAgKSArIFxuICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuICB0aGVtZV9idygpICsgICMgQXBwbHkgdGhlbWVfYncgZmlyc3QsIHNvIGN1c3RvbSB0aGVtZSBzZXR0aW5ncyBjb21lIGFmdGVyXG4gIHRoZW1lKFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFwidHJhbnNwYXJlbnRcIiksICAjIE92ZXJyaWRlIHRoZW1lX2J3IHBhbmVsXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgICAgICAgICAjIEVuc3VyZSBzaXplIGlzIHNldCBmb3IgeC1heGlzIHRleHRcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICApLFxuICAgIGF4aXMudGV4dC55ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgICAgICAgICAjIEVuc3VyZSBzaXplIGlzIHNldCBmb3IgeS1heGlzIHRleHRcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICAgIGxpbmVoZWlnaHQgPSAwLjkgICAgICAgICAgIyBBbGxvd3Mgd3JhcHBpbmcgZm9yIHktYXhpcyBsYWJlbHMgdG8gZml0IGludG8gMiBsaW5lc1xuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCIsXG4gICAgICBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gIClcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFwiLi5cIiwgXCJHT1wiLCBcIkdPX2dyb3Vwc19wc1wiKVxud2lkdGggPC0gcGFuZWxTaXplKDIuNykqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS4yKSptbVRvSW5jaFxuc3ZnbGl0ZShwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgIn0= -->\n\n```r\nGOfigDir <- here(figDir, \\../GO\\)\n\n#####################\nGO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\n\nfwrite(GO0.df, here(\\GO_PS_group0.tsv\\), sep = \\\\t\\)\nfwrite(GO1.df, here(\\GO_PS_group1.tsv\\), sep = \\\\t\\)\nfwrite(GO2.df, here(\\GO_PS_group2.tsv\\), sep = \\\\t\\)\nfwrite(GO3.df, here(\\GO_PS_group3.tsv\\), sep = \\\\t\\)\nfwrite(GO4.df, here(\\GO_PS_group4.tsv\\), sep = \\\\t\\)\n\nGO0.df <- fread(here(\\GO_PS_group0.tsv\\))\nGO1.df <- fread(here(\\GO_PS_group1.tsv\\))\nGO2.df <- fread(here(\\GO_PS_group2.tsv\\))\nGO3.df <- fread(here(\\GO_PS_group3.tsv\\))\nGO4.df <- fread(here(\\GO_PS_group4.tsv\\))\n\nsubset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 0\\) %>%\n  dplyr::arrange(p.adjust)\nsubset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 1\\) %>%\n  dplyr::arrange(p.adjust)\nsubset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 2\\) %>%\n  dplyr::arrange(p.adjust)\nsubset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 3\\) %>%\n  dplyr::arrange(p.adjust)\nsubset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 4\\) %>%\n  dplyr::arrange(p.adjust)\n\nsubset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\n\n\nGOlist <- factor(c(\\GO:0008380\\, \\GO:0006397\\, \\GO:0034470\\, \\GO:0022613\\, \\GO:0016055\\,\n                   \\GO:0061138\\, \\GO:0060562\\, \\GO:0007389\\, \\GO:0060485\\, \\GO:0048638\\, \\GO:0045664\\))\n\ndata <- bind_rows(bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset3), subset4) %>%\n  dplyr::filter(ID %in% GOlist)\n\ndescOrder <- sort(unique(data$Description))[rev(c(10, 4, 5, 9, 11,\n                                                  2, 6,\n                                                  3, 1, 8, 7))]\n\ndata <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))\np <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + \n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM) + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      # limits = c(0, 1),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL) +\n  theme_bw() +  # Apply theme_bw first, so custom theme settings come after\n  theme(\n    panel.background = element_rect(fill = \\transparent\\),  # Override theme_bw panel\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      size = fontSizeS,         # Ensure size is set for x-axis text\n      family = fontType,\n      color = \\#000000\\,\n    ),\n    axis.text.y = element_text(\n      size = fontSizeS,         # Ensure size is set for y-axis text\n      family = fontType,\n      color = \\#000000\\,\n      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_ps\\)\nwidth <- panelSize(2.7)*mmToInch\nheight <- panelSize(1.2)*mmToInch\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
GOfigDir <- here(figDir, \../GO\)

#####################
GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))

fwrite(GO0.df, here(\GO_PS_group0.tsv\), sep = \\t\)
fwrite(GO1.df, here(\GO_PS_group1.tsv\), sep = \\t\)
fwrite(GO2.df, here(\GO_PS_group2.tsv\), sep = \\t\)
fwrite(GO3.df, here(\GO_PS_group3.tsv\), sep = \\t\)
fwrite(GO4.df, here(\GO_PS_group4.tsv\), sep = \\t\)

GO0.df <- fread(here(\GO_PS_group0.tsv\))
GO1.df <- fread(here(\GO_PS_group1.tsv\))
GO2.df <- fread(here(\GO_PS_group2.tsv\))
GO3.df <- fread(here(\GO_PS_group3.tsv\))
GO4.df <- fread(here(\GO_PS_group4.tsv\))

subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 0\) %>%
  dplyr::arrange(p.adjust)
subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 1\) %>%
  dplyr::arrange(p.adjust)
subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 2\) %>%
  dplyr::arrange(p.adjust)
subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 3\) %>%
  dplyr::arrange(p.adjust)
subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 4\) %>%
  dplyr::arrange(p.adjust)

subset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))


GOlist <- factor(c(\GO:0008380\, \GO:0006397\, \GO:0034470\, \GO:0022613\, \GO:0016055\,
                   \GO:0061138\, \GO:0060562\, \GO:0007389\, \GO:0060485\, \GO:0048638\, \GO:0045664\))

data <- bind_rows(bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset3), subset4) %>%
  dplyr::filter(ID %in% GOlist)

descOrder <- sort(unique(data$Description))[rev(c(10, 4, 5, 9, 11,
                                                  2, 6,
                                                  3, 1, 8, 7))]

data <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))
p <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + 
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM) + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = \white\, high = \#CB333A\,
                      # limits = c(0, 1),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL) +
  theme_bw() +  # Apply theme_bw first, so custom theme settings come after
  theme(
    panel.background = element_rect(fill = \transparent\),  # Override theme_bw panel
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      size = fontSizeS,         # Ensure size is set for x-axis text
      family = fontType,
      color = \#000000\,
    ),
    axis.text.y = element_text(
      size = fontSizeS,         # Ensure size is set for y-axis text
      family = fontType,
      color = \#000000\,
      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, \..\, \GO\, \GO_groups_ps\)
width <- panelSize(2.7)*mmToInch
height <- panelSize(1.2)*mmToInch
svglite(paste0(fileName, \.svg\), height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuR09maWdEaXIgPC0gaGVyZShmaWdEaXIsIFxcLi4vR09cXClcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5HTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcLCByZWFkYWJsZSA9IFRSVUUpKVxuR08xLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjEsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCwgcmVhZGFibGUgPSBUUlVFKSlcbkdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwsIHJlYWRhYmxlID0gVFJVRSkpXG5HTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcLCByZWFkYWJsZSA9IFRSVUUpKVxuR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCwgcmVhZGFibGUgPSBUUlVFKSlcblxuZndyaXRlKEdPMC5kZiwgaGVyZShcXEdPX1BTX2dyb3VwMC50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoR08xLmRmLCBoZXJlKFxcR09fUFNfZ3JvdXAxLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZShHTzIuZGYsIGhlcmUoXFxHT19QU19ncm91cDIudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuZndyaXRlKEdPMy5kZiwgaGVyZShcXEdPX1BTX2dyb3VwMy50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoR080LmRmLCBoZXJlKFxcR09fUFNfZ3JvdXA0LnRzdlxcKSwgc2VwID0gXFxcXHRcXClcblxuR08wLmRmIDwtIGZyZWFkKGhlcmUoXFxHT19QU19ncm91cDAudHN2XFwpKVxuR08xLmRmIDwtIGZyZWFkKGhlcmUoXFxHT19QU19ncm91cDEudHN2XFwpKVxuR08yLmRmIDwtIGZyZWFkKGhlcmUoXFxHT19QU19ncm91cDIudHN2XFwpKVxuR08zLmRmIDwtIGZyZWFkKGhlcmUoXFxHT19QU19ncm91cDMudHN2XFwpKVxuR080LmRmIDwtIGZyZWFkKGhlcmUoXFxHT19QU19ncm91cDQudHN2XFwpKVxuXG5zdWJzZXQwIDwtIEdPMC5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxHcm91cCAwXFwpICU+JVxuICBkcGx5cjo6YXJyYW5nZShwLmFkanVzdClcbnN1YnNldDEgPC0gR08xLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXEdyb3VwIDFcXCkgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcR3JvdXAgMlxcKSAlPiVcbiAgZHBseXI6OmFycmFuZ2UocC5hZGp1c3QpXG5zdWJzZXQzIDwtIEdPMy5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxHcm91cCAzXFwpICU+JVxuICBkcGx5cjo6YXJyYW5nZShwLmFkanVzdClcbnN1YnNldDQgPC0gR080LmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXEdyb3VwIDRcXCkgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuXG5zdWJzZXQwJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MCRHZW5lUmF0aW8sIFxcL1xcKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5zdWJzZXQxJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MSRHZW5lUmF0aW8sIFxcL1xcKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5zdWJzZXQyJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MiRHZW5lUmF0aW8sIFxcL1xcKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5zdWJzZXQzJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MyRHZW5lUmF0aW8sIFxcL1xcKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5zdWJzZXQ0JEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0NCRHZW5lUmF0aW8sIFxcL1xcKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5cblxuR09saXN0IDwtIGZhY3RvcihjKFxcR086MDAwODM4MFxcLCBcXEdPOjAwMDYzOTdcXCwgXFxHTzowMDM0NDcwXFwsIFxcR086MDAyMjYxM1xcLCBcXEdPOjAwMTYwNTVcXCxcbiAgICAgICAgICAgICAgICAgICBcXEdPOjAwNjExMzhcXCwgXFxHTzowMDYwNTYyXFwsIFxcR086MDAwNzM4OVxcLCBcXEdPOjAwNjA0ODVcXCwgXFxHTzowMDQ4NjM4XFwsIFxcR086MDA0NTY2NFxcKSlcblxuZGF0YSA8LSBiaW5kX3Jvd3MoYmluZF9yb3dzKGJpbmRfcm93cyhiaW5kX3Jvd3Moc3Vic2V0MCwgc3Vic2V0MSksIHN1YnNldDIpLCBzdWJzZXQzKSwgc3Vic2V0NCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoSUQgJWluJSBHT2xpc3QpXG5cbmRlc2NPcmRlciA8LSBzb3J0KHVuaXF1ZShkYXRhJERlc2NyaXB0aW9uKSlbcmV2KGMoMTAsIDQsIDUsIDksIDExLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAyLCA2LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAzLCAxLCA4LCA3KSldXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiUgZHBseXI6Om11dGF0ZShwVmFsdWVMb2cgPSBtaW4oLWxvZzEwKHAuYWRqdXN0KSwgcFZhbHVlTG9nTWF4KSlcbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBmYWN0b3IoRGVzY3JpcHRpb24sIGxldmVscyA9IGRlc2NPcmRlciksIHNpemUgPSBwVmFsdWVMb2csIGZpbGwgPSBHZW5lUmF0aW8pKSArIFxuICBnZW9tX3BvaW50KHNoYXBlID0gMjEsICAgICAgICAjIEVuc3VyZXMgYSBwb2ludCB3aXRoIGFuIG91dGxpbmVcbiAgICAgICAgICAgICBzdHJva2UgPSAxKnB0VG9NTSkgKyBcbiAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygwLjUsIDIpKSArICAjIFNldCBtaW4gYW5kIG1heCBwb2ludCBzaXplcyBoZXJlXG4gIHNjYWxlX2ZpbGxfZ3JhZGllbnQobG93ID0gXFx3aGl0ZVxcLCBoaWdoID0gXFwjQ0IzMzNBXFwsXG4gICAgICAgICAgICAgICAgICAgICAgIyBsaW1pdHMgPSBjKDAsIDEpLFxuICAgICAgICAgICAgICAgICAgICAgIG9vYiA9IHNjYWxlczo6c3F1aXNoLCAjIERlZmluZSBncmFkaWVudCBjb2xvcnNcbiAgICAgICAgICAgICAgICAgICAgICBndWlkZSA9IGd1aWRlX2NvbG9yYmFyKFxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyd2lkdGggPSAxLjUvNS4wOCwgICMgQWRqdXN0IHdpZHRoIG9mIHRoZSBjb2xvciBiYXJcbiAgICAgICAgICAgICAgICAgICAgICAgIGJhcmhlaWdodCA9IDE1LzUuMDggICAjIEFkanVzdCBoZWlnaHQgb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgIClcbiAgKSArIFxuICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuICB0aGVtZV9idygpICsgICMgQXBwbHkgdGhlbWVfYncgZmlyc3QsIHNvIGN1c3RvbSB0aGVtZSBzZXR0aW5ncyBjb21lIGFmdGVyXG4gIHRoZW1lKFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksICAjIE92ZXJyaWRlIHRoZW1lX2J3IHBhbmVsXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgICAgICAgICAjIEVuc3VyZSBzaXplIGlzIHNldCBmb3IgeC1heGlzIHRleHRcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICApLFxuICAgIGF4aXMudGV4dC55ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgICAgICAgICAjIEVuc3VyZSBzaXplIGlzIHNldCBmb3IgeS1heGlzIHRleHRcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIGxpbmVoZWlnaHQgPSAwLjkgICAgICAgICAgIyBBbGxvd3Mgd3JhcHBpbmcgZm9yIHktYXhpcyBsYWJlbHMgdG8gZml0IGludG8gMiBsaW5lc1xuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gIClcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc19wc1xcKVxud2lkdGggPC0gcGFuZWxTaXplKDIuNykqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS4yKSptbVRvSW5jaFxuc3ZnbGl0ZShwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\nGOfigDir <- here(figDir, \\../GO\\)\n\n#####################\nGO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\n\nfwrite(GO0.df, here(\\GO_PS_group0.tsv\\), sep = \\\\t\\)\nfwrite(GO1.df, here(\\GO_PS_group1.tsv\\), sep = \\\\t\\)\nfwrite(GO2.df, here(\\GO_PS_group2.tsv\\), sep = \\\\t\\)\nfwrite(GO3.df, here(\\GO_PS_group3.tsv\\), sep = \\\\t\\)\nfwrite(GO4.df, here(\\GO_PS_group4.tsv\\), sep = \\\\t\\)\n\nGO0.df <- fread(here(\\GO_PS_group0.tsv\\))\nGO1.df <- fread(here(\\GO_PS_group1.tsv\\))\nGO2.df <- fread(here(\\GO_PS_group2.tsv\\))\nGO3.df <- fread(here(\\GO_PS_group3.tsv\\))\nGO4.df <- fread(here(\\GO_PS_group4.tsv\\))\n\nsubset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 0\\) %>%\n  dplyr::arrange(p.adjust)\nsubset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 1\\) %>%\n  dplyr::arrange(p.adjust)\nsubset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 2\\) %>%\n  dplyr::arrange(p.adjust)\nsubset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 3\\) %>%\n  dplyr::arrange(p.adjust)\nsubset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 4\\) %>%\n  dplyr::arrange(p.adjust)\n\nsubset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\n\n\nGOlist <- factor(c(\\GO:0008380\\, \\GO:0006397\\, \\GO:0034470\\, \\GO:0022613\\, \\GO:0016055\\,\n                   \\GO:0061138\\, \\GO:0060562\\, \\GO:0007389\\, \\GO:0060485\\, \\GO:0048638\\, \\GO:0045664\\))\n\ndata <- bind_rows(bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset3), subset4) %>%\n  dplyr::filter(ID %in% GOlist)\n\ndescOrder <- sort(unique(data$Description))[rev(c(10, 4, 5, 9, 11,\n                                                  2, 6,\n                                                  3, 1, 8, 7))]\n\ndata <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))\np <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + \n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM) + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      # limits = c(0, 1),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL) +\n  theme_bw() +  # Apply theme_bw first, so custom theme settings come after\n  theme(\n    panel.background = element_rect(fill = \\transparent\\),  # Override theme_bw panel\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      size = fontSizeS,         # Ensure size is set for x-axis text\n      family = fontType,\n      color = \\#000000\\,\n    ),\n    axis.text.y = element_text(\n      size = fontSizeS,         # Ensure size is set for y-axis text\n      family = fontType,\n      color = \\#000000\\,\n      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_ps\\)\nwidth <- panelSize(2.7)*mmToInch\nheight <- panelSize(1.2)*mmToInch\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuR09maWdEaXIgPC0gaGVyZShmaWdEaXIsIFxcLi4vR09cXClcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5HTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcLCByZWFkYWJsZSA9IFRSVUUpKVxuR08xLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjEsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCwgcmVhZGFibGUgPSBUUlVFKSlcbkdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwsIHJlYWRhYmxlID0gVFJVRSkpXG5HTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcLCByZWFkYWJsZSA9IFRSVUUpKVxuR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCwgcmVhZGFibGUgPSBUUlVFKSlcblxuZndyaXRlKEdPMC5kZiwgaGVyZShcXEdPX1BTX2dyb3VwMC50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoR08xLmRmLCBoZXJlKFxcR09fUFNfZ3JvdXAxLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZShHTzIuZGYsIGhlcmUoXFxHT19QU19ncm91cDIudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuZndyaXRlKEdPMy5kZiwgaGVyZShcXEdPX1BTX2dyb3VwMy50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoR080LmRmLCBoZXJlKFxcR09fUFNfZ3JvdXA0LnRzdlxcKSwgc2VwID0gXFxcXHRcXClcblxuR08wLmRmIDwtIGZyZWFkKGhlcmUoXFxHT19QU19ncm91cDAudHN2XFwpKVxuR08xLmRmIDwtIGZyZWFkKGhlcmUoXFxHT19QU19ncm91cDEudHN2XFwpKVxuR08yLmRmIDwtIGZyZWFkKGhlcmUoXFxHT19QU19ncm91cDIudHN2XFwpKVxuR08zLmRmIDwtIGZyZWFkKGhlcmUoXFxHT19QU19ncm91cDMudHN2XFwpKVxuR080LmRmIDwtIGZyZWFkKGhlcmUoXFxHT19QU19ncm91cDQudHN2XFwpKVxuXG5zdWJzZXQwIDwtIEdPMC5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxHcm91cCAwXFwpICU+JVxuICBkcGx5cjo6YXJyYW5nZShwLmFkanVzdClcbnN1YnNldDEgPC0gR08xLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXEdyb3VwIDFcXCkgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcR3JvdXAgMlxcKSAlPiVcbiAgZHBseXI6OmFycmFuZ2UocC5hZGp1c3QpXG5zdWJzZXQzIDwtIEdPMy5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxHcm91cCAzXFwpICU+JVxuICBkcGx5cjo6YXJyYW5nZShwLmFkanVzdClcbnN1YnNldDQgPC0gR080LmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXEdyb3VwIDRcXCkgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuXG5zdWJzZXQwJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MCRHZW5lUmF0aW8sIFxcL1xcKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5zdWJzZXQxJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MSRHZW5lUmF0aW8sIFxcL1xcKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5zdWJzZXQyJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MiRHZW5lUmF0aW8sIFxcL1xcKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5zdWJzZXQzJEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0MyRHZW5lUmF0aW8sIFxcL1xcKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5zdWJzZXQ0JEdlbmVSYXRpbyA8LSBzYXBwbHkoc3Ryc3BsaXQoc3Vic2V0NCRHZW5lUmF0aW8sIFxcL1xcKSwgZnVuY3Rpb24oeCkgYXMubnVtZXJpYyh4WzFdKSAvIGFzLm51bWVyaWMoeFsyXSkpXG5cblxuR09saXN0IDwtIGZhY3RvcihjKFxcR086MDAwODM4MFxcLCBcXEdPOjAwMDYzOTdcXCwgXFxHTzowMDM0NDcwXFwsIFxcR086MDAyMjYxM1xcLCBcXEdPOjAwMTYwNTVcXCxcbiAgICAgICAgICAgICAgICAgICBcXEdPOjAwNjExMzhcXCwgXFxHTzowMDYwNTYyXFwsIFxcR086MDAwNzM4OVxcLCBcXEdPOjAwNjA0ODVcXCwgXFxHTzowMDQ4NjM4XFwsIFxcR086MDA0NTY2NFxcKSlcblxuZGF0YSA8LSBiaW5kX3Jvd3MoYmluZF9yb3dzKGJpbmRfcm93cyhiaW5kX3Jvd3Moc3Vic2V0MCwgc3Vic2V0MSksIHN1YnNldDIpLCBzdWJzZXQzKSwgc3Vic2V0NCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoSUQgJWluJSBHT2xpc3QpXG5cbmRlc2NPcmRlciA8LSBzb3J0KHVuaXF1ZShkYXRhJERlc2NyaXB0aW9uKSlbcmV2KGMoMTAsIDQsIDUsIDksIDExLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAyLCA2LFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAzLCAxLCA4LCA3KSldXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiUgZHBseXI6Om11dGF0ZShwVmFsdWVMb2cgPSBtaW4oLWxvZzEwKHAuYWRqdXN0KSwgcFZhbHVlTG9nTWF4KSlcbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBmYWN0b3IoRGVzY3JpcHRpb24sIGxldmVscyA9IGRlc2NPcmRlciksIHNpemUgPSBwVmFsdWVMb2csIGZpbGwgPSBHZW5lUmF0aW8pKSArIFxuICBnZW9tX3BvaW50KHNoYXBlID0gMjEsICAgICAgICAjIEVuc3VyZXMgYSBwb2ludCB3aXRoIGFuIG91dGxpbmVcbiAgICAgICAgICAgICBzdHJva2UgPSAxKnB0VG9NTSkgKyBcbiAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygwLjUsIDIpKSArICAjIFNldCBtaW4gYW5kIG1heCBwb2ludCBzaXplcyBoZXJlXG4gIHNjYWxlX2ZpbGxfZ3JhZGllbnQobG93ID0gXFx3aGl0ZVxcLCBoaWdoID0gXFwjQ0IzMzNBXFwsXG4gICAgICAgICAgICAgICAgICAgICAgIyBsaW1pdHMgPSBjKDAsIDEpLFxuICAgICAgICAgICAgICAgICAgICAgIG9vYiA9IHNjYWxlczo6c3F1aXNoLCAjIERlZmluZSBncmFkaWVudCBjb2xvcnNcbiAgICAgICAgICAgICAgICAgICAgICBndWlkZSA9IGd1aWRlX2NvbG9yYmFyKFxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyd2lkdGggPSAxLjUvNS4wOCwgICMgQWRqdXN0IHdpZHRoIG9mIHRoZSBjb2xvciBiYXJcbiAgICAgICAgICAgICAgICAgICAgICAgIGJhcmhlaWdodCA9IDE1LzUuMDggICAjIEFkanVzdCBoZWlnaHQgb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgIClcbiAgKSArIFxuICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuICB0aGVtZV9idygpICsgICMgQXBwbHkgdGhlbWVfYncgZmlyc3QsIHNvIGN1c3RvbSB0aGVtZSBzZXR0aW5ncyBjb21lIGFmdGVyXG4gIHRoZW1lKFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksICAjIE92ZXJyaWRlIHRoZW1lX2J3IHBhbmVsXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgICAgICAgICAjIEVuc3VyZSBzaXplIGlzIHNldCBmb3IgeC1heGlzIHRleHRcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICApLFxuICAgIGF4aXMudGV4dC55ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgICAgICAgICAjIEVuc3VyZSBzaXplIGlzIHNldCBmb3IgeS1heGlzIHRleHRcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIGxpbmVoZWlnaHQgPSAwLjkgICAgICAgICAgIyBBbGxvd3Mgd3JhcHBpbmcgZm9yIHktYXhpcyBsYWJlbHMgdG8gZml0IGludG8gMiBsaW5lc1xuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gIClcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc19wc1xcKVxud2lkdGggPC0gcGFuZWxTaXplKDIuNykqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS4yKSptbVRvSW5jaFxuc3ZnbGl0ZShwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
GOfigDir <- here(figDir, \../GO\)

#####################
GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))

fwrite(GO0.df, here(\GO_PS_group0.tsv\), sep = \\t\)
fwrite(GO1.df, here(\GO_PS_group1.tsv\), sep = \\t\)
fwrite(GO2.df, here(\GO_PS_group2.tsv\), sep = \\t\)
fwrite(GO3.df, here(\GO_PS_group3.tsv\), sep = \\t\)
fwrite(GO4.df, here(\GO_PS_group4.tsv\), sep = \\t\)

GO0.df <- fread(here(\GO_PS_group0.tsv\))
GO1.df <- fread(here(\GO_PS_group1.tsv\))
GO2.df <- fread(here(\GO_PS_group2.tsv\))
GO3.df <- fread(here(\GO_PS_group3.tsv\))
GO4.df <- fread(here(\GO_PS_group4.tsv\))

subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 0\) %>%
  dplyr::arrange(p.adjust)
subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 1\) %>%
  dplyr::arrange(p.adjust)
subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 2\) %>%
  dplyr::arrange(p.adjust)
subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 3\) %>%
  dplyr::arrange(p.adjust)
subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 4\) %>%
  dplyr::arrange(p.adjust)

subset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))


GOlist <- factor(c(\GO:0008380\, \GO:0006397\, \GO:0034470\, \GO:0022613\, \GO:0016055\,
                   \GO:0061138\, \GO:0060562\, \GO:0007389\, \GO:0060485\, \GO:0048638\, \GO:0045664\))

data <- bind_rows(bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset3), subset4) %>%
  dplyr::filter(ID %in% GOlist)

descOrder <- sort(unique(data$Description))[rev(c(10, 4, 5, 9, 11,
                                                  2, 6,
                                                  3, 1, 8, 7))]

data <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))
p <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + 
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM) + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = \white\, high = \#CB333A\,
                      # limits = c(0, 1),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL) +
  theme_bw() +  # Apply theme_bw first, so custom theme settings come after
  theme(
    panel.background = element_rect(fill = \transparent\),  # Override theme_bw panel
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      size = fontSizeS,         # Ensure size is set for x-axis text
      family = fontType,
      color = \#000000\,
    ),
    axis.text.y = element_text(
      size = fontSizeS,         # Ensure size is set for y-axis text
      family = fontType,
      color = \#000000\,
      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, \..\, \GO\, \GO_groups_ps\)
width <- panelSize(2.7)*mmToInch
height <- panelSize(1.2)*mmToInch
svglite(paste0(fileName, \.svg\), height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Grouping with P-S number
##### Grouping

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXCJwc092ZXIwXCIsIFwicHNPdmVyMVwiKSwgNSlcbnBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcInBzT3ZlcjFcIiwgXCJwc092ZXIyXCIpLCA1KVxucHMyMyA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFwicHNPdmVyMlwiLCBcInBzT3ZlcjNcIiksIDUpXG5wczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXCJwc092ZXIzXCIsIFwicHNPdmVyNFwiKSwgNSlcbnBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcInBzT3ZlcjJcIiwgXCJwc092ZXI0XCIpLCA1KVxucHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFwicHNPdmVyMVwiLCBcInBzT3ZlcjRcIiksIDUpXG5wczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXCJwc092ZXIwXCIsIFwicHNPdmVyNFwiKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBzT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgXG4gIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgXG4gICAgICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLFxuICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIixcbiAgICAgICAgICAgICAgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXCJibGFja1wiLFxuICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZU1lZGl1bSAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCIsXG4gICAgICAgICAgICAgICBvdXRsaWVyLnNoYXBlID0gTkFcbiAgKSArIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXCJBdmVyYWdlIM6UIGxvb3Agc2NvcmVcIikgK1xuICBzdGF0X3N1bW1hcnkoXG4gICAgYWVzKGdyb3VwID0gcHNPdmVyKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcImJsYWNrXCIsIGNvbG9yID0gXCJibGFja1wiXG4gICkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFwiIzAwMDAwMFwiXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIiwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXCJ0cmFuc3BhcmVudFwiKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApK1xuICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcInBzMDE6IFwiLCBjb252UHZhbHVlKHBzMDEpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczEyOiBcIiwgY29udlB2YWx1ZShwczEyKSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHMyMzogXCIsIGNvbnZQdmFsdWUocHMyMyksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMzQ6IFwiLCBjb252UHZhbHVlKHBzMzQpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczI0OiBcIiwgY29udlB2YWx1ZShwczI0KSwgXCJcXG5cIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMTQ6IFwiLCBjb252UHZhbHVlKHBzMTQpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczA0OiBcIiwgY29udlB2YWx1ZShwczA0KSwgXCJcXG5cIiksIFxuICAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMikgK1xuICAgIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGMoXCIjNzc3Nzc3XCIsIFwiIzhCN0U2NVwiLCBcIiNBMjg0NTJcIiwgXCIjQzI4ODREXCIsIFwiI0YyOEUyQ1wiKSkgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTAuNSwgMC4xKSlcblxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcImRpZmZTY29yZV9iYXJwbG90X3BzR3JvdXBfZFRBR192c19ETVNPXzJcIilcbndpZHRoIDwtIDMzKm1tVG9JbmNoXG5oZWlnaHQgPC0zMyptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgIn0= -->\n\n```r\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nps01 <- round(getPvalWilcox(temp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(temp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(temp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(temp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(temp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(temp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(temp, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + \n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\Average Δ loop score\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) +\n    scale_fill_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)) +\n  coord_cartesian(ylim = c(-0.5, 0.1))\n\n\n\nfileName <- paste0(\\diffScore_barplot_psGroup_dTAG_vs_DMSO_2\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

ps01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(temp, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(temp, \psOver1\, \psOver4\), 5)
ps04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)


p <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + 
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineMedium * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \Average Δ loop score\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) +
    scale_fill_manual(values = c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\)) +
  coord_cartesian(ylim = c(-0.5, 0.1))



fileName <- paste0(\diffScore_barplot_psGroup_dTAG_vs_DMSO_2\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbnBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxucHMyMyA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjNcXCksIDUpXG5wczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbnBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxucHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjRcXCksIDUpXG5wczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyNFxcKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBzT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgXG4gIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgXG4gICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZU1lZGl1bSAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsXG4gICAgICAgICAgICAgICBvdXRsaWVyLnNoYXBlID0gTkFcbiAgKSArIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXFxBdmVyYWdlIM6UIGxvb3Agc2NvcmVcXCkgK1xuICBzdGF0X3N1bW1hcnkoXG4gICAgYWVzKGdyb3VwID0gcHNPdmVyKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMikgK1xuICAgIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGMoXFwjNzc3Nzc3XFwsIFxcIzhCN0U2NVxcLCBcXCNBMjg0NTJcXCwgXFwjQzI4ODREXFwsIFxcI0YyOEUyQ1xcKSkgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTAuNSwgMC4xKSlcblxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGRpZmZTY29yZV9iYXJwbG90X3BzR3JvdXBfZFRBR192c19ETVNPXzJcXClcbndpZHRoIDwtIDMzKm1tVG9JbmNoXG5oZWlnaHQgPC0zMyptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nps01 <- round(getPvalWilcox(temp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(temp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(temp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(temp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(temp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(temp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(temp, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + \n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\Average Δ loop score\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) +\n    scale_fill_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)) +\n  coord_cartesian(ylim = c(-0.5, 0.1))\n\n\n\nfileName <- paste0(\\diffScore_barplot_psGroup_dTAG_vs_DMSO_2\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbnBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxucHMyMyA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjNcXCksIDUpXG5wczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbnBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxucHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjRcXCksIDUpXG5wczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyNFxcKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBzT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgXG4gIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgXG4gICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZU1lZGl1bSAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsXG4gICAgICAgICAgICAgICBvdXRsaWVyLnNoYXBlID0gTkFcbiAgKSArIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXFxBdmVyYWdlIM6UIGxvb3Agc2NvcmVcXCkgK1xuICBzdGF0X3N1bW1hcnkoXG4gICAgYWVzKGdyb3VwID0gcHNPdmVyKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMikgK1xuICAgIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGMoXFwjNzc3Nzc3XFwsIFxcIzhCN0U2NVxcLCBcXCNBMjg0NTJcXCwgXFwjQzI4ODREXFwsIFxcI0YyOEUyQ1xcKSkgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTAuNSwgMC4xKSlcblxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGRpZmZTY29yZV9iYXJwbG90X3BzR3JvdXBfZFRBR192c19ETVNPXzJcXClcbndpZHRoIDwtIDMzKm1tVG9JbmNoXG5oZWlnaHQgPC0zMyptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

ps01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(temp, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(temp, \psOver1\, \psOver4\), 5)
ps04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)


p <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + 
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineMedium * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \Average Δ loop score\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) +
    scale_fill_manual(values = c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\)) +
  coord_cartesian(ylim = c(-0.5, 0.1))



fileName <- paste0(\diffScore_barplot_psGroup_dTAG_vs_DMSO_2\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### GO for each group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\n\nks_result1 <- ks.test(\n  temp %>% dplyr::filter(psOver == \"psOver4\") %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \"psOver3\") %>% pull(absLog2FC)\n)\nks_result2 <- ks.test(\n  temp %>% dplyr::filter(psOver == \"psOver4\") %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \"psOver2\") %>% pull(absLog2FC)\n)\nks_result3 <- ks.test(\n  temp %>% dplyr::filter(psOver == \"psOver4\") %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \"psOver1\") %>% pull(absLog2FC)\n)\nks_result4 <- ks.test(\n  temp %>% dplyr::filter(psOver == \"psOver4\") %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \"psOver0\") %>% pull(absLog2FC)\n)\n\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (c(\"#777777\", \"#8B7E65\", \"#A28452\", \"#C2884D\", \"#F28E2C\"))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \"square\" ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \"Abs. log2(fold change)\",\n    y = \"Cumulative Probability\"\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.position = \"none\",\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\"log2FC_cdf_psGroup_dTAG_vs_DMSO\")\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \"psOver0\", \"psOver1\"), 5)\nps12 <- round(getPvalWilcox(tempDown, \"psOver1\", \"psOver2\"), 5)\nps23 <- round(getPvalWilcox(tempDown, \"psOver2\", \"psOver3\"), 5)\nps34 <- round(getPvalWilcox(tempDown, \"psOver3\", \"psOver4\"), 5)\nps24 <- round(getPvalWilcox(tempDown, \"psOver2\", \"psOver4\"), 5)\nps14 <- round(getPvalWilcox(tempDown, \"psOver1\", \"psOver4\"), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \"psOver0\", \"psOver4\"), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\"#D9D9D9\", \"#BFBFBF\", \"#A6A6A6\", \"#8C8C8C\", \"#737373\")) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \"black\",\n              linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \"log2(fold change)\") +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \"point\", shape = 21, size = 1,\n    fill = \"red\", color = \"black\"\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\"text\", x = 1, y = -0.5, label = paste0(\"ps01: \", convPvalue(ps01), \"\\n\",\n                                                \"ps12: \", convPvalue(ps12), \"\\n\",\n                                                \"ps23: \", convPvalue(ps23), \"\\n\",\n                                                \"ps34: \", convPvalue(ps34), \"\\n\",\n                                                \"ps24: \", convPvalue(ps24), \"\\n\", \n                                                \"ps14: \", convPvalue(ps14), \"\\n\",\n                                                \"ps04: \", convPvalue(ps04), \"\\n\"), \n           color = \"black\", hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\"log2FC_barplot_psGroup_dTAG_vs_DMSO_down\")\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \"psOver0\", \"psOver1\"), 5)\nps12 <- round(getPvalWilcox(tempUp, \"psOver1\", \"psOver2\"), 5)\nps23 <- round(getPvalWilcox(tempUp, \"psOver2\", \"psOver3\"), 5)\nps34 <- round(getPvalWilcox(tempUp, \"psOver3\", \"psOver4\"), 5)\nps24 <- round(getPvalWilcox(tempUp, \"psOver2\", \"psOver4\"), 5)\nps14 <- round(getPvalWilcox(tempUp, \"psOver1\", \"psOver4\"), 5)\nps04 <- round(getPvalWilcox(tempUp, \"psOver0\", \"psOver4\"), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\"#D9D9D9\", \"#BFBFBF\", \"#A6A6A6\", \"#8C8C8C\", \"#737373\")) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \"black\",\n              linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \"log2(fold change)\") +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \"point\", shape = 21, size = 1,\n    fill = \"red\", color = \"black\"\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\"text\", x = 1, y = 0.5, label = paste0(\"ps01: \", convPvalue(ps01), \"\\n\",\n                                                \"ps12: \", convPvalue(ps12), \"\\n\",\n                                                \"ps23: \", convPvalue(ps23), \"\\n\",\n                                                \"ps34: \", convPvalue(ps34), \"\\n\",\n                                                \"ps24: \", convPvalue(ps24), \"\\n\", \n                                                \"ps14: \", convPvalue(ps14), \"\\n\",\n                                                \"ps04: \", convPvalue(ps04), \"\\n\"), \n           color = \"black\", hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\"log2FC_barplot_psGroup_dTAG_vs_DMSO_up\")\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\n\nks_result1 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver3\\) %>% pull(absLog2FC)\n)\nks_result2 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver2\\) %>% pull(absLog2FC)\n)\nks_result3 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver1\\) %>% pull(absLog2FC)\n)\nks_result4 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver0\\) %>% pull(absLog2FC)\n)\n\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\\log2FC_cdf_psGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\\log2FC_barplot_psGroup_dTAG_vs_DMSO_down\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_psGroup_dTAG_vs_DMSO_up\\)\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
temp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))

ks_result1 <- ks.test(
  temp %>% dplyr::filter(psOver == \psOver4\) %>% pull(absLog2FC),
  temp %>% dplyr::filter(psOver == \psOver3\) %>% pull(absLog2FC)
)
ks_result2 <- ks.test(
  temp %>% dplyr::filter(psOver == \psOver4\) %>% pull(absLog2FC),
  temp %>% dplyr::filter(psOver == \psOver2\) %>% pull(absLog2FC)
)
ks_result3 <- ks.test(
  temp %>% dplyr::filter(psOver == \psOver4\) %>% pull(absLog2FC),
  temp %>% dplyr::filter(psOver == \psOver1\) %>% pull(absLog2FC)
)
ks_result4 <- ks.test(
  temp %>% dplyr::filter(psOver == \psOver4\) %>% pull(absLog2FC),
  temp %>% dplyr::filter(psOver == \psOver0\) %>% pull(absLog2FC)
)

p <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +
scale_color_manual(values = (c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \square\ ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Abs. log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.position = \none\,
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))
fileName <- paste0(\log2FC_cdf_psGroup_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()




#
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
 
ps01 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(tempDown, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver4\), 5)

ps04 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver4\), 5)


p <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \log2(fold change)\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = -0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))
  
fileName <- paste0(\log2FC_barplot_psGroup_dTAG_vs_DMSO_down\)
width <- panelSize(1.2)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
ps01 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(tempUp, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver4\), 5)
ps04 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver4\), 5)




p <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \log2(fold change)\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_psGroup_dTAG_vs_DMSO_up\)
width <- panelSize(1.18)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\n\nks_result1 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver3\\) %>% pull(absLog2FC)\n)\nks_result2 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver2\\) %>% pull(absLog2FC)\n)\nks_result3 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver1\\) %>% pull(absLog2FC)\n)\nks_result4 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver0\\) %>% pull(absLog2FC)\n)\n\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\\log2FC_cdf_psGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\\log2FC_barplot_psGroup_dTAG_vs_DMSO_down\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_psGroup_dTAG_vs_DMSO_up\\)\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\n\nks_result1 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver3\\) %>% pull(absLog2FC)\n)\nks_result2 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver2\\) %>% pull(absLog2FC)\n)\nks_result3 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver1\\) %>% pull(absLog2FC)\n)\nks_result4 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver0\\) %>% pull(absLog2FC)\n)\n\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\\log2FC_cdf_psGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\\log2FC_barplot_psGroup_dTAG_vs_DMSO_down\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_psGroup_dTAG_vs_DMSO_up\\)\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\n\nks_result1 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver3\\) %>% pull(absLog2FC)\n)\nks_result2 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver2\\) %>% pull(absLog2FC)\n)\nks_result3 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver1\\) %>% pull(absLog2FC)\n)\nks_result4 <- ks.test(\n  temp %>% dplyr::filter(psOver == \\psOver4\\) %>% pull(absLog2FC),\n  temp %>% dplyr::filter(psOver == \\psOver0\\) %>% pull(absLog2FC)\n)\n\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\\log2FC_cdf_psGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\\log2FC_barplot_psGroup_dTAG_vs_DMSO_down\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_psGroup_dTAG_vs_DMSO_up\\)\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r
temp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))

ks_result1 <- ks.test(
  temp %>% dplyr::filter(psOver == \psOver4\) %>% pull(absLog2FC),
  temp %>% dplyr::filter(psOver == \psOver3\) %>% pull(absLog2FC)
)
ks_result2 <- ks.test(
  temp %>% dplyr::filter(psOver == \psOver4\) %>% pull(absLog2FC),
  temp %>% dplyr::filter(psOver == \psOver2\) %>% pull(absLog2FC)
)
ks_result3 <- ks.test(
  temp %>% dplyr::filter(psOver == \psOver4\) %>% pull(absLog2FC),
  temp %>% dplyr::filter(psOver == \psOver1\) %>% pull(absLog2FC)
)
ks_result4 <- ks.test(
  temp %>% dplyr::filter(psOver == \psOver4\) %>% pull(absLog2FC),
  temp %>% dplyr::filter(psOver == \psOver0\) %>% pull(absLog2FC)
)

p <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +
scale_color_manual(values = (c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \square\ ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Abs. log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.position = \none\,
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))
fileName <- paste0(\log2FC_cdf_psGroup_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()




#
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
 
ps01 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(tempDown, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver4\), 5)

ps04 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver4\), 5)


p <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \log2(fold change)\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = -0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))
  
fileName <- paste0(\log2FC_barplot_psGroup_dTAG_vs_DMSO_down\)
width <- panelSize(1.2)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
ps01 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(tempUp, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver4\), 5)
ps04 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver4\), 5)




p <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \log2(fold change)\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_psGroup_dTAG_vs_DMSO_up\)
width <- panelSize(1.18)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### loop score

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUIwWlcxd01pQmpiMjUwWVdsdWN5Qm5aVzVsY3lCbWNtOXRJR2R5YjNWd0lERXNJRElzSURVc0lEZ2dZVzVrSUd4dmIzQWdZMjkxYm5SelhHNGpZMkZzWTNWc1lYUnBibWNnWkdsbVppQnpZMjl5WlNCaGJtUWdiRzluTW1aaklHUnBjM1J5YVdKMWRHbHZiaUJpWVhObFpDQnZiaUJ3TFc0Z2JuVnRZbVZ5YzF4dVhHNXdjMDkyWlhJMElEd3RJQ2gwWlcxd01pQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHVkVzFmY0dVZ1BqMGdOQ2twSkdkbGJtVmNibkJ6VDNabGNqTWdQQzBnS0hSbGJYQXlJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRzUxYlY5d1pTQStQU0F6TENCdWRXMWZjR1VnUENBMEtTa2taMlZ1WlZ4dWNITlBkbVZ5TWlBOExTQW9kR1Z0Y0RJZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb2JuVnRYM0JsSUQ0OUlESXNJRzUxYlY5d1pTQThJRE1wS1NSblpXNWxYRzV3YzA5MlpYSXhJRHd0SUNoMFpXMXdNaUFsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWh1ZFcxZmNHVWdQajBnTVN3Z2JuVnRYM0JsSUR3Z01pa3BKR2RsYm1WY2JuQnpUM1psY2pBZ1BDMGdLSFJsYlhBeUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHNTFiVjl3WlNBOElERXBLU1JuWlc1bFhHNWNibHh1WEc0akl5QkVhWFpwWkdsdVp5Qm5aVzVsY3lCcGJuUnZJR2R5YjNWd2MxeHVkR1Z0Y0NBOExTQm5aVzVsUVc1dWIwUmhkR0VnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWkdsbVpsOWtWRUZIWDBSTlUwOHNJR1JwYzNSaGJtTmxMQ0JuWlc1bEtTQWxQaVVnWEc0Z0lIVnVibVZ6ZENoblpXNWxLU0FsUGlVZ1ozSnZkWEJmWW5rb1oyVnVaU2tnSlQ0bFhHNGdJSE4xYlcxaGNtbDZaU2h0WldGdVgyUnBabVpmYzJOdmNtVWdQU0J0WldGdUtHUnBabVpmWkZSQlIxOUVUVk5QS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJRzFsWVc1ZlpHbHpkR0Z1WTJVZ1BTQnRaV0Z1S0dScGMzUmhibU5sS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQzVuY205MWNITWdQU0FuWkhKdmNDY3BYRzVjYm1ScFptWXVVazVCSUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNJbVJwWm1aZlJ6RXVaRlJCUjE5SE1TNHlhUzVrVkVGSFgzWnpYMGN4TGpKcExrUk5VMDh1ZEhOMlhDSXBLU0FsUGlWY2JpQWdaSEJzZVhJNk9uTmxiR1ZqZENobGJuTmxiV0pzWDJkbGJtVmZhV1FzSUd4dlp6SkdiMnhrUTJoaGJtZGxMQ0J6YUhKcGJtdGxaRjlzYjJjeVJrTXNJSEJoWkdvc0lHVjRkR1Z5Ym1Gc1gyZGxibVZmYm1GdFpTbGNibHh1YldGNFRHOW5Na1pESUQwZ01seHVYRzUwWlcxd0lEd3RJR3hsWm5SZmFtOXBiaWgwWlcxd0xDQmthV1ptTGxKT1FTd2dZbmtnUFNCaktGd2laMlZ1WlZ3aUlEMGdYQ0psYm5ObGJXSnNYMmRsYm1WZmFXUmNJaWtwSUNVK0pTQmNiaUFnWkhCc2VYSTZPbTExZEdGMFpTaG1iR0ZuSUQwZ2FXWmxiSE5sS0dkbGJtVWdKV2x1SlNCa2FXWm1MbEpPUVM1SE1TNWtWRUZISkdWdWMyVnRZbXhmWjJWdVpWOXBaQ3dnWENJeVJFOVhUbHdpTENCY0lqQk9UMXdpS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCdFlYaEdiR0ZuSUQwZ0tHRmljeWh6YUhKcGJtdGxaRjlzYjJjeVJrTXBJRDRnYldGNFRHOW5Na1pES1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCc2IyY3labU5OWVhnZ1BTQndiV0Y0S0hCdGFXNG9jMmh5YVc1clpXUmZiRzluTWtaRExDQnRZWGhNYjJjeVJrTXBMQ0F0YldGNFRHOW5Na1pES1NrZ0pUNGxJRnh1SUNCa2NHeDVjam82WVhKeVlXNW5aU2htYkdGbktTQWxQaVZjYmlBZ1pISnZjRjl1WVNoemFISnBibXRsWkY5c2IyY3lSa01wWEc1Y2JuUmxiWEFnUEMwZ2RHVnRjQ0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hjYmlBZ2NITlBkbVZ5SUQwZ2FXWmxiSE5sS0dkbGJtVWdKV2x1SlNCd2MwOTJaWEkwTENCY0luQnpUM1psY2pSY0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaG5aVzVsSUNWcGJpVWdjSE5QZG1WeU15d2dYQ0p3YzA5MlpYSXpYQ0lzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3YzA5MlpYSXlMQ0JjSW5CelQzWmxjakpjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3YzA5MlpYSXhMQ0JjSW5CelQzWmxjakZjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaG5aVzVsSUNWcGJpVWdjSE5QZG1WeU1Dd2dYQ0p3YzA5MlpYSXdYQ0lzSUU1QktTa3BLU2twSUNVK0pWeHVJQ0JrY205d1gyNWhLSEJ6VDNabGNpbGNibHh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbiMgdGVtcDIgY29udGFpbnMgZ2VuZXMgZnJvbSBncm91cCAxLCAyLCA1LCA4IGFuZCBsb29wIGNvdW50c1xuI2NhbGN1bGF0aW5nIGRpZmYgc2NvcmUgYW5kIGxvZzJmYyBkaXN0cmlidXRpb24gYmFzZWQgb24gcC1uIG51bWJlcnNcblxucHNPdmVyNCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDQpKSRnZW5lXG5wc092ZXIzIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMywgbnVtX3BlIDwgNCkpJGdlbmVcbnBzT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAyLCBudW1fcGUgPCAzKSkkZ2VuZVxucHNPdmVyMSA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDEsIG51bV9wZSA8IDIpKSRnZW5lXG5wc092ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPCAxKSkkZ2VuZVxuXG5cblxuIyMgRGl2aWRpbmcgZ2VuZXMgaW50byBncm91cHNcbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmZfZFRBR19ETVNPLCBkaXN0YW5jZSwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmX2RUQUdfRE1TTyksXG4gICAgICAgICAgICBtZWFuX2Rpc3RhbmNlID0gbWVhbihkaXN0YW5jZSksXG4gICAgICAgICAgICAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibF9nZW5lX2lkLCBsb2cyRm9sZENoYW5nZSwgc2hyaW5rZWRfbG9nMkZDLCBwYWRqLCBleHRlcm5hbF9nZW5lX25hbWUpXG5cbm1heExvZzJGQyA9IDJcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcXGdlbmVcXCA9IFxcZW5zZW1ibF9nZW5lX2lkXFwpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoZmxhZyA9IGlmZWxzZShnZW5lICVpbiUgZGlmZi5STkEuRzEuZFRBRyRlbnNlbWJsX2dlbmVfaWQsIFxcMkRPV05cXCwgXFwwTk9cXCksXG4gICAgICAgICAgICAgICAgbWF4RmxhZyA9IChhYnMoc2hyaW5rZWRfbG9nMkZDKSA+IG1heExvZzJGQyksXG4gICAgICAgICAgICAgICAgbG9nMmZjTWF4ID0gcG1heChwbWluKHNocmlua2VkX2xvZzJGQywgbWF4TG9nMkZDKSwgLW1heExvZzJGQykpICU+JSBcbiAgZHBseXI6OmFycmFuZ2UoZmxhZykgJT4lXG4gIGRyb3BfbmEoc2hyaW5rZWRfbG9nMkZDKVxuXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBzT3ZlciA9IGlmZWxzZShnZW5lICVpbiUgcHNPdmVyNCwgXFxwc092ZXI0XFwsXG4gICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjMsIFxccHNPdmVyM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMiwgXFxwc092ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMSwgXFxwc092ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjAsIFxccHNPdmVyMFxcLCBOQSkpKSkpKSAlPiVcbiAgZHJvcF9uYShwc092ZXIpXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

psOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \2DOWN\, \0NO\),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  psOver = ifelse(gene %in% psOver4, \psOver4\,
                  ifelse(gene %in% psOver3, \psOver3\,
                         ifelse(gene %in% psOver2, \psOver2\,
                                ifelse(gene %in% psOver1, \psOver1\,
                                       ifelse(gene %in% psOver0, \psOver0\, NA)))))) %>%
  drop_na(psOver)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QjBaVzF3TWlCamIyNTBZV2x1Y3lCblpXNWxjeUJtY205dElHZHliM1Z3SURFc0lESXNJRFVzSURnZ1lXNWtJR3h2YjNBZ1kyOTFiblJ6WEc0alkyRnNZM1ZzWVhScGJtY2daR2xtWmlCelkyOXlaU0JoYm1RZ2JHOW5NbVpqSUdScGMzUnlhV0oxZEdsdmJpQmlZWE5sWkNCdmJpQndMVzRnYm5WdFltVnljMXh1WEc1d2MwOTJaWEkwSUR3dElDaDBaVzF3TWlBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lodWRXMWZjR1VnUGowZ05Da3BKR2RsYm1WY2JuQnpUM1psY2pNZ1BDMGdLSFJsYlhBeUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHNTFiVjl3WlNBK1BTQXpMQ0J1ZFcxZmNHVWdQQ0EwS1Nra1oyVnVaVnh1Y0hOUGRtVnlNaUE4TFNBb2RHVnRjRElnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvYm5WdFgzQmxJRDQ5SURJc0lHNTFiVjl3WlNBOElETXBLU1JuWlc1bFhHNXdjMDkyWlhJeElEd3RJQ2gwWlcxd01pQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHVkVzFmY0dVZ1BqMGdNU3dnYm5WdFgzQmxJRHdnTWlrcEpHZGxibVZjYm5CelQzWmxjakFnUEMwZ0tIUmxiWEF5SUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0c1MWJWOXdaU0E4SURFcEtTUm5aVzVsWEc1Y2JseHVYRzRqSXlCRWFYWnBaR2x1WnlCblpXNWxjeUJwYm5SdklHZHliM1Z3YzF4dWRHVnRjQ0E4TFNCblpXNWxRVzV1YjBSaGRHRWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aR2xtWmw5a1ZFRkhYMFJOVTA4c0lHUnBjM1JoYm1ObExDQm5aVzVsS1NBbFBpVWdYRzRnSUhWdWJtVnpkQ2huWlc1bEtTQWxQaVVnWjNKdmRYQmZZbmtvWjJWdVpTa2dKVDRsWEc0Z0lITjFiVzFoY21sNlpTaHRaV0Z1WDJScFptWmZjMk52Y21VZ1BTQnRaV0Z1S0dScFptWmZaRlJCUjE5RVRWTlBLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lHMWxZVzVmWkdsemRHRnVZMlVnUFNCdFpXRnVLR1JwYzNSaGJtTmxLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDNW5jbTkxY0hNZ1BTQW5aSEp2Y0NjcFhHNWNibVJwWm1ZdVVrNUJJRHd0SUdaeVpXRmtLR2hsY21Vb2NtVm1SR2x5TENCY1hHUnBabVpmUnpFdVpGUkJSMTlITVM0eWFTNWtWRUZIWDNaelgwY3hMakpwTGtSTlUwOHVkSE4yWEZ3cEtTQWxQaVZjYmlBZ1pIQnNlWEk2T25ObGJHVmpkQ2hsYm5ObGJXSnNYMmRsYm1WZmFXUXNJR3h2WnpKR2IyeGtRMmhoYm1kbExDQnphSEpwYm10bFpGOXNiMmN5UmtNc0lIQmhaR29zSUdWNGRHVnlibUZzWDJkbGJtVmZibUZ0WlNsY2JseHViV0Y0VEc5bk1rWkRJRDBnTWx4dVhHNTBaVzF3SUR3dElHeGxablJmYW05cGJpaDBaVzF3TENCa2FXWm1MbEpPUVN3Z1lua2dQU0JqS0Z4Y1oyVnVaVnhjSUQwZ1hGeGxibk5sYldKc1gyZGxibVZmYVdSY1hDa3BJQ1UrSlNCY2JpQWdaSEJzZVhJNk9tMTFkR0YwWlNobWJHRm5JRDBnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0JrYVdabUxsSk9RUzVITVM1a1ZFRkhKR1Z1YzJWdFlteGZaMlZ1WlY5cFpDd2dYRnd5UkU5WFRseGNMQ0JjWERCT1QxeGNLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J0WVhoR2JHRm5JRDBnS0dGaWN5aHphSEpwYm10bFpGOXNiMmN5UmtNcElENGdiV0Y0VEc5bk1rWkRLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JzYjJjeVptTk5ZWGdnUFNCd2JXRjRLSEJ0YVc0b2MyaHlhVzVyWldSZmJHOW5Na1pETENCdFlYaE1iMmN5UmtNcExDQXRiV0Y0VEc5bk1rWkRLU2tnSlQ0bElGeHVJQ0JrY0d4NWNqbzZZWEp5WVc1blpTaG1iR0ZuS1NBbFBpVmNiaUFnWkhKdmNGOXVZU2h6YUhKcGJtdGxaRjlzYjJjeVJrTXBYRzVjYm5SbGJYQWdQQzBnZEdWdGNDQWxQaVVnWkhCc2VYSTZPbTExZEdGMFpTaGNiaUFnY0hOUGRtVnlJRDBnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3YzA5MlpYSTBMQ0JjWEhCelQzWmxjalJjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNoblpXNWxJQ1ZwYmlVZ2NITlBkbVZ5TXl3Z1hGeHdjMDkyWlhJelhGd3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHZGxibVVnSldsdUpTQndjMDkyWlhJeUxDQmNYSEJ6VDNabGNqSmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHZGxibVVnSldsdUpTQndjMDkyWlhJeExDQmNYSEJ6VDNabGNqRmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNoblpXNWxJQ1ZwYmlVZ2NITlBkbVZ5TUN3Z1hGeHdjMDkyWlhJd1hGd3NJRTVCS1NrcEtTa3BJQ1UrSlZ4dUlDQmtjbTl3WDI1aEtIQnpUM1psY2lsY2JseHVZR0JnWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5gYGByXG4jIHRlbXAyIGNvbnRhaW5zIGdlbmVzIGZyb20gZ3JvdXAgMSwgMiwgNSwgOCBhbmQgbG9vcCBjb3VudHNcbiNjYWxjdWxhdGluZyBkaWZmIHNjb3JlIGFuZCBsb2cyZmMgZGlzdHJpYnV0aW9uIGJhc2VkIG9uIHAtbiBudW1iZXJzXG5cbnBzT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSA0KSkkZ2VuZVxucHNPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDMsIG51bV9wZSA8IDQpKSRnZW5lXG5wc092ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMiwgbnVtX3BlIDwgMykpJGdlbmVcbnBzT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAxLCBudW1fcGUgPCAyKSkkZ2VuZVxucHNPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlIDwgMSkpJGdlbmVcblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX2RUQUdfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9kVEFHX0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGZsYWcgPSBpZmVsc2UoZ2VuZSAlaW4lIGRpZmYuUk5BLkcxLmRUQUckZW5zZW1ibF9nZW5lX2lkLCBcXDJET1dOXFwsIFxcME5PXFwpLFxuICAgICAgICAgICAgICAgIG1heEZsYWcgPSAoYWJzKHNocmlua2VkX2xvZzJGQykgPiBtYXhMb2cyRkMpLFxuICAgICAgICAgICAgICAgIGxvZzJmY01heCA9IHBtYXgocG1pbihzaHJpbmtlZF9sb2cyRkMsIG1heExvZzJGQyksIC1tYXhMb2cyRkMpKSAlPiUgXG4gIGRwbHlyOjphcnJhbmdlKGZsYWcpICU+JVxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6bXV0YXRlKFxuICBwc092ZXIgPSBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjQsIFxccHNPdmVyNFxcLFxuICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIzLCBcXHBzT3ZlcjNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjIsIFxccHNPdmVyMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjEsIFxccHNPdmVyMVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIwLCBcXHBzT3ZlcjBcXCwgTkEpKSkpKSkgJT4lXG4gIGRyb3BfbmEocHNPdmVyKVxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyB0ZW1wMiBjb250YWlucyBnZW5lcyBmcm9tIGdyb3VwIDEsIDIsIDUsIDggYW5kIGxvb3AgY291bnRzXG4jY2FsY3VsYXRpbmcgZGlmZiBzY29yZSBhbmQgbG9nMmZjIGRpc3RyaWJ1dGlvbiBiYXNlZCBvbiBwLW4gbnVtYmVyc1xuXG5wc092ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gNCkpJGdlbmVcbnBzT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAzLCBudW1fcGUgPCA0KSkkZ2VuZVxucHNPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDIsIG51bV9wZSA8IDMpKSRnZW5lXG5wc092ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMSwgbnVtX3BlIDwgMikpJGdlbmVcbnBzT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA8IDEpKSRnZW5lXG5cblxuXG4jIyBEaXZpZGluZyBnZW5lcyBpbnRvIGdyb3Vwc1xudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZl9kVEFHX0RNU08sIGRpc3RhbmNlLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmZfZFRBR19ETVNPKSxcbiAgICAgICAgICAgIG1lYW5fZGlzdGFuY2UgPSBtZWFuKGRpc3RhbmNlKSxcbiAgICAgICAgICAgIC5ncm91cHMgPSAnZHJvcCcpXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxubWF4TG9nMkZDID0gMlxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHBseXI6Om11dGF0ZShmbGFnID0gaWZlbHNlKGdlbmUgJWluJSBkaWZmLlJOQS5HMS5kVEFHJGVuc2VtYmxfZ2VuZV9pZCwgXFwyRE9XTlxcLCBcXDBOT1xcKSxcbiAgICAgICAgICAgICAgICBtYXhGbGFnID0gKGFicyhzaHJpbmtlZF9sb2cyRkMpID4gbWF4TG9nMkZDKSxcbiAgICAgICAgICAgICAgICBsb2cyZmNNYXggPSBwbWF4KHBtaW4oc2hyaW5rZWRfbG9nMkZDLCBtYXhMb2cyRkMpLCAtbWF4TG9nMkZDKSkgJT4lIFxuICBkcGx5cjo6YXJyYW5nZShmbGFnKSAlPiVcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShcbiAgcHNPdmVyID0gaWZlbHNlKGdlbmUgJWluJSBwc092ZXI0LCBcXHBzT3ZlcjRcXCxcbiAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMywgXFxwc092ZXIzXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIyLCBcXHBzT3ZlcjJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIxLCBcXHBzT3ZlcjFcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMCwgXFxwc092ZXIwXFwsIE5BKSkpKSkpICU+JVxuICBkcm9wX25hKHBzT3ZlcilcblxuYGBgXG5gYGAifQ== -->

```r
```r
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

psOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \2DOWN\, \0NO\),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  psOver = ifelse(gene %in% psOver4, \psOver4\,
                  ifelse(gene %in% psOver3, \psOver3\,
                         ifelse(gene %in% psOver2, \psOver2\,
                                ifelse(gene %in% psOver1, \psOver1\,
                                       ifelse(gene %in% psOver0, \psOver0\, NA)))))) %>%
  drop_na(psOver)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### log2FC

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuR09maWdEaXIgPC0gaGVyZShmaWdEaXIsIFwiLi4vR09cIilcbiMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuR08wLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjAsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIiwgcmVhZGFibGUgPSBUUlVFKSlcbkdPMS5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIxLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFwiRU5TRU1CTFwiLCBvbnQgPSBcIkJQXCIsIHJlYWRhYmxlID0gVFJVRSkpXG5HTzIuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiLCByZWFkYWJsZSA9IFRSVUUpKVxuR08zLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjMsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIiwgcmVhZGFibGUgPSBUUlVFKSlcbkdPNC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXI0LCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFwiRU5TRU1CTFwiLCBvbnQgPSBcIkJQXCIsIHJlYWRhYmxlID0gVFJVRSkpXG5cbiMgZndyaXRlKEdPMC5kZiwgaGVyZShcIkdPX1BFX2dyb3VwMC50c3ZcIiksIHNlcCA9IFwiXFx0XCIpXG4jIGZ3cml0ZShHTzEuZGYsIGhlcmUoXCJHT19QRV9ncm91cDEudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuIyBmd3JpdGUoR08yLmRmLCBoZXJlKFwiR09fUEVfZ3JvdXAyLnRzdlwiKSwgc2VwID0gXCJcXHRcIilcbiMgZndyaXRlKEdPMy5kZiwgaGVyZShcIkdPX1BFX2dyb3VwMy50c3ZcIiksIHNlcCA9IFwiXFx0XCIpXG4jIGZ3cml0ZShHTzQuZGYsIGhlcmUoXCJHT19QRV9ncm91cDQudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuXG5cbnN1YnNldDAgPC0gR08wLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcIkdyb3VwIDBcIikgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwiR3JvdXAgMVwiKSAlPiVcbiAgZHBseXI6OmFycmFuZ2UocC5hZGp1c3QpXG5zdWJzZXQyIDwtIEdPMi5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXCJHcm91cCAyXCIpICU+JVxuICBkcGx5cjo6YXJyYW5nZShwLmFkanVzdClcbnN1YnNldDMgPC0gR08zLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcIkdyb3VwIDNcIikgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwiR3JvdXAgNFwiKSAlPiVcbiAgZHBseXI6OmFycmFuZ2UocC5hZGp1c3QpXG5cbnN1YnNldDAkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQwJEdlbmVSYXRpbywgXCIvXCIpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcbnN1YnNldDEkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQxJEdlbmVSYXRpbywgXCIvXCIpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcbnN1YnNldDIkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQyJEdlbmVSYXRpbywgXCIvXCIpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcbnN1YnNldDMkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQzJEdlbmVSYXRpbywgXCIvXCIpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcbnN1YnNldDQkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQ0JEdlbmVSYXRpbywgXCIvXCIpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcblxuR09saXN0IDwtIGZhY3RvcihjKFwiR086MDAwODM4MFwiLCBcIkdPOjAwMDYzOTdcIiwgXCJHTzowMDM0NDcwXCIsIFwiR086MDAyMjYxM1wiLCBcIkdPOjAwMTYwNTVcIixcbiAgICAgICAgICAgICAgICAgICBcIkdPOjAwNjExMzhcIiwgXCJHTzowMDYwNTYyXCIsIFwiR086MDAwNzM4OVwiLCBcIkdPOjAwNjA0ODVcIiwgXCJHTzowMDQ4NjM4XCIsIFwiR086MDA0NTY2NFwiLFxuICAgICAgICAgICAgICAgICAgIFwiR086MDA0MDAyOVwiKSlcblxuZGF0YSA8LSBiaW5kX3Jvd3MoYmluZF9yb3dzKGJpbmRfcm93cyhzdWJzZXQwLCBzdWJzZXQxKSwgc3Vic2V0MiksIHN1YnNldDQpICU+JVxuICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuXG5kZXNjT3JkZXIgPC0gc29ydCh1bmlxdWUoZGF0YSREZXNjcmlwdGlvbikpW3JldihjKDExLCA1LCA2LCAxMCwgMTIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDMsIDcsIDQsIDIsIDksIDgpKV1cblxuZW1wdHlfcm93MyA8LSBkYXRhLmZyYW1lKFxuICBJRCA9IE5BLCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIyBObyBzcGVjaWZpYyBJRFxuICBEZXNjcmlwdGlvbiA9IE5BLCAgICAgICAgICAgICAgICAgICAgIyBObyBkZXNjcmlwdGlvblxuICBHZW5lUmF0aW8gPSBOQSwgICAgICAgICAgICAgICAgICAgICAgIyBObyBnZW5lIHJhdGlvXG4gIHAuYWRqdXN0ID0gTkEsICAgICAgICAgICAgICAgICAgICAgICAjIE5vIHAuYWRqdXN0IHZhbHVlXG4gIGdyb3VwID0gXCJHcm91cCAzXCIgICAgICAgICAgICAgICAgICAgIyBHcm91cCB0byBhZGQgYXMgZW1wdHkgY29sdW1uXG4pXG5cbmVtcHR5X3JvdzQgPC0gZGF0YS5mcmFtZShcbiAgSUQgPSBOQSwgICAgICAgICAgICAgICAgICAgICAgICAgICAgICMgTm8gc3BlY2lmaWMgSURcbiAgRGVzY3JpcHRpb24gPSBOQSwgICAgICAgICAgICAgICAgICAgICMgTm8gZGVzY3JpcHRpb25cbiAgR2VuZVJhdGlvID0gTkEsICAgICAgICAgICAgICAgICAgICAgICMgTm8gZ2VuZSByYXRpb1xuICBwLmFkanVzdCA9IE5BLCAgICAgICAgICAgICAgICAgICAgICAgIyBObyBwLmFkanVzdCB2YWx1ZVxuICBncm91cCA9IFwiR3JvdXAgNFwiICAgICAgICAgICAgICAgICAgICMgR3JvdXAgdG8gYWRkIGFzIGVtcHR5IGNvbHVtblxuKVxuXG4jIEFwcGVuZCB0aGUgZW1wdHkgcm93IHRvIHlvdXIgZGF0YXNldFxuZGF0YSA8LSByYmluZChkYXRhLCBlbXB0eV9yb3czLCBlbXB0eV9yb3c0KVxuXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiUgZHBseXI6Om11dGF0ZShwVmFsdWVMb2cgPSBtaW4oLWxvZzEwKHAuYWRqdXN0KSwgcFZhbHVlTG9nTWF4KSlcbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBmYWN0b3IoRGVzY3JpcHRpb24sIGxldmVscyA9IGRlc2NPcmRlciksIHNpemUgPSBwVmFsdWVMb2csIGZpbGwgPSBHZW5lUmF0aW8pKSArIFxuICBnZW9tX3BvaW50KHNoYXBlID0gMjEsICAgICAgICAjIEVuc3VyZXMgYSBwb2ludCB3aXRoIGFuIG91dGxpbmVcbiAgICAgICAgICAgICBzdHJva2UgPSAxKnB0VG9NTSkgKyBcbiAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygwLjUsIDIpKSArICAjIFNldCBtaW4gYW5kIG1heCBwb2ludCBzaXplcyBoZXJlXG4gIHNjYWxlX2ZpbGxfZ3JhZGllbnQobG93ID0gXCJ3aGl0ZVwiLCBoaWdoID0gXCIjQ0IzMzNBXCIsXG4gICAgICAgICAgICAgICAgICAgICAgIyBsaW1pdHMgPSBjKDAsIDEpLFxuICAgICAgICAgICAgICAgICAgICAgIG9vYiA9IHNjYWxlczo6c3F1aXNoLCAjIERlZmluZSBncmFkaWVudCBjb2xvcnNcbiAgICAgICAgICAgICAgICAgICAgICBndWlkZSA9IGd1aWRlX2NvbG9yYmFyKFxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyd2lkdGggPSAxLjUvNS4wOCwgICMgQWRqdXN0IHdpZHRoIG9mIHRoZSBjb2xvciBiYXJcbiAgICAgICAgICAgICAgICAgICAgICAgIGJhcmhlaWdodCA9IDE1LzUuMDggICAjIEFkanVzdCBoZWlnaHQgb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgIClcbiAgKSArIFxuICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuICB0aGVtZV9idygpICsgICMgQXBwbHkgdGhlbWVfYncgZmlyc3QsIHNvIGN1c3RvbSB0aGVtZSBzZXR0aW5ncyBjb21lIGFmdGVyXG4gIHRoZW1lKFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFwidHJhbnNwYXJlbnRcIiksICAjIE92ZXJyaWRlIHRoZW1lX2J3IHBhbmVsXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgICAgICAgICAjIEVuc3VyZSBzaXplIGlzIHNldCBmb3IgeC1heGlzIHRleHRcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICApLFxuICAgIGF4aXMudGV4dC55ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgICAgICAgICAjIEVuc3VyZSBzaXplIGlzIHNldCBmb3IgeS1heGlzIHRleHRcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICAgIGxpbmVoZWlnaHQgPSAwLjkgICAgICAgICAgIyBBbGxvd3Mgd3JhcHBpbmcgZm9yIHktYXhpcyBsYWJlbHMgdG8gZml0IGludG8gMiBsaW5lc1xuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCIsXG4gICAgICBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gIClcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFwiLi5cIiwgXCJHT1wiLCBcIkdPX2dyb3Vwc19wZVwiKVxud2lkdGggPC0gcGFuZWxTaXplKDIuNjUpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuMykqbW1Ub0luY2hcbnN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIiksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYCJ9 -->\n\n```r\nGOfigDir <- here(figDir, \\../GO\\)\n#####################\nGO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\n\n# fwrite(GO0.df, here(\\GO_PE_group0.tsv\\), sep = \\\\t\\)\n# fwrite(GO1.df, here(\\GO_PE_group1.tsv\\), sep = \\\\t\\)\n# fwrite(GO2.df, here(\\GO_PE_group2.tsv\\), sep = \\\\t\\)\n# fwrite(GO3.df, here(\\GO_PE_group3.tsv\\), sep = \\\\t\\)\n# fwrite(GO4.df, here(\\GO_PE_group4.tsv\\), sep = \\\\t\\)\n\n\nsubset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 0\\) %>%\n  dplyr::arrange(p.adjust)\nsubset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 1\\) %>%\n  dplyr::arrange(p.adjust)\nsubset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 2\\) %>%\n  dplyr::arrange(p.adjust)\nsubset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 3\\) %>%\n  dplyr::arrange(p.adjust)\nsubset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 4\\) %>%\n  dplyr::arrange(p.adjust)\n\nsubset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\n\nGOlist <- factor(c(\\GO:0008380\\, \\GO:0006397\\, \\GO:0034470\\, \\GO:0022613\\, \\GO:0016055\\,\n                   \\GO:0061138\\, \\GO:0060562\\, \\GO:0007389\\, \\GO:0060485\\, \\GO:0048638\\, \\GO:0045664\\,\n                   \\GO:0040029\\))\n\ndata <- bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset4) %>%\n  dplyr::filter(ID %in% GOlist)\n\ndescOrder <- sort(unique(data$Description))[rev(c(11, 5, 6, 10, 12,\n                                                  1,\n                                                  3, 7, 4, 2, 9, 8))]\n\nempty_row3 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 3\\                   # Group to add as empty column\n)\n\nempty_row4 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 4\\                   # Group to add as empty column\n)\n\n# Append the empty row to your dataset\ndata <- rbind(data, empty_row3, empty_row4)\n\n\ndata <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))\np <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + \n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM) + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      # limits = c(0, 1),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL) +\n  theme_bw() +  # Apply theme_bw first, so custom theme settings come after\n  theme(\n    panel.background = element_rect(fill = \\transparent\\),  # Override theme_bw panel\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      size = fontSizeS,         # Ensure size is set for x-axis text\n      family = fontType,\n      color = \\#000000\\,\n    ),\n    axis.text.y = element_text(\n      size = fontSizeS,         # Ensure size is set for y-axis text\n      family = fontType,\n      color = \\#000000\\,\n      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pe\\)\nwidth <- panelSize(2.65)*mmToInch\nheight <- panelSize(1.3)*mmToInch\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
GOfigDir <- here(figDir, \../GO\)
#####################
GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))

# fwrite(GO0.df, here(\GO_PE_group0.tsv\), sep = \\t\)
# fwrite(GO1.df, here(\GO_PE_group1.tsv\), sep = \\t\)
# fwrite(GO2.df, here(\GO_PE_group2.tsv\), sep = \\t\)
# fwrite(GO3.df, here(\GO_PE_group3.tsv\), sep = \\t\)
# fwrite(GO4.df, here(\GO_PE_group4.tsv\), sep = \\t\)


subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 0\) %>%
  dplyr::arrange(p.adjust)
subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 1\) %>%
  dplyr::arrange(p.adjust)
subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 2\) %>%
  dplyr::arrange(p.adjust)
subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 3\) %>%
  dplyr::arrange(p.adjust)
subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 4\) %>%
  dplyr::arrange(p.adjust)

subset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))

GOlist <- factor(c(\GO:0008380\, \GO:0006397\, \GO:0034470\, \GO:0022613\, \GO:0016055\,
                   \GO:0061138\, \GO:0060562\, \GO:0007389\, \GO:0060485\, \GO:0048638\, \GO:0045664\,
                   \GO:0040029\))

data <- bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset4) %>%
  dplyr::filter(ID %in% GOlist)

descOrder <- sort(unique(data$Description))[rev(c(11, 5, 6, 10, 12,
                                                  1,
                                                  3, 7, 4, 2, 9, 8))]

empty_row3 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = \Group 3\                   # Group to add as empty column
)

empty_row4 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = \Group 4\                   # Group to add as empty column
)

# Append the empty row to your dataset
data <- rbind(data, empty_row3, empty_row4)


data <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))
p <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + 
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM) + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = \white\, high = \#CB333A\,
                      # limits = c(0, 1),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL) +
  theme_bw() +  # Apply theme_bw first, so custom theme settings come after
  theme(
    panel.background = element_rect(fill = \transparent\),  # Override theme_bw panel
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      size = fontSizeS,         # Ensure size is set for x-axis text
      family = fontType,
      color = \#000000\,
    ),
    axis.text.y = element_text(
      size = fontSizeS,         # Ensure size is set for y-axis text
      family = fontType,
      color = \#000000\,
      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, \..\, \GO\, \GO_groups_pe\)
width <- panelSize(2.65)*mmToInch
height <- panelSize(1.3)*mmToInch
svglite(paste0(fileName, \.svg\), height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuR09maWdEaXIgPC0gaGVyZShmaWdEaXIsIFxcLi4vR09cXClcbiMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuR08wLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjAsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCwgcmVhZGFibGUgPSBUUlVFKSlcbkdPMS5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIxLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwsIHJlYWRhYmxlID0gVFJVRSkpXG5HTzIuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcLCByZWFkYWJsZSA9IFRSVUUpKVxuR08zLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjMsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCwgcmVhZGFibGUgPSBUUlVFKSlcbkdPNC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXI0LCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwsIHJlYWRhYmxlID0gVFJVRSkpXG5cbiMgZndyaXRlKEdPMC5kZiwgaGVyZShcXEdPX1BFX2dyb3VwMC50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG4jIGZ3cml0ZShHTzEuZGYsIGhlcmUoXFxHT19QRV9ncm91cDEudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuIyBmd3JpdGUoR08yLmRmLCBoZXJlKFxcR09fUEVfZ3JvdXAyLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbiMgZndyaXRlKEdPMy5kZiwgaGVyZShcXEdPX1BFX2dyb3VwMy50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG4jIGZ3cml0ZShHTzQuZGYsIGhlcmUoXFxHT19QRV9ncm91cDQudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG5cbnN1YnNldDAgPC0gR08wLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXEdyb3VwIDBcXCkgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcR3JvdXAgMVxcKSAlPiVcbiAgZHBseXI6OmFycmFuZ2UocC5hZGp1c3QpXG5zdWJzZXQyIDwtIEdPMi5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxHcm91cCAyXFwpICU+JVxuICBkcGx5cjo6YXJyYW5nZShwLmFkanVzdClcbnN1YnNldDMgPC0gR08zLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXEdyb3VwIDNcXCkgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcR3JvdXAgNFxcKSAlPiVcbiAgZHBseXI6OmFycmFuZ2UocC5hZGp1c3QpXG5cbnN1YnNldDAkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQwJEdlbmVSYXRpbywgXFwvXFwpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcbnN1YnNldDEkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQxJEdlbmVSYXRpbywgXFwvXFwpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcbnN1YnNldDIkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQyJEdlbmVSYXRpbywgXFwvXFwpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcbnN1YnNldDMkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQzJEdlbmVSYXRpbywgXFwvXFwpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcbnN1YnNldDQkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQ0JEdlbmVSYXRpbywgXFwvXFwpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcblxuR09saXN0IDwtIGZhY3RvcihjKFxcR086MDAwODM4MFxcLCBcXEdPOjAwMDYzOTdcXCwgXFxHTzowMDM0NDcwXFwsIFxcR086MDAyMjYxM1xcLCBcXEdPOjAwMTYwNTVcXCxcbiAgICAgICAgICAgICAgICAgICBcXEdPOjAwNjExMzhcXCwgXFxHTzowMDYwNTYyXFwsIFxcR086MDAwNzM4OVxcLCBcXEdPOjAwNjA0ODVcXCwgXFxHTzowMDQ4NjM4XFwsIFxcR086MDA0NTY2NFxcLFxuICAgICAgICAgICAgICAgICAgIFxcR086MDA0MDAyOVxcKSlcblxuZGF0YSA8LSBiaW5kX3Jvd3MoYmluZF9yb3dzKGJpbmRfcm93cyhzdWJzZXQwLCBzdWJzZXQxKSwgc3Vic2V0MiksIHN1YnNldDQpICU+JVxuICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuXG5kZXNjT3JkZXIgPC0gc29ydCh1bmlxdWUoZGF0YSREZXNjcmlwdGlvbikpW3JldihjKDExLCA1LCA2LCAxMCwgMTIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDMsIDcsIDQsIDIsIDksIDgpKV1cblxuZW1wdHlfcm93MyA8LSBkYXRhLmZyYW1lKFxuICBJRCA9IE5BLCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIyBObyBzcGVjaWZpYyBJRFxuICBEZXNjcmlwdGlvbiA9IE5BLCAgICAgICAgICAgICAgICAgICAgIyBObyBkZXNjcmlwdGlvblxuICBHZW5lUmF0aW8gPSBOQSwgICAgICAgICAgICAgICAgICAgICAgIyBObyBnZW5lIHJhdGlvXG4gIHAuYWRqdXN0ID0gTkEsICAgICAgICAgICAgICAgICAgICAgICAjIE5vIHAuYWRqdXN0IHZhbHVlXG4gIGdyb3VwID0gXFxHcm91cCAzXFwgICAgICAgICAgICAgICAgICAgIyBHcm91cCB0byBhZGQgYXMgZW1wdHkgY29sdW1uXG4pXG5cbmVtcHR5X3JvdzQgPC0gZGF0YS5mcmFtZShcbiAgSUQgPSBOQSwgICAgICAgICAgICAgICAgICAgICAgICAgICAgICMgTm8gc3BlY2lmaWMgSURcbiAgRGVzY3JpcHRpb24gPSBOQSwgICAgICAgICAgICAgICAgICAgICMgTm8gZGVzY3JpcHRpb25cbiAgR2VuZVJhdGlvID0gTkEsICAgICAgICAgICAgICAgICAgICAgICMgTm8gZ2VuZSByYXRpb1xuICBwLmFkanVzdCA9IE5BLCAgICAgICAgICAgICAgICAgICAgICAgIyBObyBwLmFkanVzdCB2YWx1ZVxuICBncm91cCA9IFxcR3JvdXAgNFxcICAgICAgICAgICAgICAgICAgICMgR3JvdXAgdG8gYWRkIGFzIGVtcHR5IGNvbHVtblxuKVxuXG4jIEFwcGVuZCB0aGUgZW1wdHkgcm93IHRvIHlvdXIgZGF0YXNldFxuZGF0YSA8LSByYmluZChkYXRhLCBlbXB0eV9yb3czLCBlbXB0eV9yb3c0KVxuXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiUgZHBseXI6Om11dGF0ZShwVmFsdWVMb2cgPSBtaW4oLWxvZzEwKHAuYWRqdXN0KSwgcFZhbHVlTG9nTWF4KSlcbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBmYWN0b3IoRGVzY3JpcHRpb24sIGxldmVscyA9IGRlc2NPcmRlciksIHNpemUgPSBwVmFsdWVMb2csIGZpbGwgPSBHZW5lUmF0aW8pKSArIFxuICBnZW9tX3BvaW50KHNoYXBlID0gMjEsICAgICAgICAjIEVuc3VyZXMgYSBwb2ludCB3aXRoIGFuIG91dGxpbmVcbiAgICAgICAgICAgICBzdHJva2UgPSAxKnB0VG9NTSkgKyBcbiAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygwLjUsIDIpKSArICAjIFNldCBtaW4gYW5kIG1heCBwb2ludCBzaXplcyBoZXJlXG4gIHNjYWxlX2ZpbGxfZ3JhZGllbnQobG93ID0gXFx3aGl0ZVxcLCBoaWdoID0gXFwjQ0IzMzNBXFwsXG4gICAgICAgICAgICAgICAgICAgICAgIyBsaW1pdHMgPSBjKDAsIDEpLFxuICAgICAgICAgICAgICAgICAgICAgIG9vYiA9IHNjYWxlczo6c3F1aXNoLCAjIERlZmluZSBncmFkaWVudCBjb2xvcnNcbiAgICAgICAgICAgICAgICAgICAgICBndWlkZSA9IGd1aWRlX2NvbG9yYmFyKFxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyd2lkdGggPSAxLjUvNS4wOCwgICMgQWRqdXN0IHdpZHRoIG9mIHRoZSBjb2xvciBiYXJcbiAgICAgICAgICAgICAgICAgICAgICAgIGJhcmhlaWdodCA9IDE1LzUuMDggICAjIEFkanVzdCBoZWlnaHQgb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgIClcbiAgKSArIFxuICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuICB0aGVtZV9idygpICsgICMgQXBwbHkgdGhlbWVfYncgZmlyc3QsIHNvIGN1c3RvbSB0aGVtZSBzZXR0aW5ncyBjb21lIGFmdGVyXG4gIHRoZW1lKFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksICAjIE92ZXJyaWRlIHRoZW1lX2J3IHBhbmVsXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgICAgICAgICAjIEVuc3VyZSBzaXplIGlzIHNldCBmb3IgeC1heGlzIHRleHRcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICApLFxuICAgIGF4aXMudGV4dC55ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgICAgICAgICAjIEVuc3VyZSBzaXplIGlzIHNldCBmb3IgeS1heGlzIHRleHRcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIGxpbmVoZWlnaHQgPSAwLjkgICAgICAgICAgIyBBbGxvd3Mgd3JhcHBpbmcgZm9yIHktYXhpcyBsYWJlbHMgdG8gZml0IGludG8gMiBsaW5lc1xuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gIClcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc19wZVxcKVxud2lkdGggPC0gcGFuZWxTaXplKDIuNjUpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuMykqbW1Ub0luY2hcbnN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\nGOfigDir <- here(figDir, \\../GO\\)\n#####################\nGO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\n\n# fwrite(GO0.df, here(\\GO_PE_group0.tsv\\), sep = \\\\t\\)\n# fwrite(GO1.df, here(\\GO_PE_group1.tsv\\), sep = \\\\t\\)\n# fwrite(GO2.df, here(\\GO_PE_group2.tsv\\), sep = \\\\t\\)\n# fwrite(GO3.df, here(\\GO_PE_group3.tsv\\), sep = \\\\t\\)\n# fwrite(GO4.df, here(\\GO_PE_group4.tsv\\), sep = \\\\t\\)\n\n\nsubset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 0\\) %>%\n  dplyr::arrange(p.adjust)\nsubset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 1\\) %>%\n  dplyr::arrange(p.adjust)\nsubset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 2\\) %>%\n  dplyr::arrange(p.adjust)\nsubset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 3\\) %>%\n  dplyr::arrange(p.adjust)\nsubset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 4\\) %>%\n  dplyr::arrange(p.adjust)\n\nsubset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\n\nGOlist <- factor(c(\\GO:0008380\\, \\GO:0006397\\, \\GO:0034470\\, \\GO:0022613\\, \\GO:0016055\\,\n                   \\GO:0061138\\, \\GO:0060562\\, \\GO:0007389\\, \\GO:0060485\\, \\GO:0048638\\, \\GO:0045664\\,\n                   \\GO:0040029\\))\n\ndata <- bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset4) %>%\n  dplyr::filter(ID %in% GOlist)\n\ndescOrder <- sort(unique(data$Description))[rev(c(11, 5, 6, 10, 12,\n                                                  1,\n                                                  3, 7, 4, 2, 9, 8))]\n\nempty_row3 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 3\\                   # Group to add as empty column\n)\n\nempty_row4 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 4\\                   # Group to add as empty column\n)\n\n# Append the empty row to your dataset\ndata <- rbind(data, empty_row3, empty_row4)\n\n\ndata <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))\np <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + \n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM) + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      # limits = c(0, 1),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL) +\n  theme_bw() +  # Apply theme_bw first, so custom theme settings come after\n  theme(\n    panel.background = element_rect(fill = \\transparent\\),  # Override theme_bw panel\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      size = fontSizeS,         # Ensure size is set for x-axis text\n      family = fontType,\n      color = \\#000000\\,\n    ),\n    axis.text.y = element_text(\n      size = fontSizeS,         # Ensure size is set for y-axis text\n      family = fontType,\n      color = \\#000000\\,\n      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pe\\)\nwidth <- panelSize(2.65)*mmToInch\nheight <- panelSize(1.3)*mmToInch\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuR09maWdEaXIgPC0gaGVyZShmaWdEaXIsIFxcLi4vR09cXClcbiMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuR08wLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjAsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCwgcmVhZGFibGUgPSBUUlVFKSlcbkdPMS5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIxLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwsIHJlYWRhYmxlID0gVFJVRSkpXG5HTzIuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcLCByZWFkYWJsZSA9IFRSVUUpKVxuR08zLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjMsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCwgcmVhZGFibGUgPSBUUlVFKSlcbkdPNC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXI0LCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwsIHJlYWRhYmxlID0gVFJVRSkpXG5cbiMgZndyaXRlKEdPMC5kZiwgaGVyZShcXEdPX1BFX2dyb3VwMC50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG4jIGZ3cml0ZShHTzEuZGYsIGhlcmUoXFxHT19QRV9ncm91cDEudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuIyBmd3JpdGUoR08yLmRmLCBoZXJlKFxcR09fUEVfZ3JvdXAyLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcbiMgZndyaXRlKEdPMy5kZiwgaGVyZShcXEdPX1BFX2dyb3VwMy50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG4jIGZ3cml0ZShHTzQuZGYsIGhlcmUoXFxHT19QRV9ncm91cDQudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG5cbnN1YnNldDAgPC0gR08wLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXEdyb3VwIDBcXCkgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcR3JvdXAgMVxcKSAlPiVcbiAgZHBseXI6OmFycmFuZ2UocC5hZGp1c3QpXG5zdWJzZXQyIDwtIEdPMi5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxHcm91cCAyXFwpICU+JVxuICBkcGx5cjo6YXJyYW5nZShwLmFkanVzdClcbnN1YnNldDMgPC0gR08zLmRmICU+JSBkcGx5cjo6c2VsZWN0KElELCBEZXNjcmlwdGlvbiwgR2VuZVJhdGlvLCBwLmFkanVzdCkgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXEdyb3VwIDNcXCkgJT4lXG4gIGRwbHlyOjphcnJhbmdlKHAuYWRqdXN0KVxuc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcR3JvdXAgNFxcKSAlPiVcbiAgZHBseXI6OmFycmFuZ2UocC5hZGp1c3QpXG5cbnN1YnNldDAkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQwJEdlbmVSYXRpbywgXFwvXFwpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcbnN1YnNldDEkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQxJEdlbmVSYXRpbywgXFwvXFwpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcbnN1YnNldDIkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQyJEdlbmVSYXRpbywgXFwvXFwpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcbnN1YnNldDMkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQzJEdlbmVSYXRpbywgXFwvXFwpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcbnN1YnNldDQkR2VuZVJhdGlvIDwtIHNhcHBseShzdHJzcGxpdChzdWJzZXQ0JEdlbmVSYXRpbywgXFwvXFwpLCBmdW5jdGlvbih4KSBhcy5udW1lcmljKHhbMV0pIC8gYXMubnVtZXJpYyh4WzJdKSlcblxuR09saXN0IDwtIGZhY3RvcihjKFxcR086MDAwODM4MFxcLCBcXEdPOjAwMDYzOTdcXCwgXFxHTzowMDM0NDcwXFwsIFxcR086MDAyMjYxM1xcLCBcXEdPOjAwMTYwNTVcXCxcbiAgICAgICAgICAgICAgICAgICBcXEdPOjAwNjExMzhcXCwgXFxHTzowMDYwNTYyXFwsIFxcR086MDAwNzM4OVxcLCBcXEdPOjAwNjA0ODVcXCwgXFxHTzowMDQ4NjM4XFwsIFxcR086MDA0NTY2NFxcLFxuICAgICAgICAgICAgICAgICAgIFxcR086MDA0MDAyOVxcKSlcblxuZGF0YSA8LSBiaW5kX3Jvd3MoYmluZF9yb3dzKGJpbmRfcm93cyhzdWJzZXQwLCBzdWJzZXQxKSwgc3Vic2V0MiksIHN1YnNldDQpICU+JVxuICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuXG5kZXNjT3JkZXIgPC0gc29ydCh1bmlxdWUoZGF0YSREZXNjcmlwdGlvbikpW3JldihjKDExLCA1LCA2LCAxMCwgMTIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDMsIDcsIDQsIDIsIDksIDgpKV1cblxuZW1wdHlfcm93MyA8LSBkYXRhLmZyYW1lKFxuICBJRCA9IE5BLCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIyBObyBzcGVjaWZpYyBJRFxuICBEZXNjcmlwdGlvbiA9IE5BLCAgICAgICAgICAgICAgICAgICAgIyBObyBkZXNjcmlwdGlvblxuICBHZW5lUmF0aW8gPSBOQSwgICAgICAgICAgICAgICAgICAgICAgIyBObyBnZW5lIHJhdGlvXG4gIHAuYWRqdXN0ID0gTkEsICAgICAgICAgICAgICAgICAgICAgICAjIE5vIHAuYWRqdXN0IHZhbHVlXG4gIGdyb3VwID0gXFxHcm91cCAzXFwgICAgICAgICAgICAgICAgICAgIyBHcm91cCB0byBhZGQgYXMgZW1wdHkgY29sdW1uXG4pXG5cbmVtcHR5X3JvdzQgPC0gZGF0YS5mcmFtZShcbiAgSUQgPSBOQSwgICAgICAgICAgICAgICAgICAgICAgICAgICAgICMgTm8gc3BlY2lmaWMgSURcbiAgRGVzY3JpcHRpb24gPSBOQSwgICAgICAgICAgICAgICAgICAgICMgTm8gZGVzY3JpcHRpb25cbiAgR2VuZVJhdGlvID0gTkEsICAgICAgICAgICAgICAgICAgICAgICMgTm8gZ2VuZSByYXRpb1xuICBwLmFkanVzdCA9IE5BLCAgICAgICAgICAgICAgICAgICAgICAgIyBObyBwLmFkanVzdCB2YWx1ZVxuICBncm91cCA9IFxcR3JvdXAgNFxcICAgICAgICAgICAgICAgICAgICMgR3JvdXAgdG8gYWRkIGFzIGVtcHR5IGNvbHVtblxuKVxuXG4jIEFwcGVuZCB0aGUgZW1wdHkgcm93IHRvIHlvdXIgZGF0YXNldFxuZGF0YSA8LSByYmluZChkYXRhLCBlbXB0eV9yb3czLCBlbXB0eV9yb3c0KVxuXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiUgZHBseXI6Om11dGF0ZShwVmFsdWVMb2cgPSBtaW4oLWxvZzEwKHAuYWRqdXN0KSwgcFZhbHVlTG9nTWF4KSlcbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBmYWN0b3IoRGVzY3JpcHRpb24sIGxldmVscyA9IGRlc2NPcmRlciksIHNpemUgPSBwVmFsdWVMb2csIGZpbGwgPSBHZW5lUmF0aW8pKSArIFxuICBnZW9tX3BvaW50KHNoYXBlID0gMjEsICAgICAgICAjIEVuc3VyZXMgYSBwb2ludCB3aXRoIGFuIG91dGxpbmVcbiAgICAgICAgICAgICBzdHJva2UgPSAxKnB0VG9NTSkgKyBcbiAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygwLjUsIDIpKSArICAjIFNldCBtaW4gYW5kIG1heCBwb2ludCBzaXplcyBoZXJlXG4gIHNjYWxlX2ZpbGxfZ3JhZGllbnQobG93ID0gXFx3aGl0ZVxcLCBoaWdoID0gXFwjQ0IzMzNBXFwsXG4gICAgICAgICAgICAgICAgICAgICAgIyBsaW1pdHMgPSBjKDAsIDEpLFxuICAgICAgICAgICAgICAgICAgICAgIG9vYiA9IHNjYWxlczo6c3F1aXNoLCAjIERlZmluZSBncmFkaWVudCBjb2xvcnNcbiAgICAgICAgICAgICAgICAgICAgICBndWlkZSA9IGd1aWRlX2NvbG9yYmFyKFxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyd2lkdGggPSAxLjUvNS4wOCwgICMgQWRqdXN0IHdpZHRoIG9mIHRoZSBjb2xvciBiYXJcbiAgICAgICAgICAgICAgICAgICAgICAgIGJhcmhlaWdodCA9IDE1LzUuMDggICAjIEFkanVzdCBoZWlnaHQgb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgIClcbiAgKSArIFxuICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuICB0aGVtZV9idygpICsgICMgQXBwbHkgdGhlbWVfYncgZmlyc3QsIHNvIGN1c3RvbSB0aGVtZSBzZXR0aW5ncyBjb21lIGFmdGVyXG4gIHRoZW1lKFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksICAjIE92ZXJyaWRlIHRoZW1lX2J3IHBhbmVsXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgICAgICAgICAjIEVuc3VyZSBzaXplIGlzIHNldCBmb3IgeC1heGlzIHRleHRcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICApLFxuICAgIGF4aXMudGV4dC55ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgICAgICAgICAjIEVuc3VyZSBzaXplIGlzIHNldCBmb3IgeS1heGlzIHRleHRcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIGxpbmVoZWlnaHQgPSAwLjkgICAgICAgICAgIyBBbGxvd3Mgd3JhcHBpbmcgZm9yIHktYXhpcyBsYWJlbHMgdG8gZml0IGludG8gMiBsaW5lc1xuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gIClcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc19wZVxcKVxud2lkdGggPC0gcGFuZWxTaXplKDIuNjUpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuMykqbW1Ub0luY2hcbnN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
GOfigDir <- here(figDir, \../GO\)
#####################
GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))

# fwrite(GO0.df, here(\GO_PE_group0.tsv\), sep = \\t\)
# fwrite(GO1.df, here(\GO_PE_group1.tsv\), sep = \\t\)
# fwrite(GO2.df, here(\GO_PE_group2.tsv\), sep = \\t\)
# fwrite(GO3.df, here(\GO_PE_group3.tsv\), sep = \\t\)
# fwrite(GO4.df, here(\GO_PE_group4.tsv\), sep = \\t\)


subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 0\) %>%
  dplyr::arrange(p.adjust)
subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 1\) %>%
  dplyr::arrange(p.adjust)
subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 2\) %>%
  dplyr::arrange(p.adjust)
subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 3\) %>%
  dplyr::arrange(p.adjust)
subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 4\) %>%
  dplyr::arrange(p.adjust)

subset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))

GOlist <- factor(c(\GO:0008380\, \GO:0006397\, \GO:0034470\, \GO:0022613\, \GO:0016055\,
                   \GO:0061138\, \GO:0060562\, \GO:0007389\, \GO:0060485\, \GO:0048638\, \GO:0045664\,
                   \GO:0040029\))

data <- bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset4) %>%
  dplyr::filter(ID %in% GOlist)

descOrder <- sort(unique(data$Description))[rev(c(11, 5, 6, 10, 12,
                                                  1,
                                                  3, 7, 4, 2, 9, 8))]

empty_row3 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = \Group 3\                   # Group to add as empty column
)

empty_row4 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = \Group 4\                   # Group to add as empty column
)

# Append the empty row to your dataset
data <- rbind(data, empty_row3, empty_row4)


data <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))
p <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + 
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM) + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = \white\, high = \#CB333A\,
                      # limits = c(0, 1),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL) +
  theme_bw() +  # Apply theme_bw first, so custom theme settings come after
  theme(
    panel.background = element_rect(fill = \transparent\),  # Override theme_bw panel
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      size = fontSizeS,         # Ensure size is set for x-axis text
      family = fontType,
      color = \#000000\,
    ),
    axis.text.y = element_text(
      size = fontSizeS,         # Ensure size is set for y-axis text
      family = fontType,
      color = \#000000\,
      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, \..\, \GO\, \GO_groups_pe\)
width <- panelSize(2.65)*mmToInch
height <- panelSize(1.3)*mmToInch
svglite(paste0(fileName, \.svg\), height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



#### Grouping with P-E number
##### Grouping

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXCJwc092ZXIwXCIsIFwicHNPdmVyMVwiKSwgNSlcbnBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcInBzT3ZlcjFcIiwgXCJwc092ZXIyXCIpLCA1KVxucHMyMyA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFwicHNPdmVyMlwiLCBcInBzT3ZlcjNcIiksIDUpXG5wczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXCJwc092ZXIzXCIsIFwicHNPdmVyNFwiKSwgNSlcbnBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcInBzT3ZlcjJcIiwgXCJwc092ZXI0XCIpLCA1KVxucHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFwicHNPdmVyMVwiLCBcInBzT3ZlcjRcIiksIDUpXG5wczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXCJwc092ZXIwXCIsIFwicHNPdmVyNFwiKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBzT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgXG4gICAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcIiM3Nzc3NzdcIiwgXCIjOEI3RTY1XCIsIFwiI0EyODQ1MlwiLCBcIiNDMjg4NERcIiwgXCIjRjI4RTJDXCIpKSArXG4gIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgXG4gICAgICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLFxuICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIixcbiAgICAgICAgICAgICAgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXCJibGFja1wiLFxuICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZU1lZGl1bSAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCIsXG4gICAgICAgICAgICAgICBvdXRsaWVyLnNoYXBlID0gTkFcbiAgKSArIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXCJBdmVyYWdlIM6UIGxvb3Agc2NvcmVcIikgK1xuICBzdGF0X3N1bW1hcnkoXG4gICAgYWVzKGdyb3VwID0gcHNPdmVyKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcImJsYWNrXCIsIGNvbG9yID0gXCJibGFja1wiXG4gICkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFwiIzAwMDAwMFwiXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIiwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXCJ0cmFuc3BhcmVudFwiKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApK1xuICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcInBzMDE6IFwiLCBjb252UHZhbHVlKHBzMDEpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczEyOiBcIiwgY29udlB2YWx1ZShwczEyKSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHMyMzogXCIsIGNvbnZQdmFsdWUocHMyMyksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMzQ6IFwiLCBjb252UHZhbHVlKHBzMzQpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczI0OiBcIiwgY29udlB2YWx1ZShwczI0KSwgXCJcXG5cIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMTQ6IFwiLCBjb252UHZhbHVlKHBzMTQpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczA0OiBcIiwgY29udlB2YWx1ZShwczA0KSwgXCJcXG5cIiksIFxuICAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMikgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTAuNSwgMC4xKSlcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJkaWZmU2NvcmVfYmFycGxvdF9wZUdyb3VwX2RUQUdfdnNfRE1TT1wiKVxud2lkdGggPC0gMzMqbW1Ub0luY2hcbmhlaWdodCA8LTMzKm1tVG9JbmNoXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGAifQ== -->\n\n```r\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nps01 <- round(getPvalWilcox(temp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(temp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(temp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(temp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(temp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(temp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(temp, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + \n    scale_fill_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)) +\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\Average Δ loop score\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) +\n  coord_cartesian(ylim = c(-0.5, 0.1))\n\n\nfileName <- paste0(\\diffScore_barplot_peGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

ps01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(temp, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(temp, \psOver1\, \psOver4\), 5)
ps04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)


p <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + 
    scale_fill_manual(values = c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\)) +
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineMedium * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \Average Δ loop score\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) +
  coord_cartesian(ylim = c(-0.5, 0.1))


fileName <- paste0(\diffScore_barplot_peGroup_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbnBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxucHMyMyA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjNcXCksIDUpXG5wczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbnBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxucHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjRcXCksIDUpXG5wczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyNFxcKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBzT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgXG4gICAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcXCM3Nzc3NzdcXCwgXFwjOEI3RTY1XFwsIFxcI0EyODQ1MlxcLCBcXCNDMjg4NERcXCwgXFwjRjI4RTJDXFwpKSArXG4gIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgXG4gICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZU1lZGl1bSAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsXG4gICAgICAgICAgICAgICBvdXRsaWVyLnNoYXBlID0gTkFcbiAgKSArIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXFxBdmVyYWdlIM6UIGxvb3Agc2NvcmVcXCkgK1xuICBzdGF0X3N1bW1hcnkoXG4gICAgYWVzKGdyb3VwID0gcHNPdmVyKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMikgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTAuNSwgMC4xKSlcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxkaWZmU2NvcmVfYmFycGxvdF9wZUdyb3VwX2RUQUdfdnNfRE1TT1xcKVxud2lkdGggPC0gMzMqbW1Ub0luY2hcbmhlaWdodCA8LTMzKm1tVG9JbmNoXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nps01 <- round(getPvalWilcox(temp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(temp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(temp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(temp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(temp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(temp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(temp, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + \n    scale_fill_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)) +\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\Average Δ loop score\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) +\n  coord_cartesian(ylim = c(-0.5, 0.1))\n\n\nfileName <- paste0(\\diffScore_barplot_peGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbnBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxucHMyMyA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjNcXCksIDUpXG5wczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbnBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxucHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjRcXCksIDUpXG5wczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyNFxcKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBzT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgXG4gICAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcXCM3Nzc3NzdcXCwgXFwjOEI3RTY1XFwsIFxcI0EyODQ1MlxcLCBcXCNDMjg4NERcXCwgXFwjRjI4RTJDXFwpKSArXG4gIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgXG4gICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZU1lZGl1bSAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsXG4gICAgICAgICAgICAgICBvdXRsaWVyLnNoYXBlID0gTkFcbiAgKSArIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXFxBdmVyYWdlIM6UIGxvb3Agc2NvcmVcXCkgK1xuICBzdGF0X3N1bW1hcnkoXG4gICAgYWVzKGdyb3VwID0gcHNPdmVyKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMikgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTAuNSwgMC4xKSlcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxkaWZmU2NvcmVfYmFycGxvdF9wZUdyb3VwX2RUQUdfdnNfRE1TT1xcKVxud2lkdGggPC0gMzMqbW1Ub0luY2hcbmhlaWdodCA8LTMzKm1tVG9JbmNoXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

ps01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(temp, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(temp, \psOver1\, \psOver4\), 5)
ps04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)


p <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + 
    scale_fill_manual(values = c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\)) +
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineMedium * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \Average Δ loop score\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) +
  coord_cartesian(ylim = c(-0.5, 0.1))


fileName <- paste0(\diffScore_barplot_peGroup_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### GO for each group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (c(\"#777777\", \"#8B7E65\", \"#A28452\", \"#C2884D\", \"#F28E2C\"))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \"square\" ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \"Abs. log2(fold change)\",\n    y = \"Cumulative Probability\"\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.position = \"none\",\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\"log2FC_cdf_peGroup_dTAG_vs_DMSO\")\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \"psOver0\", \"psOver1\"), 5)\nps12 <- round(getPvalWilcox(tempDown, \"psOver1\", \"psOver2\"), 5)\nps23 <- round(getPvalWilcox(tempDown, \"psOver2\", \"psOver3\"), 5)\nps34 <- round(getPvalWilcox(tempDown, \"psOver3\", \"psOver4\"), 5)\nps24 <- round(getPvalWilcox(tempDown, \"psOver2\", \"psOver4\"), 5)\nps14 <- round(getPvalWilcox(tempDown, \"psOver1\", \"psOver4\"), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \"psOver0\", \"psOver4\"), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\"#D9D9D9\", \"#BFBFBF\", \"#A6A6A6\", \"#8C8C8C\", \"#737373\")) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \"black\",\n              linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \"log2(fold change)\") +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \"point\", shape = 21, size = 1,\n    fill = \"red\", color = \"black\"\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\"text\", x = 1, y = -0.5, label = paste0(\"ps01: \", convPvalue(ps01), \"\\n\",\n                                                \"ps12: \", convPvalue(ps12), \"\\n\",\n                                                \"ps23: \", convPvalue(ps23), \"\\n\",\n                                                \"ps34: \", convPvalue(ps34), \"\\n\",\n                                                \"ps24: \", convPvalue(ps24), \"\\n\", \n                                                \"ps14: \", convPvalue(ps14), \"\\n\",\n                                                \"ps04: \", convPvalue(ps04), \"\\n\"), \n           color = \"black\", hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\"log2FC_barplot_peGroup_dTAG_vs_DMSO_down\")\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \"psOver0\", \"psOver1\"), 5)\nps12 <- round(getPvalWilcox(tempUp, \"psOver1\", \"psOver2\"), 5)\nps23 <- round(getPvalWilcox(tempUp, \"psOver2\", \"psOver3\"), 5)\nps34 <- round(getPvalWilcox(tempUp, \"psOver3\", \"psOver4\"), 5)\nps24 <- round(getPvalWilcox(tempUp, \"psOver2\", \"psOver4\"), 5)\nps14 <- round(getPvalWilcox(tempUp, \"psOver1\", \"psOver4\"), 5)\nps04 <- round(getPvalWilcox(tempUp, \"psOver0\", \"psOver4\"), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\"#D9D9D9\", \"#BFBFBF\", \"#A6A6A6\", \"#8C8C8C\", \"#737373\")) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \"black\",\n              linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \"log2(fold change)\") +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \"point\", shape = 21, size = 1,\n    fill = \"red\", color = \"black\"\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\"text\", x = 1, y = 0.5, label = paste0(\"ps01: \", convPvalue(ps01), \"\\n\",\n                                                \"ps12: \", convPvalue(ps12), \"\\n\",\n                                                \"ps23: \", convPvalue(ps23), \"\\n\",\n                                                \"ps34: \", convPvalue(ps34), \"\\n\",\n                                                \"ps24: \", convPvalue(ps24), \"\\n\", \n                                                \"ps14: \", convPvalue(ps14), \"\\n\",\n                                                \"ps04: \", convPvalue(ps04), \"\\n\"), \n           color = \"black\", hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\"log2FC_barplot_peGroup_dTAG_vs_DMSO_up\")\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\\log2FC_cdf_peGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\\log2FC_barplot_peGroup_dTAG_vs_DMSO_down\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_peGroup_dTAG_vs_DMSO_up\\)\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
temp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))
p <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +
scale_color_manual(values = (c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \square\ ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Abs. log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.position = \none\,
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))
fileName <- paste0(\log2FC_cdf_peGroup_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


#
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
 
ps01 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(tempDown, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver4\), 5)

ps04 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver4\), 5)


p <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \log2(fold change)\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = -0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))
  
fileName <- paste0(\log2FC_barplot_peGroup_dTAG_vs_DMSO_down\)
width <- panelSize(1.2)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
ps01 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(tempUp, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver4\), 5)
ps04 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver4\), 5)




p <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \log2(fold change)\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_peGroup_dTAG_vs_DMSO_up\)
width <- panelSize(1.18)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\\log2FC_cdf_peGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\\log2FC_barplot_peGroup_dTAG_vs_DMSO_down\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_peGroup_dTAG_vs_DMSO_up\\)\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\\log2FC_cdf_peGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\\log2FC_barplot_peGroup_dTAG_vs_DMSO_down\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_peGroup_dTAG_vs_DMSO_up\\)\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\\log2FC_cdf_peGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\\log2FC_barplot_peGroup_dTAG_vs_DMSO_down\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_peGroup_dTAG_vs_DMSO_up\\)\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r
temp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))
p <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +
scale_color_manual(values = (c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \square\ ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Abs. log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.position = \none\,
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))
fileName <- paste0(\log2FC_cdf_peGroup_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


#
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
 
ps01 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(tempDown, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver4\), 5)

ps04 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver4\), 5)


p <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \log2(fold change)\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = -0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))
  
fileName <- paste0(\log2FC_barplot_peGroup_dTAG_vs_DMSO_down\)
width <- panelSize(1.2)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
ps01 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(tempUp, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver4\), 5)
ps04 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver4\), 5)




p <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \log2(fold change)\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_peGroup_dTAG_vs_DMSO_up\)
width <- panelSize(1.18)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### loop score

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUIwWlcxd01pQmpiMjUwWVdsdWN5Qm5aVzVsY3lCbWNtOXRJR2R5YjNWd0lERXNJRElzSURVc0lEZ2dZVzVrSUd4dmIzQWdZMjkxYm5SelhHNGpZMkZzWTNWc1lYUnBibWNnWkdsbVppQnpZMjl5WlNCaGJtUWdiRzluTW1aaklHUnBjM1J5YVdKMWRHbHZiaUJpWVhObFpDQnZiaUJ3TFc0Z2JuVnRZbVZ5YzF4dVhHNXdjMDkyWlhJMElEd3RJQ2gwWlcxd01pQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHVkVzFmY0hBZ1BqMGdOQ2twSkdkbGJtVmNibkJ6VDNabGNqTWdQQzBnS0hSbGJYQXlJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRzUxYlY5d2NDQStQU0F6TENCdWRXMWZjSEFnUENBMEtTa2taMlZ1WlZ4dWNITlBkbVZ5TWlBOExTQW9kR1Z0Y0RJZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb2JuVnRYM0J3SUQ0OUlESXNJRzUxYlY5d2NDQThJRE1wS1NSblpXNWxYRzV3YzA5MlpYSXhJRHd0SUNoMFpXMXdNaUFsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWh1ZFcxZmNIQWdQajBnTVN3Z2JuVnRYM0J3SUR3Z01pa3BKR2RsYm1WY2JuQnpUM1psY2pBZ1BDMGdLSFJsYlhBeUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHNTFiVjl3Y0NBOElERXBLU1JuWlc1bFhHNWNibHh1WEc0akl5QkVhWFpwWkdsdVp5Qm5aVzVsY3lCcGJuUnZJR2R5YjNWd2MxeHVkR1Z0Y0NBOExTQm5aVzVsUVc1dWIwUmhkR0VnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWkdsbVpsOWtWRUZIWDBSTlUwOHNJR1JwYzNSaGJtTmxMQ0JuWlc1bEtTQWxQaVVnWEc0Z0lIVnVibVZ6ZENoblpXNWxLU0FsUGlVZ1ozSnZkWEJmWW5rb1oyVnVaU2tnSlQ0bFhHNGdJSE4xYlcxaGNtbDZaU2h0WldGdVgyUnBabVpmYzJOdmNtVWdQU0J0WldGdUtHUnBabVpmWkZSQlIxOUVUVk5QS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJRzFsWVc1ZlpHbHpkR0Z1WTJVZ1BTQnRaV0Z1S0dScGMzUmhibU5sS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQzVuY205MWNITWdQU0FuWkhKdmNDY3BYRzVjYm1ScFptWXVVazVCSUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNJbVJwWm1aZlJ6RXVaRlJCUjE5SE1TNHlhUzVrVkVGSFgzWnpYMGN4TGpKcExrUk5VMDh1ZEhOMlhDSXBLU0FsUGlWY2JpQWdaSEJzZVhJNk9uTmxiR1ZqZENobGJuTmxiV0pzWDJkbGJtVmZhV1FzSUd4dlp6SkdiMnhrUTJoaGJtZGxMQ0J6YUhKcGJtdGxaRjlzYjJjeVJrTXNJSEJoWkdvc0lHVjRkR1Z5Ym1Gc1gyZGxibVZmYm1GdFpTbGNibHh1YldGNFRHOW5Na1pESUQwZ01seHVYRzUwWlcxd0lEd3RJR3hsWm5SZmFtOXBiaWgwWlcxd0xDQmthV1ptTGxKT1FTd2dZbmtnUFNCaktGd2laMlZ1WlZ3aUlEMGdYQ0psYm5ObGJXSnNYMmRsYm1WZmFXUmNJaWtwSUNVK0pTQmNiaUFnWkhCc2VYSTZPbTExZEdGMFpTaG1iR0ZuSUQwZ2FXWmxiSE5sS0dkbGJtVWdKV2x1SlNCa2FXWm1MbEpPUVM1SE1TNWtWRUZISkdWdWMyVnRZbXhmWjJWdVpWOXBaQ3dnWENJeVJFOVhUbHdpTENCY0lqQk9UMXdpS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCdFlYaEdiR0ZuSUQwZ0tHRmljeWh6YUhKcGJtdGxaRjlzYjJjeVJrTXBJRDRnYldGNFRHOW5Na1pES1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCc2IyY3labU5OWVhnZ1BTQndiV0Y0S0hCdGFXNG9jMmh5YVc1clpXUmZiRzluTWtaRExDQnRZWGhNYjJjeVJrTXBMQ0F0YldGNFRHOW5Na1pES1NrZ0pUNGxJRnh1SUNCa2NHeDVjam82WVhKeVlXNW5aU2htYkdGbktTQWxQaVZjYmlBZ1pISnZjRjl1WVNoemFISnBibXRsWkY5c2IyY3lSa01wWEc1Y2JuUmxiWEFnUEMwZ2RHVnRjQ0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hjYmlBZ2NITlBkbVZ5SUQwZ2FXWmxiSE5sS0dkbGJtVWdKV2x1SlNCd2MwOTJaWEkwTENCY0luQnpUM1psY2pSY0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaG5aVzVsSUNWcGJpVWdjSE5QZG1WeU15d2dYQ0p3YzA5MlpYSXpYQ0lzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3YzA5MlpYSXlMQ0JjSW5CelQzWmxjakpjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3YzA5MlpYSXhMQ0JjSW5CelQzWmxjakZjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaG5aVzVsSUNWcGJpVWdjSE5QZG1WeU1Dd2dYQ0p3YzA5MlpYSXdYQ0lzSUU1QktTa3BLU2twSUNVK0pWeHVJQ0JrY205d1gyNWhLSEJ6VDNabGNpbGNibHh1WEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG4jIHRlbXAyIGNvbnRhaW5zIGdlbmVzIGZyb20gZ3JvdXAgMSwgMiwgNSwgOCBhbmQgbG9vcCBjb3VudHNcbiNjYWxjdWxhdGluZyBkaWZmIHNjb3JlIGFuZCBsb2cyZmMgZGlzdHJpYnV0aW9uIGJhc2VkIG9uIHAtbiBudW1iZXJzXG5cbnBzT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSA0KSkkZ2VuZVxucHNPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDMsIG51bV9wcCA8IDQpKSRnZW5lXG5wc092ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMiwgbnVtX3BwIDwgMykpJGdlbmVcbnBzT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAxLCBudW1fcHAgPCAyKSkkZ2VuZVxucHNPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwIDwgMSkpJGdlbmVcblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX2RUQUdfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9kVEFHX0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGZsYWcgPSBpZmVsc2UoZ2VuZSAlaW4lIGRpZmYuUk5BLkcxLmRUQUckZW5zZW1ibF9nZW5lX2lkLCBcXDJET1dOXFwsIFxcME5PXFwpLFxuICAgICAgICAgICAgICAgIG1heEZsYWcgPSAoYWJzKHNocmlua2VkX2xvZzJGQykgPiBtYXhMb2cyRkMpLFxuICAgICAgICAgICAgICAgIGxvZzJmY01heCA9IHBtYXgocG1pbihzaHJpbmtlZF9sb2cyRkMsIG1heExvZzJGQyksIC1tYXhMb2cyRkMpKSAlPiUgXG4gIGRwbHlyOjphcnJhbmdlKGZsYWcpICU+JVxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6bXV0YXRlKFxuICBwc092ZXIgPSBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjQsIFxccHNPdmVyNFxcLFxuICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIzLCBcXHBzT3ZlcjNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjIsIFxccHNPdmVyMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjEsIFxccHNPdmVyMVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIwLCBcXHBzT3ZlcjBcXCwgTkEpKSkpKSkgJT4lXG4gIGRyb3BfbmEocHNPdmVyKVxuXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

psOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \2DOWN\, \0NO\),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  psOver = ifelse(gene %in% psOver4, \psOver4\,
                  ifelse(gene %in% psOver3, \psOver3\,
                         ifelse(gene %in% psOver2, \psOver2\,
                                ifelse(gene %in% psOver1, \psOver1\,
                                       ifelse(gene %in% psOver0, \psOver0\, NA)))))) %>%
  drop_na(psOver)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QjBaVzF3TWlCamIyNTBZV2x1Y3lCblpXNWxjeUJtY205dElHZHliM1Z3SURFc0lESXNJRFVzSURnZ1lXNWtJR3h2YjNBZ1kyOTFiblJ6WEc0alkyRnNZM1ZzWVhScGJtY2daR2xtWmlCelkyOXlaU0JoYm1RZ2JHOW5NbVpqSUdScGMzUnlhV0oxZEdsdmJpQmlZWE5sWkNCdmJpQndMVzRnYm5WdFltVnljMXh1WEc1d2MwOTJaWEkwSUR3dElDaDBaVzF3TWlBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lodWRXMWZjSEFnUGowZ05Da3BKR2RsYm1WY2JuQnpUM1psY2pNZ1BDMGdLSFJsYlhBeUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHNTFiVjl3Y0NBK1BTQXpMQ0J1ZFcxZmNIQWdQQ0EwS1Nra1oyVnVaVnh1Y0hOUGRtVnlNaUE4TFNBb2RHVnRjRElnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvYm5WdFgzQndJRDQ5SURJc0lHNTFiVjl3Y0NBOElETXBLU1JuWlc1bFhHNXdjMDkyWlhJeElEd3RJQ2gwWlcxd01pQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHVkVzFmY0hBZ1BqMGdNU3dnYm5WdFgzQndJRHdnTWlrcEpHZGxibVZjYm5CelQzWmxjakFnUEMwZ0tIUmxiWEF5SUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0c1MWJWOXdjQ0E4SURFcEtTUm5aVzVsWEc1Y2JseHVYRzRqSXlCRWFYWnBaR2x1WnlCblpXNWxjeUJwYm5SdklHZHliM1Z3YzF4dWRHVnRjQ0E4TFNCblpXNWxRVzV1YjBSaGRHRWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aR2xtWmw5a1ZFRkhYMFJOVTA4c0lHUnBjM1JoYm1ObExDQm5aVzVsS1NBbFBpVWdYRzRnSUhWdWJtVnpkQ2huWlc1bEtTQWxQaVVnWjNKdmRYQmZZbmtvWjJWdVpTa2dKVDRsWEc0Z0lITjFiVzFoY21sNlpTaHRaV0Z1WDJScFptWmZjMk52Y21VZ1BTQnRaV0Z1S0dScFptWmZaRlJCUjE5RVRWTlBLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lHMWxZVzVmWkdsemRHRnVZMlVnUFNCdFpXRnVLR1JwYzNSaGJtTmxLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDNW5jbTkxY0hNZ1BTQW5aSEp2Y0NjcFhHNWNibVJwWm1ZdVVrNUJJRHd0SUdaeVpXRmtLR2hsY21Vb2NtVm1SR2x5TENCY1hHUnBabVpmUnpFdVpGUkJSMTlITVM0eWFTNWtWRUZIWDNaelgwY3hMakpwTGtSTlUwOHVkSE4yWEZ3cEtTQWxQaVZjYmlBZ1pIQnNlWEk2T25ObGJHVmpkQ2hsYm5ObGJXSnNYMmRsYm1WZmFXUXNJR3h2WnpKR2IyeGtRMmhoYm1kbExDQnphSEpwYm10bFpGOXNiMmN5UmtNc0lIQmhaR29zSUdWNGRHVnlibUZzWDJkbGJtVmZibUZ0WlNsY2JseHViV0Y0VEc5bk1rWkRJRDBnTWx4dVhHNTBaVzF3SUR3dElHeGxablJmYW05cGJpaDBaVzF3TENCa2FXWm1MbEpPUVN3Z1lua2dQU0JqS0Z4Y1oyVnVaVnhjSUQwZ1hGeGxibk5sYldKc1gyZGxibVZmYVdSY1hDa3BJQ1UrSlNCY2JpQWdaSEJzZVhJNk9tMTFkR0YwWlNobWJHRm5JRDBnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0JrYVdabUxsSk9RUzVITVM1a1ZFRkhKR1Z1YzJWdFlteGZaMlZ1WlY5cFpDd2dYRnd5UkU5WFRseGNMQ0JjWERCT1QxeGNLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J0WVhoR2JHRm5JRDBnS0dGaWN5aHphSEpwYm10bFpGOXNiMmN5UmtNcElENGdiV0Y0VEc5bk1rWkRLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JzYjJjeVptTk5ZWGdnUFNCd2JXRjRLSEJ0YVc0b2MyaHlhVzVyWldSZmJHOW5Na1pETENCdFlYaE1iMmN5UmtNcExDQXRiV0Y0VEc5bk1rWkRLU2tnSlQ0bElGeHVJQ0JrY0d4NWNqbzZZWEp5WVc1blpTaG1iR0ZuS1NBbFBpVmNiaUFnWkhKdmNGOXVZU2h6YUhKcGJtdGxaRjlzYjJjeVJrTXBYRzVjYm5SbGJYQWdQQzBnZEdWdGNDQWxQaVVnWkhCc2VYSTZPbTExZEdGMFpTaGNiaUFnY0hOUGRtVnlJRDBnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3YzA5MlpYSTBMQ0JjWEhCelQzWmxjalJjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNoblpXNWxJQ1ZwYmlVZ2NITlBkbVZ5TXl3Z1hGeHdjMDkyWlhJelhGd3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHZGxibVVnSldsdUpTQndjMDkyWlhJeUxDQmNYSEJ6VDNabGNqSmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHZGxibVVnSldsdUpTQndjMDkyWlhJeExDQmNYSEJ6VDNabGNqRmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNoblpXNWxJQ1ZwYmlVZ2NITlBkbVZ5TUN3Z1hGeHdjMDkyWlhJd1hGd3NJRTVCS1NrcEtTa3BJQ1UrSlZ4dUlDQmtjbTl3WDI1aEtIQnpUM1psY2lsY2JseHVYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG4jIHRlbXAyIGNvbnRhaW5zIGdlbmVzIGZyb20gZ3JvdXAgMSwgMiwgNSwgOCBhbmQgbG9vcCBjb3VudHNcbiNjYWxjdWxhdGluZyBkaWZmIHNjb3JlIGFuZCBsb2cyZmMgZGlzdHJpYnV0aW9uIGJhc2VkIG9uIHAtbiBudW1iZXJzXG5cbnBzT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSA0KSkkZ2VuZVxucHNPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDMsIG51bV9wcCA8IDQpKSRnZW5lXG5wc092ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMiwgbnVtX3BwIDwgMykpJGdlbmVcbnBzT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAxLCBudW1fcHAgPCAyKSkkZ2VuZVxucHNPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwIDwgMSkpJGdlbmVcblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX2RUQUdfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9kVEFHX0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5kVEFHX0cxLjJpLmRUQUdfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGZsYWcgPSBpZmVsc2UoZ2VuZSAlaW4lIGRpZmYuUk5BLkcxLmRUQUckZW5zZW1ibF9nZW5lX2lkLCBcXDJET1dOXFwsIFxcME5PXFwpLFxuICAgICAgICAgICAgICAgIG1heEZsYWcgPSAoYWJzKHNocmlua2VkX2xvZzJGQykgPiBtYXhMb2cyRkMpLFxuICAgICAgICAgICAgICAgIGxvZzJmY01heCA9IHBtYXgocG1pbihzaHJpbmtlZF9sb2cyRkMsIG1heExvZzJGQyksIC1tYXhMb2cyRkMpKSAlPiUgXG4gIGRwbHlyOjphcnJhbmdlKGZsYWcpICU+JVxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6bXV0YXRlKFxuICBwc092ZXIgPSBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjQsIFxccHNPdmVyNFxcLFxuICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIzLCBcXHBzT3ZlcjNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjIsIFxccHNPdmVyMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjEsIFxccHNPdmVyMVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIwLCBcXHBzT3ZlcjBcXCwgTkEpKSkpKSkgJT4lXG4gIGRyb3BfbmEocHNPdmVyKVxuXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyB0ZW1wMiBjb250YWlucyBnZW5lcyBmcm9tIGdyb3VwIDEsIDIsIDUsIDggYW5kIGxvb3AgY291bnRzXG4jY2FsY3VsYXRpbmcgZGlmZiBzY29yZSBhbmQgbG9nMmZjIGRpc3RyaWJ1dGlvbiBiYXNlZCBvbiBwLW4gbnVtYmVyc1xuXG5wc092ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gNCkpJGdlbmVcbnBzT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAzLCBudW1fcHAgPCA0KSkkZ2VuZVxucHNPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDIsIG51bV9wcCA8IDMpKSRnZW5lXG5wc092ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMSwgbnVtX3BwIDwgMikpJGdlbmVcbnBzT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA8IDEpKSRnZW5lXG5cblxuXG4jIyBEaXZpZGluZyBnZW5lcyBpbnRvIGdyb3Vwc1xudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZl9kVEFHX0RNU08sIGRpc3RhbmNlLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmZfZFRBR19ETVNPKSxcbiAgICAgICAgICAgIG1lYW5fZGlzdGFuY2UgPSBtZWFuKGRpc3RhbmNlKSxcbiAgICAgICAgICAgIC5ncm91cHMgPSAnZHJvcCcpXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGRpZmZfRzEuZFRBR19HMS4yaS5kVEFHX3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxubWF4TG9nMkZDID0gMlxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHBseXI6Om11dGF0ZShmbGFnID0gaWZlbHNlKGdlbmUgJWluJSBkaWZmLlJOQS5HMS5kVEFHJGVuc2VtYmxfZ2VuZV9pZCwgXFwyRE9XTlxcLCBcXDBOT1xcKSxcbiAgICAgICAgICAgICAgICBtYXhGbGFnID0gKGFicyhzaHJpbmtlZF9sb2cyRkMpID4gbWF4TG9nMkZDKSxcbiAgICAgICAgICAgICAgICBsb2cyZmNNYXggPSBwbWF4KHBtaW4oc2hyaW5rZWRfbG9nMkZDLCBtYXhMb2cyRkMpLCAtbWF4TG9nMkZDKSkgJT4lIFxuICBkcGx5cjo6YXJyYW5nZShmbGFnKSAlPiVcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShcbiAgcHNPdmVyID0gaWZlbHNlKGdlbmUgJWluJSBwc092ZXI0LCBcXHBzT3ZlcjRcXCxcbiAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMywgXFxwc092ZXIzXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIyLCBcXHBzT3ZlcjJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIxLCBcXHBzT3ZlcjFcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMCwgXFxwc092ZXIwXFwsIE5BKSkpKSkpICU+JVxuICBkcm9wX25hKHBzT3ZlcilcblxuXG5gYGBcbmBgYCJ9 -->

```r
```r
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

psOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \2DOWN\, \0NO\),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  psOver = ifelse(gene %in% psOver4, \psOver4\,
                  ifelse(gene %in% psOver3, \psOver3\,
                         ifelse(gene %in% psOver2, \psOver2\,
                                ifelse(gene %in% psOver1, \psOver1\,
                                       ifelse(gene %in% psOver0, \psOver0\, NA)))))) %>%
  drop_na(psOver)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### log2FC

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\nGOfigDir <- here(figDir, \"../GO\")\n\n#####################\nGO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\", readable = TRUE))\nGO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\", readable = TRUE))\nGO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\", readable = TRUE))\nGO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\", readable = TRUE))\nGO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\", readable = TRUE))\n# \n# fwrite(GO0.df, here(\"GO_PP_group0.tsv\"), sep = \"\\t\")\n# fwrite(GO1.df, here(\"GO_PP_group1.tsv\"), sep = \"\\t\")\n# fwrite(GO2.df, here(\"GO_PP_group2.tsv\"), sep = \"\\t\")\n# fwrite(GO3.df, here(\"GO_PP_group3.tsv\"), sep = \"\\t\")\n# fwrite(GO4.df, here(\"GO_PP_group4.tsv\"), sep = \"\\t\")\n\nsubset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \"Group 0\") %>%\n  dplyr::arrange(p.adjust)\nsubset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \"Group 1\") %>%\n  dplyr::arrange(p.adjust)\nsubset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \"Group 2\") %>%\n  dplyr::arrange(p.adjust)\nsubset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \"Group 3\") %>%\n  dplyr::arrange(p.adjust)\nsubset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \"Group 4\") %>%\n  dplyr::arrange(p.adjust)\n\nsubset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \"/\"), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \"/\"), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \"/\"), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \"/\"), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \"/\"), function(x) as.numeric(x[1]) / as.numeric(x[2]))\n\nGOlist <- factor(c(\"GO:0008380\", \"GO:0006397\", \"GO:0034470\", \"GO:0022613\", \"GO:0016055\",\n                   \"GO:0061138\", \"GO:0060562\", \"GO:0007389\", \"GO:0060485\", \"GO:0048638\", \"GO:0045664\"))\n\ndata <- bind_rows(subset0, subset1) %>%\n  dplyr::filter(ID %in% GOlist)\n\n\n\nempty_row2 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \"Group 2\"                   # Group to add as empty column\n)\n\nempty_row3 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \"Group 3\"                   # Group to add as empty column\n)\n\nempty_row4 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \"Group 4\"                   # Group to add as empty column\n)\n\n# Append the empty row to your dataset\ndata <- rbind(data, empty_row2, empty_row3, empty_row4)\ndescOrder <- sort(unique(data$Description))[rev(c(12,\n                                                  4, 5, 9, 11, 10, \n                                                  2, 6, 3, 1, 8, 7))]\ndata <- data %>% dplyr::filter(Description %in% descOrder)\n\n\ndata <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))\np <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + \n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM) + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \"white\", high = \"#CB333A\",\n                      # limits = c(0, 1),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL) +\n  theme_bw() +  # Apply theme_bw first, so custom theme settings come after\n  theme(\n    panel.background = element_rect(fill = \"transparent\"),  # Override theme_bw panel\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      size = fontSizeS,         # Ensure size is set for x-axis text\n      family = fontType,\n      color = \"#000000\",\n    ),\n    axis.text.y = element_text(\n      size = fontSizeS,         # Ensure size is set for y-axis text\n      family = fontType,\n      color = \"#000000\",\n      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick * mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick * mmToLineUnit,\n      lineend = \"square\"\n    ),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \"..\", \"GO\", \"GO_groups_pp\")\nwidth <- panelSize(2.65)*mmToInch\nheight <- panelSize(1.2)*mmToInch\nsvglite(paste0(fileName, \".svg\"), height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\nGOfigDir <- here(figDir, \\../GO\\)\n\n#####################\nGO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\n# \n# fwrite(GO0.df, here(\\GO_PP_group0.tsv\\), sep = \\\\t\\)\n# fwrite(GO1.df, here(\\GO_PP_group1.tsv\\), sep = \\\\t\\)\n# fwrite(GO2.df, here(\\GO_PP_group2.tsv\\), sep = \\\\t\\)\n# fwrite(GO3.df, here(\\GO_PP_group3.tsv\\), sep = \\\\t\\)\n# fwrite(GO4.df, here(\\GO_PP_group4.tsv\\), sep = \\\\t\\)\n\nsubset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 0\\) %>%\n  dplyr::arrange(p.adjust)\nsubset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 1\\) %>%\n  dplyr::arrange(p.adjust)\nsubset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 2\\) %>%\n  dplyr::arrange(p.adjust)\nsubset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 3\\) %>%\n  dplyr::arrange(p.adjust)\nsubset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 4\\) %>%\n  dplyr::arrange(p.adjust)\n\nsubset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\n\nGOlist <- factor(c(\\GO:0008380\\, \\GO:0006397\\, \\GO:0034470\\, \\GO:0022613\\, \\GO:0016055\\,\n                   \\GO:0061138\\, \\GO:0060562\\, \\GO:0007389\\, \\GO:0060485\\, \\GO:0048638\\, \\GO:0045664\\))\n\ndata <- bind_rows(subset0, subset1) %>%\n  dplyr::filter(ID %in% GOlist)\n\n\n\nempty_row2 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 2\\                   # Group to add as empty column\n)\n\nempty_row3 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 3\\                   # Group to add as empty column\n)\n\nempty_row4 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 4\\                   # Group to add as empty column\n)\n\n# Append the empty row to your dataset\ndata <- rbind(data, empty_row2, empty_row3, empty_row4)\ndescOrder <- sort(unique(data$Description))[rev(c(12,\n                                                  4, 5, 9, 11, 10, \n                                                  2, 6, 3, 1, 8, 7))]\ndata <- data %>% dplyr::filter(Description %in% descOrder)\n\n\ndata <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))\np <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + \n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM) + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      # limits = c(0, 1),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL) +\n  theme_bw() +  # Apply theme_bw first, so custom theme settings come after\n  theme(\n    panel.background = element_rect(fill = \\transparent\\),  # Override theme_bw panel\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      size = fontSizeS,         # Ensure size is set for x-axis text\n      family = fontType,\n      color = \\#000000\\,\n    ),\n    axis.text.y = element_text(\n      size = fontSizeS,         # Ensure size is set for y-axis text\n      family = fontType,\n      color = \\#000000\\,\n      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pp\\)\nwidth <- panelSize(2.65)*mmToInch\nheight <- panelSize(1.2)*mmToInch\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
GOfigDir <- here(figDir, \../GO\)

#####################
GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
# 
# fwrite(GO0.df, here(\GO_PP_group0.tsv\), sep = \\t\)
# fwrite(GO1.df, here(\GO_PP_group1.tsv\), sep = \\t\)
# fwrite(GO2.df, here(\GO_PP_group2.tsv\), sep = \\t\)
# fwrite(GO3.df, here(\GO_PP_group3.tsv\), sep = \\t\)
# fwrite(GO4.df, here(\GO_PP_group4.tsv\), sep = \\t\)

subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 0\) %>%
  dplyr::arrange(p.adjust)
subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 1\) %>%
  dplyr::arrange(p.adjust)
subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 2\) %>%
  dplyr::arrange(p.adjust)
subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 3\) %>%
  dplyr::arrange(p.adjust)
subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 4\) %>%
  dplyr::arrange(p.adjust)

subset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))

GOlist <- factor(c(\GO:0008380\, \GO:0006397\, \GO:0034470\, \GO:0022613\, \GO:0016055\,
                   \GO:0061138\, \GO:0060562\, \GO:0007389\, \GO:0060485\, \GO:0048638\, \GO:0045664\))

data <- bind_rows(subset0, subset1) %>%
  dplyr::filter(ID %in% GOlist)



empty_row2 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = \Group 2\                   # Group to add as empty column
)

empty_row3 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = \Group 3\                   # Group to add as empty column
)

empty_row4 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = \Group 4\                   # Group to add as empty column
)

# Append the empty row to your dataset
data <- rbind(data, empty_row2, empty_row3, empty_row4)
descOrder <- sort(unique(data$Description))[rev(c(12,
                                                  4, 5, 9, 11, 10, 
                                                  2, 6, 3, 1, 8, 7))]
data <- data %>% dplyr::filter(Description %in% descOrder)


data <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))
p <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + 
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM) + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = \white\, high = \#CB333A\,
                      # limits = c(0, 1),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL) +
  theme_bw() +  # Apply theme_bw first, so custom theme settings come after
  theme(
    panel.background = element_rect(fill = \transparent\),  # Override theme_bw panel
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      size = fontSizeS,         # Ensure size is set for x-axis text
      family = fontType,
      color = \#000000\,
    ),
    axis.text.y = element_text(
      size = fontSizeS,         # Ensure size is set for y-axis text
      family = fontType,
      color = \#000000\,
      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, \..\, \GO\, \GO_groups_pp\)
width <- panelSize(2.65)*mmToInch
height <- panelSize(1.2)*mmToInch
svglite(paste0(fileName, \.svg\), height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\nGOfigDir <- here(figDir, \\../GO\\)\n\n#####################\nGO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\n# \n# fwrite(GO0.df, here(\\GO_PP_group0.tsv\\), sep = \\\\t\\)\n# fwrite(GO1.df, here(\\GO_PP_group1.tsv\\), sep = \\\\t\\)\n# fwrite(GO2.df, here(\\GO_PP_group2.tsv\\), sep = \\\\t\\)\n# fwrite(GO3.df, here(\\GO_PP_group3.tsv\\), sep = \\\\t\\)\n# fwrite(GO4.df, here(\\GO_PP_group4.tsv\\), sep = \\\\t\\)\n\nsubset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 0\\) %>%\n  dplyr::arrange(p.adjust)\nsubset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 1\\) %>%\n  dplyr::arrange(p.adjust)\nsubset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 2\\) %>%\n  dplyr::arrange(p.adjust)\nsubset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 3\\) %>%\n  dplyr::arrange(p.adjust)\nsubset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 4\\) %>%\n  dplyr::arrange(p.adjust)\n\nsubset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\n\nGOlist <- factor(c(\\GO:0008380\\, \\GO:0006397\\, \\GO:0034470\\, \\GO:0022613\\, \\GO:0016055\\,\n                   \\GO:0061138\\, \\GO:0060562\\, \\GO:0007389\\, \\GO:0060485\\, \\GO:0048638\\, \\GO:0045664\\))\n\ndata <- bind_rows(subset0, subset1) %>%\n  dplyr::filter(ID %in% GOlist)\n\n\n\nempty_row2 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 2\\                   # Group to add as empty column\n)\n\nempty_row3 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 3\\                   # Group to add as empty column\n)\n\nempty_row4 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 4\\                   # Group to add as empty column\n)\n\n# Append the empty row to your dataset\ndata <- rbind(data, empty_row2, empty_row3, empty_row4)\ndescOrder <- sort(unique(data$Description))[rev(c(12,\n                                                  4, 5, 9, 11, 10, \n                                                  2, 6, 3, 1, 8, 7))]\ndata <- data %>% dplyr::filter(Description %in% descOrder)\n\n\ndata <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))\np <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + \n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM) + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      # limits = c(0, 1),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL) +\n  theme_bw() +  # Apply theme_bw first, so custom theme settings come after\n  theme(\n    panel.background = element_rect(fill = \\transparent\\),  # Override theme_bw panel\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      size = fontSizeS,         # Ensure size is set for x-axis text\n      family = fontType,\n      color = \\#000000\\,\n    ),\n    axis.text.y = element_text(\n      size = fontSizeS,         # Ensure size is set for y-axis text\n      family = fontType,\n      color = \\#000000\\,\n      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pp\\)\nwidth <- panelSize(2.65)*mmToInch\nheight <- panelSize(1.2)*mmToInch\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\nGOfigDir <- here(figDir, \\../GO\\)\n\n#####################\nGO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\n# \n# fwrite(GO0.df, here(\\GO_PP_group0.tsv\\), sep = \\\\t\\)\n# fwrite(GO1.df, here(\\GO_PP_group1.tsv\\), sep = \\\\t\\)\n# fwrite(GO2.df, here(\\GO_PP_group2.tsv\\), sep = \\\\t\\)\n# fwrite(GO3.df, here(\\GO_PP_group3.tsv\\), sep = \\\\t\\)\n# fwrite(GO4.df, here(\\GO_PP_group4.tsv\\), sep = \\\\t\\)\n\nsubset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 0\\) %>%\n  dplyr::arrange(p.adjust)\nsubset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 1\\) %>%\n  dplyr::arrange(p.adjust)\nsubset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 2\\) %>%\n  dplyr::arrange(p.adjust)\nsubset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 3\\) %>%\n  dplyr::arrange(p.adjust)\nsubset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 4\\) %>%\n  dplyr::arrange(p.adjust)\n\nsubset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\n\nGOlist <- factor(c(\\GO:0008380\\, \\GO:0006397\\, \\GO:0034470\\, \\GO:0022613\\, \\GO:0016055\\,\n                   \\GO:0061138\\, \\GO:0060562\\, \\GO:0007389\\, \\GO:0060485\\, \\GO:0048638\\, \\GO:0045664\\))\n\ndata <- bind_rows(subset0, subset1) %>%\n  dplyr::filter(ID %in% GOlist)\n\n\n\nempty_row2 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 2\\                   # Group to add as empty column\n)\n\nempty_row3 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 3\\                   # Group to add as empty column\n)\n\nempty_row4 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 4\\                   # Group to add as empty column\n)\n\n# Append the empty row to your dataset\ndata <- rbind(data, empty_row2, empty_row3, empty_row4)\ndescOrder <- sort(unique(data$Description))[rev(c(12,\n                                                  4, 5, 9, 11, 10, \n                                                  2, 6, 3, 1, 8, 7))]\ndata <- data %>% dplyr::filter(Description %in% descOrder)\n\n\ndata <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))\np <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + \n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM) + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      # limits = c(0, 1),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL) +\n  theme_bw() +  # Apply theme_bw first, so custom theme settings come after\n  theme(\n    panel.background = element_rect(fill = \\transparent\\),  # Override theme_bw panel\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      size = fontSizeS,         # Ensure size is set for x-axis text\n      family = fontType,\n      color = \\#000000\\,\n    ),\n    axis.text.y = element_text(\n      size = fontSizeS,         # Ensure size is set for y-axis text\n      family = fontType,\n      color = \\#000000\\,\n      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pp\\)\nwidth <- panelSize(2.65)*mmToInch\nheight <- panelSize(1.2)*mmToInch\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\nGOfigDir <- here(figDir, \\../GO\\)\n\n#####################\nGO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\nGO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\, readable = TRUE))\n# \n# fwrite(GO0.df, here(\\GO_PP_group0.tsv\\), sep = \\\\t\\)\n# fwrite(GO1.df, here(\\GO_PP_group1.tsv\\), sep = \\\\t\\)\n# fwrite(GO2.df, here(\\GO_PP_group2.tsv\\), sep = \\\\t\\)\n# fwrite(GO3.df, here(\\GO_PP_group3.tsv\\), sep = \\\\t\\)\n# fwrite(GO4.df, here(\\GO_PP_group4.tsv\\), sep = \\\\t\\)\n\nsubset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 0\\) %>%\n  dplyr::arrange(p.adjust)\nsubset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 1\\) %>%\n  dplyr::arrange(p.adjust)\nsubset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 2\\) %>%\n  dplyr::arrange(p.adjust)\nsubset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 3\\) %>%\n  dplyr::arrange(p.adjust)\nsubset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\Group 4\\) %>%\n  dplyr::arrange(p.adjust)\n\nsubset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\nsubset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \\/\\), function(x) as.numeric(x[1]) / as.numeric(x[2]))\n\nGOlist <- factor(c(\\GO:0008380\\, \\GO:0006397\\, \\GO:0034470\\, \\GO:0022613\\, \\GO:0016055\\,\n                   \\GO:0061138\\, \\GO:0060562\\, \\GO:0007389\\, \\GO:0060485\\, \\GO:0048638\\, \\GO:0045664\\))\n\ndata <- bind_rows(subset0, subset1) %>%\n  dplyr::filter(ID %in% GOlist)\n\n\n\nempty_row2 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 2\\                   # Group to add as empty column\n)\n\nempty_row3 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 3\\                   # Group to add as empty column\n)\n\nempty_row4 <- data.frame(\n  ID = NA,                             # No specific ID\n  Description = NA,                    # No description\n  GeneRatio = NA,                      # No gene ratio\n  p.adjust = NA,                       # No p.adjust value\n  group = \\Group 4\\                   # Group to add as empty column\n)\n\n# Append the empty row to your dataset\ndata <- rbind(data, empty_row2, empty_row3, empty_row4)\ndescOrder <- sort(unique(data$Description))[rev(c(12,\n                                                  4, 5, 9, 11, 10, \n                                                  2, 6, 3, 1, 8, 7))]\ndata <- data %>% dplyr::filter(Description %in% descOrder)\n\n\ndata <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))\np <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + \n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM) + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      # limits = c(0, 1),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL) +\n  theme_bw() +  # Apply theme_bw first, so custom theme settings come after\n  theme(\n    panel.background = element_rect(fill = \\transparent\\),  # Override theme_bw panel\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      size = fontSizeS,         # Ensure size is set for x-axis text\n      family = fontType,\n      color = \\#000000\\,\n    ),\n    axis.text.y = element_text(\n      size = fontSizeS,         # Ensure size is set for y-axis text\n      family = fontType,\n      color = \\#000000\\,\n      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick * mmToLineUnit,\n      lineend = \\square\\\n    ),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pp\\)\nwidth <- panelSize(2.65)*mmToInch\nheight <- panelSize(1.2)*mmToInch\nsvglite(paste0(fileName, \\.svg\\), height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r
GOfigDir <- here(figDir, \../GO\)

#####################
GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\, readable = TRUE))
# 
# fwrite(GO0.df, here(\GO_PP_group0.tsv\), sep = \\t\)
# fwrite(GO1.df, here(\GO_PP_group1.tsv\), sep = \\t\)
# fwrite(GO2.df, here(\GO_PP_group2.tsv\), sep = \\t\)
# fwrite(GO3.df, here(\GO_PP_group3.tsv\), sep = \\t\)
# fwrite(GO4.df, here(\GO_PP_group4.tsv\), sep = \\t\)

subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 0\) %>%
  dplyr::arrange(p.adjust)
subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 1\) %>%
  dplyr::arrange(p.adjust)
subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 2\) %>%
  dplyr::arrange(p.adjust)
subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 3\) %>%
  dplyr::arrange(p.adjust)
subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \Group 4\) %>%
  dplyr::arrange(p.adjust)

subset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, \/\), function(x) as.numeric(x[1]) / as.numeric(x[2]))

GOlist <- factor(c(\GO:0008380\, \GO:0006397\, \GO:0034470\, \GO:0022613\, \GO:0016055\,
                   \GO:0061138\, \GO:0060562\, \GO:0007389\, \GO:0060485\, \GO:0048638\, \GO:0045664\))

data <- bind_rows(subset0, subset1) %>%
  dplyr::filter(ID %in% GOlist)



empty_row2 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = \Group 2\                   # Group to add as empty column
)

empty_row3 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = \Group 3\                   # Group to add as empty column
)

empty_row4 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = \Group 4\                   # Group to add as empty column
)

# Append the empty row to your dataset
data <- rbind(data, empty_row2, empty_row3, empty_row4)
descOrder <- sort(unique(data$Description))[rev(c(12,
                                                  4, 5, 9, 11, 10, 
                                                  2, 6, 3, 1, 8, 7))]
data <- data %>% dplyr::filter(Description %in% descOrder)


data <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))
p <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + 
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM) + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = \white\, high = \#CB333A\,
                      # limits = c(0, 1),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL) +
  theme_bw() +  # Apply theme_bw first, so custom theme settings come after
  theme(
    panel.background = element_rect(fill = \transparent\),  # Override theme_bw panel
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      size = fontSizeS,         # Ensure size is set for x-axis text
      family = fontType,
      color = \#000000\,
    ),
    axis.text.y = element_text(
      size = fontSizeS,         # Ensure size is set for y-axis text
      family = fontType,
      color = \#000000\,
      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick * mmToLineUnit,
      lineend = \square\
    ),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, \..\, \GO\, \GO_groups_pp\)
width <- panelSize(2.65)*mmToInch
height <- panelSize(1.2)*mmToInch
svglite(paste0(fileName, \.svg\), height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



#### Grouping with P-P number
##### Grouping

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXCJwc092ZXIwXCIsIFwicHNPdmVyMVwiKSwgNSlcbnBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcInBzT3ZlcjFcIiwgXCJwc092ZXIyXCIpLCA1KVxucHMyMyA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFwicHNPdmVyMlwiLCBcInBzT3ZlcjNcIiksIDUpXG5wczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXCJwc092ZXIzXCIsIFwicHNPdmVyNFwiKSwgNSlcbnBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcInBzT3ZlcjJcIiwgXCJwc092ZXI0XCIpLCA1KVxucHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFwicHNPdmVyMVwiLCBcInBzT3ZlcjRcIiksIDUpXG5wczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXCJwc092ZXIwXCIsIFwicHNPdmVyNFwiKSwgNSlcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBwc092ZXIsIHkgPSBtZWFuX2RpZmZfc2NvcmUpKSArIFxuICAgIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IHJldihjKFwiIzc3Nzc3N1wiLCBcIiM4QjdFNjVcIiwgXCIjQTI4NDUyXCIsIFwiI0MyODg0RFwiLCBcIiNGMjhFMkNcIikpKSArXG4gIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgXG4gICAgICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLFxuICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIixcbiAgICAgICAgICAgICAgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXCJibGFja1wiLFxuICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZU1lZGl1bSAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCIsXG4gICAgICAgICAgICAgICBvdXRsaWVyLnNoYXBlID0gTkFcbiAgKSArIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXCJBdmVyYWdlIM6UIGxvb3Agc2NvcmVcIikgK1xuICBzdGF0X3N1bW1hcnkoXG4gICAgYWVzKGdyb3VwID0gcHNPdmVyKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcImJsYWNrXCIsIGNvbG9yID0gXCJibGFja1wiXG4gICkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFwiIzAwMDAwMFwiXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIiwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXCJ0cmFuc3BhcmVudFwiKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApK1xuICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcInBzMDE6IFwiLCBjb252UHZhbHVlKHBzMDEpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczEyOiBcIiwgY29udlB2YWx1ZShwczEyKSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHMyMzogXCIsIGNvbnZQdmFsdWUocHMyMyksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMzQ6IFwiLCBjb252UHZhbHVlKHBzMzQpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczI0OiBcIiwgY29udlB2YWx1ZShwczI0KSwgXCJcXG5cIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMTQ6IFwiLCBjb252UHZhbHVlKHBzMTQpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczA0OiBcIiwgY29udlB2YWx1ZShwczA0KSwgXCJcXG5cIiksIFxuICAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMikgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTAuNSwgMC4xKSlcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJkaWZmU2NvcmVfYmFycGxvdF9wcEdyb3VwX2RUQUdfdnNfRE1TT1wiKVxud2lkdGggPC0gMzMqbW1Ub0luY2hcbmhlaWdodCA8LTMzKm1tVG9JbmNoXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5cbmBgYCJ9 -->\n\n```r\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nps01 <- round(getPvalWilcox(temp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(temp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(temp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(temp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(temp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(temp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(temp, \\psOver0\\, \\psOver4\\), 5)\n\np <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + \n    scale_fill_manual(values = rev(c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\Average Δ loop score\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) +\n  coord_cartesian(ylim = c(-0.5, 0.1))\n\n\nfileName <- paste0(\\diffScore_barplot_ppGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n```\n\n<!-- rnb-source-end -->\n"} -->
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

ps01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(temp, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(temp, \psOver1\, \psOver4\), 5)
ps04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)

p <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + 
    scale_fill_manual(values = rev(c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\))) +
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineMedium * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \Average Δ loop score\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) +
  coord_cartesian(ylim = c(-0.5, 0.1))


fileName <- paste0(\diffScore_barplot_ppGroup_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbnBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxucHMyMyA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjNcXCksIDUpXG5wczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbnBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxucHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjRcXCksIDUpXG5wczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyNFxcKSwgNSlcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBwc092ZXIsIHkgPSBtZWFuX2RpZmZfc2NvcmUpKSArIFxuICAgIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IHJldihjKFxcIzc3Nzc3N1xcLCBcXCM4QjdFNjVcXCwgXFwjQTI4NDUyXFwsIFxcI0MyODg0RFxcLCBcXCNGMjhFMkNcXCkpKSArXG4gIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgXG4gICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZU1lZGl1bSAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsXG4gICAgICAgICAgICAgICBvdXRsaWVyLnNoYXBlID0gTkFcbiAgKSArIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXFxBdmVyYWdlIM6UIGxvb3Agc2NvcmVcXCkgK1xuICBzdGF0X3N1bW1hcnkoXG4gICAgYWVzKGdyb3VwID0gcHNPdmVyKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMikgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTAuNSwgMC4xKSlcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxkaWZmU2NvcmVfYmFycGxvdF9wcEdyb3VwX2RUQUdfdnNfRE1TT1xcKVxud2lkdGggPC0gMzMqbW1Ub0luY2hcbmhlaWdodCA8LTMzKm1tVG9JbmNoXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nps01 <- round(getPvalWilcox(temp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(temp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(temp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(temp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(temp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(temp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(temp, \\psOver0\\, \\psOver4\\), 5)\n\np <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + \n    scale_fill_manual(values = rev(c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\Average Δ loop score\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) +\n  coord_cartesian(ylim = c(-0.5, 0.1))\n\n\nfileName <- paste0(\\diffScore_barplot_ppGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbnBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxucHMyMyA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjNcXCksIDUpXG5wczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbnBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxucHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjRcXCksIDUpXG5wczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyNFxcKSwgNSlcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBwc092ZXIsIHkgPSBtZWFuX2RpZmZfc2NvcmUpKSArIFxuICAgIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IHJldihjKFxcIzc3Nzc3N1xcLCBcXCM4QjdFNjVcXCwgXFwjQTI4NDUyXFwsIFxcI0MyODg0RFxcLCBcXCNGMjhFMkNcXCkpKSArXG4gIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgXG4gICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZU1lZGl1bSAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsXG4gICAgICAgICAgICAgICBvdXRsaWVyLnNoYXBlID0gTkFcbiAgKSArIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXFxBdmVyYWdlIM6UIGxvb3Agc2NvcmVcXCkgK1xuICBzdGF0X3N1bW1hcnkoXG4gICAgYWVzKGdyb3VwID0gcHNPdmVyKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMikgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTAuNSwgMC4xKSlcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxkaWZmU2NvcmVfYmFycGxvdF9wcEdyb3VwX2RUQUdfdnNfRE1TT1xcKVxud2lkdGggPC0gMzMqbW1Ub0luY2hcbmhlaWdodCA8LTMzKm1tVG9JbmNoXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5cbmBgYFxuYGBgIn0= -->

```r
```r
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

ps01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(temp, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(temp, \psOver1\, \psOver4\), 5)
ps04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)

p <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + 
    scale_fill_manual(values = rev(c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\))) +
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineMedium * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \Average Δ loop score\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) +
  coord_cartesian(ylim = c(-0.5, 0.1))


fileName <- paste0(\diffScore_barplot_ppGroup_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### GO for each group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (rev(c(\"#777777\", \"#8B7E65\", \"#A28452\", \"#C2884D\", \"#F28E2C\")))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \"square\" ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \"Abs. log2(fold change)\",\n    y = \"Cumulative Probability\"\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.position = \"none\",\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\"log2FC_cdf_ppGroup_dTAG_vs_DMSO\")\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \"psOver0\", \"psOver1\"), 5)\nps12 <- round(getPvalWilcox(tempDown, \"psOver1\", \"psOver2\"), 5)\nps23 <- round(getPvalWilcox(tempDown, \"psOver2\", \"psOver3\"), 5)\nps34 <- round(getPvalWilcox(tempDown, \"psOver3\", \"psOver4\"), 5)\nps24 <- round(getPvalWilcox(tempDown, \"psOver2\", \"psOver4\"), 5)\nps14 <- round(getPvalWilcox(tempDown, \"psOver1\", \"psOver4\"), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \"psOver0\", \"psOver4\"), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\"#D9D9D9\", \"#BFBFBF\", \"#A6A6A6\", \"#8C8C8C\", \"#737373\")) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \"black\",\n              linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \"log2(fold change)\") +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \"point\", shape = 21, size = 1,\n    fill = \"red\", color = \"black\"\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\"text\", x = 1, y = -0.5, label = paste0(\"ps01: \", convPvalue(ps01), \"\\n\",\n                                                \"ps12: \", convPvalue(ps12), \"\\n\",\n                                                \"ps23: \", convPvalue(ps23), \"\\n\",\n                                                \"ps34: \", convPvalue(ps34), \"\\n\",\n                                                \"ps24: \", convPvalue(ps24), \"\\n\", \n                                                \"ps14: \", convPvalue(ps14), \"\\n\",\n                                                \"ps04: \", convPvalue(ps04), \"\\n\"), \n           color = \"black\", hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\"log2FC_barplot_ppGroup_dTAG_vs_DMSO_down\")\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \"psOver0\", \"psOver1\"), 5)\nps12 <- round(getPvalWilcox(tempUp, \"psOver1\", \"psOver2\"), 5)\nps23 <- round(getPvalWilcox(tempUp, \"psOver2\", \"psOver3\"), 5)\nps34 <- round(getPvalWilcox(tempUp, \"psOver3\", \"psOver4\"), 5)\nps24 <- round(getPvalWilcox(tempUp, \"psOver2\", \"psOver4\"), 5)\nps14 <- round(getPvalWilcox(tempUp, \"psOver1\", \"psOver4\"), 5)\nps04 <- round(getPvalWilcox(tempUp, \"psOver0\", \"psOver4\"), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\"#D9D9D9\", \"#BFBFBF\", \"#A6A6A6\", \"#8C8C8C\", \"#737373\")) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \"black\",\n              linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \"log2(fold change)\") +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \"point\", shape = 21, size = 1,\n    fill = \"red\", color = \"black\"\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\"text\", x = 1, y = 0.5, label = paste0(\"ps01: \", convPvalue(ps01), \"\\n\",\n                                                \"ps12: \", convPvalue(ps12), \"\\n\",\n                                                \"ps23: \", convPvalue(ps23), \"\\n\",\n                                                \"ps34: \", convPvalue(ps34), \"\\n\",\n                                                \"ps24: \", convPvalue(ps24), \"\\n\", \n                                                \"ps14: \", convPvalue(ps14), \"\\n\",\n                                                \"ps04: \", convPvalue(ps04), \"\\n\"), \n           color = \"black\", hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\"log2FC_barplot_ppGroup_dTAG_vs_DMSO_up\")\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (rev(c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\\log2FC_cdf_ppGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\\log2FC_barplot_ppGroup_dTAG_vs_DMSO_down\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_ppGroup_dTAG_vs_DMSO_up\\)\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
temp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))
p <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +
scale_color_manual(values = (rev(c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\)))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \square\ ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Abs. log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.position = \none\,
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))
fileName <- paste0(\log2FC_cdf_ppGroup_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



#
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
 
ps01 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(tempDown, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver4\), 5)

ps04 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver4\), 5)


p <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \log2(fold change)\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = -0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))
  
fileName <- paste0(\log2FC_barplot_ppGroup_dTAG_vs_DMSO_down\)
width <- panelSize(1.2)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
ps01 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(tempUp, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver4\), 5)
ps04 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver4\), 5)




p <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \log2(fold change)\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_ppGroup_dTAG_vs_DMSO_up\)
width <- panelSize(1.18)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (rev(c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\\log2FC_cdf_ppGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\\log2FC_barplot_ppGroup_dTAG_vs_DMSO_down\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_ppGroup_dTAG_vs_DMSO_up\\)\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (rev(c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\\log2FC_cdf_ppGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\\log2FC_barplot_ppGroup_dTAG_vs_DMSO_down\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_ppGroup_dTAG_vs_DMSO_up\\)\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ntemp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))\np <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +\nscale_color_manual(values = (rev(c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\nfileName <- paste0(\\log2FC_cdf_ppGroup_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n#\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n \nps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n\nps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))\n  \nfileName <- paste0(\\log2FC_barplot_ppGroup_dTAG_vs_DMSO_down\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \nps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\nps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\nps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\nps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\nps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\nps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\nps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n\n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + \n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) + # Five shades of grey\n  geom_violin(aes(fill = psOver), \n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\log2(fold change)\\) +\n  stat_summary(\n    aes(group = psOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_ppGroup_dTAG_vs_DMSO_up\\)\nwidth <- panelSize(1.18)*mmToInch\nheight <- panelSize(1)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r
temp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))
p <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +
scale_color_manual(values = (rev(c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\)))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \square\ ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Abs. log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.position = \none\,
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))
fileName <- paste0(\log2FC_cdf_ppGroup_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



#
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
 
ps01 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(tempDown, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver4\), 5)

ps04 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver4\), 5)


p <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \log2(fold change)\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = -0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))
  
fileName <- paste0(\log2FC_barplot_ppGroup_dTAG_vs_DMSO_down\)
width <- panelSize(1.2)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
ps01 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver1\), 5)
ps12 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver2\), 5)
ps23 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver3\), 5)
ps34 <- round(getPvalWilcox(tempUp, \psOver3\, \psOver4\), 5)
ps24 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver4\), 5)
ps14 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver4\), 5)
ps04 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver4\), 5)




p <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \log2(fold change)\) +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_ppGroup_dTAG_vs_DMSO_up\)
width <- panelSize(1.18)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### loop score

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlNakl5TWpJeU1qWEc1blpXNWxRVzV1YjBSaGRHRWdQQzBnYkc5aFpFeHZiM0JCYm01dlJHRjBZU2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lYM0F0Ymw5bGJuTmxiV0pzVEdsemRDNTBjM1pjSWlrcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JrYVdabVEzVjBiMlptSUQwZ01DNHlMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCaGJtNXZUR2x6ZENBOUlHTW9YQ0pRTFZCY0lpd2dYQ0pRTFVWY0lpd2dYQ0pRTFZOY0lpd2dYQ0pRTFZoY0lpa3BKVDRsSUZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0dScGMzUmhibU5sSUQwZ2MzUmhjblF5SUMwZ2MzUmhjblF4TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUhCbFlXdEpSQ0E5SUhCaGMzUmxLR05vY205dE1Td2djM1JoY25ReExDQnpkR0Z5ZERJc0lITmxjQ0E5SUZ3aVgxd2lLU2xjYmx4dVhHNGpJSFJsYlhBeVhHNGpZMkZzWTNWc1lYUnBibWNnWkdsbVppQnpZMjl5WlNCaGJtUWdiRzluTW1aaklHUnBjM1J5YVdKMWRHbHZiaUJpWVhObFpDQnZiaUJ3TFc0Z2JuVnRZbVZ5YzF4dWRHVnRjRElnUEMwZ2NtVmhaRkpFVXlob1pYSmxLSEpsYzNWc2RFUnBjaXdnWENKblpXNWxYMnh2YjNCZmJHbHVhMTlCTkRnMUxuSmtjMXdpS1NsY2JseHVjRzVQZG1WeU9DQThMU0FvZEdWdGNESWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9kRzkwWVd3Z1BqMGdPQ2twSkdkbGJtVmNibkJ1VDNabGNqWWdQQzBnS0hSbGJYQXlJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLSFJ2ZEdGc0lENDlJRFlzSUhSdmRHRnNJRHdnT0NrcEpHZGxibVZjYm5CdVQzWmxjalFnUEMwZ0tIUmxiWEF5SUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0hSdmRHRnNJRDQ5SURRc0lIUnZkR0ZzSUR3Z05pa3BKR2RsYm1WY2JuQnVUM1psY2pJZ1BDMGdLSFJsYlhBeUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtIUnZkR0ZzSUQ0OUlESXNJSFJ2ZEdGc0lEd2dOQ2twSkdkbGJtVmNibkJ1VDNabGNqQWdQQzBnS0hSbGJYQXlJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLSFJ2ZEdGc0lEd2dNaWtwSkdkbGJtVmNibHh1WEc1Y2JpTWpJRVJwZG1sa2FXNW5JR2RsYm1WeklHbHVkRzhnWjNKdmRYQnpYRzUwWlcxd0lEd3RJR2RsYm1WQmJtNXZSR0YwWVNBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoa2FXWm1YMEUwT0RWZlJFMVRUeXdnWkdsemRHRnVZMlVzSUdkbGJtVXBJQ1UrSlNCY2JpQWdkVzV1WlhOMEtHZGxibVVwSUNVK0pTQm5jbTkxY0Y5aWVTaG5aVzVsS1NBbFBpVmNiaUFnYzNWdGJXRnlhWHBsS0cxbFlXNWZaR2xtWmw5elkyOXlaU0E5SUcxbFlXNG9aR2xtWmw5Qk5EZzFYMFJOVTA4cExGeHVJQ0FnSUNBZ0lDQWdJQ0FnYldWaGJsOWthWE4wWVc1alpTQTlJRzFsWVc0b1pHbHpkR0Z1WTJVcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnTG1keWIzVndjeUE5SUNka2NtOXdKeWxjYmx4dVpHbG1aaTVTVGtFZ1BDMGdabkpsWVdRb2FHVnlaU2h5WldaRWFYSXNJRndpWkdsbVpsOUhNUzVCTkRnMUxuTmxiR1ZqZEdWa01sOUhNUzR5YVM1Qk5EZzFYM1p6WDBjeExqSnBMa1JOVTA4dWRITjJYQ0lwS1NBbFBpVmNiaUFnWkhCc2VYSTZPbk5sYkdWamRDaGxibk5sYldKc1gyZGxibVZmYVdRc0lHeHZaekpHYjJ4a1EyaGhibWRsTENCemFISnBibXRsWkY5c2IyY3lSa01zSUhCaFpHb3NJR1Y0ZEdWeWJtRnNYMmRsYm1WZmJtRnRaU2xjYmx4dWJXRjRURzluTWtaRElEMGdNbHh1WEc1MFpXMXdJRHd0SUd4bFpuUmZhbTlwYmloMFpXMXdMQ0JrYVdabUxsSk9RU3dnWW5rZ1BTQmpLRndpWjJWdVpWd2lJRDBnWENKbGJuTmxiV0pzWDJkbGJtVmZhV1JjSWlrcElDVStKU0JjYmlBZ1pISnZjRjl1WVNoemFISnBibXRsWkY5c2IyY3lSa01wWEc1Y2JuUmxiWEFnUEMwZ2RHVnRjQ0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hjYmlBZ2NHNVBkbVZ5SUQwZ2FXWmxiSE5sS0dkbGJtVWdKV2x1SlNCd2JrOTJaWEk0TENCY0luQnVUM1psY2poY0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaG5aVzVsSUNWcGJpVWdjRzVQZG1WeU5pd2dYQ0p3Yms5MlpYSTJYQ0lzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3Yms5MlpYSTBMQ0JjSW5CdVQzWmxjalJjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3Yms5MlpYSXlMQ0JjSW5CdVQzWmxjakpjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaG5aVzVsSUNWcGJpVWdjRzVQZG1WeU1Dd2dYQ0p3Yms5MlpYSXdYQ0lzSUU1QktTa3BLU2twSUNVK0pWeHVJQ0JrY205d1gyNWhLSEJ1VDNabGNpbGNibUJnWUNKOSAtLT5cblxuYGBgclxuIyMjIyMjIyMjIyMjXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSlcblxuXG4jIHRlbXAyXG4jY2FsY3VsYXRpbmcgZGlmZiBzY29yZSBhbmQgbG9nMmZjIGRpc3RyaWJ1dGlvbiBiYXNlZCBvbiBwLW4gbnVtYmVyc1xudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXFxnZW5lX2xvb3BfbGlua19BNDg1LnJkc1xcKSlcblxucG5PdmVyOCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIodG90YWwgPj0gOCkpJGdlbmVcbnBuT3ZlcjYgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsID49IDYsIHRvdGFsIDwgOCkpJGdlbmVcbnBuT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsID49IDQsIHRvdGFsIDwgNikpJGdlbmVcbnBuT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsID49IDIsIHRvdGFsIDwgNCkpJGdlbmVcbnBuT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsIDwgMikpJGdlbmVcblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX0E0ODVfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9BNDg1X0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5BNDg1LnNlbGVjdGVkMl9HMS4yaS5BNDg1X3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxubWF4TG9nMkZDID0gMlxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShcbiAgcG5PdmVyID0gaWZlbHNlKGdlbmUgJWluJSBwbk92ZXI4LCBcXHBuT3ZlcjhcXCxcbiAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcG5PdmVyNiwgXFxwbk92ZXI2XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwbk92ZXI0LCBcXHBuT3ZlcjRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwbk92ZXIyLCBcXHBuT3ZlcjJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcG5PdmVyMCwgXFxwbk92ZXIwXFwsIE5BKSkpKSkpICU+JVxuICBkcm9wX25hKHBuT3ZlcilcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
############
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))


# temp2
#calculating diff score and log2fc distribution based on p-n numbers
temp2 <- readRDS(here(resultDir, \gene_loop_link_A485.rds\))

pnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene
pnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene
pnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene
pnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene
pnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  pnOver = ifelse(gene %in% pnOver8, \pnOver8\,
                  ifelse(gene %in% pnOver6, \pnOver6\,
                         ifelse(gene %in% pnOver4, \pnOver4\,
                                ifelse(gene %in% pnOver2, \pnOver2\,
                                       ifelse(gene %in% pnOver0, \pnOver0\, NA)))))) %>%
  drop_na(pnOver)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeU1qSXlNakl5TWpYRzVuWlc1bFFXNXViMFJoZEdFZ1BDMGdiRzloWkV4dmIzQkJibTV2UkdGMFlTaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gzQXRibDlsYm5ObGJXSnNUR2x6ZEM1MGMzWmNYQ2twTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmthV1ptUTNWMGIyWm1JRDBnTUM0eUxGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JoYm01dlRHbHpkQ0E5SUdNb1hGeFFMVkJjWEN3Z1hGeFFMVVZjWEN3Z1hGeFFMVk5jWEN3Z1hGeFFMVmhjWENrcEpUNGxJRnh1SUNCa2NHeDVjam82YlhWMFlYUmxLR1JwYzNSaGJtTmxJRDBnYzNSaGNuUXlJQzBnYzNSaGNuUXhMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJSEJsWVd0SlJDQTlJSEJoYzNSbEtHTm9jbTl0TVN3Z2MzUmhjblF4TENCemRHRnlkRElzSUhObGNDQTlJRnhjWDF4Y0tTbGNibHh1WEc0aklIUmxiWEF5WEc0alkyRnNZM1ZzWVhScGJtY2daR2xtWmlCelkyOXlaU0JoYm1RZ2JHOW5NbVpqSUdScGMzUnlhV0oxZEdsdmJpQmlZWE5sWkNCdmJpQndMVzRnYm5WdFltVnljMXh1ZEdWdGNESWdQQzBnY21WaFpGSkVVeWhvWlhKbEtISmxjM1ZzZEVScGNpd2dYRnhuWlc1bFgyeHZiM0JmYkdsdWExOUJORGcxTG5Ka2MxeGNLU2xjYmx4dWNHNVBkbVZ5T0NBOExTQW9kR1Z0Y0RJZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb2RHOTBZV3dnUGowZ09Da3BKR2RsYm1WY2JuQnVUM1psY2pZZ1BDMGdLSFJsYlhBeUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtIUnZkR0ZzSUQ0OUlEWXNJSFJ2ZEdGc0lEd2dPQ2twSkdkbGJtVmNibkJ1VDNabGNqUWdQQzBnS0hSbGJYQXlJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLSFJ2ZEdGc0lENDlJRFFzSUhSdmRHRnNJRHdnTmlrcEpHZGxibVZjYm5CdVQzWmxjaklnUEMwZ0tIUmxiWEF5SUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0hSdmRHRnNJRDQ5SURJc0lIUnZkR0ZzSUR3Z05Da3BKR2RsYm1WY2JuQnVUM1psY2pBZ1BDMGdLSFJsYlhBeUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtIUnZkR0ZzSUR3Z01pa3BKR2RsYm1WY2JseHVYRzVjYmlNaklFUnBkbWxrYVc1bklHZGxibVZ6SUdsdWRHOGdaM0p2ZFhCelhHNTBaVzF3SUR3dElHZGxibVZCYm01dlJHRjBZU0FsUGlVZ1pIQnNlWEk2T25ObGJHVmpkQ2hrYVdabVgwRTBPRFZmUkUxVFR5d2daR2x6ZEdGdVkyVXNJR2RsYm1VcElDVStKU0JjYmlBZ2RXNXVaWE4wS0dkbGJtVXBJQ1UrSlNCbmNtOTFjRjlpZVNoblpXNWxLU0FsUGlWY2JpQWdjM1Z0YldGeWFYcGxLRzFsWVc1ZlpHbG1abDl6WTI5eVpTQTlJRzFsWVc0b1pHbG1abDlCTkRnMVgwUk5VMDhwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdiV1ZoYmw5a2FYTjBZVzVqWlNBOUlHMWxZVzRvWkdsemRHRnVZMlVwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdMbWR5YjNWd2N5QTlJQ2RrY205d0p5bGNibHh1WkdsbVppNVNUa0VnUEMwZ1puSmxZV1FvYUdWeVpTaHlaV1pFYVhJc0lGeGNaR2xtWmw5SE1TNUJORGcxTG5ObGJHVmpkR1ZrTWw5SE1TNHlhUzVCTkRnMVgzWnpYMGN4TGpKcExrUk5VMDh1ZEhOMlhGd3BLU0FsUGlWY2JpQWdaSEJzZVhJNk9uTmxiR1ZqZENobGJuTmxiV0pzWDJkbGJtVmZhV1FzSUd4dlp6SkdiMnhrUTJoaGJtZGxMQ0J6YUhKcGJtdGxaRjlzYjJjeVJrTXNJSEJoWkdvc0lHVjRkR1Z5Ym1Gc1gyZGxibVZmYm1GdFpTbGNibHh1YldGNFRHOW5Na1pESUQwZ01seHVYRzUwWlcxd0lEd3RJR3hsWm5SZmFtOXBiaWgwWlcxd0xDQmthV1ptTGxKT1FTd2dZbmtnUFNCaktGeGNaMlZ1WlZ4Y0lEMGdYRnhsYm5ObGJXSnNYMmRsYm1WZmFXUmNYQ2twSUNVK0pTQmNiaUFnWkhKdmNGOXVZU2h6YUhKcGJtdGxaRjlzYjJjeVJrTXBYRzVjYm5SbGJYQWdQQzBnZEdWdGNDQWxQaVVnWkhCc2VYSTZPbTExZEdGMFpTaGNiaUFnY0c1UGRtVnlJRDBnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3Yms5MlpYSTRMQ0JjWEhCdVQzWmxjamhjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNoblpXNWxJQ1ZwYmlVZ2NHNVBkbVZ5Tml3Z1hGeHdiazkyWlhJMlhGd3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHZGxibVVnSldsdUpTQndiazkyWlhJMExDQmNYSEJ1VDNabGNqUmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHZGxibVVnSldsdUpTQndiazkyWlhJeUxDQmNYSEJ1VDNabGNqSmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNoblpXNWxJQ1ZwYmlVZ2NHNVBkbVZ5TUN3Z1hGeHdiazkyWlhJd1hGd3NJRTVCS1NrcEtTa3BJQ1UrSlZ4dUlDQmtjbTl3WDI1aEtIQnVUM1psY2lsY2JtQmdZRnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbmBgYHJcbiMjIyMjIyMjIyMjI1xuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLW5fZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IDAuMixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYW5ub0xpc3QgPSBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcUC1TXFwsIFxcUC1YXFwpKSU+JSBcbiAgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICBwZWFrSUQgPSBwYXN0ZShjaHJvbTEsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcXF9cXCkpXG5cblxuIyB0ZW1wMlxuI2NhbGN1bGF0aW5nIGRpZmYgc2NvcmUgYW5kIGxvZzJmYyBkaXN0cmlidXRpb24gYmFzZWQgb24gcC1uIG51bWJlcnNcbnRlbXAyIDwtIHJlYWRSRFMoaGVyZShyZXN1bHREaXIsIFxcZ2VuZV9sb29wX2xpbmtfQTQ4NS5yZHNcXCkpXG5cbnBuT3ZlcjggPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsID49IDgpKSRnZW5lXG5wbk92ZXI2IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA2LCB0b3RhbCA8IDgpKSRnZW5lXG5wbk92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA0LCB0b3RhbCA8IDYpKSRnZW5lXG5wbk92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSAyLCB0b3RhbCA8IDQpKSRnZW5lXG5wbk92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA8IDIpKSRnZW5lXG5cblxuXG4jIyBEaXZpZGluZyBnZW5lcyBpbnRvIGdyb3Vwc1xudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZl9BNDg1X0RNU08sIGRpc3RhbmNlLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmZfQTQ4NV9ETVNPKSxcbiAgICAgICAgICAgIG1lYW5fZGlzdGFuY2UgPSBtZWFuKGRpc3RhbmNlKSxcbiAgICAgICAgICAgIC5ncm91cHMgPSAnZHJvcCcpXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGRpZmZfRzEuQTQ4NS5zZWxlY3RlZDJfRzEuMmkuQTQ4NV92c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibF9nZW5lX2lkLCBsb2cyRm9sZENoYW5nZSwgc2hyaW5rZWRfbG9nMkZDLCBwYWRqLCBleHRlcm5hbF9nZW5lX25hbWUpXG5cbm1heExvZzJGQyA9IDJcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcXGdlbmVcXCA9IFxcZW5zZW1ibF9nZW5lX2lkXFwpKSAlPiUgXG4gIGRyb3BfbmEoc2hyaW5rZWRfbG9nMkZDKVxuXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBuT3ZlciA9IGlmZWxzZShnZW5lICVpbiUgcG5PdmVyOCwgXFxwbk92ZXI4XFwsXG4gICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBuT3ZlcjYsIFxccG5PdmVyNlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcG5PdmVyNCwgXFxwbk92ZXI0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcG5PdmVyMiwgXFxwbk92ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBuT3ZlcjAsIFxccG5PdmVyMFxcLCBOQSkpKSkpKSAlPiVcbiAgZHJvcF9uYShwbk92ZXIpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyMjIyMjIyMjXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lIFxuICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgIHBlYWtJRCA9IHBhc3RlKGNocm9tMSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSlcblxuXG4jIHRlbXAyXG4jY2FsY3VsYXRpbmcgZGlmZiBzY29yZSBhbmQgbG9nMmZjIGRpc3RyaWJ1dGlvbiBiYXNlZCBvbiBwLW4gbnVtYmVyc1xudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXFxnZW5lX2xvb3BfbGlua19BNDg1LnJkc1xcKSlcblxucG5PdmVyOCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIodG90YWwgPj0gOCkpJGdlbmVcbnBuT3ZlcjYgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsID49IDYsIHRvdGFsIDwgOCkpJGdlbmVcbnBuT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsID49IDQsIHRvdGFsIDwgNikpJGdlbmVcbnBuT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsID49IDIsIHRvdGFsIDwgNCkpJGdlbmVcbnBuT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsIDwgMikpJGdlbmVcblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX0E0ODVfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9BNDg1X0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5BNDg1LnNlbGVjdGVkMl9HMS4yaS5BNDg1X3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxubWF4TG9nMkZDID0gMlxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShcbiAgcG5PdmVyID0gaWZlbHNlKGdlbmUgJWluJSBwbk92ZXI4LCBcXHBuT3ZlcjhcXCxcbiAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcG5PdmVyNiwgXFxwbk92ZXI2XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwbk92ZXI0LCBcXHBuT3ZlcjRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwbk92ZXIyLCBcXHBuT3ZlcjJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcG5PdmVyMCwgXFxwbk92ZXIwXFwsIE5BKSkpKSkpICU+JVxuICBkcm9wX25hKHBuT3ZlcilcbmBgYFxuYGBgIn0= -->

```r
```r
############
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))


# temp2
#calculating diff score and log2fc distribution based on p-n numbers
temp2 <- readRDS(here(resultDir, \gene_loop_link_A485.rds\))

pnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene
pnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene
pnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene
pnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene
pnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  pnOver = ifelse(gene %in% pnOver8, \pnOver8\,
                  ifelse(gene %in% pnOver6, \pnOver6\,
                         ifelse(gene %in% pnOver4, \pnOver4\,
                                ifelse(gene %in% pnOver2, \pnOver2\,
                                       ifelse(gene %in% pnOver0, \pnOver0\, NA)))))) %>%
  drop_na(pnOver)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### log2FC

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBHT2ZpZ0RpciA8LSBoZXJlKGZpZ0RpciwgXCIuLi9HT1wiKVxuIyBnZXRHTyhcInBuT3ZlcjhcIiwgR09maWdEaXIsIHBuT3ZlcjgpXG4jIGdldEdPKFwicG5PdmVyNlwiLCBHT2ZpZ0RpciwgcG5PdmVyNilcbiMgZ2V0R08oXCJwbk92ZXI0XCIsIEdPZmlnRGlyLCBwbk92ZXI0KVxuIyBnZXRHTyhcInBuT3ZlcjJcIiwgR09maWdEaXIsIHBuT3ZlcjIpXG4jIGdldEdPKFwicG5PdmVyMFwiLCBHT2ZpZ0RpciwgcG5PdmVyMClcbiMgXG4jICMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBHTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcG5PdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKSlcbiMgR08yLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBuT3ZlcjIsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIikpXG4jIEdPNC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwbk92ZXI0LCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFwiRU5TRU1CTFwiLCBvbnQgPSBcIkJQXCIpKVxuIyBHTzYuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcG5PdmVyNiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKSlcbiMgR084LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBuT3ZlcjgsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIikpXG4jIFxuIyBcbiMgc3Vic2V0MCA8LSBHTzAuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicG5PdmVyMFwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicG5PdmVyMlwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicG5PdmVyNFwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NiA8LSBHTzYuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicG5PdmVyNlwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0OCA8LSBHTzguZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicG5PdmVyOFwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgXG4jIFxuIyBHT2xpc3QgPC0gZmFjdG9yKGMoXCJHTzowMDA2Mzk3XCIsIFwiR086MDAwODM4MFwiLCBcIkdPOjAwMjI2MTNcIiwgXCJHTzowMDM0NDcwXCIsXG4jICAgICAgICAgICAgICAgICAgICBcIkdPOjAwMTYwNTVcIiwgXCJHTzowMDA3Mzg5XCIsIFwiR086MDA0ODU2MlwiLCBcIkdPOjAwNDUxNjVcIiwgXG4jICAgICAgICAgICAgICAgICAgICBcIkdPOjAwNzIwMDFcIiwgXCJHTzowMDA3NTE3XCIsIFwiR086MDA0ODcwNVwiKSlcbiMgXG4jIGRhdGEgPC0gYmluZF9yb3dzKGJpbmRfcm93cyhiaW5kX3Jvd3Moc3Vic2V0MCwgc3Vic2V0MiksIHN1YnNldDQpLCBzdWJzZXQ4KSAlPiVcbiMgICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuIyBcbiMgcCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IERlc2NyaXB0aW9uLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuIyAgIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuIyAgIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFwicmVkXCIsIGhpZ2ggPSBcImJsdWVcIiwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuIyAgIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiMgICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFwiLi5cIiwgXCJHT1wiLCBcIkdPX2dyb3Vwc19wblwiKVxuIyBoZWlnaHQgPSAyXG4jIHdpZHRoID0gMy4zXG4jIHN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIiksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5gYGAifQ== -->\n\n```r\n# GOfigDir <- here(figDir, \\../GO\\)\n# getGO(\\pnOver8\\, GOfigDir, pnOver8)\n# getGO(\\pnOver6\\, GOfigDir, pnOver6)\n# getGO(\\pnOver4\\, GOfigDir, pnOver4)\n# getGO(\\pnOver2\\, GOfigDir, pnOver2)\n# getGO(\\pnOver0\\, GOfigDir, pnOver0)\n# \n# #####################\n# GO0.df <- as.data.frame(enrichGO(gene = pnOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO2.df <- as.data.frame(enrichGO(gene = pnOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO4.df <- as.data.frame(enrichGO(gene = pnOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO6.df <- as.data.frame(enrichGO(gene = pnOver6, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO8.df <- as.data.frame(enrichGO(gene = pnOver8, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# \n# \n# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver0\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver2\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver4\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset6 <- GO6.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver6\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset8 <- GO8.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver8\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# \n# \n# GOlist <- factor(c(\\GO:0006397\\, \\GO:0008380\\, \\GO:0022613\\, \\GO:0034470\\,\n#                    \\GO:0016055\\, \\GO:0007389\\, \\GO:0048562\\, \\GO:0045165\\, \n#                    \\GO:0072001\\, \\GO:0007517\\, \\GO:0048705\\))\n# \n# data <- bind_rows(bind_rows(bind_rows(subset0, subset2), subset4), subset8) %>%\n#   dplyr::filter(ID %in% GOlist)\n# \n# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + \n#   geom_point() + theme_bw() +\n#   scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n#   scale_size_continuous(range = c(0, 3)) +\n#   labs(x = NULL, y = NULL) +\n#   theme(axis.text = element_text(size = 6),  # Set axis text size\n#         axis.title = element_text(size = 6), # Set axis title size (if not removed)\n#         legend.text = element_text(size = 6), # Set legend text size\n#         legend.title = element_text(size = 6)) \n# \n# fileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pn\\)\n# height = 2\n# width = 3.3\n# svglite(paste0(fileName, \\.svg\\), height = height, width = width)\n# print(p)\n# dev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# GOfigDir <- here(figDir, \../GO\)
# getGO(\pnOver8\, GOfigDir, pnOver8)
# getGO(\pnOver6\, GOfigDir, pnOver6)
# getGO(\pnOver4\, GOfigDir, pnOver4)
# getGO(\pnOver2\, GOfigDir, pnOver2)
# getGO(\pnOver0\, GOfigDir, pnOver0)
# 
# #####################
# GO0.df <- as.data.frame(enrichGO(gene = pnOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO2.df <- as.data.frame(enrichGO(gene = pnOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO4.df <- as.data.frame(enrichGO(gene = pnOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO6.df <- as.data.frame(enrichGO(gene = pnOver6, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO8.df <- as.data.frame(enrichGO(gene = pnOver8, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# 
# 
# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver0\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver2\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver4\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset6 <- GO6.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver6\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset8 <- GO8.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver8\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# 
# GOlist <- factor(c(\GO:0006397\, \GO:0008380\, \GO:0022613\, \GO:0034470\,
#                    \GO:0016055\, \GO:0007389\, \GO:0048562\, \GO:0045165\, 
#                    \GO:0072001\, \GO:0007517\, \GO:0048705\))
# 
# data <- bind_rows(bind_rows(bind_rows(subset0, subset2), subset4), subset8) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, \..\, \GO\, \GO_groups_pn\)
# height = 2
# width = 3.3
# svglite(paste0(fileName, \.svg\), height = height, width = width)
# print(p)
# dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBHT2ZpZ0RpciA8LSBoZXJlKGZpZ0RpciwgXFwuLi9HT1xcKVxuIyBnZXRHTyhcXHBuT3ZlcjhcXCwgR09maWdEaXIsIHBuT3ZlcjgpXG4jIGdldEdPKFxccG5PdmVyNlxcLCBHT2ZpZ0RpciwgcG5PdmVyNilcbiMgZ2V0R08oXFxwbk92ZXI0XFwsIEdPZmlnRGlyLCBwbk92ZXI0KVxuIyBnZXRHTyhcXHBuT3ZlcjJcXCwgR09maWdEaXIsIHBuT3ZlcjIpXG4jIGdldEdPKFxccG5PdmVyMFxcLCBHT2ZpZ0RpciwgcG5PdmVyMClcbiMgXG4jICMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBHTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcG5PdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR08yLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBuT3ZlcjIsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIEdPNC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwbk92ZXI0LCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpKVxuIyBHTzYuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcG5PdmVyNiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR084LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBuT3ZlcjgsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIFxuIyBcbiMgc3Vic2V0MCA8LSBHTzAuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccG5PdmVyMFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccG5PdmVyMlxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccG5PdmVyNFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NiA8LSBHTzYuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccG5PdmVyNlxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0OCA8LSBHTzguZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccG5PdmVyOFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgXG4jIFxuIyBHT2xpc3QgPC0gZmFjdG9yKGMoXFxHTzowMDA2Mzk3XFwsIFxcR086MDAwODM4MFxcLCBcXEdPOjAwMjI2MTNcXCwgXFxHTzowMDM0NDcwXFwsXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwMTYwNTVcXCwgXFxHTzowMDA3Mzg5XFwsIFxcR086MDA0ODU2MlxcLCBcXEdPOjAwNDUxNjVcXCwgXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwNzIwMDFcXCwgXFxHTzowMDA3NTE3XFwsIFxcR086MDA0ODcwNVxcKSlcbiMgXG4jIGRhdGEgPC0gYmluZF9yb3dzKGJpbmRfcm93cyhiaW5kX3Jvd3Moc3Vic2V0MCwgc3Vic2V0MiksIHN1YnNldDQpLCBzdWJzZXQ4KSAlPiVcbiMgICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuIyBcbiMgcCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IERlc2NyaXB0aW9uLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuIyAgIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuIyAgIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFxccmVkXFwsIGhpZ2ggPSBcXGJsdWVcXCwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuIyAgIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiMgICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc19wblxcKVxuIyBoZWlnaHQgPSAyXG4jIHdpZHRoID0gMy4zXG4jIHN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\n# GOfigDir <- here(figDir, \\../GO\\)\n# getGO(\\pnOver8\\, GOfigDir, pnOver8)\n# getGO(\\pnOver6\\, GOfigDir, pnOver6)\n# getGO(\\pnOver4\\, GOfigDir, pnOver4)\n# getGO(\\pnOver2\\, GOfigDir, pnOver2)\n# getGO(\\pnOver0\\, GOfigDir, pnOver0)\n# \n# #####################\n# GO0.df <- as.data.frame(enrichGO(gene = pnOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO2.df <- as.data.frame(enrichGO(gene = pnOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO4.df <- as.data.frame(enrichGO(gene = pnOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO6.df <- as.data.frame(enrichGO(gene = pnOver6, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO8.df <- as.data.frame(enrichGO(gene = pnOver8, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# \n# \n# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver0\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver2\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver4\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset6 <- GO6.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver6\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset8 <- GO8.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\pnOver8\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# \n# \n# GOlist <- factor(c(\\GO:0006397\\, \\GO:0008380\\, \\GO:0022613\\, \\GO:0034470\\,\n#                    \\GO:0016055\\, \\GO:0007389\\, \\GO:0048562\\, \\GO:0045165\\, \n#                    \\GO:0072001\\, \\GO:0007517\\, \\GO:0048705\\))\n# \n# data <- bind_rows(bind_rows(bind_rows(subset0, subset2), subset4), subset8) %>%\n#   dplyr::filter(ID %in% GOlist)\n# \n# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + \n#   geom_point() + theme_bw() +\n#   scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n#   scale_size_continuous(range = c(0, 3)) +\n#   labs(x = NULL, y = NULL) +\n#   theme(axis.text = element_text(size = 6),  # Set axis text size\n#         axis.title = element_text(size = 6), # Set axis title size (if not removed)\n#         legend.text = element_text(size = 6), # Set legend text size\n#         legend.title = element_text(size = 6)) \n# \n# fileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pn\\)\n# height = 2\n# width = 3.3\n# svglite(paste0(fileName, \\.svg\\), height = height, width = width)\n# print(p)\n# dev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBHT2ZpZ0RpciA8LSBoZXJlKGZpZ0RpciwgXFwuLi9HT1xcKVxuIyBnZXRHTyhcXHBuT3ZlcjhcXCwgR09maWdEaXIsIHBuT3ZlcjgpXG4jIGdldEdPKFxccG5PdmVyNlxcLCBHT2ZpZ0RpciwgcG5PdmVyNilcbiMgZ2V0R08oXFxwbk92ZXI0XFwsIEdPZmlnRGlyLCBwbk92ZXI0KVxuIyBnZXRHTyhcXHBuT3ZlcjJcXCwgR09maWdEaXIsIHBuT3ZlcjIpXG4jIGdldEdPKFxccG5PdmVyMFxcLCBHT2ZpZ0RpciwgcG5PdmVyMClcbiMgXG4jICMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBHTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcG5PdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR08yLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBuT3ZlcjIsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIEdPNC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwbk92ZXI0LCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpKVxuIyBHTzYuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcG5PdmVyNiwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR084LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBuT3ZlcjgsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIFxuIyBcbiMgc3Vic2V0MCA8LSBHTzAuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccG5PdmVyMFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccG5PdmVyMlxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccG5PdmVyNFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NiA8LSBHTzYuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccG5PdmVyNlxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0OCA8LSBHTzguZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccG5PdmVyOFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgXG4jIFxuIyBHT2xpc3QgPC0gZmFjdG9yKGMoXFxHTzowMDA2Mzk3XFwsIFxcR086MDAwODM4MFxcLCBcXEdPOjAwMjI2MTNcXCwgXFxHTzowMDM0NDcwXFwsXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwMTYwNTVcXCwgXFxHTzowMDA3Mzg5XFwsIFxcR086MDA0ODU2MlxcLCBcXEdPOjAwNDUxNjVcXCwgXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwNzIwMDFcXCwgXFxHTzowMDA3NTE3XFwsIFxcR086MDA0ODcwNVxcKSlcbiMgXG4jIGRhdGEgPC0gYmluZF9yb3dzKGJpbmRfcm93cyhiaW5kX3Jvd3Moc3Vic2V0MCwgc3Vic2V0MiksIHN1YnNldDQpLCBzdWJzZXQ4KSAlPiVcbiMgICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuIyBcbiMgcCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IERlc2NyaXB0aW9uLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuIyAgIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuIyAgIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFxccmVkXFwsIGhpZ2ggPSBcXGJsdWVcXCwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuIyAgIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiMgICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc19wblxcKVxuIyBoZWlnaHQgPSAyXG4jIHdpZHRoID0gMy4zXG4jIHN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
# GOfigDir <- here(figDir, \../GO\)
# getGO(\pnOver8\, GOfigDir, pnOver8)
# getGO(\pnOver6\, GOfigDir, pnOver6)
# getGO(\pnOver4\, GOfigDir, pnOver4)
# getGO(\pnOver2\, GOfigDir, pnOver2)
# getGO(\pnOver0\, GOfigDir, pnOver0)
# 
# #####################
# GO0.df <- as.data.frame(enrichGO(gene = pnOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO2.df <- as.data.frame(enrichGO(gene = pnOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO4.df <- as.data.frame(enrichGO(gene = pnOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO6.df <- as.data.frame(enrichGO(gene = pnOver6, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO8.df <- as.data.frame(enrichGO(gene = pnOver8, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# 
# 
# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver0\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver2\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver4\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset6 <- GO6.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver6\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset8 <- GO8.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \pnOver8\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# 
# GOlist <- factor(c(\GO:0006397\, \GO:0008380\, \GO:0022613\, \GO:0034470\,
#                    \GO:0016055\, \GO:0007389\, \GO:0048562\, \GO:0045165\, 
#                    \GO:0072001\, \GO:0007517\, \GO:0048705\))
# 
# data <- bind_rows(bind_rows(bind_rows(subset0, subset2), subset4), subset8) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, \..\, \GO\, \GO_groups_pn\)
# height = 2
# width = 3.3
# svglite(paste0(fileName, \.svg\), height = height, width = width)
# print(p)
# dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### A485
#### Grouping with P-N number
##### Grouping

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJuWlhSUWRtRnNWMmxzWTI5NElEd3RJR1oxYm1OMGFXOXVLR1JoZEdFc0lHZHliM1Z3TVN3Z1ozSnZkWEF5S1h0Y2JpTWdJQ0JrYVhOMFlXNWpaVEVnUEMwZ0tHUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvY0c1UGRtVnlJRDA5WjNKdmRYQXhLU0FwSkcxbFlXNWZaR2xtWmw5elkyOXlaVnh1SXlBZ0lHUnBjM1JoYm1ObE1pQThMU0FvWkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHdiazkyWlhJZ1BUMW5jbTkxY0RJcElDa2tiV1ZoYmw5a2FXWm1YM05qYjNKbFhHNGpJQ0FnZDJsc0lEd3RJSGRwYkdOdmVDNTBaWE4wS0dScGMzUmhibU5sTVN3Z1pHbHpkR0Z1WTJVeUtWeHVJeUFnSUhKbGRIVnliaWgzYVd3a2NDNTJZV3gxWlNsY2JpTWdmVnh1SXlCY2JpTWdjSFl3TWlBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBc0lGd2ljRzVQZG1WeU1Gd2lMQ0JjSW5CdVQzWmxjakpjSWlrc0lEVXBYRzRqSUhCMk1qUWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMQ0JjSW5CdVQzWmxjakpjSWl3Z1hDSndiazkyWlhJMFhDSXBMQ0ExS1Z4dUl5QndkalEySUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0N3Z1hDSndiazkyWlhJMFhDSXNJRndpY0c1UGRtVnlObHdpS1N3Z05TbGNiaU1nY0hZd09DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXNJRndpY0c1UGRtVnlNRndpTENCY0luQnVUM1psY2poY0lpa3NJRFVwWEc0aklIQjJNamdnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaDBaVzF3TENCY0luQnVUM1psY2pKY0lpd2dYQ0p3Yms5MlpYSTRYQ0lwTENBMUtWeHVJeUJ3ZGpRNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dYQ0p3Yms5MlpYSTBYQ0lzSUZ3aWNHNVBkbVZ5T0Z3aUtTd2dOU2xjYmlNZ2NIWTJPQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEFzSUZ3aWNHNVBkbVZ5Tmx3aUxDQmNJbkJ1VDNabGNqaGNJaWtzSURVcFhHNWNibHh1Y0NBOExTQm5aM0JzYjNRb2RHVnRjQ3dnWVdWektIZ2dQU0J3Yms5MlpYSXNJSGtnUFNCdFpXRnVYMlJwWm1aZmMyTnZjbVVwS1NBcklHZGxiMjFmZG1sdmJHbHVLR0ZsY3lobWFXeHNJRDBnY0c1UGRtVnlLU3dnYzJodmR5NXNaV2RsYm1RZ1BTQkdRVXhUUlNrZ0sxeHVJQ0JuWlc5dFgySnZlSEJzYjNRb2QybGtkR2dnUFNBd0xqRXNJRzkxZEd4cFpYSXVjMmhoY0dVZ1BTQk9RU2tnS3lCMGFHVnRaVjlqYkdGemMybGpLQ2tnS3lCY2JpQWdjM1JoZEY5emRXMXRZWEo1S0dGbGN5aG5jbTkxY0NBOUlIQnVUM1psY2lrc0lHWjFiaUE5SUcxbFlXNHNJR2RsYjIwZ1BTQmNJbkJ2YVc1MFhDSXNJSE5vWVhCbElEMGdNakVzSUhOcGVtVWdQU0F5TENCbWFXeHNJRDBnWENKeVpXUmNJaXdnWTI5c2IzSWdQU0JjSW1Kc1lXTnJYQ0lwSUN0Y2JpQWdaMlZ2YlY5b2JHbHVaU2g1YVc1MFpYSmpaWEIwSUQwZ01DbGNiaUFnSXlCaGJtNXZkR0YwWlNoY0luUmxlSFJjSWl3Z2VDQTlJREVzSUhrZ1BTQXdMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNJbkIyTURJNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCMk1ESXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkIyTWpRNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCMk1qUXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkIyTkRZNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCMk5EWXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkIyTmpnNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCMk5qZ3BMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkIyTkRnNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCMk5EZ3BMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkIyTWpnNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCMk1qZ3BMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkIyTURnNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCMk1EZ3BMQ0JjSWx4Y2Jsd2lLU3dnWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJRE1wWEc1Y2JpQWdJRnh1Wm1sc1pVNWhiV1VnUEMwZ2NHRnpkR1V3S0Z3aVpHbG1abE5qYjNKbFgySmhjbkJzYjNSZmNHNUhjbTkxY0Y5Qk5EZzFYM1p6WDBSTlUwOWNJaWxjYm1obGFXZG9kQ0E4TFNBelhHNTNhV1IwYUNBOExTQXpYRzV3Ym1jb2FHVnlaU2htYVdkRWFYSXNJSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYQ0l1Y0c1blhDSXBLU3dnY21WeklEMGdOakF3TENCMWJtbDBJRDBnWENKcGJsd2lMQ0JvWldsbmFIUWdQU0JvWldsbmFIUXNJSGRwWkhSb0lEMGdkMmxrZEdncFhHNXdjbWx1ZENod0tWeHVaR1YyTG05bVppZ3BYRzV6ZG1kc2FYUmxLR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ3aUxuTjJaMXdpS1Nrc0lDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc1d2NtbHVkQ2h3S1Z4dVpHVjJMbTltWmlncFhHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocG5PdmVyID09Z3JvdXAxKSApJG1lYW5fZGlmZl9zY29yZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4jICAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuIyAgIHJldHVybih3aWwkcC52YWx1ZSlcbiMgfVxuIyBcbiMgcHYwMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjJcXCksIDUpXG4jIHB2MjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI0XFwpLCA1KVxuIyBwdjQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwbk92ZXI0XFwsIFxccG5PdmVyNlxcKSwgNSlcbiMgcHYwOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjhcXCksIDUpXG4jIHB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBwdjQ4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwbk92ZXI0XFwsIFxccG5PdmVyOFxcKSwgNSlcbiMgcHY2OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyNlxcLCBcXHBuT3ZlcjhcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBwbk92ZXIsIHkgPSBtZWFuX2RpZmZfc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcG5PdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBuT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHB2MDI6IFxcLCBjb252UHZhbHVlKHB2MDIpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjQ6IFxcLCBjb252UHZhbHVlKHB2MjQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NDY6IFxcLCBjb252UHZhbHVlKHB2NDYpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Njg6IFxcLCBjb252UHZhbHVlKHB2NjgpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NDg6IFxcLCBjb252UHZhbHVlKHB2NDgpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBjb252UHZhbHVlKHB2MjgpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MDg6IFxcLCBjb252UHZhbHVlKHB2MDgpLCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG5cbiAgIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcZGlmZlNjb3JlX2JhcnBsb3RfcG5Hcm91cF9BNDg1X3ZzX0RNU09cXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$mean_diff_score
#   distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$mean_diff_score
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# pv02 <- round(getPvalWilcox(temp, \pnOver0\, \pnOver2\), 5)
# pv24 <- round(getPvalWilcox(temp, \pnOver2\, \pnOver4\), 5)
# pv46 <- round(getPvalWilcox(temp, \pnOver4\, \pnOver6\), 5)
# pv08 <- round(getPvalWilcox(temp, \pnOver0\, \pnOver8\), 5)
# pv28 <- round(getPvalWilcox(temp, \pnOver2\, \pnOver8\), 5)
# pv48 <- round(getPvalWilcox(temp, \pnOver4\, \pnOver8\), 5)
# pv68 <- round(getPvalWilcox(temp, \pnOver6\, \pnOver8\), 5)


p <- ggplot(temp, aes(x = pnOver, y = mean_diff_score)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0, label = paste0(\pv02: \, convPvalue(pv02), \\n\,
  #                                               \pv24: \, convPvalue(pv24), \\n\,
  #                                               \pv46: \, convPvalue(pv46), \\n\,
  #                                               \pv68: \, convPvalue(pv68), \\n\,
  #                                               \pv48: \, convPvalue(pv48), \\n\,
  #                                               \pv28: \, convPvalue(pv28), \\n\,
  #                                               \pv08: \, convPvalue(pv08), \\n\), 
  #          color = \black\, hjust = 0, size = 3)

   
fileName <- paste0(\diffScore_barplot_pnGroup_A485_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5Qm5aWFJRZG1Gc1YybHNZMjk0SUR3dElHWjFibU4wYVc5dUtHUmhkR0VzSUdkeWIzVndNU3dnWjNKdmRYQXlLWHRjYmlNZ0lDQmthWE4wWVc1alpURWdQQzBnS0dSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9jRzVQZG1WeUlEMDlaM0p2ZFhBeEtTQXBKRzFsWVc1ZlpHbG1abDl6WTI5eVpWeHVJeUFnSUdScGMzUmhibU5sTWlBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lod2JrOTJaWElnUFQxbmNtOTFjRElwSUNra2JXVmhibDlrYVdabVgzTmpiM0psWEc0aklDQWdkMmxzSUR3dElIZHBiR052ZUM1MFpYTjBLR1JwYzNSaGJtTmxNU3dnWkdsemRHRnVZMlV5S1Z4dUl5QWdJSEpsZEhWeWJpaDNhV3drY0M1MllXeDFaU2xjYmlNZ2ZWeHVJeUJjYmlNZ2NIWXdNaUE4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEFzSUZ4Y2NHNVBkbVZ5TUZ4Y0xDQmNYSEJ1VDNabGNqSmNYQ2tzSURVcFhHNGpJSEIyTWpRZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xDQmNYSEJ1VDNabGNqSmNYQ3dnWEZ4d2JrOTJaWEkwWEZ3cExDQTFLVnh1SXlCd2RqUTJJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnWEZ4d2JrOTJaWEkwWEZ3c0lGeGNjRzVQZG1WeU5seGNLU3dnTlNsY2JpTWdjSFl3T0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBc0lGeGNjRzVQZG1WeU1GeGNMQ0JjWEhCdVQzWmxjamhjWENrc0lEVXBYRzRqSUhCMk1qZ2dQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMQ0JjWEhCdVQzWmxjakpjWEN3Z1hGeHdiazkyWlhJNFhGd3BMQ0ExS1Z4dUl5QndkalE0SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0N3Z1hGeHdiazkyWlhJMFhGd3NJRnhjY0c1UGRtVnlPRnhjS1N3Z05TbGNiaU1nY0hZMk9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXNJRnhjY0c1UGRtVnlObHhjTENCY1hIQnVUM1psY2poY1hDa3NJRFVwWEc1Y2JseHVjQ0E4TFNCblozQnNiM1FvZEdWdGNDd2dZV1Z6S0hnZ1BTQndiazkyWlhJc0lIa2dQU0J0WldGdVgyUnBabVpmYzJOdmNtVXBLU0FySUdkbGIyMWZkbWx2YkdsdUtHRmxjeWhtYVd4c0lEMGdjRzVQZG1WeUtTd2djMmh2ZHk1c1pXZGxibVFnUFNCR1FVeFRSU2tnSzF4dUlDQm5aVzl0WDJKdmVIQnNiM1FvZDJsa2RHZ2dQU0F3TGpFc0lHOTFkR3hwWlhJdWMyaGhjR1VnUFNCT1FTa2dLeUIwYUdWdFpWOWpiR0Z6YzJsaktDa2dLeUJjYmlBZ2MzUmhkRjl6ZFcxdFlYSjVLR0ZsY3lobmNtOTFjQ0E5SUhCdVQzWmxjaWtzSUdaMWJpQTlJRzFsWVc0c0lHZGxiMjBnUFNCY1hIQnZhVzUwWEZ3c0lITm9ZWEJsSUQwZ01qRXNJSE5wZW1VZ1BTQXlMQ0JtYVd4c0lEMGdYRnh5WldSY1hDd2dZMjlzYjNJZ1BTQmNYR0pzWVdOclhGd3BJQ3RjYmlBZ1oyVnZiVjlvYkdsdVpTaDVhVzUwWlhKalpYQjBJRDBnTUNsY2JpQWdJeUJoYm01dmRHRjBaU2hjWEhSbGVIUmNYQ3dnZUNBOUlERXNJSGtnUFNBd0xDQnNZV0psYkNBOUlIQmhjM1JsTUNoY1hIQjJNREk2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEIyTURJcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQjJNalE2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEIyTWpRcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQjJORFk2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEIyTkRZcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQjJOamc2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEIyTmpncExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQjJORGc2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEIyTkRncExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQjJNamc2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEIyTWpncExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQjJNRGc2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEIyTURncExDQmNYRnhjYmx4Y0tTd2dYRzRnSUNNZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlETXBYRzVjYmlBZ0lGeHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRnhjWkdsbVpsTmpiM0psWDJKaGNuQnNiM1JmY0c1SGNtOTFjRjlCTkRnMVgzWnpYMFJOVTA5Y1hDbGNibWhsYVdkb2RDQThMU0F6WEc1M2FXUjBhQ0E4TFNBelhHNXdibWNvYUdWeVpTaG1hV2RFYVhJc0lIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hGd3VjRzVuWEZ3cEtTd2djbVZ6SUQwZ05qQXdMQ0IxYm1sMElEMGdYRnhwYmx4Y0xDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc1d2NtbHVkQ2h3S1Z4dVpHVjJMbTltWmlncFhHNXpkbWRzYVhSbEtHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRnhjTG5OMloxeGNLU2tzSUNCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzV3Y21sdWRDaHdLVnh1WkdWMkxtOW1aaWdwWEc1Z1lHQmNibUJnWUNKOSAtLT5cblxuYGBgclxuYGBgclxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocG5PdmVyID09Z3JvdXAxKSApJG1lYW5fZGlmZl9zY29yZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4jICAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuIyAgIHJldHVybih3aWwkcC52YWx1ZSlcbiMgfVxuIyBcbiMgcHYwMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjJcXCksIDUpXG4jIHB2MjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI0XFwpLCA1KVxuIyBwdjQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwbk92ZXI0XFwsIFxccG5PdmVyNlxcKSwgNSlcbiMgcHYwOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjhcXCksIDUpXG4jIHB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBwdjQ4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwbk92ZXI0XFwsIFxccG5PdmVyOFxcKSwgNSlcbiMgcHY2OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyNlxcLCBcXHBuT3ZlcjhcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBwbk92ZXIsIHkgPSBtZWFuX2RpZmZfc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcG5PdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBuT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHB2MDI6IFxcLCBjb252UHZhbHVlKHB2MDIpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjQ6IFxcLCBjb252UHZhbHVlKHB2MjQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NDY6IFxcLCBjb252UHZhbHVlKHB2NDYpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Njg6IFxcLCBjb252UHZhbHVlKHB2NjgpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NDg6IFxcLCBjb252UHZhbHVlKHB2NDgpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBjb252UHZhbHVlKHB2MjgpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MDg6IFxcLCBjb252UHZhbHVlKHB2MDgpLCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG5cbiAgIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcZGlmZlNjb3JlX2JhcnBsb3RfcG5Hcm91cF9BNDg1X3ZzX0RNU09cXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocG5PdmVyID09Z3JvdXAxKSApJG1lYW5fZGlmZl9zY29yZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4jICAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuIyAgIHJldHVybih3aWwkcC52YWx1ZSlcbiMgfVxuIyBcbiMgcHYwMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjJcXCksIDUpXG4jIHB2MjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI0XFwpLCA1KVxuIyBwdjQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwbk92ZXI0XFwsIFxccG5PdmVyNlxcKSwgNSlcbiMgcHYwOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjhcXCksIDUpXG4jIHB2MjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBwdjQ4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwbk92ZXI0XFwsIFxccG5PdmVyOFxcKSwgNSlcbiMgcHY2OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccG5PdmVyNlxcLCBcXHBuT3ZlcjhcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBwbk92ZXIsIHkgPSBtZWFuX2RpZmZfc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcG5PdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBuT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHB2MDI6IFxcLCBjb252UHZhbHVlKHB2MDIpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MjQ6IFxcLCBjb252UHZhbHVlKHB2MjQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NDY6IFxcLCBjb252UHZhbHVlKHB2NDYpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Njg6IFxcLCBjb252UHZhbHVlKHB2NjgpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2NDg6IFxcLCBjb252UHZhbHVlKHB2NDgpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2Mjg6IFxcLCBjb252UHZhbHVlKHB2MjgpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHB2MDg6IFxcLCBjb252UHZhbHVlKHB2MDgpLCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG5cbiAgIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcZGlmZlNjb3JlX2JhcnBsb3RfcG5Hcm91cF9BNDg1X3ZzX0RNU09cXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$mean_diff_score
#   distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$mean_diff_score
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# pv02 <- round(getPvalWilcox(temp, \pnOver0\, \pnOver2\), 5)
# pv24 <- round(getPvalWilcox(temp, \pnOver2\, \pnOver4\), 5)
# pv46 <- round(getPvalWilcox(temp, \pnOver4\, \pnOver6\), 5)
# pv08 <- round(getPvalWilcox(temp, \pnOver0\, \pnOver8\), 5)
# pv28 <- round(getPvalWilcox(temp, \pnOver2\, \pnOver8\), 5)
# pv48 <- round(getPvalWilcox(temp, \pnOver4\, \pnOver8\), 5)
# pv68 <- round(getPvalWilcox(temp, \pnOver6\, \pnOver8\), 5)


p <- ggplot(temp, aes(x = pnOver, y = mean_diff_score)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0, label = paste0(\pv02: \, convPvalue(pv02), \\n\,
  #                                               \pv24: \, convPvalue(pv24), \\n\,
  #                                               \pv46: \, convPvalue(pv46), \\n\,
  #                                               \pv68: \, convPvalue(pv68), \\n\,
  #                                               \pv48: \, convPvalue(pv48), \\n\,
  #                                               \pv28: \, convPvalue(pv28), \\n\,
  #                                               \pv08: \, convPvalue(pv08), \\n\), 
  #          color = \black\, hjust = 0, size = 3)

   
fileName <- paste0(\diffScore_barplot_pnGroup_A485_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### (SKIP) GO for each group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuI1xuIyAgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBuT3ZlciA9PWdyb3VwMSkgKSRsb2cyRm9sZENoYW5nZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxudGVtcERvd24gPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihsb2cyRm9sZENoYW5nZSA8IDApXG4jICBcbiMgcHYwMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjBcIiwgXCJwbk92ZXIyXCIpLCA1KVxuIyBwdjA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFwicG5PdmVyMFwiLCBcInBuT3ZlcjRcIiksIDUpXG4jIHB2MDYgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXCJwbk92ZXIwXCIsIFwicG5PdmVyNlwiKSwgNSlcbiMgcHYwOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjBcIiwgXCJwbk92ZXI4XCIpLCA1KVxuIyBwdjI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFwicG5PdmVyMlwiLCBcInBuT3ZlcjRcIiksIDUpXG4jIHB2MjYgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXCJwbk92ZXIyXCIsIFwicG5PdmVyNlwiKSwgNSlcbiMgcHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjJcIiwgXCJwbk92ZXI4XCIpLCA1KVxuIyBwdjQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFwicG5PdmVyNFwiLCBcInBuT3ZlcjZcIiksIDUpXG4jIHB2NDggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXCJwbk92ZXI0XCIsIFwicG5PdmVyOFwiKSwgNSlcbiMgcHY2OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBuT3ZlcjZcIiwgXCJwbk92ZXI4XCIpLCA1KVxuXG5cblxuXG5wIDwtIGdncGxvdCh0ZW1wRG93biwgYWVzKHggPSBwbk92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwbk92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcInJlZFwiLCBjb2xvciA9IFwiYmxhY2tcIikgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKVxuICAjIGFubm90YXRlKFwidGV4dFwiLCB4ID0gMSwgeSA9IC0wLjUsIGxhYmVsID0gcGFzdGUwKFwicHYwMjogXCIsIGNvbnZQdmFsdWUocHYwMiksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHYwNDogXCIsIGNvbnZQdmFsdWUocHYwNCksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHYwNjogXCIsIGNvbnZQdmFsdWUocHYwNiksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHYwODogXCIsIGNvbnZQdmFsdWUocHYwOCksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHYyNDogXCIsIGNvbnZQdmFsdWUocHYyNCksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHYyNjogXCIsIGNvbnZQdmFsdWUocHYyNiksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHYyODogXCIsIGNvbnZQdmFsdWUocHYyOCksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHY0NjogXCIsIGNvbnZQdmFsdWUocHY0NiksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHY0ODogXCIsIGNvbnZQdmFsdWUocHY0OCksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHY2ODogXCIsIGNvbnZQdmFsdWUocHY2OCksIFwiXFxuXCIpLCBcbiAgIyAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMykgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTEsIDApKVxuXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFwibG9nMkZDX2JhcnBsb3RfcG5Hcm91cF9BNDg1X3ZzX0RNU09fZG93blwiKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcblxuXG5cbnRlbXBVcCA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGxvZzJGb2xkQ2hhbmdlID4gMClcbiMgIFxuIyBwdjAyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBuT3ZlcjBcIiwgXCJwbk92ZXIyXCIpLCA1KVxuIyBwdjA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBuT3ZlcjBcIiwgXCJwbk92ZXI0XCIpLCA1KVxuIyBwdjA2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBuT3ZlcjBcIiwgXCJwbk92ZXI2XCIpLCA1KVxuIyBwdjA4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBuT3ZlcjBcIiwgXCJwbk92ZXI4XCIpLCA1KVxuIyBwdjI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBuT3ZlcjJcIiwgXCJwbk92ZXI0XCIpLCA1KVxuIyBwdjI2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBuT3ZlcjJcIiwgXCJwbk92ZXI2XCIpLCA1KVxuIyBwdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBuT3ZlcjJcIiwgXCJwbk92ZXI4XCIpLCA1KVxuIyBwdjQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBuT3ZlcjRcIiwgXCJwbk92ZXI2XCIpLCA1KVxuIyBwdjQ4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBuT3ZlcjRcIiwgXCJwbk92ZXI4XCIpLCA1KVxuIyBwdjY4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBuT3ZlcjZcIiwgXCJwbk92ZXI4XCIpLCA1KVxuIyBcblxuXG5cbnAgPC0gZ2dwbG90KHRlbXBVcCwgYWVzKHggPSBwbk92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwbk92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcInJlZFwiLCBjb2xvciA9IFwiYmxhY2tcIikgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKVxuICAjIGFubm90YXRlKFwidGV4dFwiLCB4ID0gMSwgeSA9IDAuNSwgbGFiZWwgPSBwYXN0ZTAoXCJwdjAyOiBcIiwgY29udlB2YWx1ZShwdjAyKSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjA0OiBcIiwgY29udlB2YWx1ZShwdjA0KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjA2OiBcIiwgY29udlB2YWx1ZShwdjA2KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjA4OiBcIiwgY29udlB2YWx1ZShwdjA4KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjI0OiBcIiwgY29udlB2YWx1ZShwdjI0KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjI2OiBcIiwgY29udlB2YWx1ZShwdjI2KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjI4OiBcIiwgY29udlB2YWx1ZShwdjI4KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjQ2OiBcIiwgY29udlB2YWx1ZShwdjQ2KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjQ4OiBcIiwgY29udlB2YWx1ZShwdjQ4KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwdjY4OiBcIiwgY29udlB2YWx1ZShwdjY4KSwgXCJcXG5cIiksIFxuICAjICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygwLCAxKSlcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcImxvZzJGQ19iYXJwbG90X3BuR3JvdXBfQTQ4NV92c19ETVNPX3VwXCIpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgIn0= -->\n\n```r\n#\n#  getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$log2FoldChange\n#   distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$log2FoldChange\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n# \ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n#  \n# pv02 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver2\\), 5)\n# pv04 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver4\\), 5)\n# pv06 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver6\\), 5)\n# pv08 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver8\\), 5)\n# pv24 <- round(getPvalWilcox(tempDown, \\pnOver2\\, \\pnOver4\\), 5)\n# pv26 <- round(getPvalWilcox(tempDown, \\pnOver2\\, \\pnOver6\\), 5)\n# pv28 <- round(getPvalWilcox(tempDown, \\pnOver2\\, \\pnOver8\\), 5)\n# pv46 <- round(getPvalWilcox(tempDown, \\pnOver4\\, \\pnOver6\\), 5)\n# pv48 <- round(getPvalWilcox(tempDown, \\pnOver4\\, \\pnOver8\\), 5)\n# pv68 <- round(getPvalWilcox(tempDown, \\pnOver6\\, \\pnOver8\\), 5)\n\n\n\n\np <- ggplot(tempDown, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = pnOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\pv02: \\, convPvalue(pv02), \\\\n\\,\n  #                                                  \\pv04: \\, convPvalue(pv04), \\\\n\\,\n  #                                                  \\pv06: \\, convPvalue(pv06), \\\\n\\,\n  #                                                  \\pv08: \\, convPvalue(pv08), \\\\n\\,\n  #                                                  \\pv24: \\, convPvalue(pv24), \\\\n\\,\n  #                                                  \\pv26: \\, convPvalue(pv26), \\\\n\\,\n  #                                                  \\pv28: \\, convPvalue(pv28), \\\\n\\,\n  #                                                  \\pv46: \\, convPvalue(pv46), \\\\n\\,\n  #                                                  \\pv48: \\, convPvalue(pv48), \\\\n\\,\n  #                                                  \\pv68: \\, convPvalue(pv68), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))\n\n  \nfileName <- paste0(\\log2FC_barplot_pnGroup_A485_vs_DMSO_down\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n#  \n# pv02 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver2\\), 5)\n# pv04 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver4\\), 5)\n# pv06 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver6\\), 5)\n# pv08 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver8\\), 5)\n# pv24 <- round(getPvalWilcox(tempUp, \\pnOver2\\, \\pnOver4\\), 5)\n# pv26 <- round(getPvalWilcox(tempUp, \\pnOver2\\, \\pnOver6\\), 5)\n# pv28 <- round(getPvalWilcox(tempUp, \\pnOver2\\, \\pnOver8\\), 5)\n# pv46 <- round(getPvalWilcox(tempUp, \\pnOver4\\, \\pnOver6\\), 5)\n# pv48 <- round(getPvalWilcox(tempUp, \\pnOver4\\, \\pnOver8\\), 5)\n# pv68 <- round(getPvalWilcox(tempUp, \\pnOver6\\, \\pnOver8\\), 5)\n# \n\n\n\np <- ggplot(tempUp, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = pnOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\pv02: \\, convPvalue(pv02), \\\\n\\,\n  #                                                  \\pv04: \\, convPvalue(pv04), \\\\n\\,\n  #                                                  \\pv06: \\, convPvalue(pv06), \\\\n\\,\n  #                                                  \\pv08: \\, convPvalue(pv08), \\\\n\\,\n  #                                                  \\pv24: \\, convPvalue(pv24), \\\\n\\,\n  #                                                  \\pv26: \\, convPvalue(pv26), \\\\n\\,\n  #                                                  \\pv28: \\, convPvalue(pv28), \\\\n\\,\n  #                                                  \\pv46: \\, convPvalue(pv46), \\\\n\\,\n  #                                                  \\pv48: \\, convPvalue(pv48), \\\\n\\,\n  #                                                  \\pv68: \\, convPvalue(pv68), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_pnGroup_A485_vs_DMSO_up\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
#
#  getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$log2FoldChange
#   distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$log2FoldChange
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
#  
# pv02 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver2\), 5)
# pv04 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver4\), 5)
# pv06 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver6\), 5)
# pv08 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver8\), 5)
# pv24 <- round(getPvalWilcox(tempDown, \pnOver2\, \pnOver4\), 5)
# pv26 <- round(getPvalWilcox(tempDown, \pnOver2\, \pnOver6\), 5)
# pv28 <- round(getPvalWilcox(tempDown, \pnOver2\, \pnOver8\), 5)
# pv46 <- round(getPvalWilcox(tempDown, \pnOver4\, \pnOver6\), 5)
# pv48 <- round(getPvalWilcox(tempDown, \pnOver4\, \pnOver8\), 5)
# pv68 <- round(getPvalWilcox(tempDown, \pnOver6\, \pnOver8\), 5)




p <- ggplot(tempDown, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = -0.5, label = paste0(\pv02: \, convPvalue(pv02), \\n\,
  #                                                  \pv04: \, convPvalue(pv04), \\n\,
  #                                                  \pv06: \, convPvalue(pv06), \\n\,
  #                                                  \pv08: \, convPvalue(pv08), \\n\,
  #                                                  \pv24: \, convPvalue(pv24), \\n\,
  #                                                  \pv26: \, convPvalue(pv26), \\n\,
  #                                                  \pv28: \, convPvalue(pv28), \\n\,
  #                                                  \pv46: \, convPvalue(pv46), \\n\,
  #                                                  \pv48: \, convPvalue(pv48), \\n\,
  #                                                  \pv68: \, convPvalue(pv68), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0(\log2FC_barplot_pnGroup_A485_vs_DMSO_down\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
#  
# pv02 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver2\), 5)
# pv04 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver4\), 5)
# pv06 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver6\), 5)
# pv08 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver8\), 5)
# pv24 <- round(getPvalWilcox(tempUp, \pnOver2\, \pnOver4\), 5)
# pv26 <- round(getPvalWilcox(tempUp, \pnOver2\, \pnOver6\), 5)
# pv28 <- round(getPvalWilcox(tempUp, \pnOver2\, \pnOver8\), 5)
# pv46 <- round(getPvalWilcox(tempUp, \pnOver4\, \pnOver6\), 5)
# pv48 <- round(getPvalWilcox(tempUp, \pnOver4\, \pnOver8\), 5)
# pv68 <- round(getPvalWilcox(tempUp, \pnOver6\, \pnOver8\), 5)
# 



p <- ggplot(tempUp, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0.5, label = paste0(\pv02: \, convPvalue(pv02), \\n\,
  #                                                  \pv04: \, convPvalue(pv04), \\n\,
  #                                                  \pv06: \, convPvalue(pv06), \\n\,
  #                                                  \pv08: \, convPvalue(pv08), \\n\,
  #                                                  \pv24: \, convPvalue(pv24), \\n\,
  #                                                  \pv26: \, convPvalue(pv26), \\n\,
  #                                                  \pv28: \, convPvalue(pv28), \\n\,
  #                                                  \pv46: \, convPvalue(pv46), \\n\,
  #                                                  \pv48: \, convPvalue(pv48), \\n\,
  #                                                  \pv68: \, convPvalue(pv68), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_pnGroup_A485_vs_DMSO_up\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuI1xuIyAgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBuT3ZlciA9PWdyb3VwMSkgKSRsb2cyRm9sZENoYW5nZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxudGVtcERvd24gPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihsb2cyRm9sZENoYW5nZSA8IDApXG4jICBcbiMgcHYwMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXIyXFwpLCA1KVxuIyBwdjA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjRcXCksIDUpXG4jIHB2MDYgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwbk92ZXIwXFwsIFxccG5PdmVyNlxcKSwgNSlcbiMgcHYwOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBwdjI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccG5PdmVyMlxcLCBcXHBuT3ZlcjRcXCksIDUpXG4jIHB2MjYgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwbk92ZXIyXFwsIFxccG5PdmVyNlxcKSwgNSlcbiMgcHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBwdjQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccG5PdmVyNFxcLCBcXHBuT3ZlcjZcXCksIDUpXG4jIHB2NDggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwbk92ZXI0XFwsIFxccG5PdmVyOFxcKSwgNSlcbiMgcHY2OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjZcXCwgXFxwbk92ZXI4XFwpLCA1KVxuXG5cblxuXG5wIDwtIGdncGxvdCh0ZW1wRG93biwgYWVzKHggPSBwbk92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwbk92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKVxuICAjIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IC0wLjUsIGxhYmVsID0gcGFzdGUwKFxccHYwMjogXFwsIGNvbnZQdmFsdWUocHYwMiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYwNDogXFwsIGNvbnZQdmFsdWUocHYwNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYwNjogXFwsIGNvbnZQdmFsdWUocHYwNiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYwODogXFwsIGNvbnZQdmFsdWUocHYwOCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNDogXFwsIGNvbnZQdmFsdWUocHYyNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNjogXFwsIGNvbnZQdmFsdWUocHYyNiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyODogXFwsIGNvbnZQdmFsdWUocHYyOCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY0NjogXFwsIGNvbnZQdmFsdWUocHY0NiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY0ODogXFwsIGNvbnZQdmFsdWUocHY0OCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY2ODogXFwsIGNvbnZQdmFsdWUocHY2OCksIFxcXFxuXFwpLCBcbiAgIyAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTEsIDApKVxuXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcbG9nMkZDX2JhcnBsb3RfcG5Hcm91cF9BNDg1X3ZzX0RNU09fZG93blxcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcblxuXG5cbnRlbXBVcCA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGxvZzJGb2xkQ2hhbmdlID4gMClcbiMgIFxuIyBwdjAyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXIyXFwpLCA1KVxuIyBwdjA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI0XFwpLCA1KVxuIyBwdjA2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI2XFwpLCA1KVxuIyBwdjA4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBwdjI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI0XFwpLCA1KVxuIyBwdjI2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI2XFwpLCA1KVxuIyBwdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBwdjQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI2XFwpLCA1KVxuIyBwdjQ4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBwdjY4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjZcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBcblxuXG5cbnAgPC0gZ2dwbG90KHRlbXBVcCwgYWVzKHggPSBwbk92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwbk92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKVxuICAjIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDAuNSwgbGFiZWwgPSBwYXN0ZTAoXFxwdjAyOiBcXCwgY29udlB2YWx1ZShwdjAyKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjA0OiBcXCwgY29udlB2YWx1ZShwdjA0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjA2OiBcXCwgY29udlB2YWx1ZShwdjA2KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjA4OiBcXCwgY29udlB2YWx1ZShwdjA4KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI0OiBcXCwgY29udlB2YWx1ZShwdjI0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI2OiBcXCwgY29udlB2YWx1ZShwdjI2KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgY29udlB2YWx1ZShwdjI4KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjQ2OiBcXCwgY29udlB2YWx1ZShwdjQ2KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjQ4OiBcXCwgY29udlB2YWx1ZShwdjQ4KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjY4OiBcXCwgY29udlB2YWx1ZShwdjY4KSwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygwLCAxKSlcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXGxvZzJGQ19iYXJwbG90X3BuR3JvdXBfQTQ4NV92c19ETVNPX3VwXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n#\n#  getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$log2FoldChange\n#   distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$log2FoldChange\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n# \ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n#  \n# pv02 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver2\\), 5)\n# pv04 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver4\\), 5)\n# pv06 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver6\\), 5)\n# pv08 <- round(getPvalWilcox(tempDown, \\pnOver0\\, \\pnOver8\\), 5)\n# pv24 <- round(getPvalWilcox(tempDown, \\pnOver2\\, \\pnOver4\\), 5)\n# pv26 <- round(getPvalWilcox(tempDown, \\pnOver2\\, \\pnOver6\\), 5)\n# pv28 <- round(getPvalWilcox(tempDown, \\pnOver2\\, \\pnOver8\\), 5)\n# pv46 <- round(getPvalWilcox(tempDown, \\pnOver4\\, \\pnOver6\\), 5)\n# pv48 <- round(getPvalWilcox(tempDown, \\pnOver4\\, \\pnOver8\\), 5)\n# pv68 <- round(getPvalWilcox(tempDown, \\pnOver6\\, \\pnOver8\\), 5)\n\n\n\n\np <- ggplot(tempDown, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = pnOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\pv02: \\, convPvalue(pv02), \\\\n\\,\n  #                                                  \\pv04: \\, convPvalue(pv04), \\\\n\\,\n  #                                                  \\pv06: \\, convPvalue(pv06), \\\\n\\,\n  #                                                  \\pv08: \\, convPvalue(pv08), \\\\n\\,\n  #                                                  \\pv24: \\, convPvalue(pv24), \\\\n\\,\n  #                                                  \\pv26: \\, convPvalue(pv26), \\\\n\\,\n  #                                                  \\pv28: \\, convPvalue(pv28), \\\\n\\,\n  #                                                  \\pv46: \\, convPvalue(pv46), \\\\n\\,\n  #                                                  \\pv48: \\, convPvalue(pv48), \\\\n\\,\n  #                                                  \\pv68: \\, convPvalue(pv68), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))\n\n  \nfileName <- paste0(\\log2FC_barplot_pnGroup_A485_vs_DMSO_down\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n#  \n# pv02 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver2\\), 5)\n# pv04 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver4\\), 5)\n# pv06 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver6\\), 5)\n# pv08 <- round(getPvalWilcox(tempUp, \\pnOver0\\, \\pnOver8\\), 5)\n# pv24 <- round(getPvalWilcox(tempUp, \\pnOver2\\, \\pnOver4\\), 5)\n# pv26 <- round(getPvalWilcox(tempUp, \\pnOver2\\, \\pnOver6\\), 5)\n# pv28 <- round(getPvalWilcox(tempUp, \\pnOver2\\, \\pnOver8\\), 5)\n# pv46 <- round(getPvalWilcox(tempUp, \\pnOver4\\, \\pnOver6\\), 5)\n# pv48 <- round(getPvalWilcox(tempUp, \\pnOver4\\, \\pnOver8\\), 5)\n# pv68 <- round(getPvalWilcox(tempUp, \\pnOver6\\, \\pnOver8\\), 5)\n# \n\n\n\np <- ggplot(tempUp, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = pnOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\pv02: \\, convPvalue(pv02), \\\\n\\,\n  #                                                  \\pv04: \\, convPvalue(pv04), \\\\n\\,\n  #                                                  \\pv06: \\, convPvalue(pv06), \\\\n\\,\n  #                                                  \\pv08: \\, convPvalue(pv08), \\\\n\\,\n  #                                                  \\pv24: \\, convPvalue(pv24), \\\\n\\,\n  #                                                  \\pv26: \\, convPvalue(pv26), \\\\n\\,\n  #                                                  \\pv28: \\, convPvalue(pv28), \\\\n\\,\n  #                                                  \\pv46: \\, convPvalue(pv46), \\\\n\\,\n  #                                                  \\pv48: \\, convPvalue(pv48), \\\\n\\,\n  #                                                  \\pv68: \\, convPvalue(pv68), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_pnGroup_A485_vs_DMSO_up\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuI1xuIyAgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBuT3ZlciA9PWdyb3VwMSkgKSRsb2cyRm9sZENoYW5nZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxudGVtcERvd24gPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihsb2cyRm9sZENoYW5nZSA8IDApXG4jICBcbiMgcHYwMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXIyXFwpLCA1KVxuIyBwdjA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccG5PdmVyMFxcLCBcXHBuT3ZlcjRcXCksIDUpXG4jIHB2MDYgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwbk92ZXIwXFwsIFxccG5PdmVyNlxcKSwgNSlcbiMgcHYwOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBwdjI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccG5PdmVyMlxcLCBcXHBuT3ZlcjRcXCksIDUpXG4jIHB2MjYgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwbk92ZXIyXFwsIFxccG5PdmVyNlxcKSwgNSlcbiMgcHYyOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBwdjQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccG5PdmVyNFxcLCBcXHBuT3ZlcjZcXCksIDUpXG4jIHB2NDggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwbk92ZXI0XFwsIFxccG5PdmVyOFxcKSwgNSlcbiMgcHY2OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBuT3ZlcjZcXCwgXFxwbk92ZXI4XFwpLCA1KVxuXG5cblxuXG5wIDwtIGdncGxvdCh0ZW1wRG93biwgYWVzKHggPSBwbk92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwbk92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKVxuICAjIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IC0wLjUsIGxhYmVsID0gcGFzdGUwKFxccHYwMjogXFwsIGNvbnZQdmFsdWUocHYwMiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYwNDogXFwsIGNvbnZQdmFsdWUocHYwNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYwNjogXFwsIGNvbnZQdmFsdWUocHYwNiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYwODogXFwsIGNvbnZQdmFsdWUocHYwOCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNDogXFwsIGNvbnZQdmFsdWUocHYyNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyNjogXFwsIGNvbnZQdmFsdWUocHYyNiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHYyODogXFwsIGNvbnZQdmFsdWUocHYyOCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY0NjogXFwsIGNvbnZQdmFsdWUocHY0NiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY0ODogXFwsIGNvbnZQdmFsdWUocHY0OCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHY2ODogXFwsIGNvbnZQdmFsdWUocHY2OCksIFxcXFxuXFwpLCBcbiAgIyAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTEsIDApKVxuXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcbG9nMkZDX2JhcnBsb3RfcG5Hcm91cF9BNDg1X3ZzX0RNU09fZG93blxcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcblxuXG5cbnRlbXBVcCA8LSB0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGxvZzJGb2xkQ2hhbmdlID4gMClcbiMgIFxuIyBwdjAyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXIyXFwpLCA1KVxuIyBwdjA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI0XFwpLCA1KVxuIyBwdjA2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI2XFwpLCA1KVxuIyBwdjA4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjBcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBwdjI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI0XFwpLCA1KVxuIyBwdjI2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI2XFwpLCA1KVxuIyBwdjI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjJcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBwdjQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI2XFwpLCA1KVxuIyBwdjQ4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjRcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBwdjY4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBuT3ZlcjZcXCwgXFxwbk92ZXI4XFwpLCA1KVxuIyBcblxuXG5cbnAgPC0gZ2dwbG90KHRlbXBVcCwgYWVzKHggPSBwbk92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwbk92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKVxuICAjIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDAuNSwgbGFiZWwgPSBwYXN0ZTAoXFxwdjAyOiBcXCwgY29udlB2YWx1ZShwdjAyKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjA0OiBcXCwgY29udlB2YWx1ZShwdjA0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjA2OiBcXCwgY29udlB2YWx1ZShwdjA2KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjA4OiBcXCwgY29udlB2YWx1ZShwdjA4KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI0OiBcXCwgY29udlB2YWx1ZShwdjI0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI2OiBcXCwgY29udlB2YWx1ZShwdjI2KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjI4OiBcXCwgY29udlB2YWx1ZShwdjI4KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjQ2OiBcXCwgY29udlB2YWx1ZShwdjQ2KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjQ4OiBcXCwgY29udlB2YWx1ZShwdjQ4KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwdjY4OiBcXCwgY29udlB2YWx1ZShwdjY4KSwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygwLCAxKSlcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXGxvZzJGQ19iYXJwbG90X3BuR3JvdXBfQTQ4NV92c19ETVNPX3VwXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
#
#  getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$log2FoldChange
#   distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$log2FoldChange
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
#  
# pv02 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver2\), 5)
# pv04 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver4\), 5)
# pv06 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver6\), 5)
# pv08 <- round(getPvalWilcox(tempDown, \pnOver0\, \pnOver8\), 5)
# pv24 <- round(getPvalWilcox(tempDown, \pnOver2\, \pnOver4\), 5)
# pv26 <- round(getPvalWilcox(tempDown, \pnOver2\, \pnOver6\), 5)
# pv28 <- round(getPvalWilcox(tempDown, \pnOver2\, \pnOver8\), 5)
# pv46 <- round(getPvalWilcox(tempDown, \pnOver4\, \pnOver6\), 5)
# pv48 <- round(getPvalWilcox(tempDown, \pnOver4\, \pnOver8\), 5)
# pv68 <- round(getPvalWilcox(tempDown, \pnOver6\, \pnOver8\), 5)




p <- ggplot(tempDown, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = -0.5, label = paste0(\pv02: \, convPvalue(pv02), \\n\,
  #                                                  \pv04: \, convPvalue(pv04), \\n\,
  #                                                  \pv06: \, convPvalue(pv06), \\n\,
  #                                                  \pv08: \, convPvalue(pv08), \\n\,
  #                                                  \pv24: \, convPvalue(pv24), \\n\,
  #                                                  \pv26: \, convPvalue(pv26), \\n\,
  #                                                  \pv28: \, convPvalue(pv28), \\n\,
  #                                                  \pv46: \, convPvalue(pv46), \\n\,
  #                                                  \pv48: \, convPvalue(pv48), \\n\,
  #                                                  \pv68: \, convPvalue(pv68), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0(\log2FC_barplot_pnGroup_A485_vs_DMSO_down\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
#  
# pv02 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver2\), 5)
# pv04 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver4\), 5)
# pv06 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver6\), 5)
# pv08 <- round(getPvalWilcox(tempUp, \pnOver0\, \pnOver8\), 5)
# pv24 <- round(getPvalWilcox(tempUp, \pnOver2\, \pnOver4\), 5)
# pv26 <- round(getPvalWilcox(tempUp, \pnOver2\, \pnOver6\), 5)
# pv28 <- round(getPvalWilcox(tempUp, \pnOver2\, \pnOver8\), 5)
# pv46 <- round(getPvalWilcox(tempUp, \pnOver4\, \pnOver6\), 5)
# pv48 <- round(getPvalWilcox(tempUp, \pnOver4\, \pnOver8\), 5)
# pv68 <- round(getPvalWilcox(tempUp, \pnOver6\, \pnOver8\), 5)
# 



p <- ggplot(tempUp, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0.5, label = paste0(\pv02: \, convPvalue(pv02), \\n\,
  #                                                  \pv04: \, convPvalue(pv04), \\n\,
  #                                                  \pv06: \, convPvalue(pv06), \\n\,
  #                                                  \pv08: \, convPvalue(pv08), \\n\,
  #                                                  \pv24: \, convPvalue(pv24), \\n\,
  #                                                  \pv26: \, convPvalue(pv26), \\n\,
  #                                                  \pv28: \, convPvalue(pv28), \\n\,
  #                                                  \pv46: \, convPvalue(pv46), \\n\,
  #                                                  \pv48: \, convPvalue(pv48), \\n\,
  #                                                  \pv68: \, convPvalue(pv68), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_pnGroup_A485_vs_DMSO_up\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



##### loop score

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUIwWlcxd01pQmpiMjUwWVdsdWN5Qm5aVzVsY3lCbWNtOXRJR2R5YjNWd0lERXNJRElzSURVc0lEZ2dZVzVrSUd4dmIzQWdZMjkxYm5SelhHNGpZMkZzWTNWc1lYUnBibWNnWkdsbVppQnpZMjl5WlNCaGJtUWdiRzluTW1aaklHUnBjM1J5YVdKMWRHbHZiaUJpWVhObFpDQnZiaUJ3TFc0Z2JuVnRZbVZ5YzF4dVhHNXdjMDkyWlhJMElEd3RJQ2gwWlcxd01pQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHVkVzFmY0hNZ1BqMGdOQ2twSkdkbGJtVmNibkJ6VDNabGNqTWdQQzBnS0hSbGJYQXlJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRzUxYlY5d2N5QStQU0F6TENCdWRXMWZjSE1nUENBMEtTa2taMlZ1WlZ4dWNITlBkbVZ5TWlBOExTQW9kR1Z0Y0RJZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb2JuVnRYM0J6SUQ0OUlESXNJRzUxYlY5d2N5QThJRE1wS1NSblpXNWxYRzV3YzA5MlpYSXhJRHd0SUNoMFpXMXdNaUFsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWh1ZFcxZmNITWdQajBnTVN3Z2JuVnRYM0J6SUR3Z01pa3BKR2RsYm1WY2JuQnpUM1psY2pBZ1BDMGdLSFJsYlhBeUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHNTFiVjl3Y3lBOElERXBLU1JuWlc1bFhHNWNibHh1WEc1Y2JpTWpJRVJwZG1sa2FXNW5JR2RsYm1WeklHbHVkRzhnWjNKdmRYQnpYRzUwWlcxd0lEd3RJR2RsYm1WQmJtNXZSR0YwWVNBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoa2FXWm1YMEUwT0RWZlJFMVRUeXdnWkdsemRHRnVZMlVzSUdkbGJtVXBJQ1UrSlNCY2JpQWdkVzV1WlhOMEtHZGxibVVwSUNVK0pTQm5jbTkxY0Y5aWVTaG5aVzVsS1NBbFBpVmNiaUFnYzNWdGJXRnlhWHBsS0cxbFlXNWZaR2xtWmw5elkyOXlaU0E5SUcxbFlXNG9aR2xtWmw5Qk5EZzFYMFJOVTA4cExGeHVJQ0FnSUNBZ0lDQWdJQ0FnYldWaGJsOWthWE4wWVc1alpTQTlJRzFsWVc0b1pHbHpkR0Z1WTJVcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnTG1keWIzVndjeUE5SUNka2NtOXdKeWxjYmx4dVpHbG1aaTVTVGtFZ1BDMGdabkpsWVdRb2FHVnlaU2h5WldaRWFYSXNJRndpWkdsbVpsOUhNUzVCTkRnMUxuTmxiR1ZqZEdWa01sOUhNUzR5YVM1Qk5EZzFYM1p6WDBjeExqSnBMa1JOVTA4dWRITjJYQ0lwS1NBbFBpVmNiaUFnWkhCc2VYSTZPbk5sYkdWamRDaGxibk5sYldKc1gyZGxibVZmYVdRc0lHeHZaekpHYjJ4a1EyaGhibWRsTENCemFISnBibXRsWkY5c2IyY3lSa01zSUhCaFpHb3NJR1Y0ZEdWeWJtRnNYMmRsYm1WZmJtRnRaU2xjYmx4dWJXRjRURzluTWtaRElEMGdNbHh1WEc1MFpXMXdJRHd0SUd4bFpuUmZhbTlwYmloMFpXMXdMQ0JrYVdabUxsSk9RU3dnWW5rZ1BTQmpLRndpWjJWdVpWd2lJRDBnWENKbGJuTmxiV0pzWDJkbGJtVmZhV1JjSWlrcElDVStKU0JjYmlBZ1pISnZjRjl1WVNoemFISnBibXRsWkY5c2IyY3lSa01wWEc1Y2JseHVkR1Z0Y0NBOExTQjBaVzF3SUNVK0pTQmtjR3g1Y2pvNmJYVjBZWFJsS0Z4dUlDQndjMDkyWlhJZ1BTQnBabVZzYzJVb1oyVnVaU0FsYVc0bElIQnpUM1psY2pRc0lGd2ljSE5QZG1WeU5Gd2lMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3YzA5MlpYSXpMQ0JjSW5CelQzWmxjak5jSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCcFptVnNjMlVvWjJWdVpTQWxhVzRsSUhCelQzWmxjaklzSUZ3aWNITlBkbVZ5TWx3aUxGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCcFptVnNjMlVvWjJWdVpTQWxhVzRsSUhCelQzWmxjakVzSUZ3aWNITlBkbVZ5TVZ3aUxGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3YzA5MlpYSXdMQ0JjSW5CelQzWmxjakJjSWl3Z1RrRXBLU2twS1NrZ0pUNGxYRzRnSUdSeWIzQmZibUVvY0hOUGRtVnlLVnh1WEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG4jIHRlbXAyIGNvbnRhaW5zIGdlbmVzIGZyb20gZ3JvdXAgMSwgMiwgNSwgOCBhbmQgbG9vcCBjb3VudHNcbiNjYWxjdWxhdGluZyBkaWZmIHNjb3JlIGFuZCBsb2cyZmMgZGlzdHJpYnV0aW9uIGJhc2VkIG9uIHAtbiBudW1iZXJzXG5cbnBzT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSA0KSkkZ2VuZVxucHNPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDMsIG51bV9wcyA8IDQpKSRnZW5lXG5wc092ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMiwgbnVtX3BzIDwgMykpJGdlbmVcbnBzT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAxLCBudW1fcHMgPCAyKSkkZ2VuZVxucHNPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzIDwgMSkpJGdlbmVcblxuXG5cblxuIyMgRGl2aWRpbmcgZ2VuZXMgaW50byBncm91cHNcbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmZfQTQ4NV9ETVNPLCBkaXN0YW5jZSwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmX0E0ODVfRE1TTyksXG4gICAgICAgICAgICBtZWFuX2Rpc3RhbmNlID0gbWVhbihkaXN0YW5jZSksXG4gICAgICAgICAgICAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLkE0ODUuc2VsZWN0ZWQyX0cxLjJpLkE0ODVfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxuXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBzT3ZlciA9IGlmZWxzZShnZW5lICVpbiUgcHNPdmVyNCwgXFxwc092ZXI0XFwsXG4gICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjMsIFxccHNPdmVyM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMiwgXFxwc092ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMSwgXFxwc092ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjAsIFxccHNPdmVyMFxcLCBOQSkpKSkpKSAlPiVcbiAgZHJvcF9uYShwc092ZXIpXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene




## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)


temp <- temp %>% dplyr::mutate(
  psOver = ifelse(gene %in% psOver4, \psOver4\,
                  ifelse(gene %in% psOver3, \psOver3\,
                         ifelse(gene %in% psOver2, \psOver2\,
                                ifelse(gene %in% psOver1, \psOver1\,
                                       ifelse(gene %in% psOver0, \psOver0\, NA)))))) %>%
  drop_na(psOver)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QjBaVzF3TWlCamIyNTBZV2x1Y3lCblpXNWxjeUJtY205dElHZHliM1Z3SURFc0lESXNJRFVzSURnZ1lXNWtJR3h2YjNBZ1kyOTFiblJ6WEc0alkyRnNZM1ZzWVhScGJtY2daR2xtWmlCelkyOXlaU0JoYm1RZ2JHOW5NbVpqSUdScGMzUnlhV0oxZEdsdmJpQmlZWE5sWkNCdmJpQndMVzRnYm5WdFltVnljMXh1WEc1d2MwOTJaWEkwSUR3dElDaDBaVzF3TWlBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lodWRXMWZjSE1nUGowZ05Da3BKR2RsYm1WY2JuQnpUM1psY2pNZ1BDMGdLSFJsYlhBeUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHNTFiVjl3Y3lBK1BTQXpMQ0J1ZFcxZmNITWdQQ0EwS1Nra1oyVnVaVnh1Y0hOUGRtVnlNaUE4TFNBb2RHVnRjRElnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvYm5WdFgzQnpJRDQ5SURJc0lHNTFiVjl3Y3lBOElETXBLU1JuWlc1bFhHNXdjMDkyWlhJeElEd3RJQ2gwWlcxd01pQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHVkVzFmY0hNZ1BqMGdNU3dnYm5WdFgzQnpJRHdnTWlrcEpHZGxibVZjYm5CelQzWmxjakFnUEMwZ0tIUmxiWEF5SUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0c1MWJWOXdjeUE4SURFcEtTUm5aVzVsWEc1Y2JseHVYRzVjYmlNaklFUnBkbWxrYVc1bklHZGxibVZ6SUdsdWRHOGdaM0p2ZFhCelhHNTBaVzF3SUR3dElHZGxibVZCYm01dlJHRjBZU0FsUGlVZ1pIQnNlWEk2T25ObGJHVmpkQ2hrYVdabVgwRTBPRFZmUkUxVFR5d2daR2x6ZEdGdVkyVXNJR2RsYm1VcElDVStKU0JjYmlBZ2RXNXVaWE4wS0dkbGJtVXBJQ1UrSlNCbmNtOTFjRjlpZVNoblpXNWxLU0FsUGlWY2JpQWdjM1Z0YldGeWFYcGxLRzFsWVc1ZlpHbG1abDl6WTI5eVpTQTlJRzFsWVc0b1pHbG1abDlCTkRnMVgwUk5VMDhwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdiV1ZoYmw5a2FYTjBZVzVqWlNBOUlHMWxZVzRvWkdsemRHRnVZMlVwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdMbWR5YjNWd2N5QTlJQ2RrY205d0p5bGNibHh1WkdsbVppNVNUa0VnUEMwZ1puSmxZV1FvYUdWeVpTaHlaV1pFYVhJc0lGeGNaR2xtWmw5SE1TNUJORGcxTG5ObGJHVmpkR1ZrTWw5SE1TNHlhUzVCTkRnMVgzWnpYMGN4TGpKcExrUk5VMDh1ZEhOMlhGd3BLU0FsUGlWY2JpQWdaSEJzZVhJNk9uTmxiR1ZqZENobGJuTmxiV0pzWDJkbGJtVmZhV1FzSUd4dlp6SkdiMnhrUTJoaGJtZGxMQ0J6YUhKcGJtdGxaRjlzYjJjeVJrTXNJSEJoWkdvc0lHVjRkR1Z5Ym1Gc1gyZGxibVZmYm1GdFpTbGNibHh1YldGNFRHOW5Na1pESUQwZ01seHVYRzUwWlcxd0lEd3RJR3hsWm5SZmFtOXBiaWgwWlcxd0xDQmthV1ptTGxKT1FTd2dZbmtnUFNCaktGeGNaMlZ1WlZ4Y0lEMGdYRnhsYm5ObGJXSnNYMmRsYm1WZmFXUmNYQ2twSUNVK0pTQmNiaUFnWkhKdmNGOXVZU2h6YUhKcGJtdGxaRjlzYjJjeVJrTXBYRzVjYmx4dWRHVnRjQ0E4TFNCMFpXMXdJQ1UrSlNCa2NHeDVjam82YlhWMFlYUmxLRnh1SUNCd2MwOTJaWElnUFNCcFptVnNjMlVvWjJWdVpTQWxhVzRsSUhCelQzWmxjalFzSUZ4Y2NITlBkbVZ5TkZ4Y0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHZGxibVVnSldsdUpTQndjMDkyWlhJekxDQmNYSEJ6VDNabGNqTmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JwWm1Wc2MyVW9aMlZ1WlNBbGFXNGxJSEJ6VDNabGNqSXNJRnhjY0hOUGRtVnlNbHhjTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JwWm1Wc2MyVW9aMlZ1WlNBbGFXNGxJSEJ6VDNabGNqRXNJRnhjY0hOUGRtVnlNVnhjTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHZGxibVVnSldsdUpTQndjMDkyWlhJd0xDQmNYSEJ6VDNabGNqQmNYQ3dnVGtFcEtTa3BLU2tnSlQ0bFhHNGdJR1J5YjNCZmJtRW9jSE5QZG1WeUtWeHVYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG4jIHRlbXAyIGNvbnRhaW5zIGdlbmVzIGZyb20gZ3JvdXAgMSwgMiwgNSwgOCBhbmQgbG9vcCBjb3VudHNcbiNjYWxjdWxhdGluZyBkaWZmIHNjb3JlIGFuZCBsb2cyZmMgZGlzdHJpYnV0aW9uIGJhc2VkIG9uIHAtbiBudW1iZXJzXG5cbnBzT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSA0KSkkZ2VuZVxucHNPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDMsIG51bV9wcyA8IDQpKSRnZW5lXG5wc092ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMiwgbnVtX3BzIDwgMykpJGdlbmVcbnBzT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAxLCBudW1fcHMgPCAyKSkkZ2VuZVxucHNPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzIDwgMSkpJGdlbmVcblxuXG5cblxuIyMgRGl2aWRpbmcgZ2VuZXMgaW50byBncm91cHNcbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmZfQTQ4NV9ETVNPLCBkaXN0YW5jZSwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmX0E0ODVfRE1TTyksXG4gICAgICAgICAgICBtZWFuX2Rpc3RhbmNlID0gbWVhbihkaXN0YW5jZSksXG4gICAgICAgICAgICAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLkE0ODUuc2VsZWN0ZWQyX0cxLjJpLkE0ODVfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxuXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBzT3ZlciA9IGlmZWxzZShnZW5lICVpbiUgcHNPdmVyNCwgXFxwc092ZXI0XFwsXG4gICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjMsIFxccHNPdmVyM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMiwgXFxwc092ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHNPdmVyMSwgXFxwc092ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjAsIFxccHNPdmVyMFxcLCBOQSkpKSkpKSAlPiVcbiAgZHJvcF9uYShwc092ZXIpXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyB0ZW1wMiBjb250YWlucyBnZW5lcyBmcm9tIGdyb3VwIDEsIDIsIDUsIDggYW5kIGxvb3AgY291bnRzXG4jY2FsY3VsYXRpbmcgZGlmZiBzY29yZSBhbmQgbG9nMmZjIGRpc3RyaWJ1dGlvbiBiYXNlZCBvbiBwLW4gbnVtYmVyc1xuXG5wc092ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gNCkpJGdlbmVcbnBzT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAzLCBudW1fcHMgPCA0KSkkZ2VuZVxucHNPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDIsIG51bV9wcyA8IDMpKSRnZW5lXG5wc092ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMSwgbnVtX3BzIDwgMikpJGdlbmVcbnBzT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA8IDEpKSRnZW5lXG5cblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX0E0ODVfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9BNDg1X0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5BNDg1LnNlbGVjdGVkMl9HMS4yaS5BNDg1X3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxubWF4TG9nMkZDID0gMlxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cblxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6bXV0YXRlKFxuICBwc092ZXIgPSBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjQsIFxccHNPdmVyNFxcLFxuICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIzLCBcXHBzT3ZlcjNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjIsIFxccHNPdmVyMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBzT3ZlcjEsIFxccHNPdmVyMVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwc092ZXIwLCBcXHBzT3ZlcjBcXCwgTkEpKSkpKSkgJT4lXG4gIGRyb3BfbmEocHNPdmVyKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene




## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)


temp <- temp %>% dplyr::mutate(
  psOver = ifelse(gene %in% psOver4, \psOver4\,
                  ifelse(gene %in% psOver3, \psOver3\,
                         ifelse(gene %in% psOver2, \psOver2\,
                                ifelse(gene %in% psOver1, \psOver1\,
                                       ifelse(gene %in% psOver0, \psOver0\, NA)))))) %>%
  drop_na(psOver)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### log2FC

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBHT2ZpZ0RpciA8LSBoZXJlKGZpZ0RpciwgXCIuLi9HT1wiKVxuIyBnZXRHTyhcInBzT3ZlcjRcIiwgR09maWdEaXIsIHBzT3ZlcjQpXG4jIGdldEdPKFwicHNPdmVyM1wiLCBHT2ZpZ0RpciwgcHNPdmVyMylcbiMgZ2V0R08oXCJwc092ZXIyXCIsIEdPZmlnRGlyLCBwc092ZXIyKVxuIyBnZXRHTyhcInBzT3ZlcjFcIiwgR09maWdEaXIsIHBzT3ZlcjEpXG4jIGdldEdPKFwicHNPdmVyMFwiLCBHT2ZpZ0RpciwgcHNPdmVyMClcbiMgXG4jICMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBHTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKSlcbiMgR08xLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjEsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIikpXG4jIEdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFwiRU5TRU1CTFwiLCBvbnQgPSBcIkJQXCIpKVxuIyBHTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKSlcbiMgR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIikpXG4jIFxuIyBcbiMgc3Vic2V0MCA8LSBHTzAuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyMFwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyMVwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyMlwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MyA8LSBHTzMuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyM1wiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyNFwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgXG4jIFxuIyBHT2xpc3QgPC0gZmFjdG9yKGMoXCJHTzowMDA2Mzk3XCIsIFwiR086MDAwODM4MFwiLCBcIkdPOjAwMjI2MTNcIiwgXCJHTzowMDM0NDcwXCIsXG4jICAgICAgICAgICAgICAgICAgICBcIkdPOjAwMTYwNTVcIiwgXCJHTzowMDA3Mzg5XCIsIFwiR086MDA0ODU2MlwiLCBcIkdPOjAwNDUxNjVcIiwgXG4jICAgICAgICAgICAgICAgICAgICBcIkdPOjAwNzIwMDFcIiwgXCJHTzowMDA3NTE3XCIsIFwiR086MDA0ODcwNVwiLCBcIkdPOjAwMDMwMDJcIikpXG4jIFxuIyBkYXRhIDwtIGJpbmRfcm93cyhiaW5kX3Jvd3MoYmluZF9yb3dzKGJpbmRfcm93cyhzdWJzZXQwLCBzdWJzZXQxKSwgc3Vic2V0MiksIHN1YnNldDMpLCBzdWJzZXQ0KSAlPiVcbiMgICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuIyBcbiMgcCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IERlc2NyaXB0aW9uLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuIyAgIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuIyAgIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFwicmVkXCIsIGhpZ2ggPSBcImJsdWVcIiwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuIyAgIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiMgICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFwiLi5cIiwgXCJHT1wiLCBcIkdPX2dyb3Vwc19wc1wiKVxuIyBoZWlnaHQgPSAyXG4jIHdpZHRoID0gMy40XG4jIHN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIiksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5gYGAifQ== -->\n\n```r\n# GOfigDir <- here(figDir, \\../GO\\)\n# getGO(\\psOver4\\, GOfigDir, psOver4)\n# getGO(\\psOver3\\, GOfigDir, psOver3)\n# getGO(\\psOver2\\, GOfigDir, psOver2)\n# getGO(\\psOver1\\, GOfigDir, psOver1)\n# getGO(\\psOver0\\, GOfigDir, psOver0)\n# \n# #####################\n# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# \n# \n# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver0\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver1\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver2\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver3\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver4\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# \n# \n# GOlist <- factor(c(\\GO:0006397\\, \\GO:0008380\\, \\GO:0022613\\, \\GO:0034470\\,\n#                    \\GO:0016055\\, \\GO:0007389\\, \\GO:0048562\\, \\GO:0045165\\, \n#                    \\GO:0072001\\, \\GO:0007517\\, \\GO:0048705\\, \\GO:0003002\\))\n# \n# data <- bind_rows(bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset3), subset4) %>%\n#   dplyr::filter(ID %in% GOlist)\n# \n# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + \n#   geom_point() + theme_bw() +\n#   scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n#   scale_size_continuous(range = c(0, 3)) +\n#   labs(x = NULL, y = NULL) +\n#   theme(axis.text = element_text(size = 6),  # Set axis text size\n#         axis.title = element_text(size = 6), # Set axis title size (if not removed)\n#         legend.text = element_text(size = 6), # Set legend text size\n#         legend.title = element_text(size = 6)) \n# \n# fileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_ps\\)\n# height = 2\n# width = 3.4\n# svglite(paste0(fileName, \\.svg\\), height = height, width = width)\n# print(p)\n# dev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# GOfigDir <- here(figDir, \../GO\)
# getGO(\psOver4\, GOfigDir, psOver4)
# getGO(\psOver3\, GOfigDir, psOver3)
# getGO(\psOver2\, GOfigDir, psOver2)
# getGO(\psOver1\, GOfigDir, psOver1)
# getGO(\psOver0\, GOfigDir, psOver0)
# 
# #####################
# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# 
# 
# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver0\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver1\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver2\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver3\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver4\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# 
# GOlist <- factor(c(\GO:0006397\, \GO:0008380\, \GO:0022613\, \GO:0034470\,
#                    \GO:0016055\, \GO:0007389\, \GO:0048562\, \GO:0045165\, 
#                    \GO:0072001\, \GO:0007517\, \GO:0048705\, \GO:0003002\))
# 
# data <- bind_rows(bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset3), subset4) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, \..\, \GO\, \GO_groups_ps\)
# height = 2
# width = 3.4
# svglite(paste0(fileName, \.svg\), height = height, width = width)
# print(p)
# dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBHT2ZpZ0RpciA8LSBoZXJlKGZpZ0RpciwgXFwuLi9HT1xcKVxuIyBnZXRHTyhcXHBzT3ZlcjRcXCwgR09maWdEaXIsIHBzT3ZlcjQpXG4jIGdldEdPKFxccHNPdmVyM1xcLCBHT2ZpZ0RpciwgcHNPdmVyMylcbiMgZ2V0R08oXFxwc092ZXIyXFwsIEdPZmlnRGlyLCBwc092ZXIyKVxuIyBnZXRHTyhcXHBzT3ZlcjFcXCwgR09maWdEaXIsIHBzT3ZlcjEpXG4jIGdldEdPKFxccHNPdmVyMFxcLCBHT2ZpZ0RpciwgcHNPdmVyMClcbiMgXG4jICMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBHTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR08xLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjEsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIEdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpKVxuIyBHTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIFxuIyBcbiMgc3Vic2V0MCA8LSBHTzAuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMVxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMlxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MyA8LSBHTzMuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyM1xcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyNFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgXG4jIFxuIyBHT2xpc3QgPC0gZmFjdG9yKGMoXFxHTzowMDA2Mzk3XFwsIFxcR086MDAwODM4MFxcLCBcXEdPOjAwMjI2MTNcXCwgXFxHTzowMDM0NDcwXFwsXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwMTYwNTVcXCwgXFxHTzowMDA3Mzg5XFwsIFxcR086MDA0ODU2MlxcLCBcXEdPOjAwNDUxNjVcXCwgXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwNzIwMDFcXCwgXFxHTzowMDA3NTE3XFwsIFxcR086MDA0ODcwNVxcLCBcXEdPOjAwMDMwMDJcXCkpXG4jIFxuIyBkYXRhIDwtIGJpbmRfcm93cyhiaW5kX3Jvd3MoYmluZF9yb3dzKGJpbmRfcm93cyhzdWJzZXQwLCBzdWJzZXQxKSwgc3Vic2V0MiksIHN1YnNldDMpLCBzdWJzZXQ0KSAlPiVcbiMgICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuIyBcbiMgcCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IERlc2NyaXB0aW9uLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuIyAgIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuIyAgIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFxccmVkXFwsIGhpZ2ggPSBcXGJsdWVcXCwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuIyAgIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiMgICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc19wc1xcKVxuIyBoZWlnaHQgPSAyXG4jIHdpZHRoID0gMy40XG4jIHN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\n# GOfigDir <- here(figDir, \\../GO\\)\n# getGO(\\psOver4\\, GOfigDir, psOver4)\n# getGO(\\psOver3\\, GOfigDir, psOver3)\n# getGO(\\psOver2\\, GOfigDir, psOver2)\n# getGO(\\psOver1\\, GOfigDir, psOver1)\n# getGO(\\psOver0\\, GOfigDir, psOver0)\n# \n# #####################\n# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# \n# \n# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver0\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver1\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver2\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver3\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver4\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# \n# \n# GOlist <- factor(c(\\GO:0006397\\, \\GO:0008380\\, \\GO:0022613\\, \\GO:0034470\\,\n#                    \\GO:0016055\\, \\GO:0007389\\, \\GO:0048562\\, \\GO:0045165\\, \n#                    \\GO:0072001\\, \\GO:0007517\\, \\GO:0048705\\, \\GO:0003002\\))\n# \n# data <- bind_rows(bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset3), subset4) %>%\n#   dplyr::filter(ID %in% GOlist)\n# \n# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + \n#   geom_point() + theme_bw() +\n#   scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n#   scale_size_continuous(range = c(0, 3)) +\n#   labs(x = NULL, y = NULL) +\n#   theme(axis.text = element_text(size = 6),  # Set axis text size\n#         axis.title = element_text(size = 6), # Set axis title size (if not removed)\n#         legend.text = element_text(size = 6), # Set legend text size\n#         legend.title = element_text(size = 6)) \n# \n# fileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_ps\\)\n# height = 2\n# width = 3.4\n# svglite(paste0(fileName, \\.svg\\), height = height, width = width)\n# print(p)\n# dev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBHT2ZpZ0RpciA8LSBoZXJlKGZpZ0RpciwgXFwuLi9HT1xcKVxuIyBnZXRHTyhcXHBzT3ZlcjRcXCwgR09maWdEaXIsIHBzT3ZlcjQpXG4jIGdldEdPKFxccHNPdmVyM1xcLCBHT2ZpZ0RpciwgcHNPdmVyMylcbiMgZ2V0R08oXFxwc092ZXIyXFwsIEdPZmlnRGlyLCBwc092ZXIyKVxuIyBnZXRHTyhcXHBzT3ZlcjFcXCwgR09maWdEaXIsIHBzT3ZlcjEpXG4jIGdldEdPKFxccHNPdmVyMFxcLCBHT2ZpZ0RpciwgcHNPdmVyMClcbiMgXG4jICMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBHTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR08xLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjEsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIEdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpKVxuIyBHTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIFxuIyBcbiMgc3Vic2V0MCA8LSBHTzAuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMVxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMlxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MyA8LSBHTzMuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyM1xcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyNFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgXG4jIFxuIyBHT2xpc3QgPC0gZmFjdG9yKGMoXFxHTzowMDA2Mzk3XFwsIFxcR086MDAwODM4MFxcLCBcXEdPOjAwMjI2MTNcXCwgXFxHTzowMDM0NDcwXFwsXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwMTYwNTVcXCwgXFxHTzowMDA3Mzg5XFwsIFxcR086MDA0ODU2MlxcLCBcXEdPOjAwNDUxNjVcXCwgXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwNzIwMDFcXCwgXFxHTzowMDA3NTE3XFwsIFxcR086MDA0ODcwNVxcLCBcXEdPOjAwMDMwMDJcXCkpXG4jIFxuIyBkYXRhIDwtIGJpbmRfcm93cyhiaW5kX3Jvd3MoYmluZF9yb3dzKGJpbmRfcm93cyhzdWJzZXQwLCBzdWJzZXQxKSwgc3Vic2V0MiksIHN1YnNldDMpLCBzdWJzZXQ0KSAlPiVcbiMgICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuIyBcbiMgcCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IERlc2NyaXB0aW9uLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuIyAgIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuIyAgIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFxccmVkXFwsIGhpZ2ggPSBcXGJsdWVcXCwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuIyAgIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiMgICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc19wc1xcKVxuIyBoZWlnaHQgPSAyXG4jIHdpZHRoID0gMy40XG4jIHN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
# GOfigDir <- here(figDir, \../GO\)
# getGO(\psOver4\, GOfigDir, psOver4)
# getGO(\psOver3\, GOfigDir, psOver3)
# getGO(\psOver2\, GOfigDir, psOver2)
# getGO(\psOver1\, GOfigDir, psOver1)
# getGO(\psOver0\, GOfigDir, psOver0)
# 
# #####################
# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# 
# 
# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver0\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver1\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver2\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver3\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver4\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# 
# GOlist <- factor(c(\GO:0006397\, \GO:0008380\, \GO:0022613\, \GO:0034470\,
#                    \GO:0016055\, \GO:0007389\, \GO:0048562\, \GO:0045165\, 
#                    \GO:0072001\, \GO:0007517\, \GO:0048705\, \GO:0003002\))
# 
# data <- bind_rows(bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset3), subset4) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, \..\, \GO\, \GO_groups_ps\)
# height = 2
# width = 3.4
# svglite(paste0(fileName, \.svg\), height = height, width = width)
# print(p)
# dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Grouping with P-S number
##### Grouping

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJuWlhSUWRtRnNWMmxzWTI5NElEd3RJR1oxYm1OMGFXOXVLR1JoZEdFc0lHZHliM1Z3TVN3Z1ozSnZkWEF5S1h0Y2JpTWdJQ0JrYVhOMFlXNWpaVEVnUEMwZ0tHUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvY0hOUGRtVnlJRDA5WjNKdmRYQXhLU0FwSkcxbFlXNWZaR2xtWmw5elkyOXlaVnh1SXlBZ0lHUnBjM1JoYm1ObE1pQThMU0FvWkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHdjMDkyWlhJZ1BUMW5jbTkxY0RJcElDa2tiV1ZoYmw5a2FXWm1YM05qYjNKbFhHNGpJQ0FnZDJsc0lEd3RJSGRwYkdOdmVDNTBaWE4wS0dScGMzUmhibU5sTVN3Z1pHbHpkR0Z1WTJVeUtWeHVJeUFnSUhKbGRIVnliaWgzYVd3a2NDNTJZV3gxWlNsY2JpTWdmVnh1SXlCY2JpTWdjSE13TVNBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBc0lGd2ljSE5QZG1WeU1Gd2lMQ0JjSW5CelQzWmxjakZjSWlrc0lEVXBYRzRqSUhCek1USWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMQ0JjSW5CelQzWmxjakZjSWl3Z1hDSndjMDkyWlhJeVhDSXBMQ0ExS1Z4dUl5Qndjekl6SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0N3Z1hDSndjMDkyWlhJeVhDSXNJRndpY0hOUGRtVnlNMXdpS1N3Z05TbGNiaU1nY0hNek5DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXNJRndpY0hOUGRtVnlNMXdpTENCY0luQnpUM1psY2pSY0lpa3NJRFVwWEc0aklIQnpNalFnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaDBaVzF3TENCY0luQnpUM1psY2pKY0lpd2dYQ0p3YzA5MlpYSTBYQ0lwTENBMUtWeHVJeUJ3Y3pFMElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dYQ0p3YzA5MlpYSXhYQ0lzSUZ3aWNITlBkbVZ5TkZ3aUtTd2dOU2xjYmlNZ2NITXdOQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEFzSUZ3aWNITlBkbVZ5TUZ3aUxDQmNJbkJ6VDNabGNqUmNJaWtzSURVcFhHNGpJRnh1WEc1d0lEd3RJR2RuY0d4dmRDaDBaVzF3TENCaFpYTW9lQ0E5SUhCelQzWmxjaXdnZVNBOUlHMWxZVzVmWkdsbVpsOXpZMjl5WlNrcElDc2daMlZ2YlY5MmFXOXNhVzRvWVdWektHWnBiR3dnUFNCd2MwOTJaWElwTENCemFHOTNMbXhsWjJWdVpDQTlJRVpCVEZORktTQXJYRzRnSUdkbGIyMWZZbTk0Y0d4dmRDaDNhV1IwYUNBOUlEQXVNU3dnYjNWMGJHbGxjaTV6YUdGd1pTQTlJRTVCS1NBcklIUm9aVzFsWDJOc1lYTnphV01vS1NBcklGeHVJQ0J6ZEdGMFgzTjFiVzFoY25rb1lXVnpLR2R5YjNWd0lEMGdjSE5QZG1WeUtTd2dablZ1SUQwZ2JXVmhiaXdnWjJWdmJTQTlJRndpY0c5cGJuUmNJaXdnYzJoaGNHVWdQU0F5TVN3Z2MybDZaU0E5SURJc0lHWnBiR3dnUFNCY0luSmxaRndpTENCamIyeHZjaUE5SUZ3aVlteGhZMnRjSWlrZ0sxeHVJQ0JuWlc5dFgyaHNhVzVsS0hscGJuUmxjbU5sY0hRZ1BTQXdLVnh1SUNBaklHRnVibTkwWVhSbEtGd2lkR1Y0ZEZ3aUxDQjRJRDBnTVN3Z2VTQTlJREFzSUd4aFltVnNJRDBnY0dGemRHVXdLRndpY0hNd01Ub2dYQ0lzSUdOdmJuWlFkbUZzZFdVb2NITXdNU2tzSUZ3aVhGeHVYQ0lzWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0hNeE1qb2dYQ0lzSUdOdmJuWlFkbUZzZFdVb2NITXhNaWtzSUZ3aVhGeHVYQ0lzWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0hNeU16b2dYQ0lzSUdOdmJuWlFkbUZzZFdVb2NITXlNeWtzSUZ3aVhGeHVYQ0lzWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0hNek5Eb2dYQ0lzSUdOdmJuWlFkbUZzZFdVb2NITXpOQ2tzSUZ3aVhGeHVYQ0lzWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0hNeU5Eb2dYQ0lzSUdOdmJuWlFkbUZzZFdVb2NITXlOQ2tzSUZ3aVhGeHVYQ0lzSUZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5Cek1UUTZJRndpTENCamIyNTJVSFpoYkhWbEtIQnpNVFFwTENCY0lseGNibHdpTEZ4dUlDQWpJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5Cek1EUTZJRndpTENCamIyNTJVSFpoYkhWbEtIQnpNRFFwTENCY0lseGNibHdpS1N3Z1hHNGdJQ01nSUNBZ0lDQWdJQ0FnWTI5c2IzSWdQU0JjSW1Kc1lXTnJYQ0lzSUdocWRYTjBJRDBnTUN3Z2MybDZaU0E5SURNcFhHNWNiaUFnWEc1bWFXeGxUbUZ0WlNBOExTQndZWE4wWlRBb1hDSmthV1ptVTJOdmNtVmZZbUZ5Y0d4dmRGOXdjMGR5YjNWd1gwRTBPRFZmZG5OZlJFMVRUMXdpS1Z4dWFHVnBaMmgwSUR3dElETmNibmRwWkhSb0lEd3RJRE5jYm5CdVp5aG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjSWk1d2JtZGNJaWtwTENCeVpYTWdQU0EyTURBc0lIVnVhWFFnUFNCY0ltbHVYQ0lzSUdobGFXZG9kQ0E5SUdobGFXZG9kQ3dnZDJsa2RHZ2dQU0IzYVdSMGFDbGNibkJ5YVc1MEtIQXBYRzVrWlhZdWIyWm1LQ2xjYm5OMloyeHBkR1VvYUdWeVpTaG1hV2RFYVhJc0lIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hDSXVjM1puWENJcEtTd2dJR2hsYVdkb2RDQTlJR2hsYVdkb2RDd2dkMmxrZEdnZ1BTQjNhV1IwYUNsY2JuQnlhVzUwS0hBcFhHNWtaWFl1YjJabUtDbGNibUJnWUNKOSAtLT5cblxuYGBgclxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocHNPdmVyID09Z3JvdXAxKSApJG1lYW5fZGlmZl9zY29yZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4jICAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuIyAgIHJldHVybih3aWwkcC52YWx1ZSlcbiMgfVxuIyBcbiMgcHMwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjFcXCksIDUpXG4jIHBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIyXFwsIFxccHNPdmVyM1xcKSwgNSlcbiMgcHMzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyM1xcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIxXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIFxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBzT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwc092ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcHNPdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKVxuICAjIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDAsIGxhYmVsID0gcGFzdGUwKFxccHMwMTogXFwsIGNvbnZQdmFsdWUocHMwMSksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMxMjogXFwsIGNvbnZQdmFsdWUocHMxMiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMzNDogXFwsIGNvbnZQdmFsdWUocHMzNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyNDogXFwsIGNvbnZQdmFsdWUocHMyNCksIFxcXFxuXFwsIFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMDQ6IFxcLCBjb252UHZhbHVlKHBzMDQpLCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxkaWZmU2NvcmVfYmFycGxvdF9wc0dyb3VwX0E0ODVfdnNfRE1TT1xcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# ps01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(temp, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(temp, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)
# 

p <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + geom_violin(aes(fill = psOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = psOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\, 
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3)

  
fileName <- paste0(\diffScore_barplot_psGroup_A485_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5Qm5aWFJRZG1Gc1YybHNZMjk0SUR3dElHWjFibU4wYVc5dUtHUmhkR0VzSUdkeWIzVndNU3dnWjNKdmRYQXlLWHRjYmlNZ0lDQmthWE4wWVc1alpURWdQQzBnS0dSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9jSE5QZG1WeUlEMDlaM0p2ZFhBeEtTQXBKRzFsWVc1ZlpHbG1abDl6WTI5eVpWeHVJeUFnSUdScGMzUmhibU5sTWlBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lod2MwOTJaWElnUFQxbmNtOTFjRElwSUNra2JXVmhibDlrYVdabVgzTmpiM0psWEc0aklDQWdkMmxzSUR3dElIZHBiR052ZUM1MFpYTjBLR1JwYzNSaGJtTmxNU3dnWkdsemRHRnVZMlV5S1Z4dUl5QWdJSEpsZEhWeWJpaDNhV3drY0M1MllXeDFaU2xjYmlNZ2ZWeHVJeUJjYmlNZ2NITXdNU0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEFzSUZ4Y2NITlBkbVZ5TUZ4Y0xDQmNYSEJ6VDNabGNqRmNYQ2tzSURVcFhHNGpJSEJ6TVRJZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xDQmNYSEJ6VDNabGNqRmNYQ3dnWEZ4d2MwOTJaWEl5WEZ3cExDQTFLVnh1SXlCd2N6SXpJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnWEZ4d2MwOTJaWEl5WEZ3c0lGeGNjSE5QZG1WeU0xeGNLU3dnTlNsY2JpTWdjSE16TkNBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBc0lGeGNjSE5QZG1WeU0xeGNMQ0JjWEhCelQzWmxjalJjWENrc0lEVXBYRzRqSUhCek1qUWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMQ0JjWEhCelQzWmxjakpjWEN3Z1hGeHdjMDkyWlhJMFhGd3BMQ0ExS1Z4dUl5QndjekUwSUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0N3Z1hGeHdjMDkyWlhJeFhGd3NJRnhjY0hOUGRtVnlORnhjS1N3Z05TbGNiaU1nY0hNd05DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXNJRnhjY0hOUGRtVnlNRnhjTENCY1hIQnpUM1psY2pSY1hDa3NJRFVwWEc0aklGeHVYRzV3SUR3dElHZG5jR3h2ZENoMFpXMXdMQ0JoWlhNb2VDQTlJSEJ6VDNabGNpd2dlU0E5SUcxbFlXNWZaR2xtWmw5elkyOXlaU2twSUNzZ1oyVnZiVjkyYVc5c2FXNG9ZV1Z6S0dacGJHd2dQU0J3YzA5MlpYSXBMQ0J6YUc5M0xteGxaMlZ1WkNBOUlFWkJURk5GS1NBclhHNGdJR2RsYjIxZlltOTRjR3h2ZENoM2FXUjBhQ0E5SURBdU1Td2diM1YwYkdsbGNpNXphR0Z3WlNBOUlFNUJLU0FySUhSb1pXMWxYMk5zWVhOemFXTW9LU0FySUZ4dUlDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ2NITlBkbVZ5S1N3Z1puVnVJRDBnYldWaGJpd2daMlZ2YlNBOUlGeGNjRzlwYm5SY1hDd2djMmhoY0dVZ1BTQXlNU3dnYzJsNlpTQTlJRElzSUdacGJHd2dQU0JjWEhKbFpGeGNMQ0JqYjJ4dmNpQTlJRnhjWW14aFkydGNYQ2tnSzF4dUlDQm5aVzl0WDJoc2FXNWxLSGxwYm5SbGNtTmxjSFFnUFNBd0tWeHVJQ0FqSUdGdWJtOTBZWFJsS0Z4Y2RHVjRkRnhjTENCNElEMGdNU3dnZVNBOUlEQXNJR3hoWW1Wc0lEMGdjR0Z6ZEdVd0tGeGNjSE13TVRvZ1hGd3NJR052Ym5aUWRtRnNkV1VvY0hNd01Ta3NJRnhjWEZ4dVhGd3NYRzRnSUNNZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjSE14TWpvZ1hGd3NJR052Ym5aUWRtRnNkV1VvY0hNeE1pa3NJRnhjWEZ4dVhGd3NYRzRnSUNNZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjSE15TXpvZ1hGd3NJR052Ym5aUWRtRnNkV1VvY0hNeU15a3NJRnhjWEZ4dVhGd3NYRzRnSUNNZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjSE16TkRvZ1hGd3NJR052Ym5aUWRtRnNkV1VvY0hNek5Da3NJRnhjWEZ4dVhGd3NYRzRnSUNNZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjSE15TkRvZ1hGd3NJR052Ym5aUWRtRnNkV1VvY0hNeU5Da3NJRnhjWEZ4dVhGd3NJRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEJ6TVRRNklGeGNMQ0JqYjI1MlVIWmhiSFZsS0hCek1UUXBMQ0JjWEZ4Y2JseGNMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEJ6TURRNklGeGNMQ0JqYjI1MlVIWmhiSFZsS0hCek1EUXBMQ0JjWEZ4Y2JseGNLU3dnWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNYR0pzWVdOclhGd3NJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJRE1wWEc1Y2JpQWdYRzVtYVd4bFRtRnRaU0E4TFNCd1lYTjBaVEFvWEZ4a2FXWm1VMk52Y21WZlltRnljR3h2ZEY5d2MwZHliM1Z3WDBFME9EVmZkbk5mUkUxVFQxeGNLVnh1YUdWcFoyaDBJRHd0SUROY2JuZHBaSFJvSUR3dElETmNibkJ1Wnlob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNYQzV3Ym1kY1hDa3BMQ0J5WlhNZ1BTQTJNREFzSUhWdWFYUWdQU0JjWEdsdVhGd3NJR2hsYVdkb2RDQTlJR2hsYVdkb2RDd2dkMmxrZEdnZ1BTQjNhV1IwYUNsY2JuQnlhVzUwS0hBcFhHNWtaWFl1YjJabUtDbGNibk4yWjJ4cGRHVW9hR1Z5WlNobWFXZEVhWElzSUhCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWEZ3dWMzWm5YRndwS1N3Z0lHaGxhV2RvZENBOUlHaGxhV2RvZEN3Z2QybGtkR2dnUFNCM2FXUjBhQ2xjYm5CeWFXNTBLSEFwWEc1a1pYWXViMlptS0NsY2JtQmdZRnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbmBgYHJcbiMgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBzT3ZlciA9PWdyb3VwMSkgKSRtZWFuX2RpZmZfc2NvcmVcbiMgICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocHNPdmVyID09Z3JvdXAyKSApJG1lYW5fZGlmZl9zY29yZVxuIyAgIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiMgICByZXR1cm4od2lsJHAudmFsdWUpXG4jIH1cbiMgXG4jIHBzMDEgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjBcXCwgXFxwc092ZXIxXFwpLCA1KVxuIyBwczEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIxXFwsIFxccHNPdmVyMlxcKSwgNSlcbiMgcHMyMyA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjNcXCksIDUpXG4jIHBzMzQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjNcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIyXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMDQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjBcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBcblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBwc092ZXIsIHkgPSBtZWFuX2RpZmZfc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBzT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTI6IFxcLCBjb252UHZhbHVlKHBzMTIpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjM6IFxcLCBjb252UHZhbHVlKHBzMjMpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjQ6IFxcLCBjb252UHZhbHVlKHBzMjQpLCBcXFxcblxcLCBcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczE0OiBcXCwgY29udlB2YWx1ZShwczE0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcZGlmZlNjb3JlX2JhcnBsb3RfcHNHcm91cF9BNDg1X3ZzX0RNU09cXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocHNPdmVyID09Z3JvdXAxKSApJG1lYW5fZGlmZl9zY29yZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4jICAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuIyAgIHJldHVybih3aWwkcC52YWx1ZSlcbiMgfVxuIyBcbiMgcHMwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjFcXCksIDUpXG4jIHBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIyXFwsIFxccHNPdmVyM1xcKSwgNSlcbiMgcHMzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyM1xcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIxXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIFxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBzT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwc092ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcHNPdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKVxuICAjIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDAsIGxhYmVsID0gcGFzdGUwKFxccHMwMTogXFwsIGNvbnZQdmFsdWUocHMwMSksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMxMjogXFwsIGNvbnZQdmFsdWUocHMxMiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMzNDogXFwsIGNvbnZQdmFsdWUocHMzNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyNDogXFwsIGNvbnZQdmFsdWUocHMyNCksIFxcXFxuXFwsIFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMDQ6IFxcLCBjb252UHZhbHVlKHBzMDQpLCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxkaWZmU2NvcmVfYmFycGxvdF9wc0dyb3VwX0E0ODVfdnNfRE1TT1xcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# ps01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(temp, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(temp, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)
# 

p <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + geom_violin(aes(fill = psOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = psOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\, 
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3)

  
fileName <- paste0(\diffScore_barplot_psGroup_A485_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### (SKIP) GO for each group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuI1xuIyAgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBzT3ZlciA9PWdyb3VwMSkgKSRsb2cyRm9sZENoYW5nZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG5cbnRlbXBEb3duIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPCAwKVxuIyAgXG4jIHBzMDEgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXCJwc092ZXIwXCIsIFwicHNPdmVyMVwiKSwgNSlcbiMgcHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBzT3ZlcjFcIiwgXCJwc092ZXIyXCIpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFwicHNPdmVyMlwiLCBcInBzT3ZlcjNcIiksIDUpXG4jIHBzMzQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXCJwc092ZXIzXCIsIFwicHNPdmVyNFwiKSwgNSlcbiMgcHMyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBzT3ZlcjJcIiwgXCJwc092ZXI0XCIpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFwicHNPdmVyMVwiLCBcInBzT3ZlcjRcIiksIDUpXG4jIFxuIyBwczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFwicHNPdmVyMFwiLCBcInBzT3ZlcjRcIiksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcERvd24sIGFlcyh4ID0gcHNPdmVyLCB5ID0gbG9nMkZvbGRDaGFuZ2UpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBzT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcInBvaW50XCIsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCIpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcInRleHRcIiwgeCA9IDEsIHkgPSAtMC41LCBsYWJlbCA9IHBhc3RlMChcInBzMDE6IFwiLCBjb252UHZhbHVlKHBzMDEpLCBcIlxcblwiLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMTI6IFwiLCBjb252UHZhbHVlKHBzMTIpLCBcIlxcblwiLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMjM6IFwiLCBjb252UHZhbHVlKHBzMjMpLCBcIlxcblwiLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMzQ6IFwiLCBjb252UHZhbHVlKHBzMzQpLCBcIlxcblwiLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMjQ6IFwiLCBjb252UHZhbHVlKHBzMjQpLCBcIlxcblwiLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMTQ6IFwiLCBjb252UHZhbHVlKHBzMTQpLCBcIlxcblwiLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMDQ6IFwiLCBjb252UHZhbHVlKHBzMDQpLCBcIlxcblwiKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcImJsYWNrXCIsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKC0xLCAwKSlcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcImxvZzJGQ19iYXJwbG90X3BzR3JvdXBfQTQ4NV92c19ETVNPX2Rvd25cIilcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5cblxuXG50ZW1wVXAgPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihsb2cyRm9sZENoYW5nZSA+IDApXG4jICBcbiMgcHMwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXCJwc092ZXIwXCIsIFwicHNPdmVyMVwiKSwgNSlcbiMgcHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXCJwc092ZXIxXCIsIFwicHNPdmVyMlwiKSwgNSlcbiMgcHMyMyA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXCJwc092ZXIyXCIsIFwicHNPdmVyM1wiKSwgNSlcbiMgcHMzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXCJwc092ZXIzXCIsIFwicHNPdmVyNFwiKSwgNSlcbiMgcHMyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXCJwc092ZXIyXCIsIFwicHNPdmVyNFwiKSwgNSlcbiMgcHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXCJwc092ZXIxXCIsIFwicHNPdmVyNFwiKSwgNSlcbiMgcHMwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXCJwc092ZXIwXCIsIFwicHNPdmVyNFwiKSwgNSlcbiMgXG5cblxuXG5wIDwtIGdncGxvdCh0ZW1wVXAsIGFlcyh4ID0gcHNPdmVyLCB5ID0gbG9nMkZvbGRDaGFuZ2UpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBzT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcInBvaW50XCIsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCIpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcInRleHRcIiwgeCA9IDEsIHkgPSAwLjUsIGxhYmVsID0gcGFzdGUwKFwicHMwMTogXCIsIGNvbnZQdmFsdWUocHMwMSksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHMxMjogXCIsIGNvbnZQdmFsdWUocHMxMiksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHMyMzogXCIsIGNvbnZQdmFsdWUocHMyMyksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHMzNDogXCIsIGNvbnZQdmFsdWUocHMzNCksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHMyNDogXCIsIGNvbnZQdmFsdWUocHMyNCksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHMxNDogXCIsIGNvbnZQdmFsdWUocHMxNCksIFwiXFxuXCIsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHMwNDogXCIsIGNvbnZQdmFsdWUocHMwNCksIFwiXFxuXCIpLCBcbiAgIyAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMykgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgMSkpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJsb2cyRkNfYmFycGxvdF9wc0dyb3VwX0E0ODVfdnNfRE1TT191cFwiKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYCJ9 -->\n\n```r\n#\n#  getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n#  \n# ps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\n# ps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\n# ps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\n# ps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\n# ps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\n# ps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n# \n# ps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + geom_violin(aes(fill = psOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = psOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n  #                                               \\ps12: \\, convPvalue(ps12), \\\\n\\,\n  #                                               \\ps23: \\, convPvalue(ps23), \\\\n\\,\n  #                                               \\ps34: \\, convPvalue(ps34), \\\\n\\,\n  #                                               \\ps24: \\, convPvalue(ps24), \\\\n\\,\n  #                                               \\ps14: \\, convPvalue(ps14), \\\\n\\,\n  #                                               \\ps04: \\, convPvalue(ps04), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))\n\n  \nfileName <- paste0(\\log2FC_barplot_psGroup_A485_vs_DMSO_down\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n#  \n# ps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\n# ps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\n# ps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\n# ps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\n# ps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\n# ps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\n# ps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n# \n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + geom_violin(aes(fill = psOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = psOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n  #                                               \\ps12: \\, convPvalue(ps12), \\\\n\\,\n  #                                               \\ps23: \\, convPvalue(ps23), \\\\n\\,\n  #                                               \\ps34: \\, convPvalue(ps34), \\\\n\\,\n  #                                               \\ps24: \\, convPvalue(ps24), \\\\n\\,\n  #                                               \\ps14: \\, convPvalue(ps14), \\\\n\\,\n  #                                               \\ps04: \\, convPvalue(ps04), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_psGroup_A485_vs_DMSO_up\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
#
#  getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
#  
# ps01 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(tempDown, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver4\), 5)
# 
# ps04 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver4\), 5)


p <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + geom_violin(aes(fill = psOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = psOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = -0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0(\log2FC_barplot_psGroup_A485_vs_DMSO_down\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
#  
# ps01 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(tempUp, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver4\), 5)
# 



p <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + geom_violin(aes(fill = psOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = psOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_psGroup_A485_vs_DMSO_up\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuI1xuIyAgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBzT3ZlciA9PWdyb3VwMSkgKSRsb2cyRm9sZENoYW5nZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG5cbnRlbXBEb3duIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPCAwKVxuIyAgXG4jIHBzMDEgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbiMgcHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjNcXCksIDUpXG4jIHBzMzQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIFxuIyBwczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjRcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcERvd24sIGFlcyh4ID0gcHNPdmVyLCB5ID0gbG9nMkZvbGRDaGFuZ2UpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBzT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAtMC41LCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTI6IFxcLCBjb252UHZhbHVlKHBzMTIpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjM6IFxcLCBjb252UHZhbHVlKHBzMjMpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjQ6IFxcLCBjb252UHZhbHVlKHBzMjQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMDQ6IFxcLCBjb252UHZhbHVlKHBzMDQpLCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKC0xLCAwKSlcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXGxvZzJGQ19iYXJwbG90X3BzR3JvdXBfQTQ4NV92c19ETVNPX2Rvd25cXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5cblxuXG50ZW1wVXAgPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihsb2cyRm9sZENoYW5nZSA+IDApXG4jICBcbiMgcHMwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbiMgcHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIxXFwsIFxccHNPdmVyMlxcKSwgNSlcbiMgcHMyMyA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIyXFwsIFxccHNPdmVyM1xcKSwgNSlcbiMgcHMzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIyXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIxXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgXG5cblxuXG5wIDwtIGdncGxvdCh0ZW1wVXAsIGFlcyh4ID0gcHNPdmVyLCB5ID0gbG9nMkZvbGRDaGFuZ2UpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBzT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLjUsIGxhYmVsID0gcGFzdGUwKFxccHMwMTogXFwsIGNvbnZQdmFsdWUocHMwMSksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMxMjogXFwsIGNvbnZQdmFsdWUocHMxMiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMzNDogXFwsIGNvbnZQdmFsdWUocHMzNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyNDogXFwsIGNvbnZQdmFsdWUocHMyNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMxNDogXFwsIGNvbnZQdmFsdWUocHMxNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMwNDogXFwsIGNvbnZQdmFsdWUocHMwNCksIFxcXFxuXFwpLCBcbiAgIyAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgMSkpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxsb2cyRkNfYmFycGxvdF9wc0dyb3VwX0E0ODVfdnNfRE1TT191cFxcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\n#\n#  getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n#  \n# ps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\n# ps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\n# ps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\n# ps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\n# ps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\n# ps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n# \n# ps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + geom_violin(aes(fill = psOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = psOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n  #                                               \\ps12: \\, convPvalue(ps12), \\\\n\\,\n  #                                               \\ps23: \\, convPvalue(ps23), \\\\n\\,\n  #                                               \\ps34: \\, convPvalue(ps34), \\\\n\\,\n  #                                               \\ps24: \\, convPvalue(ps24), \\\\n\\,\n  #                                               \\ps14: \\, convPvalue(ps14), \\\\n\\,\n  #                                               \\ps04: \\, convPvalue(ps04), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))\n\n  \nfileName <- paste0(\\log2FC_barplot_psGroup_A485_vs_DMSO_down\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n#  \n# ps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\n# ps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\n# ps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\n# ps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\n# ps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\n# ps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\n# ps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n# \n\n\n\np <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + geom_violin(aes(fill = psOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = psOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n  #                                               \\ps12: \\, convPvalue(ps12), \\\\n\\,\n  #                                               \\ps23: \\, convPvalue(ps23), \\\\n\\,\n  #                                               \\ps34: \\, convPvalue(ps34), \\\\n\\,\n  #                                               \\ps24: \\, convPvalue(ps24), \\\\n\\,\n  #                                               \\ps14: \\, convPvalue(ps14), \\\\n\\,\n  #                                               \\ps04: \\, convPvalue(ps04), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_psGroup_A485_vs_DMSO_up\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuI1xuIyAgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBzT3ZlciA9PWdyb3VwMSkgKSRsb2cyRm9sZENoYW5nZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG5cbnRlbXBEb3duIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPCAwKVxuIyAgXG4jIHBzMDEgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbiMgcHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjNcXCksIDUpXG4jIHBzMzQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIFxuIyBwczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjRcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcERvd24sIGFlcyh4ID0gcHNPdmVyLCB5ID0gbG9nMkZvbGRDaGFuZ2UpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBzT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAtMC41LCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTI6IFxcLCBjb252UHZhbHVlKHBzMTIpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjM6IFxcLCBjb252UHZhbHVlKHBzMjMpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjQ6IFxcLCBjb252UHZhbHVlKHBzMjQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMDQ6IFxcLCBjb252UHZhbHVlKHBzMDQpLCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKC0xLCAwKSlcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXGxvZzJGQ19iYXJwbG90X3BzR3JvdXBfQTQ4NV92c19ETVNPX2Rvd25cXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5cblxuXG50ZW1wVXAgPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihsb2cyRm9sZENoYW5nZSA+IDApXG4jICBcbiMgcHMwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbiMgcHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIxXFwsIFxccHNPdmVyMlxcKSwgNSlcbiMgcHMyMyA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIyXFwsIFxccHNPdmVyM1xcKSwgNSlcbiMgcHMzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIyXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIxXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBVcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgXG5cblxuXG5wIDwtIGdncGxvdCh0ZW1wVXAsIGFlcyh4ID0gcHNPdmVyLCB5ID0gbG9nMkZvbGRDaGFuZ2UpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHNPdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBzT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLjUsIGxhYmVsID0gcGFzdGUwKFxccHMwMTogXFwsIGNvbnZQdmFsdWUocHMwMSksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMxMjogXFwsIGNvbnZQdmFsdWUocHMxMiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMzNDogXFwsIGNvbnZQdmFsdWUocHMzNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyNDogXFwsIGNvbnZQdmFsdWUocHMyNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMxNDogXFwsIGNvbnZQdmFsdWUocHMxNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMwNDogXFwsIGNvbnZQdmFsdWUocHMwNCksIFxcXFxuXFwpLCBcbiAgIyAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgMSkpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxsb2cyRkNfYmFycGxvdF9wc0dyb3VwX0E0ODVfdnNfRE1TT191cFxcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
#
#  getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
#  
# ps01 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(tempDown, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver4\), 5)
# 
# ps04 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver4\), 5)


p <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + geom_violin(aes(fill = psOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = psOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = -0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0(\log2FC_barplot_psGroup_A485_vs_DMSO_down\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
#  
# ps01 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(tempUp, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver4\), 5)
# 



p <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + geom_violin(aes(fill = psOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = psOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_psGroup_A485_vs_DMSO_up\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### loop score

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUIwWlcxd01pQmpiMjUwWVdsdWN5Qm5aVzVsY3lCbWNtOXRJR2R5YjNWd0lERXNJRElzSURVc0lEZ2dZVzVrSUd4dmIzQWdZMjkxYm5SelhHNGpZMkZzWTNWc1lYUnBibWNnWkdsbVppQnpZMjl5WlNCaGJtUWdiRzluTW1aaklHUnBjM1J5YVdKMWRHbHZiaUJpWVhObFpDQnZiaUJ3TFc0Z2JuVnRZbVZ5YzF4dVhHNXdaVTkyWlhJMElEd3RJQ2gwWlcxd01pQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHVkVzFmY0dVZ1BqMGdOQ2twSkdkbGJtVmNibkJsVDNabGNqTWdQQzBnS0hSbGJYQXlJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRzUxYlY5d1pTQStQU0F6TENCdWRXMWZjR1VnUENBMEtTa2taMlZ1WlZ4dWNHVlBkbVZ5TWlBOExTQW9kR1Z0Y0RJZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb2JuVnRYM0JsSUQ0OUlESXNJRzUxYlY5d1pTQThJRE1wS1NSblpXNWxYRzV3WlU5MlpYSXhJRHd0SUNoMFpXMXdNaUFsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWh1ZFcxZmNHVWdQajBnTVN3Z2JuVnRYM0JsSUR3Z01pa3BKR2RsYm1WY2JuQmxUM1psY2pBZ1BDMGdLSFJsYlhBeUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHNTFiVjl3WlNBOElERXBLU1JuWlc1bFhHNWNibHh1WEc0akl5QkVhWFpwWkdsdVp5Qm5aVzVsY3lCcGJuUnZJR2R5YjNWd2MxeHVkR1Z0Y0NBOExTQm5aVzVsUVc1dWIwUmhkR0VnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWkdsbVpsOUJORGcxWDBSTlUwOHNJR1JwYzNSaGJtTmxMQ0JuWlc1bEtTQWxQaVVnWEc0Z0lIVnVibVZ6ZENoblpXNWxLU0FsUGlVZ1ozSnZkWEJmWW5rb1oyVnVaU2tnSlQ0bFhHNGdJSE4xYlcxaGNtbDZaU2h0WldGdVgyUnBabVpmYzJOdmNtVWdQU0J0WldGdUtHUnBabVpmUVRRNE5WOUVUVk5QS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJRzFsWVc1ZlpHbHpkR0Z1WTJVZ1BTQnRaV0Z1S0dScGMzUmhibU5sS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQzVuY205MWNITWdQU0FuWkhKdmNDY3BYRzVjYm1ScFptWXVVazVCSUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNJbVJwWm1aZlJ6RXVRVFE0TlM1elpXeGxZM1JsWkRKZlJ6RXVNbWt1UVRRNE5WOTJjMTlITVM0eWFTNUVUVk5QTG5SemRsd2lLU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHpaV3hsWTNRb1pXNXpaVzFpYkY5blpXNWxYMmxrTENCc2IyY3lSbTlzWkVOb1lXNW5aU3dnYzJoeWFXNXJaV1JmYkc5bk1rWkRMQ0J3WVdScUxDQmxlSFJsY201aGJGOW5aVzVsWDI1aGJXVXBYRzVjYm0xaGVFeHZaekpHUXlBOUlESmNibHh1ZEdWdGNDQThMU0JzWldaMFgycHZhVzRvZEdWdGNDd2daR2xtWmk1U1RrRXNJR0o1SUQwZ1l5aGNJbWRsYm1WY0lpQTlJRndpWlc1elpXMWliRjluWlc1bFgybGtYQ0lwS1NBbFBpVWdYRzRnSUdSeWIzQmZibUVvYzJoeWFXNXJaV1JmYkc5bk1rWkRLVnh1WEc1Y2JuUmxiWEFnUEMwZ2RHVnRjQ0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hjYmlBZ2NHVlBkbVZ5SUQwZ2FXWmxiSE5sS0dkbGJtVWdKV2x1SlNCd1pVOTJaWEkwTENCY0luQmxUM1psY2pSY0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaG5aVzVsSUNWcGJpVWdjR1ZQZG1WeU15d2dYQ0p3WlU5MlpYSXpYQ0lzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3WlU5MlpYSXlMQ0JjSW5CbFQzWmxjakpjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3WlU5MlpYSXhMQ0JjSW5CbFQzWmxjakZjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaG5aVzVsSUNWcGJpVWdjR1ZQZG1WeU1Dd2dYQ0p3WlU5MlpYSXdYQ0lzSUU1QktTa3BLU2twSUNVK0pWeHVJQ0JrY205d1gyNWhLSEJsVDNabGNpbGNibHh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbiMgdGVtcDIgY29udGFpbnMgZ2VuZXMgZnJvbSBncm91cCAxLCAyLCA1LCA4IGFuZCBsb29wIGNvdW50c1xuI2NhbGN1bGF0aW5nIGRpZmYgc2NvcmUgYW5kIGxvZzJmYyBkaXN0cmlidXRpb24gYmFzZWQgb24gcC1uIG51bWJlcnNcblxucGVPdmVyNCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDQpKSRnZW5lXG5wZU92ZXIzIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMywgbnVtX3BlIDwgNCkpJGdlbmVcbnBlT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAyLCBudW1fcGUgPCAzKSkkZ2VuZVxucGVPdmVyMSA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDEsIG51bV9wZSA8IDIpKSRnZW5lXG5wZU92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPCAxKSkkZ2VuZVxuXG5cblxuIyMgRGl2aWRpbmcgZ2VuZXMgaW50byBncm91cHNcbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmZfQTQ4NV9ETVNPLCBkaXN0YW5jZSwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmX0E0ODVfRE1TTyksXG4gICAgICAgICAgICBtZWFuX2Rpc3RhbmNlID0gbWVhbihkaXN0YW5jZSksXG4gICAgICAgICAgICAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLkE0ODUuc2VsZWN0ZWQyX0cxLjJpLkE0ODVfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxuXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBlT3ZlciA9IGlmZWxzZShnZW5lICVpbiUgcGVPdmVyNCwgXFxwZU92ZXI0XFwsXG4gICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBlT3ZlcjMsIFxccGVPdmVyM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcGVPdmVyMiwgXFxwZU92ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcGVPdmVyMSwgXFxwZU92ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBlT3ZlcjAsIFxccGVPdmVyMFxcLCBOQSkpKSkpKSAlPiVcbiAgZHJvcF9uYShwZU92ZXIpXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)


temp <- temp %>% dplyr::mutate(
  peOver = ifelse(gene %in% peOver4, \peOver4\,
                  ifelse(gene %in% peOver3, \peOver3\,
                         ifelse(gene %in% peOver2, \peOver2\,
                                ifelse(gene %in% peOver1, \peOver1\,
                                       ifelse(gene %in% peOver0, \peOver0\, NA)))))) %>%
  drop_na(peOver)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QjBaVzF3TWlCamIyNTBZV2x1Y3lCblpXNWxjeUJtY205dElHZHliM1Z3SURFc0lESXNJRFVzSURnZ1lXNWtJR3h2YjNBZ1kyOTFiblJ6WEc0alkyRnNZM1ZzWVhScGJtY2daR2xtWmlCelkyOXlaU0JoYm1RZ2JHOW5NbVpqSUdScGMzUnlhV0oxZEdsdmJpQmlZWE5sWkNCdmJpQndMVzRnYm5WdFltVnljMXh1WEc1d1pVOTJaWEkwSUR3dElDaDBaVzF3TWlBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lodWRXMWZjR1VnUGowZ05Da3BKR2RsYm1WY2JuQmxUM1psY2pNZ1BDMGdLSFJsYlhBeUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHNTFiVjl3WlNBK1BTQXpMQ0J1ZFcxZmNHVWdQQ0EwS1Nra1oyVnVaVnh1Y0dWUGRtVnlNaUE4TFNBb2RHVnRjRElnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvYm5WdFgzQmxJRDQ5SURJc0lHNTFiVjl3WlNBOElETXBLU1JuWlc1bFhHNXdaVTkyWlhJeElEd3RJQ2gwWlcxd01pQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHVkVzFmY0dVZ1BqMGdNU3dnYm5WdFgzQmxJRHdnTWlrcEpHZGxibVZjYm5CbFQzWmxjakFnUEMwZ0tIUmxiWEF5SUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0c1MWJWOXdaU0E4SURFcEtTUm5aVzVsWEc1Y2JseHVYRzRqSXlCRWFYWnBaR2x1WnlCblpXNWxjeUJwYm5SdklHZHliM1Z3YzF4dWRHVnRjQ0E4TFNCblpXNWxRVzV1YjBSaGRHRWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aR2xtWmw5Qk5EZzFYMFJOVTA4c0lHUnBjM1JoYm1ObExDQm5aVzVsS1NBbFBpVWdYRzRnSUhWdWJtVnpkQ2huWlc1bEtTQWxQaVVnWjNKdmRYQmZZbmtvWjJWdVpTa2dKVDRsWEc0Z0lITjFiVzFoY21sNlpTaHRaV0Z1WDJScFptWmZjMk52Y21VZ1BTQnRaV0Z1S0dScFptWmZRVFE0TlY5RVRWTlBLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lHMWxZVzVmWkdsemRHRnVZMlVnUFNCdFpXRnVLR1JwYzNSaGJtTmxLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDNW5jbTkxY0hNZ1BTQW5aSEp2Y0NjcFhHNWNibVJwWm1ZdVVrNUJJRHd0SUdaeVpXRmtLR2hsY21Vb2NtVm1SR2x5TENCY1hHUnBabVpmUnpFdVFUUTROUzV6Wld4bFkzUmxaREpmUnpFdU1ta3VRVFE0TlY5MmMxOUhNUzR5YVM1RVRWTlBMblJ6ZGx4Y0tTa2dKVDRsWEc0Z0lHUndiSGx5T2pwelpXeGxZM1FvWlc1elpXMWliRjluWlc1bFgybGtMQ0JzYjJjeVJtOXNaRU5vWVc1blpTd2djMmh5YVc1clpXUmZiRzluTWtaRExDQndZV1JxTENCbGVIUmxjbTVoYkY5blpXNWxYMjVoYldVcFhHNWNibTFoZUV4dlp6SkdReUE5SURKY2JseHVkR1Z0Y0NBOExTQnNaV1owWDJwdmFXNG9kR1Z0Y0N3Z1pHbG1aaTVTVGtFc0lHSjVJRDBnWXloY1hHZGxibVZjWENBOUlGeGNaVzV6WlcxaWJGOW5aVzVsWDJsa1hGd3BLU0FsUGlVZ1hHNGdJR1J5YjNCZmJtRW9jMmh5YVc1clpXUmZiRzluTWtaREtWeHVYRzVjYm5SbGJYQWdQQzBnZEdWdGNDQWxQaVVnWkhCc2VYSTZPbTExZEdGMFpTaGNiaUFnY0dWUGRtVnlJRDBnYVdabGJITmxLR2RsYm1VZ0pXbHVKU0J3WlU5MlpYSTBMQ0JjWEhCbFQzWmxjalJjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNoblpXNWxJQ1ZwYmlVZ2NHVlBkbVZ5TXl3Z1hGeHdaVTkyWlhJelhGd3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHZGxibVVnSldsdUpTQndaVTkyWlhJeUxDQmNYSEJsVDNabGNqSmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1psYkhObEtHZGxibVVnSldsdUpTQndaVTkyWlhJeExDQmNYSEJsVDNabGNqRmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNoblpXNWxJQ1ZwYmlVZ2NHVlBkbVZ5TUN3Z1hGeHdaVTkyWlhJd1hGd3NJRTVCS1NrcEtTa3BJQ1UrSlZ4dUlDQmtjbTl3WDI1aEtIQmxUM1psY2lsY2JseHVZR0JnWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5gYGByXG4jIHRlbXAyIGNvbnRhaW5zIGdlbmVzIGZyb20gZ3JvdXAgMSwgMiwgNSwgOCBhbmQgbG9vcCBjb3VudHNcbiNjYWxjdWxhdGluZyBkaWZmIHNjb3JlIGFuZCBsb2cyZmMgZGlzdHJpYnV0aW9uIGJhc2VkIG9uIHAtbiBudW1iZXJzXG5cbnBlT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSA0KSkkZ2VuZVxucGVPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDMsIG51bV9wZSA8IDQpKSRnZW5lXG5wZU92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMiwgbnVtX3BlIDwgMykpJGdlbmVcbnBlT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAxLCBudW1fcGUgPCAyKSkkZ2VuZVxucGVPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlIDwgMSkpJGdlbmVcblxuXG5cbiMjIERpdmlkaW5nIGdlbmVzIGludG8gZ3JvdXBzXG50ZW1wIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChkaWZmX0E0ODVfRE1TTywgZGlzdGFuY2UsIGdlbmUpICU+JSBcbiAgdW5uZXN0KGdlbmUpICU+JSBncm91cF9ieShnZW5lKSAlPiVcbiAgc3VtbWFyaXplKG1lYW5fZGlmZl9zY29yZSA9IG1lYW4oZGlmZl9BNDg1X0RNU08pLFxuICAgICAgICAgICAgbWVhbl9kaXN0YW5jZSA9IG1lYW4oZGlzdGFuY2UpLFxuICAgICAgICAgICAgLmdyb3VwcyA9ICdkcm9wJylcblxuZGlmZi5STkEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZGlmZl9HMS5BNDg1LnNlbGVjdGVkMl9HMS4yaS5BNDg1X3ZzX0cxLjJpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcblxubWF4TG9nMkZDID0gMlxuXG50ZW1wIDwtIGxlZnRfam9pbih0ZW1wLCBkaWZmLlJOQSwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsX2dlbmVfaWRcXCkpICU+JSBcbiAgZHJvcF9uYShzaHJpbmtlZF9sb2cyRkMpXG5cblxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6bXV0YXRlKFxuICBwZU92ZXIgPSBpZmVsc2UoZ2VuZSAlaW4lIHBlT3ZlcjQsIFxccGVPdmVyNFxcLFxuICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwZU92ZXIzLCBcXHBlT3ZlcjNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBlT3ZlcjIsIFxccGVPdmVyMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBlT3ZlcjEsIFxccGVPdmVyMVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwZU92ZXIwLCBcXHBlT3ZlcjBcXCwgTkEpKSkpKSkgJT4lXG4gIGRyb3BfbmEocGVPdmVyKVxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyB0ZW1wMiBjb250YWlucyBnZW5lcyBmcm9tIGdyb3VwIDEsIDIsIDUsIDggYW5kIGxvb3AgY291bnRzXG4jY2FsY3VsYXRpbmcgZGlmZiBzY29yZSBhbmQgbG9nMmZjIGRpc3RyaWJ1dGlvbiBiYXNlZCBvbiBwLW4gbnVtYmVyc1xuXG5wZU92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gNCkpJGdlbmVcbnBlT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAzLCBudW1fcGUgPCA0KSkkZ2VuZVxucGVPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDIsIG51bV9wZSA8IDMpKSRnZW5lXG5wZU92ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMSwgbnVtX3BlIDwgMikpJGdlbmVcbnBlT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA8IDEpKSRnZW5lXG5cblxuXG4jIyBEaXZpZGluZyBnZW5lcyBpbnRvIGdyb3Vwc1xudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZGlmZl9BNDg1X0RNU08sIGRpc3RhbmNlLCBnZW5lKSAlPiUgXG4gIHVubmVzdChnZW5lKSAlPiUgZ3JvdXBfYnkoZ2VuZSkgJT4lXG4gIHN1bW1hcml6ZShtZWFuX2RpZmZfc2NvcmUgPSBtZWFuKGRpZmZfQTQ4NV9ETVNPKSxcbiAgICAgICAgICAgIG1lYW5fZGlzdGFuY2UgPSBtZWFuKGRpc3RhbmNlKSxcbiAgICAgICAgICAgIC5ncm91cHMgPSAnZHJvcCcpXG5cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGRpZmZfRzEuQTQ4NS5zZWxlY3RlZDJfRzEuMmkuQTQ4NV92c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibF9nZW5lX2lkLCBsb2cyRm9sZENoYW5nZSwgc2hyaW5rZWRfbG9nMkZDLCBwYWRqLCBleHRlcm5hbF9nZW5lX25hbWUpXG5cbm1heExvZzJGQyA9IDJcblxudGVtcCA8LSBsZWZ0X2pvaW4odGVtcCwgZGlmZi5STkEsIGJ5ID0gYyhcXGdlbmVcXCA9IFxcZW5zZW1ibF9nZW5lX2lkXFwpKSAlPiUgXG4gIGRyb3BfbmEoc2hyaW5rZWRfbG9nMkZDKVxuXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShcbiAgcGVPdmVyID0gaWZlbHNlKGdlbmUgJWluJSBwZU92ZXI0LCBcXHBlT3ZlcjRcXCxcbiAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcGVPdmVyMywgXFxwZU92ZXIzXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwZU92ZXIyLCBcXHBlT3ZlcjJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGdlbmUgJWluJSBwZU92ZXIxLCBcXHBlT3ZlcjFcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcGVPdmVyMCwgXFxwZU92ZXIwXFwsIE5BKSkpKSkpICU+JVxuICBkcm9wX25hKHBlT3ZlcilcblxuYGBgXG5gYGAifQ== -->

```r
```r
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)


temp <- temp %>% dplyr::mutate(
  peOver = ifelse(gene %in% peOver4, \peOver4\,
                  ifelse(gene %in% peOver3, \peOver3\,
                         ifelse(gene %in% peOver2, \peOver2\,
                                ifelse(gene %in% peOver1, \peOver1\,
                                       ifelse(gene %in% peOver0, \peOver0\, NA)))))) %>%
  drop_na(peOver)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### log2FC

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBHT2ZpZ0RpciA8LSBoZXJlKGZpZ0RpciwgXCIuLi9HT1wiKVxuIyBnZXRHTyhcInBlT3ZlcjRcIiwgR09maWdEaXIsIHBzT3ZlcjQpXG4jIGdldEdPKFwicGVPdmVyM1wiLCBHT2ZpZ0RpciwgcHNPdmVyMylcbiMgZ2V0R08oXCJwZU92ZXIyXCIsIEdPZmlnRGlyLCBwc092ZXIyKVxuIyBnZXRHTyhcInBlT3ZlcjFcIiwgR09maWdEaXIsIHBzT3ZlcjEpXG4jIGdldEdPKFwicGVPdmVyMFwiLCBHT2ZpZ0RpciwgcHNPdmVyMClcbiMgXG4jICMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBHTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKSlcbiMgR08xLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjEsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIikpXG4jIEdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFwiRU5TRU1CTFwiLCBvbnQgPSBcIkJQXCIpKVxuIyBHTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKSlcbiMgR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIikpXG4jIFxuIyBcbiMgc3Vic2V0MCA8LSBHTzAuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyMFwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyMVwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyMlwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MyA8LSBHTzMuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyM1wiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyNFwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgXG4jIFxuIyBHT2xpc3QgPC0gZmFjdG9yKGMoXCJHTzowMDA2Mzk3XCIsIFwiR086MDAwODM4MFwiLCBcIkdPOjAwMjI2MTNcIiwgXCJHTzowMDM0NDcwXCIsXG4jICAgICAgICAgICAgICAgICAgICBcIkdPOjAwMTYwNTVcIiwgXCJHTzowMDA3Mzg5XCIsIFwiR086MDA0ODU2MlwiLCBcIkdPOjAwNDUxNjVcIiwgXG4jICAgICAgICAgICAgICAgICAgICBcIkdPOjAwNzIwMDFcIiwgXCJHTzowMDA3NTE3XCIsIFwiR086MDA0ODcwNVwiLCBcbiMgICAgICAgICAgICAgICAgICAgIFwiR086MDA0MDAyOVwiLCBcIkdPOjAwMTAxNjVcIikpXG4jIFxuIyBkYXRhIDwtIGJpbmRfcm93cyhiaW5kX3Jvd3MoYmluZF9yb3dzKHN1YnNldDAsIHN1YnNldDEpLCBzdWJzZXQyKSwgc3Vic2V0NCkgJT4lXG4jICAgZHBseXI6OmZpbHRlcihJRCAlaW4lIEdPbGlzdClcbiMgXG4jIHAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBEZXNjcmlwdGlvbiwgY29sb3IgPSBwLmFkanVzdCwgc2l6ZSA9IGdyKSkgKyBcbiMgICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICtcbiMgICBzY2FsZV9jb2xvcl9ncmFkaWVudChsb3cgPSBcInJlZFwiLCBoaWdoID0gXCJibHVlXCIsIGxpbWl0cyA9IGMoMCwgMC4wNSkpICtcbiMgICBzY2FsZV9zaXplX2NvbnRpbnVvdXMocmFuZ2UgPSBjKDAsIDMpKSArXG4jICAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICtcbiMgICB0aGVtZShheGlzLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAgIyBTZXQgYXhpcyB0ZXh0IHNpemVcbiMgICAgICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgYXhpcyB0aXRsZSBzaXplIChpZiBub3QgcmVtb3ZlZClcbiMgICAgICAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICMgU2V0IGxlZ2VuZCB0ZXh0IHNpemVcbiMgICAgICAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpKSBcbiMgXG4jIGZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBcIi4uXCIsIFwiR09cIiwgXCJHT19ncm91cHNfcGVcIilcbiMgaGVpZ2h0ID0gMlxuIyB3aWR0aCA9IDMuNFxuIyBzdmdsaXRlKHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4jIHByaW50KHApXG4jIGRldi5vZmYoKVxuYGBgIn0= -->\n\n```r\n# GOfigDir <- here(figDir, \\../GO\\)\n# getGO(\\peOver4\\, GOfigDir, psOver4)\n# getGO(\\peOver3\\, GOfigDir, psOver3)\n# getGO(\\peOver2\\, GOfigDir, psOver2)\n# getGO(\\peOver1\\, GOfigDir, psOver1)\n# getGO(\\peOver0\\, GOfigDir, psOver0)\n# \n# #####################\n# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# \n# \n# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver0\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver1\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver2\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver3\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver4\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# \n# \n# GOlist <- factor(c(\\GO:0006397\\, \\GO:0008380\\, \\GO:0022613\\, \\GO:0034470\\,\n#                    \\GO:0016055\\, \\GO:0007389\\, \\GO:0048562\\, \\GO:0045165\\, \n#                    \\GO:0072001\\, \\GO:0007517\\, \\GO:0048705\\, \n#                    \\GO:0040029\\, \\GO:0010165\\))\n# \n# data <- bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset4) %>%\n#   dplyr::filter(ID %in% GOlist)\n# \n# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + \n#   geom_point() + theme_bw() +\n#   scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n#   scale_size_continuous(range = c(0, 3)) +\n#   labs(x = NULL, y = NULL) +\n#   theme(axis.text = element_text(size = 6),  # Set axis text size\n#         axis.title = element_text(size = 6), # Set axis title size (if not removed)\n#         legend.text = element_text(size = 6), # Set legend text size\n#         legend.title = element_text(size = 6)) \n# \n# fileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pe\\)\n# height = 2\n# width = 3.4\n# svglite(paste0(fileName, \\.svg\\), height = height, width = width)\n# print(p)\n# dev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# GOfigDir <- here(figDir, \../GO\)
# getGO(\peOver4\, GOfigDir, psOver4)
# getGO(\peOver3\, GOfigDir, psOver3)
# getGO(\peOver2\, GOfigDir, psOver2)
# getGO(\peOver1\, GOfigDir, psOver1)
# getGO(\peOver0\, GOfigDir, psOver0)
# 
# #####################
# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# 
# 
# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver0\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver1\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver2\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver3\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver4\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# 
# GOlist <- factor(c(\GO:0006397\, \GO:0008380\, \GO:0022613\, \GO:0034470\,
#                    \GO:0016055\, \GO:0007389\, \GO:0048562\, \GO:0045165\, 
#                    \GO:0072001\, \GO:0007517\, \GO:0048705\, 
#                    \GO:0040029\, \GO:0010165\))
# 
# data <- bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset4) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, \..\, \GO\, \GO_groups_pe\)
# height = 2
# width = 3.4
# svglite(paste0(fileName, \.svg\), height = height, width = width)
# print(p)
# dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBHT2ZpZ0RpciA8LSBoZXJlKGZpZ0RpciwgXFwuLi9HT1xcKVxuIyBnZXRHTyhcXHBlT3ZlcjRcXCwgR09maWdEaXIsIHBzT3ZlcjQpXG4jIGdldEdPKFxccGVPdmVyM1xcLCBHT2ZpZ0RpciwgcHNPdmVyMylcbiMgZ2V0R08oXFxwZU92ZXIyXFwsIEdPZmlnRGlyLCBwc092ZXIyKVxuIyBnZXRHTyhcXHBlT3ZlcjFcXCwgR09maWdEaXIsIHBzT3ZlcjEpXG4jIGdldEdPKFxccGVPdmVyMFxcLCBHT2ZpZ0RpciwgcHNPdmVyMClcbiMgXG4jICMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBHTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR08xLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjEsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIEdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpKVxuIyBHTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIFxuIyBcbiMgc3Vic2V0MCA8LSBHTzAuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMVxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMlxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MyA8LSBHTzMuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyM1xcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyNFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgXG4jIFxuIyBHT2xpc3QgPC0gZmFjdG9yKGMoXFxHTzowMDA2Mzk3XFwsIFxcR086MDAwODM4MFxcLCBcXEdPOjAwMjI2MTNcXCwgXFxHTzowMDM0NDcwXFwsXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwMTYwNTVcXCwgXFxHTzowMDA3Mzg5XFwsIFxcR086MDA0ODU2MlxcLCBcXEdPOjAwNDUxNjVcXCwgXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwNzIwMDFcXCwgXFxHTzowMDA3NTE3XFwsIFxcR086MDA0ODcwNVxcLCBcbiMgICAgICAgICAgICAgICAgICAgIFxcR086MDA0MDAyOVxcLCBcXEdPOjAwMTAxNjVcXCkpXG4jIFxuIyBkYXRhIDwtIGJpbmRfcm93cyhiaW5kX3Jvd3MoYmluZF9yb3dzKHN1YnNldDAsIHN1YnNldDEpLCBzdWJzZXQyKSwgc3Vic2V0NCkgJT4lXG4jICAgZHBseXI6OmZpbHRlcihJRCAlaW4lIEdPbGlzdClcbiMgXG4jIHAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBEZXNjcmlwdGlvbiwgY29sb3IgPSBwLmFkanVzdCwgc2l6ZSA9IGdyKSkgKyBcbiMgICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICtcbiMgICBzY2FsZV9jb2xvcl9ncmFkaWVudChsb3cgPSBcXHJlZFxcLCBoaWdoID0gXFxibHVlXFwsIGxpbWl0cyA9IGMoMCwgMC4wNSkpICtcbiMgICBzY2FsZV9zaXplX2NvbnRpbnVvdXMocmFuZ2UgPSBjKDAsIDMpKSArXG4jICAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICtcbiMgICB0aGVtZShheGlzLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAgIyBTZXQgYXhpcyB0ZXh0IHNpemVcbiMgICAgICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgYXhpcyB0aXRsZSBzaXplIChpZiBub3QgcmVtb3ZlZClcbiMgICAgICAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICMgU2V0IGxlZ2VuZCB0ZXh0IHNpemVcbiMgICAgICAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpKSBcbiMgXG4jIGZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBcXC4uXFwsIFxcR09cXCwgXFxHT19ncm91cHNfcGVcXClcbiMgaGVpZ2h0ID0gMlxuIyB3aWR0aCA9IDMuNFxuIyBzdmdsaXRlKHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4jIHByaW50KHApXG4jIGRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n# GOfigDir <- here(figDir, \\../GO\\)\n# getGO(\\peOver4\\, GOfigDir, psOver4)\n# getGO(\\peOver3\\, GOfigDir, psOver3)\n# getGO(\\peOver2\\, GOfigDir, psOver2)\n# getGO(\\peOver1\\, GOfigDir, psOver1)\n# getGO(\\peOver0\\, GOfigDir, psOver0)\n# \n# #####################\n# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# \n# \n# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver0\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver1\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver2\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver3\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver4\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# \n# \n# GOlist <- factor(c(\\GO:0006397\\, \\GO:0008380\\, \\GO:0022613\\, \\GO:0034470\\,\n#                    \\GO:0016055\\, \\GO:0007389\\, \\GO:0048562\\, \\GO:0045165\\, \n#                    \\GO:0072001\\, \\GO:0007517\\, \\GO:0048705\\, \n#                    \\GO:0040029\\, \\GO:0010165\\))\n# \n# data <- bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset4) %>%\n#   dplyr::filter(ID %in% GOlist)\n# \n# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + \n#   geom_point() + theme_bw() +\n#   scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n#   scale_size_continuous(range = c(0, 3)) +\n#   labs(x = NULL, y = NULL) +\n#   theme(axis.text = element_text(size = 6),  # Set axis text size\n#         axis.title = element_text(size = 6), # Set axis title size (if not removed)\n#         legend.text = element_text(size = 6), # Set legend text size\n#         legend.title = element_text(size = 6)) \n# \n# fileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pe\\)\n# height = 2\n# width = 3.4\n# svglite(paste0(fileName, \\.svg\\), height = height, width = width)\n# print(p)\n# dev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBHT2ZpZ0RpciA8LSBoZXJlKGZpZ0RpciwgXFwuLi9HT1xcKVxuIyBnZXRHTyhcXHBlT3ZlcjRcXCwgR09maWdEaXIsIHBzT3ZlcjQpXG4jIGdldEdPKFxccGVPdmVyM1xcLCBHT2ZpZ0RpciwgcHNPdmVyMylcbiMgZ2V0R08oXFxwZU92ZXIyXFwsIEdPZmlnRGlyLCBwc092ZXIyKVxuIyBnZXRHTyhcXHBlT3ZlcjFcXCwgR09maWdEaXIsIHBzT3ZlcjEpXG4jIGdldEdPKFxccGVPdmVyMFxcLCBHT2ZpZ0RpciwgcHNPdmVyMClcbiMgXG4jICMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBHTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR08xLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjEsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIEdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpKVxuIyBHTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIFxuIyBcbiMgc3Vic2V0MCA8LSBHTzAuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMVxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMlxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MyA8LSBHTzMuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyM1xcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyNFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgXG4jIFxuIyBHT2xpc3QgPC0gZmFjdG9yKGMoXFxHTzowMDA2Mzk3XFwsIFxcR086MDAwODM4MFxcLCBcXEdPOjAwMjI2MTNcXCwgXFxHTzowMDM0NDcwXFwsXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwMTYwNTVcXCwgXFxHTzowMDA3Mzg5XFwsIFxcR086MDA0ODU2MlxcLCBcXEdPOjAwNDUxNjVcXCwgXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwNzIwMDFcXCwgXFxHTzowMDA3NTE3XFwsIFxcR086MDA0ODcwNVxcLCBcbiMgICAgICAgICAgICAgICAgICAgIFxcR086MDA0MDAyOVxcLCBcXEdPOjAwMTAxNjVcXCkpXG4jIFxuIyBkYXRhIDwtIGJpbmRfcm93cyhiaW5kX3Jvd3MoYmluZF9yb3dzKHN1YnNldDAsIHN1YnNldDEpLCBzdWJzZXQyKSwgc3Vic2V0NCkgJT4lXG4jICAgZHBseXI6OmZpbHRlcihJRCAlaW4lIEdPbGlzdClcbiMgXG4jIHAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBEZXNjcmlwdGlvbiwgY29sb3IgPSBwLmFkanVzdCwgc2l6ZSA9IGdyKSkgKyBcbiMgICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICtcbiMgICBzY2FsZV9jb2xvcl9ncmFkaWVudChsb3cgPSBcXHJlZFxcLCBoaWdoID0gXFxibHVlXFwsIGxpbWl0cyA9IGMoMCwgMC4wNSkpICtcbiMgICBzY2FsZV9zaXplX2NvbnRpbnVvdXMocmFuZ2UgPSBjKDAsIDMpKSArXG4jICAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICtcbiMgICB0aGVtZShheGlzLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAgIyBTZXQgYXhpcyB0ZXh0IHNpemVcbiMgICAgICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgYXhpcyB0aXRsZSBzaXplIChpZiBub3QgcmVtb3ZlZClcbiMgICAgICAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICMgU2V0IGxlZ2VuZCB0ZXh0IHNpemVcbiMgICAgICAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpKSBcbiMgXG4jIGZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBcXC4uXFwsIFxcR09cXCwgXFxHT19ncm91cHNfcGVcXClcbiMgaGVpZ2h0ID0gMlxuIyB3aWR0aCA9IDMuNFxuIyBzdmdsaXRlKHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4jIHByaW50KHApXG4jIGRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
# GOfigDir <- here(figDir, \../GO\)
# getGO(\peOver4\, GOfigDir, psOver4)
# getGO(\peOver3\, GOfigDir, psOver3)
# getGO(\peOver2\, GOfigDir, psOver2)
# getGO(\peOver1\, GOfigDir, psOver1)
# getGO(\peOver0\, GOfigDir, psOver0)
# 
# #####################
# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# 
# 
# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver0\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver1\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver2\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver3\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver4\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# 
# GOlist <- factor(c(\GO:0006397\, \GO:0008380\, \GO:0022613\, \GO:0034470\,
#                    \GO:0016055\, \GO:0007389\, \GO:0048562\, \GO:0045165\, 
#                    \GO:0072001\, \GO:0007517\, \GO:0048705\, 
#                    \GO:0040029\, \GO:0010165\))
# 
# data <- bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset4) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, \..\, \GO\, \GO_groups_pe\)
# height = 2
# width = 3.4
# svglite(paste0(fileName, \.svg\), height = height, width = width)
# print(p)
# dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



#### Grouping with P-E number
##### Grouping

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJuWlhSUWRtRnNWMmxzWTI5NElEd3RJR1oxYm1OMGFXOXVLR1JoZEdFc0lHZHliM1Z3TVN3Z1ozSnZkWEF5S1h0Y2JpTWdJQ0JrYVhOMFlXNWpaVEVnUEMwZ0tHUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvY0hOUGRtVnlJRDA5WjNKdmRYQXhLU0FwSkcxbFlXNWZaR2xtWmw5elkyOXlaVnh1SXlBZ0lHUnBjM1JoYm1ObE1pQThMU0FvWkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHdjMDkyWlhJZ1BUMW5jbTkxY0RJcElDa2tiV1ZoYmw5a2FXWm1YM05qYjNKbFhHNGpJQ0FnZDJsc0lEd3RJSGRwYkdOdmVDNTBaWE4wS0dScGMzUmhibU5sTVN3Z1pHbHpkR0Z1WTJVeUtWeHVJeUFnSUhKbGRIVnliaWgzYVd3a2NDNTJZV3gxWlNsY2JpTWdmVnh1SXlCY2JpTWdjSE13TVNBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBc0lGd2ljSE5QZG1WeU1Gd2lMQ0JjSW5CelQzWmxjakZjSWlrc0lEVXBYRzRqSUhCek1USWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMQ0JjSW5CelQzWmxjakZjSWl3Z1hDSndjMDkyWlhJeVhDSXBMQ0ExS1Z4dUl5Qndjekl6SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0N3Z1hDSndjMDkyWlhJeVhDSXNJRndpY0hOUGRtVnlNMXdpS1N3Z05TbGNiaU1nY0hNek5DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXNJRndpY0hOUGRtVnlNMXdpTENCY0luQnpUM1psY2pSY0lpa3NJRFVwWEc0aklIQnpNalFnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaDBaVzF3TENCY0luQnpUM1psY2pKY0lpd2dYQ0p3YzA5MlpYSTBYQ0lwTENBMUtWeHVJeUJ3Y3pFMElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dYQ0p3YzA5MlpYSXhYQ0lzSUZ3aWNITlBkbVZ5TkZ3aUtTd2dOU2xjYmlNZ2NITXdOQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEFzSUZ3aWNITlBkbVZ5TUZ3aUxDQmNJbkJ6VDNabGNqUmNJaWtzSURVcFhHNWNibHh1Y0NBOExTQm5aM0JzYjNRb2RHVnRjQ3dnWVdWektIZ2dQU0J3WlU5MlpYSXNJSGtnUFNCdFpXRnVYMlJwWm1aZmMyTnZjbVVwS1NBcklHZGxiMjFmZG1sdmJHbHVLR0ZsY3lobWFXeHNJRDBnY0dWUGRtVnlLU3dnYzJodmR5NXNaV2RsYm1RZ1BTQkdRVXhUUlNrZ0sxeHVJQ0JuWlc5dFgySnZlSEJzYjNRb2QybGtkR2dnUFNBd0xqRXNJRzkxZEd4cFpYSXVjMmhoY0dVZ1BTQk9RU2tnS3lCMGFHVnRaVjlqYkdGemMybGpLQ2tnS3lCY2JpQWdjM1JoZEY5emRXMXRZWEo1S0dGbGN5aG5jbTkxY0NBOUlIQmxUM1psY2lrc0lHWjFiaUE5SUcxbFlXNHNJR2RsYjIwZ1BTQmNJbkJ2YVc1MFhDSXNJSE5vWVhCbElEMGdNakVzSUhOcGVtVWdQU0F5TENCbWFXeHNJRDBnWENKeVpXUmNJaXdnWTI5c2IzSWdQU0JjSW1Kc1lXTnJYQ0lwSUN0Y2JpQWdaMlZ2YlY5b2JHbHVaU2g1YVc1MFpYSmpaWEIwSUQwZ01DbGNiaUFnSXlCaGJtNXZkR0YwWlNoY0luUmxlSFJjSWl3Z2VDQTlJREVzSUhrZ1BTQXdMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNJbkJ6TURFNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCek1ERXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkJ6TVRJNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCek1USXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkJ6TWpNNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCek1qTXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkJ6TXpRNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCek16UXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkJ6TWpRNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCek1qUXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkJ6TVRRNklGd2lMR052Ym5aUWRtRnNkV1VvSUhCek1UUXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkJ6TURRNklGd2lMR052Ym5aUWRtRnNkV1VvSUhCek1EUXBMQ0JjSWx4Y2Jsd2lLU3dnWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJRE1wWEc1Y2JpQWdYRzVtYVd4bFRtRnRaU0E4TFNCd1lYTjBaVEFvWENKa2FXWm1VMk52Y21WZlltRnljR3h2ZEY5d1pVZHliM1Z3WDBFME9EVmZkbk5mUkUxVFQxd2lLVnh1YUdWcFoyaDBJRHd0SUROY2JuZHBaSFJvSUR3dElETmNibkJ1Wnlob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNJaTV3Ym1kY0lpa3BMQ0J5WlhNZ1BTQTJNREFzSUhWdWFYUWdQU0JjSW1sdVhDSXNJR2hsYVdkb2RDQTlJR2hsYVdkb2RDd2dkMmxrZEdnZ1BTQjNhV1IwYUNsY2JuQnlhVzUwS0hBcFhHNWtaWFl1YjJabUtDbGNibk4yWjJ4cGRHVW9hR1Z5WlNobWFXZEVhWElzSUhCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWENJdWMzWm5YQ0lwS1N3Z0lHaGxhV2RvZENBOUlHaGxhV2RvZEN3Z2QybGtkR2dnUFNCM2FXUjBhQ2xjYm5CeWFXNTBLSEFwWEc1a1pYWXViMlptS0NsY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG4jIGdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuIyAgIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4jICAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBzT3ZlciA9PWdyb3VwMikgKSRtZWFuX2RpZmZfc2NvcmVcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxuIyBwczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbiMgcHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjJcXCksIDUpXG4jIHBzMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXIzXFwpLCA1KVxuIyBwczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyNFxcKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBlT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwZU92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcGVPdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKVxuICAjIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDAsIGxhYmVsID0gcGFzdGUwKFxccHMwMTogXFwsIGNvbnZQdmFsdWUocHMwMSksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMxMjogXFwsIGNvbnZQdmFsdWUocHMxMiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMzNDogXFwsIGNvbnZQdmFsdWUocHMzNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyNDogXFwsIGNvbnZQdmFsdWUocHMyNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMxNDogXFwsY29udlB2YWx1ZSggcHMxNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMwNDogXFwsY29udlB2YWx1ZSggcHMwNCksIFxcXFxuXFwpLCBcbiAgIyAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXGRpZmZTY29yZV9iYXJwbG90X3BlR3JvdXBfQTQ4NV92c19ETVNPXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# ps01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(temp, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(temp, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)


p <- ggplot(temp, aes(x = peOver, y = mean_diff_score)) + geom_violin(aes(fill = peOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = peOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \,convPvalue( ps14), \\n\,
  #                                               \ps04: \,convPvalue( ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3)

  
fileName <- paste0(\diffScore_barplot_peGroup_A485_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5Qm5aWFJRZG1Gc1YybHNZMjk0SUR3dElHWjFibU4wYVc5dUtHUmhkR0VzSUdkeWIzVndNU3dnWjNKdmRYQXlLWHRjYmlNZ0lDQmthWE4wWVc1alpURWdQQzBnS0dSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9jSE5QZG1WeUlEMDlaM0p2ZFhBeEtTQXBKRzFsWVc1ZlpHbG1abDl6WTI5eVpWeHVJeUFnSUdScGMzUmhibU5sTWlBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lod2MwOTJaWElnUFQxbmNtOTFjRElwSUNra2JXVmhibDlrYVdabVgzTmpiM0psWEc0aklDQWdkMmxzSUR3dElIZHBiR052ZUM1MFpYTjBLR1JwYzNSaGJtTmxNU3dnWkdsemRHRnVZMlV5S1Z4dUl5QWdJSEpsZEhWeWJpaDNhV3drY0M1MllXeDFaU2xjYmlNZ2ZWeHVJeUJjYmlNZ2NITXdNU0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEFzSUZ4Y2NITlBkbVZ5TUZ4Y0xDQmNYSEJ6VDNabGNqRmNYQ2tzSURVcFhHNGpJSEJ6TVRJZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xDQmNYSEJ6VDNabGNqRmNYQ3dnWEZ4d2MwOTJaWEl5WEZ3cExDQTFLVnh1SXlCd2N6SXpJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnWEZ4d2MwOTJaWEl5WEZ3c0lGeGNjSE5QZG1WeU0xeGNLU3dnTlNsY2JpTWdjSE16TkNBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBc0lGeGNjSE5QZG1WeU0xeGNMQ0JjWEhCelQzWmxjalJjWENrc0lEVXBYRzRqSUhCek1qUWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMQ0JjWEhCelQzWmxjakpjWEN3Z1hGeHdjMDkyWlhJMFhGd3BMQ0ExS1Z4dUl5QndjekUwSUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0N3Z1hGeHdjMDkyWlhJeFhGd3NJRnhjY0hOUGRtVnlORnhjS1N3Z05TbGNiaU1nY0hNd05DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXNJRnhjY0hOUGRtVnlNRnhjTENCY1hIQnpUM1psY2pSY1hDa3NJRFVwWEc1Y2JseHVjQ0E4TFNCblozQnNiM1FvZEdWdGNDd2dZV1Z6S0hnZ1BTQndaVTkyWlhJc0lIa2dQU0J0WldGdVgyUnBabVpmYzJOdmNtVXBLU0FySUdkbGIyMWZkbWx2YkdsdUtHRmxjeWhtYVd4c0lEMGdjR1ZQZG1WeUtTd2djMmh2ZHk1c1pXZGxibVFnUFNCR1FVeFRSU2tnSzF4dUlDQm5aVzl0WDJKdmVIQnNiM1FvZDJsa2RHZ2dQU0F3TGpFc0lHOTFkR3hwWlhJdWMyaGhjR1VnUFNCT1FTa2dLeUIwYUdWdFpWOWpiR0Z6YzJsaktDa2dLeUJjYmlBZ2MzUmhkRjl6ZFcxdFlYSjVLR0ZsY3lobmNtOTFjQ0E5SUhCbFQzWmxjaWtzSUdaMWJpQTlJRzFsWVc0c0lHZGxiMjBnUFNCY1hIQnZhVzUwWEZ3c0lITm9ZWEJsSUQwZ01qRXNJSE5wZW1VZ1BTQXlMQ0JtYVd4c0lEMGdYRnh5WldSY1hDd2dZMjlzYjNJZ1BTQmNYR0pzWVdOclhGd3BJQ3RjYmlBZ1oyVnZiVjlvYkdsdVpTaDVhVzUwWlhKalpYQjBJRDBnTUNsY2JpQWdJeUJoYm01dmRHRjBaU2hjWEhSbGVIUmNYQ3dnZUNBOUlERXNJSGtnUFNBd0xDQnNZV0psYkNBOUlIQmhjM1JsTUNoY1hIQnpNREU2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEJ6TURFcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQnpNVEk2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEJ6TVRJcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQnpNak02SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEJ6TWpNcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQnpNelE2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEJ6TXpRcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQnpNalE2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEJ6TWpRcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQnpNVFE2SUZ4Y0xHTnZiblpRZG1Gc2RXVW9JSEJ6TVRRcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQnpNRFE2SUZ4Y0xHTnZiblpRZG1Gc2RXVW9JSEJ6TURRcExDQmNYRnhjYmx4Y0tTd2dYRzRnSUNNZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlETXBYRzVjYmlBZ1hHNW1hV3hsVG1GdFpTQThMU0J3WVhOMFpUQW9YRnhrYVdabVUyTnZjbVZmWW1GeWNHeHZkRjl3WlVkeWIzVndYMEUwT0RWZmRuTmZSRTFUVDF4Y0tWeHVhR1ZwWjJoMElEd3RJRE5jYm5kcFpIUm9JRHd0SUROY2JuQnVaeWhvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY1hDNXdibWRjWENrcExDQnlaWE1nUFNBMk1EQXNJSFZ1YVhRZ1BTQmNYR2x1WEZ3c0lHaGxhV2RvZENBOUlHaGxhV2RvZEN3Z2QybGtkR2dnUFNCM2FXUjBhQ2xjYm5CeWFXNTBLSEFwWEc1a1pYWXViMlptS0NsY2JuTjJaMnhwZEdVb2FHVnlaU2htYVdkRWFYSXNJSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYRnd1YzNablhGd3BLU3dnSUdobGFXZG9kQ0E5SUdobGFXZG9kQ3dnZDJsa2RHZ2dQU0IzYVdSMGFDbGNibkJ5YVc1MEtIQXBYRzVrWlhZdWIyWm1LQ2xjYm1CZ1lGeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYGBgclxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocHNPdmVyID09Z3JvdXAxKSApJG1lYW5fZGlmZl9zY29yZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4jICAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuIyAgIHJldHVybih3aWwkcC52YWx1ZSlcbiMgfVxuIyBcbiMgcHMwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjFcXCksIDUpXG4jIHBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIyXFwsIFxccHNPdmVyM1xcKSwgNSlcbiMgcHMzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyM1xcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIxXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjRcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBwZU92ZXIsIHkgPSBtZWFuX2RpZmZfc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcGVPdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBlT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTI6IFxcLCBjb252UHZhbHVlKHBzMTIpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjM6IFxcLCBjb252UHZhbHVlKHBzMjMpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjQ6IFxcLCBjb252UHZhbHVlKHBzMjQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLGNvbnZQdmFsdWUoIHBzMTQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMDQ6IFxcLGNvbnZQdmFsdWUoIHBzMDQpLCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxkaWZmU2NvcmVfYmFycGxvdF9wZUdyb3VwX0E0ODVfdnNfRE1TT1xcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocHNPdmVyID09Z3JvdXAxKSApJG1lYW5fZGlmZl9zY29yZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4jICAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuIyAgIHJldHVybih3aWwkcC52YWx1ZSlcbiMgfVxuIyBcbiMgcHMwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjFcXCksIDUpXG4jIHBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIyXFwsIFxccHNPdmVyM1xcKSwgNSlcbiMgcHMzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyM1xcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIxXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjRcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBwZU92ZXIsIHkgPSBtZWFuX2RpZmZfc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcGVPdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBlT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTI6IFxcLCBjb252UHZhbHVlKHBzMTIpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjM6IFxcLCBjb252UHZhbHVlKHBzMjMpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjQ6IFxcLCBjb252UHZhbHVlKHBzMjQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLGNvbnZQdmFsdWUoIHBzMTQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMDQ6IFxcLGNvbnZQdmFsdWUoIHBzMDQpLCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxkaWZmU2NvcmVfYmFycGxvdF9wZUdyb3VwX0E0ODVfdnNfRE1TT1xcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# ps01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(temp, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(temp, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)


p <- ggplot(temp, aes(x = peOver, y = mean_diff_score)) + geom_violin(aes(fill = peOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = peOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \,convPvalue( ps14), \\n\,
  #                                               \ps04: \,convPvalue( ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3)

  
fileName <- paste0(\diffScore_barplot_peGroup_A485_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### (SKIP) GO for each group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuI1xuIyAgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBzT3ZlciA9PWdyb3VwMSkgKSRsb2cyRm9sZENoYW5nZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxudGVtcERvd24gPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihsb2cyRm9sZENoYW5nZSA8IDApXG4jICBcbiMgcHMwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBzT3ZlcjBcIiwgXCJwc092ZXIxXCIpLCA1KVxuIyBwczEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFwicHNPdmVyMVwiLCBcInBzT3ZlcjJcIiksIDUpXG4jIHBzMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXCJwc092ZXIyXCIsIFwicHNPdmVyM1wiKSwgNSlcbiMgcHMzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBzT3ZlcjNcIiwgXCJwc092ZXI0XCIpLCA1KVxuIyBwczI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFwicHNPdmVyMlwiLCBcInBzT3ZlcjRcIiksIDUpXG4jIHBzMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXCJwc092ZXIxXCIsIFwicHNPdmVyNFwiKSwgNSlcbiMgcHMwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBzT3ZlcjBcIiwgXCJwc092ZXI0XCIpLCA1KVxuXG5cbnAgPC0gZ2dwbG90KHRlbXBEb3duLCBhZXMoeCA9IHBlT3ZlciwgeSA9IGxvZzJGb2xkQ2hhbmdlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IHBlT3ZlciksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBwZU92ZXIpLCBmdW4gPSBtZWFuLCBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFwicmVkXCIsIGNvbG9yID0gXCJibGFja1wiKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApXG4gICMgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAxLCB5ID0gLTAuNSwgbGFiZWwgPSBwYXN0ZTAoXCJwczAxOiBcIiwgY29udlB2YWx1ZShwczAxKSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczEyOiBcIiwgY29udlB2YWx1ZShwczEyKSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczIzOiBcIiwgY29udlB2YWx1ZShwczIzKSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczM0OiBcIiwgY29udlB2YWx1ZShwczM0KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczI0OiBcIiwgY29udlB2YWx1ZShwczI0KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczE0OiBcIiwgY29udlB2YWx1ZShwczE0KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczA0OiBcIiwgY29udlB2YWx1ZShwczA0KSwgXCJcXG5cIiksIFxuICAjICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygtMSwgMCkpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJsb2cyRkNfYmFycGxvdF9wZUdyb3VwX0E0ODVfdnNfRE1TT19kb3duXCIpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cblxudGVtcFVwIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPiAwKVxuIFxuIyBwczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBzT3ZlcjBcIiwgXCJwc092ZXIxXCIpLCA1KVxuIyBwczEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBzT3ZlcjFcIiwgXCJwc092ZXIyXCIpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBzT3ZlcjJcIiwgXCJwc092ZXIzXCIpLCA1KVxuIyBwczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBzT3ZlcjNcIiwgXCJwc092ZXI0XCIpLCA1KVxuIyBwczI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBzT3ZlcjJcIiwgXCJwc092ZXI0XCIpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBzT3ZlcjFcIiwgXCJwc092ZXI0XCIpLCA1KVxuIyBwczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcInBzT3ZlcjBcIiwgXCJwc092ZXI0XCIpLCA1KVxuIyBcblxuXG5cblxucCA8LSBnZ3Bsb3QodGVtcFVwLCBhZXMoeCA9IHBlT3ZlciwgeSA9IGxvZzJGb2xkQ2hhbmdlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IHBlT3ZlciksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBwZU92ZXIpLCBmdW4gPSBtZWFuLCBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFwicmVkXCIsIGNvbG9yID0gXCJibGFja1wiKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApXG4gICMgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAxLCB5ID0gMC41LCBsYWJlbCA9IHBhc3RlMChcInBzMDE6IFwiLCBjb252UHZhbHVlKHBzMDEpLCBcIlxcblwiLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMTI6IFwiLCBjb252UHZhbHVlKHBzMTIpLCBcIlxcblwiLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMjM6IFwiLCBjb252UHZhbHVlKHBzMjMpLCBcIlxcblwiLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMzQ6IFwiLCBjb252UHZhbHVlKHBzMzQpLCBcIlxcblwiLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMjQ6IFwiLCBjb252UHZhbHVlKHBzMjQpLCBcIlxcblwiLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMTQ6IFwiLCBjb252UHZhbHVlKHBzMTQpLCBcIlxcblwiLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMDQ6IFwiLCBjb252UHZhbHVlKHBzMDQpLCBcIlxcblwiKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcImJsYWNrXCIsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIDEpKVxuXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFwibG9nMkZDX2JhcnBsb3RfcGVHcm91cF9BNDg1X3ZzX0RNU09fdXBcIilcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGAifQ== -->\n\n```r\n#\n#  getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n# \ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n#  \n# ps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\n# ps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\n# ps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\n# ps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\n# ps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\n# ps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n# ps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = peOver, y = log2FoldChange)) + geom_violin(aes(fill = peOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = peOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n  #                                               \\ps12: \\, convPvalue(ps12), \\\\n\\,\n  #                                               \\ps23: \\, convPvalue(ps23), \\\\n\\,\n  #                                               \\ps34: \\, convPvalue(ps34), \\\\n\\,\n  #                                               \\ps24: \\, convPvalue(ps24), \\\\n\\,\n  #                                               \\ps14: \\, convPvalue(ps14), \\\\n\\,\n  #                                               \\ps04: \\, convPvalue(ps04), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))\n\n  \nfileName <- paste0(\\log2FC_barplot_peGroup_A485_vs_DMSO_down\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \n# ps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\n# ps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\n# ps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\n# ps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\n# ps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\n# ps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\n# ps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n# \n\n\n\n\np <- ggplot(tempUp, aes(x = peOver, y = log2FoldChange)) + geom_violin(aes(fill = peOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = peOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n  #                                               \\ps12: \\, convPvalue(ps12), \\\\n\\,\n  #                                               \\ps23: \\, convPvalue(ps23), \\\\n\\,\n  #                                               \\ps34: \\, convPvalue(ps34), \\\\n\\,\n  #                                               \\ps24: \\, convPvalue(ps24), \\\\n\\,\n  #                                               \\ps14: \\, convPvalue(ps14), \\\\n\\,\n  #                                               \\ps04: \\, convPvalue(ps04), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_peGroup_A485_vs_DMSO_up\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
#
#  getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
#  
# ps01 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(tempDown, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver4\), 5)


p <- ggplot(tempDown, aes(x = peOver, y = log2FoldChange)) + geom_violin(aes(fill = peOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = peOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = -0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0(\log2FC_barplot_peGroup_A485_vs_DMSO_down\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
# ps01 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(tempUp, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver4\), 5)
# 




p <- ggplot(tempUp, aes(x = peOver, y = log2FoldChange)) + geom_violin(aes(fill = peOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = peOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_peGroup_A485_vs_DMSO_up\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuI1xuIyAgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBzT3ZlciA9PWdyb3VwMSkgKSRsb2cyRm9sZENoYW5nZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxudGVtcERvd24gPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihsb2cyRm9sZENoYW5nZSA8IDApXG4jICBcbiMgcHMwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjBcXCwgXFxwc092ZXIxXFwpLCA1KVxuIyBwczEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjJcXCksIDUpXG4jIHBzMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIyXFwsIFxccHNPdmVyM1xcKSwgNSlcbiMgcHMzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjNcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIxXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjBcXCwgXFxwc092ZXI0XFwpLCA1KVxuXG5cbnAgPC0gZ2dwbG90KHRlbXBEb3duLCBhZXMoeCA9IHBlT3ZlciwgeSA9IGxvZzJGb2xkQ2hhbmdlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IHBlT3ZlciksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBwZU92ZXIpLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApXG4gICMgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gLTAuNSwgbGFiZWwgPSBwYXN0ZTAoXFxwczAxOiBcXCwgY29udlB2YWx1ZShwczAxKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczIzOiBcXCwgY29udlB2YWx1ZShwczIzKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczM0OiBcXCwgY29udlB2YWx1ZShwczM0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczE0OiBcXCwgY29udlB2YWx1ZShwczE0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygtMSwgMCkpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxsb2cyRkNfYmFycGxvdF9wZUdyb3VwX0E0ODVfdnNfRE1TT19kb3duXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cblxudGVtcFVwIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPiAwKVxuIFxuIyBwczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjBcXCwgXFxwc092ZXIxXFwpLCA1KVxuIyBwczEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXIzXFwpLCA1KVxuIyBwczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjNcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjBcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBcblxuXG5cblxucCA8LSBnZ3Bsb3QodGVtcFVwLCBhZXMoeCA9IHBlT3ZlciwgeSA9IGxvZzJGb2xkQ2hhbmdlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IHBlT3ZlciksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBwZU92ZXIpLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApXG4gICMgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMC41LCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTI6IFxcLCBjb252UHZhbHVlKHBzMTIpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjM6IFxcLCBjb252UHZhbHVlKHBzMjMpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjQ6IFxcLCBjb252UHZhbHVlKHBzMjQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMDQ6IFxcLCBjb252UHZhbHVlKHBzMDQpLCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIDEpKVxuXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcbG9nMkZDX2JhcnBsb3RfcGVHcm91cF9BNDg1X3ZzX0RNU09fdXBcXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\n#\n#  getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n# \ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n#  \n# ps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\n# ps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\n# ps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\n# ps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\n# ps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\n# ps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n# ps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\np <- ggplot(tempDown, aes(x = peOver, y = log2FoldChange)) + geom_violin(aes(fill = peOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = peOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n  #                                               \\ps12: \\, convPvalue(ps12), \\\\n\\,\n  #                                               \\ps23: \\, convPvalue(ps23), \\\\n\\,\n  #                                               \\ps34: \\, convPvalue(ps34), \\\\n\\,\n  #                                               \\ps24: \\, convPvalue(ps24), \\\\n\\,\n  #                                               \\ps14: \\, convPvalue(ps14), \\\\n\\,\n  #                                               \\ps04: \\, convPvalue(ps04), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))\n\n  \nfileName <- paste0(\\log2FC_barplot_peGroup_A485_vs_DMSO_down\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n \n# ps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\n# ps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\n# ps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\n# ps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\n# ps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\n# ps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\n# ps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n# \n\n\n\n\np <- ggplot(tempUp, aes(x = peOver, y = log2FoldChange)) + geom_violin(aes(fill = peOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = peOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n  #                                               \\ps12: \\, convPvalue(ps12), \\\\n\\,\n  #                                               \\ps23: \\, convPvalue(ps23), \\\\n\\,\n  #                                               \\ps34: \\, convPvalue(ps34), \\\\n\\,\n  #                                               \\ps24: \\, convPvalue(ps24), \\\\n\\,\n  #                                               \\ps14: \\, convPvalue(ps14), \\\\n\\,\n  #                                               \\ps04: \\, convPvalue(ps04), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_peGroup_A485_vs_DMSO_up\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuI1xuIyAgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBzT3ZlciA9PWdyb3VwMSkgKSRsb2cyRm9sZENoYW5nZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxudGVtcERvd24gPC0gdGVtcCAlPiUgZHBseXI6OmZpbHRlcihsb2cyRm9sZENoYW5nZSA8IDApXG4jICBcbiMgcHMwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjBcXCwgXFxwc092ZXIxXFwpLCA1KVxuIyBwczEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjJcXCksIDUpXG4jIHBzMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIyXFwsIFxccHNPdmVyM1xcKSwgNSlcbiMgcHMzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjNcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIxXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjBcXCwgXFxwc092ZXI0XFwpLCA1KVxuXG5cbnAgPC0gZ2dwbG90KHRlbXBEb3duLCBhZXMoeCA9IHBlT3ZlciwgeSA9IGxvZzJGb2xkQ2hhbmdlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IHBlT3ZlciksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBwZU92ZXIpLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApXG4gICMgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gLTAuNSwgbGFiZWwgPSBwYXN0ZTAoXFxwczAxOiBcXCwgY29udlB2YWx1ZShwczAxKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczIzOiBcXCwgY29udlB2YWx1ZShwczIzKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczM0OiBcXCwgY29udlB2YWx1ZShwczM0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczE0OiBcXCwgY29udlB2YWx1ZShwczE0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygtMSwgMCkpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxsb2cyRkNfYmFycGxvdF9wZUdyb3VwX0E0ODVfdnNfRE1TT19kb3duXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cblxudGVtcFVwIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPiAwKVxuIFxuIyBwczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjBcXCwgXFxwc092ZXIxXFwpLCA1KVxuIyBwczEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXIzXFwpLCA1KVxuIyBwczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjNcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcFVwLCBcXHBzT3ZlcjBcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBcblxuXG5cblxucCA8LSBnZ3Bsb3QodGVtcFVwLCBhZXMoeCA9IHBlT3ZlciwgeSA9IGxvZzJGb2xkQ2hhbmdlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IHBlT3ZlciksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBwZU92ZXIpLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApXG4gICMgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMC41LCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTI6IFxcLCBjb252UHZhbHVlKHBzMTIpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjM6IFxcLCBjb252UHZhbHVlKHBzMjMpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjQ6IFxcLCBjb252UHZhbHVlKHBzMjQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMDQ6IFxcLCBjb252UHZhbHVlKHBzMDQpLCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIDEpKVxuXG4gIFxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcbG9nMkZDX2JhcnBsb3RfcGVHcm91cF9BNDg1X3ZzX0RNU09fdXBcXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
#
#  getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
#  
# ps01 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(tempDown, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver4\), 5)


p <- ggplot(tempDown, aes(x = peOver, y = log2FoldChange)) + geom_violin(aes(fill = peOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = peOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = -0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0(\log2FC_barplot_peGroup_A485_vs_DMSO_down\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
# ps01 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(tempUp, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver4\), 5)
# 




p <- ggplot(tempUp, aes(x = peOver, y = log2FoldChange)) + geom_violin(aes(fill = peOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = peOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_peGroup_A485_vs_DMSO_up\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### loop score

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUIwWlcxd01pQmpiMjUwWVdsdWN5Qm5aVzVsY3lCbWNtOXRJR2R5YjNWd0lERXNJRElzSURVc0lEZ2dZVzVrSUd4dmIzQWdZMjkxYm5SelhHNGpZMkZzWTNWc1lYUnBibWNnWkdsbVppQnpZMjl5WlNCaGJtUWdiRzluTW1aaklHUnBjM1J5YVdKMWRHbHZiaUJpWVhObFpDQnZiaUJ3TFc0Z2JuVnRZbVZ5YzF4dWNIQlBkbVZ5TkNBOExTQW9kR1Z0Y0RJZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb2JuVnRYM0J3SUQ0OUlEUXBLU1JuWlc1bFhHNXdjRTkyWlhJeklEd3RJQ2gwWlcxd01pQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHVkVzFmY0hBZ1BqMGdNeXdnYm5WdFgzQndJRHdnTkNrcEpHZGxibVZjYm5Cd1QzWmxjaklnUEMwZ0tIUmxiWEF5SUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0c1MWJWOXdjQ0ErUFNBeUxDQnVkVzFmY0hBZ1BDQXpLU2trWjJWdVpWeHVjSEJQZG1WeU1TQThMU0FvZEdWdGNESWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9iblZ0WDNCd0lENDlJREVzSUc1MWJWOXdjQ0E4SURJcEtTUm5aVzVsWEc1d2NFOTJaWEl3SUR3dElDaDBaVzF3TWlBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lodWRXMWZjSEFnUENBeEtTa2taMlZ1WlZ4dVhHNWNibHh1SXlNZ1JHbDJhV1JwYm1jZ1oyVnVaWE1nYVc1MGJ5Qm5jbTkxY0hOY2JuUmxiWEFnUEMwZ1oyVnVaVUZ1Ym05RVlYUmhJQ1UrSlNCa2NHeDVjam82YzJWc1pXTjBLR1JwWm1aZlFUUTROVjlFVFZOUExDQmthWE4wWVc1alpTd2daMlZ1WlNrZ0pUNGxJRnh1SUNCMWJtNWxjM1FvWjJWdVpTa2dKVDRsSUdkeWIzVndYMko1S0dkbGJtVXBJQ1UrSlZ4dUlDQnpkVzF0WVhKcGVtVW9iV1ZoYmw5a2FXWm1YM05qYjNKbElEMGdiV1ZoYmloa2FXWm1YMEUwT0RWZlJFMVRUeWtzWEc0Z0lDQWdJQ0FnSUNBZ0lDQnRaV0Z1WDJScGMzUmhibU5sSUQwZ2JXVmhiaWhrYVhOMFlXNWpaU2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQXVaM0p2ZFhCeklEMGdKMlJ5YjNBbktWeHVYRzVrYVdabUxsSk9RU0E4TFNCbWNtVmhaQ2hvWlhKbEtISmxaa1JwY2l3Z1hDSmthV1ptWDBjeExrRTBPRFV1YzJWc1pXTjBaV1F5WDBjeExqSnBMa0UwT0RWZmRuTmZSekV1TW1rdVJFMVRUeTUwYzNaY0lpa3BJQ1UrSlZ4dUlDQmtjR3g1Y2pvNmMyVnNaV04wS0dWdWMyVnRZbXhmWjJWdVpWOXBaQ3dnYkc5bk1rWnZiR1JEYUdGdVoyVXNJSE5vY21sdWEyVmtYMnh2WnpKR1F5d2djR0ZrYWl3Z1pYaDBaWEp1WVd4ZloyVnVaVjl1WVcxbEtWeHVYRzV0WVhoTWIyY3lSa01nUFNBeVhHNWNiblJsYlhBZ1BDMGdiR1ZtZEY5cWIybHVLSFJsYlhBc0lHUnBabVl1VWs1QkxDQmllU0E5SUdNb1hDSm5aVzVsWENJZ1BTQmNJbVZ1YzJWdFlteGZaMlZ1WlY5cFpGd2lLU2tnSlQ0bElGeHVJQ0JrY205d1gyNWhLSE5vY21sdWEyVmtYMnh2WnpKR1F5bGNibHh1WEc1MFpXMXdJRHd0SUhSbGJYQWdKVDRsSUdSd2JIbHlPanB0ZFhSaGRHVW9YRzRnSUhCd1QzWmxjaUE5SUdsbVpXeHpaU2huWlc1bElDVnBiaVVnY0hCUGRtVnlOQ3dnWENKd2NFOTJaWEkwWENJc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnBabVZzYzJVb1oyVnVaU0FsYVc0bElIQndUM1psY2pNc0lGd2ljSEJQZG1WeU0xd2lMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaG5aVzVsSUNWcGJpVWdjSEJQZG1WeU1pd2dYQ0p3Y0U5MlpYSXlYQ0lzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaG5aVzVsSUNWcGJpVWdjSEJQZG1WeU1Td2dYQ0p3Y0U5MlpYSXhYQ0lzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnBabVZzYzJVb1oyVnVaU0FsYVc0bElIQndUM1psY2pBc0lGd2ljSEJQZG1WeU1Gd2lMQ0JPUVNrcEtTa3BLU0FsUGlWY2JpQWdaSEp2Y0Y5dVlTaHdjRTkyWlhJcFhHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuIyB0ZW1wMiBjb250YWlucyBnZW5lcyBmcm9tIGdyb3VwIDEsIDIsIDUsIDggYW5kIGxvb3AgY291bnRzXG4jY2FsY3VsYXRpbmcgZGlmZiBzY29yZSBhbmQgbG9nMmZjIGRpc3RyaWJ1dGlvbiBiYXNlZCBvbiBwLW4gbnVtYmVyc1xucHBPdmVyNCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDQpKSRnZW5lXG5wcE92ZXIzIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMywgbnVtX3BwIDwgNCkpJGdlbmVcbnBwT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAyLCBudW1fcHAgPCAzKSkkZ2VuZVxucHBPdmVyMSA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDEsIG51bV9wcCA8IDIpKSRnZW5lXG5wcE92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPCAxKSkkZ2VuZVxuXG5cblxuIyMgRGl2aWRpbmcgZ2VuZXMgaW50byBncm91cHNcbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmZfQTQ4NV9ETVNPLCBkaXN0YW5jZSwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmX0E0ODVfRE1TTyksXG4gICAgICAgICAgICBtZWFuX2Rpc3RhbmNlID0gbWVhbihkaXN0YW5jZSksXG4gICAgICAgICAgICAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLkE0ODUuc2VsZWN0ZWQyX0cxLjJpLkE0ODVfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxuXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBwT3ZlciA9IGlmZWxzZShnZW5lICVpbiUgcHBPdmVyNCwgXFxwcE92ZXI0XFwsXG4gICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBwT3ZlcjMsIFxccHBPdmVyM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHBPdmVyMiwgXFxwcE92ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHBPdmVyMSwgXFxwcE92ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBwT3ZlcjAsIFxccHBPdmVyMFxcLCBOQSkpKSkpKSAlPiVcbiAgZHJvcF9uYShwcE92ZXIpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers
ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)


temp <- temp %>% dplyr::mutate(
  ppOver = ifelse(gene %in% ppOver4, \ppOver4\,
                  ifelse(gene %in% ppOver3, \ppOver3\,
                         ifelse(gene %in% ppOver2, \ppOver2\,
                                ifelse(gene %in% ppOver1, \ppOver1\,
                                       ifelse(gene %in% ppOver0, \ppOver0\, NA)))))) %>%
  drop_na(ppOver)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QjBaVzF3TWlCamIyNTBZV2x1Y3lCblpXNWxjeUJtY205dElHZHliM1Z3SURFc0lESXNJRFVzSURnZ1lXNWtJR3h2YjNBZ1kyOTFiblJ6WEc0alkyRnNZM1ZzWVhScGJtY2daR2xtWmlCelkyOXlaU0JoYm1RZ2JHOW5NbVpqSUdScGMzUnlhV0oxZEdsdmJpQmlZWE5sWkNCdmJpQndMVzRnYm5WdFltVnljMXh1Y0hCUGRtVnlOQ0E4TFNBb2RHVnRjRElnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvYm5WdFgzQndJRDQ5SURRcEtTUm5aVzVsWEc1d2NFOTJaWEl6SUR3dElDaDBaVzF3TWlBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lodWRXMWZjSEFnUGowZ015d2diblZ0WDNCd0lEd2dOQ2twSkdkbGJtVmNibkJ3VDNabGNqSWdQQzBnS0hSbGJYQXlJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRzUxYlY5d2NDQStQU0F5TENCdWRXMWZjSEFnUENBektTa2taMlZ1WlZ4dWNIQlBkbVZ5TVNBOExTQW9kR1Z0Y0RJZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb2JuVnRYM0J3SUQ0OUlERXNJRzUxYlY5d2NDQThJRElwS1NSblpXNWxYRzV3Y0U5MlpYSXdJRHd0SUNoMFpXMXdNaUFsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWh1ZFcxZmNIQWdQQ0F4S1Nra1oyVnVaVnh1WEc1Y2JseHVJeU1nUkdsMmFXUnBibWNnWjJWdVpYTWdhVzUwYnlCbmNtOTFjSE5jYm5SbGJYQWdQQzBnWjJWdVpVRnVibTlFWVhSaElDVStKU0JrY0d4NWNqbzZjMlZzWldOMEtHUnBabVpmUVRRNE5WOUVUVk5QTENCa2FYTjBZVzVqWlN3Z1oyVnVaU2tnSlQ0bElGeHVJQ0IxYm01bGMzUW9aMlZ1WlNrZ0pUNGxJR2R5YjNWd1gySjVLR2RsYm1VcElDVStKVnh1SUNCemRXMXRZWEpwZW1Vb2JXVmhibDlrYVdabVgzTmpiM0psSUQwZ2JXVmhiaWhrYVdabVgwRTBPRFZmUkUxVFR5a3NYRzRnSUNBZ0lDQWdJQ0FnSUNCdFpXRnVYMlJwYzNSaGJtTmxJRDBnYldWaGJpaGthWE4wWVc1alpTa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBdVozSnZkWEJ6SUQwZ0oyUnliM0FuS1Z4dVhHNWthV1ptTGxKT1FTQThMU0JtY21WaFpDaG9aWEpsS0hKbFprUnBjaXdnWEZ4a2FXWm1YMGN4TGtFME9EVXVjMlZzWldOMFpXUXlYMGN4TGpKcExrRTBPRFZmZG5OZlJ6RXVNbWt1UkUxVFR5NTBjM1pjWENrcElDVStKVnh1SUNCa2NHeDVjam82YzJWc1pXTjBLR1Z1YzJWdFlteGZaMlZ1WlY5cFpDd2diRzluTWtadmJHUkRhR0Z1WjJVc0lITm9jbWx1YTJWa1gyeHZaekpHUXl3Z2NHRmthaXdnWlhoMFpYSnVZV3hmWjJWdVpWOXVZVzFsS1Z4dVhHNXRZWGhNYjJjeVJrTWdQU0F5WEc1Y2JuUmxiWEFnUEMwZ2JHVm1kRjlxYjJsdUtIUmxiWEFzSUdScFptWXVVazVCTENCaWVTQTlJR01vWEZ4blpXNWxYRndnUFNCY1hHVnVjMlZ0WW14ZloyVnVaVjlwWkZ4Y0tTa2dKVDRsSUZ4dUlDQmtjbTl3WDI1aEtITm9jbWx1YTJWa1gyeHZaekpHUXlsY2JseHVYRzUwWlcxd0lEd3RJSFJsYlhBZ0pUNGxJR1J3YkhseU9qcHRkWFJoZEdVb1hHNGdJSEJ3VDNabGNpQTlJR2xtWld4elpTaG5aVzVsSUNWcGJpVWdjSEJQZG1WeU5Dd2dYRnh3Y0U5MlpYSTBYRndzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCcFptVnNjMlVvWjJWdVpTQWxhVzRsSUhCd1QzWmxjak1zSUZ4Y2NIQlBkbVZ5TTF4Y0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNoblpXNWxJQ1ZwYmlVZ2NIQlBkbVZ5TWl3Z1hGeHdjRTkyWlhJeVhGd3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNoblpXNWxJQ1ZwYmlVZ2NIQlBkbVZ5TVN3Z1hGeHdjRTkyWlhJeFhGd3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCcFptVnNjMlVvWjJWdVpTQWxhVzRsSUhCd1QzWmxjakFzSUZ4Y2NIQlBkbVZ5TUZ4Y0xDQk9RU2twS1NrcEtTQWxQaVZjYmlBZ1pISnZjRjl1WVNod2NFOTJaWElwWEc1Z1lHQmNibUJnWUNKOSAtLT5cblxuYGBgclxuYGBgclxuIyB0ZW1wMiBjb250YWlucyBnZW5lcyBmcm9tIGdyb3VwIDEsIDIsIDUsIDggYW5kIGxvb3AgY291bnRzXG4jY2FsY3VsYXRpbmcgZGlmZiBzY29yZSBhbmQgbG9nMmZjIGRpc3RyaWJ1dGlvbiBiYXNlZCBvbiBwLW4gbnVtYmVyc1xucHBPdmVyNCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDQpKSRnZW5lXG5wcE92ZXIzIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMywgbnVtX3BwIDwgNCkpJGdlbmVcbnBwT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAyLCBudW1fcHAgPCAzKSkkZ2VuZVxucHBPdmVyMSA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDEsIG51bV9wcCA8IDIpKSRnZW5lXG5wcE92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPCAxKSkkZ2VuZVxuXG5cblxuIyMgRGl2aWRpbmcgZ2VuZXMgaW50byBncm91cHNcbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmZfQTQ4NV9ETVNPLCBkaXN0YW5jZSwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmX0E0ODVfRE1TTyksXG4gICAgICAgICAgICBtZWFuX2Rpc3RhbmNlID0gbWVhbihkaXN0YW5jZSksXG4gICAgICAgICAgICAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLkE0ODUuc2VsZWN0ZWQyX0cxLjJpLkE0ODVfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxuXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBwT3ZlciA9IGlmZWxzZShnZW5lICVpbiUgcHBPdmVyNCwgXFxwcE92ZXI0XFwsXG4gICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBwT3ZlcjMsIFxccHBPdmVyM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHBPdmVyMiwgXFxwcE92ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHBPdmVyMSwgXFxwcE92ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBwT3ZlcjAsIFxccHBPdmVyMFxcLCBOQSkpKSkpKSAlPiVcbiAgZHJvcF9uYShwcE92ZXIpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyB0ZW1wMiBjb250YWlucyBnZW5lcyBmcm9tIGdyb3VwIDEsIDIsIDUsIDggYW5kIGxvb3AgY291bnRzXG4jY2FsY3VsYXRpbmcgZGlmZiBzY29yZSBhbmQgbG9nMmZjIGRpc3RyaWJ1dGlvbiBiYXNlZCBvbiBwLW4gbnVtYmVyc1xucHBPdmVyNCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDQpKSRnZW5lXG5wcE92ZXIzIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMywgbnVtX3BwIDwgNCkpJGdlbmVcbnBwT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAyLCBudW1fcHAgPCAzKSkkZ2VuZVxucHBPdmVyMSA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDEsIG51bV9wcCA8IDIpKSRnZW5lXG5wcE92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPCAxKSkkZ2VuZVxuXG5cblxuIyMgRGl2aWRpbmcgZ2VuZXMgaW50byBncm91cHNcbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6c2VsZWN0KGRpZmZfQTQ4NV9ETVNPLCBkaXN0YW5jZSwgZ2VuZSkgJT4lIFxuICB1bm5lc3QoZ2VuZSkgJT4lIGdyb3VwX2J5KGdlbmUpICU+JVxuICBzdW1tYXJpemUobWVhbl9kaWZmX3Njb3JlID0gbWVhbihkaWZmX0E0ODVfRE1TTyksXG4gICAgICAgICAgICBtZWFuX2Rpc3RhbmNlID0gbWVhbihkaXN0YW5jZSksXG4gICAgICAgICAgICAuZ3JvdXBzID0gJ2Ryb3AnKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLkE0ODUuc2VsZWN0ZWQyX0cxLjJpLkE0ODVfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuXG5tYXhMb2cyRkMgPSAyXG5cbnRlbXAgPC0gbGVmdF9qb2luKHRlbXAsIGRpZmYuUk5BLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxfZ2VuZV9pZFxcKSkgJT4lIFxuICBkcm9wX25hKHNocmlua2VkX2xvZzJGQylcblxuXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBwT3ZlciA9IGlmZWxzZShnZW5lICVpbiUgcHBPdmVyNCwgXFxwcE92ZXI0XFwsXG4gICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBwT3ZlcjMsIFxccHBPdmVyM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHBPdmVyMiwgXFxwcE92ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShnZW5lICVpbiUgcHBPdmVyMSwgXFxwcE92ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZ2VuZSAlaW4lIHBwT3ZlcjAsIFxccHBPdmVyMFxcLCBOQSkpKSkpKSAlPiVcbiAgZHJvcF9uYShwcE92ZXIpXG5gYGBcbmBgYCJ9 -->

```r
```r
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers
ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  drop_na(shrinked_log2FC)


temp <- temp %>% dplyr::mutate(
  ppOver = ifelse(gene %in% ppOver4, \ppOver4\,
                  ifelse(gene %in% ppOver3, \ppOver3\,
                         ifelse(gene %in% ppOver2, \ppOver2\,
                                ifelse(gene %in% ppOver1, \ppOver1\,
                                       ifelse(gene %in% ppOver0, \ppOver0\, NA)))))) %>%
  drop_na(ppOver)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### log2FC

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBHT2ZpZ0RpciA8LSBoZXJlKGZpZ0RpciwgXCIuLi9HT1wiKVxuIyBnZXRHTyhcInBwT3ZlcjRcIiwgR09maWdEaXIsIHBzT3ZlcjQpXG4jIGdldEdPKFwicHBPdmVyM1wiLCBHT2ZpZ0RpciwgcHNPdmVyMylcbiMgZ2V0R08oXCJwcE92ZXIyXCIsIEdPZmlnRGlyLCBwc092ZXIyKVxuIyBnZXRHTyhcInBwT3ZlcjFcIiwgR09maWdEaXIsIHBzT3ZlcjEpXG4jIGdldEdPKFwicHBPdmVyMFwiLCBHT2ZpZ0RpciwgcHNPdmVyMClcbiMgXG4jICMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBHTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKSlcbiMgR08xLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjEsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIikpXG4jIEdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFwiRU5TRU1CTFwiLCBvbnQgPSBcIkJQXCIpKVxuIyBHTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKSlcbiMgR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIikpXG4jIFxuIyBcbiMgc3Vic2V0MCA8LSBHTzAuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyMFwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyMVwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyMlwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MyA8LSBHTzMuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyM1wiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwicHNPdmVyNFwiKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgXG4jIFxuIyBHT2xpc3QgPC0gZmFjdG9yKGMoXCJHTzowMDA2Mzk3XCIsIFwiR086MDAwODM4MFwiLCBcIkdPOjAwMjI2MTNcIiwgXCJHTzowMDM0NDcwXCIsXG4jICAgICAgICAgICAgICAgICAgICBcIkdPOjAwMTYwNTVcIiwgXCJHTzowMDA3Mzg5XCIsIFwiR086MDA0ODU2MlwiLCBcIkdPOjAwNDUxNjVcIiwgXG4jICAgICAgICAgICAgICAgICAgICBcIkdPOjAwNzIwMDFcIiwgXCJHTzowMDA3NTE3XCIsIFwiR086MDA0ODcwNVwiLCBcIkdPOjAwMDMwMDJcIiwgXCJHTzowMDA5NDExXCIpKVxuIyBcbiMgZGF0YSA8LSBiaW5kX3Jvd3MoYmluZF9yb3dzKHN1YnNldDAsIHN1YnNldDEpLCBzdWJzZXQzKSAlPiVcbiMgICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuIyBcbiMgcCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IERlc2NyaXB0aW9uLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuIyAgIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuIyAgIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFwicmVkXCIsIGhpZ2ggPSBcImJsdWVcIiwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuIyAgIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiMgICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFwiLi5cIiwgXCJHT1wiLCBcIkdPX2dyb3Vwc19wcFwiKVxuIyBoZWlnaHQgPSAyXG4jIHdpZHRoID0gMy40XG4jIHN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIiksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5gYGAifQ== -->\n\n```r\n# GOfigDir <- here(figDir, \\../GO\\)\n# getGO(\\ppOver4\\, GOfigDir, psOver4)\n# getGO(\\ppOver3\\, GOfigDir, psOver3)\n# getGO(\\ppOver2\\, GOfigDir, psOver2)\n# getGO(\\ppOver1\\, GOfigDir, psOver1)\n# getGO(\\ppOver0\\, GOfigDir, psOver0)\n# \n# #####################\n# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# \n# \n# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver0\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver1\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver2\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver3\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver4\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# \n# \n# GOlist <- factor(c(\\GO:0006397\\, \\GO:0008380\\, \\GO:0022613\\, \\GO:0034470\\,\n#                    \\GO:0016055\\, \\GO:0007389\\, \\GO:0048562\\, \\GO:0045165\\, \n#                    \\GO:0072001\\, \\GO:0007517\\, \\GO:0048705\\, \\GO:0003002\\, \\GO:0009411\\))\n# \n# data <- bind_rows(bind_rows(subset0, subset1), subset3) %>%\n#   dplyr::filter(ID %in% GOlist)\n# \n# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + \n#   geom_point() + theme_bw() +\n#   scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n#   scale_size_continuous(range = c(0, 3)) +\n#   labs(x = NULL, y = NULL) +\n#   theme(axis.text = element_text(size = 6),  # Set axis text size\n#         axis.title = element_text(size = 6), # Set axis title size (if not removed)\n#         legend.text = element_text(size = 6), # Set legend text size\n#         legend.title = element_text(size = 6)) \n# \n# fileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pp\\)\n# height = 2\n# width = 3.4\n# svglite(paste0(fileName, \\.svg\\), height = height, width = width)\n# print(p)\n# dev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# GOfigDir <- here(figDir, \../GO\)
# getGO(\ppOver4\, GOfigDir, psOver4)
# getGO(\ppOver3\, GOfigDir, psOver3)
# getGO(\ppOver2\, GOfigDir, psOver2)
# getGO(\ppOver1\, GOfigDir, psOver1)
# getGO(\ppOver0\, GOfigDir, psOver0)
# 
# #####################
# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# 
# 
# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver0\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver1\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver2\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver3\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver4\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# 
# GOlist <- factor(c(\GO:0006397\, \GO:0008380\, \GO:0022613\, \GO:0034470\,
#                    \GO:0016055\, \GO:0007389\, \GO:0048562\, \GO:0045165\, 
#                    \GO:0072001\, \GO:0007517\, \GO:0048705\, \GO:0003002\, \GO:0009411\))
# 
# data <- bind_rows(bind_rows(subset0, subset1), subset3) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, \..\, \GO\, \GO_groups_pp\)
# height = 2
# width = 3.4
# svglite(paste0(fileName, \.svg\), height = height, width = width)
# print(p)
# dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBHT2ZpZ0RpciA8LSBoZXJlKGZpZ0RpciwgXFwuLi9HT1xcKVxuIyBnZXRHTyhcXHBwT3ZlcjRcXCwgR09maWdEaXIsIHBzT3ZlcjQpXG4jIGdldEdPKFxccHBPdmVyM1xcLCBHT2ZpZ0RpciwgcHNPdmVyMylcbiMgZ2V0R08oXFxwcE92ZXIyXFwsIEdPZmlnRGlyLCBwc092ZXIyKVxuIyBnZXRHTyhcXHBwT3ZlcjFcXCwgR09maWdEaXIsIHBzT3ZlcjEpXG4jIGdldEdPKFxccHBPdmVyMFxcLCBHT2ZpZ0RpciwgcHNPdmVyMClcbiMgXG4jICMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBHTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR08xLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjEsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIEdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpKVxuIyBHTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIFxuIyBcbiMgc3Vic2V0MCA8LSBHTzAuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMVxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMlxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MyA8LSBHTzMuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyM1xcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyNFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgXG4jIFxuIyBHT2xpc3QgPC0gZmFjdG9yKGMoXFxHTzowMDA2Mzk3XFwsIFxcR086MDAwODM4MFxcLCBcXEdPOjAwMjI2MTNcXCwgXFxHTzowMDM0NDcwXFwsXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwMTYwNTVcXCwgXFxHTzowMDA3Mzg5XFwsIFxcR086MDA0ODU2MlxcLCBcXEdPOjAwNDUxNjVcXCwgXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwNzIwMDFcXCwgXFxHTzowMDA3NTE3XFwsIFxcR086MDA0ODcwNVxcLCBcXEdPOjAwMDMwMDJcXCwgXFxHTzowMDA5NDExXFwpKVxuIyBcbiMgZGF0YSA8LSBiaW5kX3Jvd3MoYmluZF9yb3dzKHN1YnNldDAsIHN1YnNldDEpLCBzdWJzZXQzKSAlPiVcbiMgICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuIyBcbiMgcCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IERlc2NyaXB0aW9uLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuIyAgIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuIyAgIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFxccmVkXFwsIGhpZ2ggPSBcXGJsdWVcXCwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuIyAgIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiMgICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc19wcFxcKVxuIyBoZWlnaHQgPSAyXG4jIHdpZHRoID0gMy40XG4jIHN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\n# GOfigDir <- here(figDir, \\../GO\\)\n# getGO(\\ppOver4\\, GOfigDir, psOver4)\n# getGO(\\ppOver3\\, GOfigDir, psOver3)\n# getGO(\\ppOver2\\, GOfigDir, psOver2)\n# getGO(\\ppOver1\\, GOfigDir, psOver1)\n# getGO(\\ppOver0\\, GOfigDir, psOver0)\n# \n# #####################\n# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n# \n# \n# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver0\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver1\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver2\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver3\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\psOver4\\) %>%\n#   dplyr::mutate(\n#     gr = sapply(GeneRatio, function(x) {\n#       # Split the string by \\/\\\n#       parts <- unlist(strsplit(x, \\/\\))\n#       # Convert to numeric and perform the division\n#       as.numeric(parts[1]) / as.numeric(parts[2])\n#     })\n#   ) %>% dplyr::arrange(desc(gr))\n# \n# \n# GOlist <- factor(c(\\GO:0006397\\, \\GO:0008380\\, \\GO:0022613\\, \\GO:0034470\\,\n#                    \\GO:0016055\\, \\GO:0007389\\, \\GO:0048562\\, \\GO:0045165\\, \n#                    \\GO:0072001\\, \\GO:0007517\\, \\GO:0048705\\, \\GO:0003002\\, \\GO:0009411\\))\n# \n# data <- bind_rows(bind_rows(subset0, subset1), subset3) %>%\n#   dplyr::filter(ID %in% GOlist)\n# \n# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + \n#   geom_point() + theme_bw() +\n#   scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n#   scale_size_continuous(range = c(0, 3)) +\n#   labs(x = NULL, y = NULL) +\n#   theme(axis.text = element_text(size = 6),  # Set axis text size\n#         axis.title = element_text(size = 6), # Set axis title size (if not removed)\n#         legend.text = element_text(size = 6), # Set legend text size\n#         legend.title = element_text(size = 6)) \n# \n# fileName <- here(figDir, \\..\\, \\GO\\, \\GO_groups_pp\\)\n# height = 2\n# width = 3.4\n# svglite(paste0(fileName, \\.svg\\), height = height, width = width)\n# print(p)\n# dev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBHT2ZpZ0RpciA8LSBoZXJlKGZpZ0RpciwgXFwuLi9HT1xcKVxuIyBnZXRHTyhcXHBwT3ZlcjRcXCwgR09maWdEaXIsIHBzT3ZlcjQpXG4jIGdldEdPKFxccHBPdmVyM1xcLCBHT2ZpZ0RpciwgcHNPdmVyMylcbiMgZ2V0R08oXFxwcE92ZXIyXFwsIEdPZmlnRGlyLCBwc092ZXIyKVxuIyBnZXRHTyhcXHBwT3ZlcjFcXCwgR09maWdEaXIsIHBzT3ZlcjEpXG4jIGdldEdPKFxccHBPdmVyMFxcLCBHT2ZpZ0RpciwgcHNPdmVyMClcbiMgXG4jICMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBHTzAuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR08xLmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjEsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIEdPMi5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBwc092ZXIyLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpKVxuIyBHTzMuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gcHNPdmVyMywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbiMgR080LmRmIDwtIGFzLmRhdGEuZnJhbWUoZW5yaWNoR08oZ2VuZSA9IHBzT3ZlcjQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG4jIFxuIyBcbiMgc3Vic2V0MCA8LSBHTzAuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MSA8LSBHTzEuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMVxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MiA8LSBHTzIuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyMlxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0MyA8LSBHTzMuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyM1xcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgc3Vic2V0NCA8LSBHTzQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxccHNPdmVyNFxcKSAlPiVcbiMgICBkcGx5cjo6bXV0YXRlKFxuIyAgICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4jICAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuIyAgICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuIyAgICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiMgICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuIyAgICAgfSlcbiMgICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcbiMgXG4jIFxuIyBHT2xpc3QgPC0gZmFjdG9yKGMoXFxHTzowMDA2Mzk3XFwsIFxcR086MDAwODM4MFxcLCBcXEdPOjAwMjI2MTNcXCwgXFxHTzowMDM0NDcwXFwsXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwMTYwNTVcXCwgXFxHTzowMDA3Mzg5XFwsIFxcR086MDA0ODU2MlxcLCBcXEdPOjAwNDUxNjVcXCwgXG4jICAgICAgICAgICAgICAgICAgICBcXEdPOjAwNzIwMDFcXCwgXFxHTzowMDA3NTE3XFwsIFxcR086MDA0ODcwNVxcLCBcXEdPOjAwMDMwMDJcXCwgXFxHTzowMDA5NDExXFwpKVxuIyBcbiMgZGF0YSA8LSBiaW5kX3Jvd3MoYmluZF9yb3dzKHN1YnNldDAsIHN1YnNldDEpLCBzdWJzZXQzKSAlPiVcbiMgICBkcGx5cjo6ZmlsdGVyKElEICVpbiUgR09saXN0KVxuIyBcbiMgcCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IERlc2NyaXB0aW9uLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuIyAgIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgK1xuIyAgIHNjYWxlX2NvbG9yX2dyYWRpZW50KGxvdyA9IFxccmVkXFwsIGhpZ2ggPSBcXGJsdWVcXCwgbGltaXRzID0gYygwLCAwLjA1KSkgK1xuIyAgIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiMgICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcLi5cXCwgXFxHT1xcLCBcXEdPX2dyb3Vwc19wcFxcKVxuIyBoZWlnaHQgPSAyXG4jIHdpZHRoID0gMy40XG4jIHN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
# GOfigDir <- here(figDir, \../GO\)
# getGO(\ppOver4\, GOfigDir, psOver4)
# getGO(\ppOver3\, GOfigDir, psOver3)
# getGO(\ppOver2\, GOfigDir, psOver2)
# getGO(\ppOver1\, GOfigDir, psOver1)
# getGO(\ppOver0\, GOfigDir, psOver0)
# 
# #####################
# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
# 
# 
# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver0\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver1\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver2\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver3\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \psOver4\) %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by \/\
#       parts <- unlist(strsplit(x, \/\))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# 
# GOlist <- factor(c(\GO:0006397\, \GO:0008380\, \GO:0022613\, \GO:0034470\,
#                    \GO:0016055\, \GO:0007389\, \GO:0048562\, \GO:0045165\, 
#                    \GO:0072001\, \GO:0007517\, \GO:0048705\, \GO:0003002\, \GO:0009411\))
# 
# data <- bind_rows(bind_rows(subset0, subset1), subset3) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, \..\, \GO\, \GO_groups_pp\)
# height = 2
# width = 3.4
# svglite(paste0(fileName, \.svg\), height = height, width = width)
# print(p)
# dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



#### Grouping with P-P number
##### Grouping

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJuWlhSUWRtRnNWMmxzWTI5NElEd3RJR1oxYm1OMGFXOXVLR1JoZEdFc0lHZHliM1Z3TVN3Z1ozSnZkWEF5S1h0Y2JpTWdJQ0JrYVhOMFlXNWpaVEVnUEMwZ0tHUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvY0hOUGRtVnlJRDA5WjNKdmRYQXhLU0FwSkcxbFlXNWZaR2xtWmw5elkyOXlaVnh1SXlBZ0lHUnBjM1JoYm1ObE1pQThMU0FvWkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaHdjMDkyWlhJZ1BUMW5jbTkxY0RJcElDa2tiV1ZoYmw5a2FXWm1YM05qYjNKbFhHNGpJQ0FnZDJsc0lEd3RJSGRwYkdOdmVDNTBaWE4wS0dScGMzUmhibU5sTVN3Z1pHbHpkR0Z1WTJVeUtWeHVJeUFnSUhKbGRIVnliaWgzYVd3a2NDNTJZV3gxWlNsY2JpTWdmVnh1SXlCY2JpTWdjSE13TVNBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBc0lGd2ljSE5QZG1WeU1Gd2lMQ0JjSW5CelQzWmxjakZjSWlrc0lEVXBYRzRqSUhCek1USWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMQ0JjSW5CelQzWmxjakZjSWl3Z1hDSndjMDkyWlhJeVhDSXBMQ0ExS1Z4dUl5Qndjekl6SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0N3Z1hDSndjMDkyWlhJeVhDSXNJRndpY0hOUGRtVnlNMXdpS1N3Z05TbGNiaU1nY0hNek5DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXNJRndpY0hOUGRtVnlNMXdpTENCY0luQnpUM1psY2pSY0lpa3NJRFVwWEc0aklIQnpNalFnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaDBaVzF3TENCY0luQnpUM1psY2pKY0lpd2dYQ0p3YzA5MlpYSTBYQ0lwTENBMUtWeHVJeUJ3Y3pFMElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDd2dYQ0p3YzA5MlpYSXhYQ0lzSUZ3aWNITlBkbVZ5TkZ3aUtTd2dOU2xjYmlNZ2NITXdOQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEFzSUZ3aWNITlBkbVZ5TUZ3aUxDQmNJbkJ6VDNabGNqUmNJaWtzSURVcFhHNWNibHh1Y0NBOExTQm5aM0JzYjNRb2RHVnRjQ3dnWVdWektIZ2dQU0J3Y0U5MlpYSXNJSGtnUFNCdFpXRnVYMlJwWm1aZmMyTnZjbVVwS1NBcklHZGxiMjFmZG1sdmJHbHVLR0ZsY3lobWFXeHNJRDBnY0hCUGRtVnlLU3dnYzJodmR5NXNaV2RsYm1RZ1BTQkdRVXhUUlNrZ0sxeHVJQ0JuWlc5dFgySnZlSEJzYjNRb2QybGtkR2dnUFNBd0xqRXNJRzkxZEd4cFpYSXVjMmhoY0dVZ1BTQk9RU2tnS3lCMGFHVnRaVjlqYkdGemMybGpLQ2tnS3lCY2JpQWdjM1JoZEY5emRXMXRZWEo1S0dGbGN5aG5jbTkxY0NBOUlIQndUM1psY2lrc0lHWjFiaUE5SUcxbFlXNHNJR2RsYjIwZ1BTQmNJbkJ2YVc1MFhDSXNJSE5vWVhCbElEMGdNakVzSUhOcGVtVWdQU0F5TENCbWFXeHNJRDBnWENKeVpXUmNJaXdnWTI5c2IzSWdQU0JjSW1Kc1lXTnJYQ0lwSUN0Y2JpQWdaMlZ2YlY5b2JHbHVaU2g1YVc1MFpYSmpaWEIwSUQwZ01DbGNiaUFnSXlCaGJtNXZkR0YwWlNoY0luUmxlSFJjSWl3Z2VDQTlJREVzSUhrZ1BTQXdMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNJbkJ6TURFNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCek1ERXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkJ6TVRJNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCek1USXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkJ6TWpNNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCek1qTXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkJ6TXpRNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCek16UXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkJ6TWpRNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCek1qUXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkJ6TVRRNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCek1UUXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBaklDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkJ6TURRNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hCek1EUXBMQ0JjSWx4Y2Jsd2lLU3dnWEc0Z0lDTWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJRE1wWEc1Y2JpQWdYRzVtYVd4bFRtRnRaU0E4TFNCd1lYTjBaVEFvWENKa2FXWm1VMk52Y21WZlltRnljR3h2ZEY5d2NFZHliM1Z3WDBFME9EVmZkbk5mUkUxVFQxd2lLVnh1YUdWcFoyaDBJRHd0SUROY2JuZHBaSFJvSUR3dElETmNibkJ1Wnlob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNJaTV3Ym1kY0lpa3BMQ0J5WlhNZ1BTQTJNREFzSUhWdWFYUWdQU0JjSW1sdVhDSXNJR2hsYVdkb2RDQTlJR2hsYVdkb2RDd2dkMmxrZEdnZ1BTQjNhV1IwYUNsY2JuQnlhVzUwS0hBcFhHNWtaWFl1YjJabUtDbGNibk4yWjJ4cGRHVW9hR1Z5WlNobWFXZEVhWElzSUhCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWENJdWMzWm5YQ0lwS1N3Z0lHaGxhV2RvZENBOUlHaGxhV2RvZEN3Z2QybGtkR2dnUFNCM2FXUjBhQ2xjYm5CeWFXNTBLSEFwWEc1a1pYWXViMlptS0NsY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG4jIGdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuIyAgIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4jICAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBzT3ZlciA9PWdyb3VwMikgKSRtZWFuX2RpZmZfc2NvcmVcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxuIyBwczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbiMgcHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjJcXCksIDUpXG4jIHBzMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXIzXFwpLCA1KVxuIyBwczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIwXFwsIFxccHNPdmVyNFxcKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBwT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwcE92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcHBPdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKVxuICAjIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDAsIGxhYmVsID0gcGFzdGUwKFxccHMwMTogXFwsIGNvbnZQdmFsdWUocHMwMSksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMxMjogXFwsIGNvbnZQdmFsdWUocHMxMiksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMzNDogXFwsIGNvbnZQdmFsdWUocHMzNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyNDogXFwsIGNvbnZQdmFsdWUocHMyNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMxNDogXFwsIGNvbnZQdmFsdWUocHMxNCksIFxcXFxuXFwsXG4gICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMwNDogXFwsIGNvbnZQdmFsdWUocHMwNCksIFxcXFxuXFwpLCBcbiAgIyAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXGRpZmZTY29yZV9iYXJwbG90X3BwR3JvdXBfQTQ4NV92c19ETVNPXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# ps01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(temp, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(temp, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)


p <- ggplot(temp, aes(x = ppOver, y = mean_diff_score)) + geom_violin(aes(fill = ppOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = ppOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3)

  
fileName <- paste0(\diffScore_barplot_ppGroup_A485_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5Qm5aWFJRZG1Gc1YybHNZMjk0SUR3dElHWjFibU4wYVc5dUtHUmhkR0VzSUdkeWIzVndNU3dnWjNKdmRYQXlLWHRjYmlNZ0lDQmthWE4wWVc1alpURWdQQzBnS0dSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9jSE5QZG1WeUlEMDlaM0p2ZFhBeEtTQXBKRzFsWVc1ZlpHbG1abDl6WTI5eVpWeHVJeUFnSUdScGMzUmhibU5sTWlBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lod2MwOTJaWElnUFQxbmNtOTFjRElwSUNra2JXVmhibDlrYVdabVgzTmpiM0psWEc0aklDQWdkMmxzSUR3dElIZHBiR052ZUM1MFpYTjBLR1JwYzNSaGJtTmxNU3dnWkdsemRHRnVZMlV5S1Z4dUl5QWdJSEpsZEhWeWJpaDNhV3drY0M1MllXeDFaU2xjYmlNZ2ZWeHVJeUJjYmlNZ2NITXdNU0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEFzSUZ4Y2NITlBkbVZ5TUZ4Y0xDQmNYSEJ6VDNabGNqRmNYQ2tzSURVcFhHNGpJSEJ6TVRJZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xDQmNYSEJ6VDNabGNqRmNYQ3dnWEZ4d2MwOTJaWEl5WEZ3cExDQTFLVnh1SXlCd2N6SXpJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQ3dnWEZ4d2MwOTJaWEl5WEZ3c0lGeGNjSE5QZG1WeU0xeGNLU3dnTlNsY2JpTWdjSE16TkNBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBc0lGeGNjSE5QZG1WeU0xeGNMQ0JjWEhCelQzWmxjalJjWENrc0lEVXBYRzRqSUhCek1qUWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMQ0JjWEhCelQzWmxjakpjWEN3Z1hGeHdjMDkyWlhJMFhGd3BMQ0ExS1Z4dUl5QndjekUwSUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0N3Z1hGeHdjMDkyWlhJeFhGd3NJRnhjY0hOUGRtVnlORnhjS1N3Z05TbGNiaU1nY0hNd05DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXNJRnhjY0hOUGRtVnlNRnhjTENCY1hIQnpUM1psY2pSY1hDa3NJRFVwWEc1Y2JseHVjQ0E4TFNCblozQnNiM1FvZEdWdGNDd2dZV1Z6S0hnZ1BTQndjRTkyWlhJc0lIa2dQU0J0WldGdVgyUnBabVpmYzJOdmNtVXBLU0FySUdkbGIyMWZkbWx2YkdsdUtHRmxjeWhtYVd4c0lEMGdjSEJQZG1WeUtTd2djMmh2ZHk1c1pXZGxibVFnUFNCR1FVeFRSU2tnSzF4dUlDQm5aVzl0WDJKdmVIQnNiM1FvZDJsa2RHZ2dQU0F3TGpFc0lHOTFkR3hwWlhJdWMyaGhjR1VnUFNCT1FTa2dLeUIwYUdWdFpWOWpiR0Z6YzJsaktDa2dLeUJjYmlBZ2MzUmhkRjl6ZFcxdFlYSjVLR0ZsY3lobmNtOTFjQ0E5SUhCd1QzWmxjaWtzSUdaMWJpQTlJRzFsWVc0c0lHZGxiMjBnUFNCY1hIQnZhVzUwWEZ3c0lITm9ZWEJsSUQwZ01qRXNJSE5wZW1VZ1BTQXlMQ0JtYVd4c0lEMGdYRnh5WldSY1hDd2dZMjlzYjNJZ1BTQmNYR0pzWVdOclhGd3BJQ3RjYmlBZ1oyVnZiVjlvYkdsdVpTaDVhVzUwWlhKalpYQjBJRDBnTUNsY2JpQWdJeUJoYm01dmRHRjBaU2hjWEhSbGVIUmNYQ3dnZUNBOUlERXNJSGtnUFNBd0xDQnNZV0psYkNBOUlIQmhjM1JsTUNoY1hIQnpNREU2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEJ6TURFcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQnpNVEk2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEJ6TVRJcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQnpNak02SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEJ6TWpNcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQnpNelE2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEJ6TXpRcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQnpNalE2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEJ6TWpRcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQnpNVFE2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEJ6TVRRcExDQmNYRnhjYmx4Y0xGeHVJQ0FqSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQnpNRFE2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEJ6TURRcExDQmNYRnhjYmx4Y0tTd2dYRzRnSUNNZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlETXBYRzVjYmlBZ1hHNW1hV3hsVG1GdFpTQThMU0J3WVhOMFpUQW9YRnhrYVdabVUyTnZjbVZmWW1GeWNHeHZkRjl3Y0VkeWIzVndYMEUwT0RWZmRuTmZSRTFUVDF4Y0tWeHVhR1ZwWjJoMElEd3RJRE5jYm5kcFpIUm9JRHd0SUROY2JuQnVaeWhvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY1hDNXdibWRjWENrcExDQnlaWE1nUFNBMk1EQXNJSFZ1YVhRZ1BTQmNYR2x1WEZ3c0lHaGxhV2RvZENBOUlHaGxhV2RvZEN3Z2QybGtkR2dnUFNCM2FXUjBhQ2xjYm5CeWFXNTBLSEFwWEc1a1pYWXViMlptS0NsY2JuTjJaMnhwZEdVb2FHVnlaU2htYVdkRWFYSXNJSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYRnd1YzNablhGd3BLU3dnSUdobGFXZG9kQ0E5SUdobGFXZG9kQ3dnZDJsa2RHZ2dQU0IzYVdSMGFDbGNibkJ5YVc1MEtIQXBYRzVrWlhZdWIyWm1LQ2xjYm1CZ1lGeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYGBgclxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocHNPdmVyID09Z3JvdXAxKSApJG1lYW5fZGlmZl9zY29yZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4jICAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuIyAgIHJldHVybih3aWwkcC52YWx1ZSlcbiMgfVxuIyBcbiMgcHMwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjFcXCksIDUpXG4jIHBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIyXFwsIFxccHNPdmVyM1xcKSwgNSlcbiMgcHMzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyM1xcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIxXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjRcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBwcE92ZXIsIHkgPSBtZWFuX2RpZmZfc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHBPdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBwT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTI6IFxcLCBjb252UHZhbHVlKHBzMTIpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjM6IFxcLCBjb252UHZhbHVlKHBzMjMpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjQ6IFxcLCBjb252UHZhbHVlKHBzMjQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMDQ6IFxcLCBjb252UHZhbHVlKHBzMDQpLCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxkaWZmU2NvcmVfYmFycGxvdF9wcEdyb3VwX0E0ODVfdnNfRE1TT1xcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIocHNPdmVyID09Z3JvdXAxKSApJG1lYW5fZGlmZl9zY29yZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4jICAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuIyAgIHJldHVybih3aWwkcC52YWx1ZSlcbiMgfVxuIyBcbiMgcHMwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjFcXCksIDUpXG4jIHBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIyXFwsIFxccHNPdmVyM1xcKSwgNSlcbiMgcHMzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyM1xcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwc092ZXIxXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjRcXCksIDUpXG5cblxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBwcE92ZXIsIHkgPSBtZWFuX2RpZmZfc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcHBPdmVyKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgKyBcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IHBwT3ZlciksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcbiAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTI6IFxcLCBjb252UHZhbHVlKHBzMTIpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjM6IFxcLCBjb252UHZhbHVlKHBzMjMpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMjQ6IFxcLCBjb252UHZhbHVlKHBzMjQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMDQ6IFxcLCBjb252UHZhbHVlKHBzMDQpLCBcXFxcblxcKSwgXG4gICMgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxkaWZmU2NvcmVfYmFycGxvdF9wcEdyb3VwX0E0ODVfdnNfRE1TT1xcKVxuaGVpZ2h0IDwtIDNcbndpZHRoIDwtIDNcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# ps01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(temp, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(temp, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)


p <- ggplot(temp, aes(x = ppOver, y = mean_diff_score)) + geom_violin(aes(fill = ppOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = ppOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3)

  
fileName <- paste0(\diffScore_barplot_ppGroup_A485_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### (SKIP) GO for each group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuI1xuIyAgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBzT3ZlciA9PWdyb3VwMSkgKSRsb2cyRm9sZENoYW5nZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG5cbnRlbXBEb3duIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPCAwKVxuIyAgXG4jIHBzMDEgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXCJwc092ZXIwXCIsIFwicHNPdmVyMVwiKSwgNSlcbiMgcHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBzT3ZlcjFcIiwgXCJwc092ZXIyXCIpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFwicHNPdmVyMlwiLCBcInBzT3ZlcjNcIiksIDUpXG4jIHBzMzQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXCJwc092ZXIzXCIsIFwicHNPdmVyNFwiKSwgNSlcbiMgcHMyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcInBzT3ZlcjJcIiwgXCJwc092ZXI0XCIpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFwicHNPdmVyMVwiLCBcInBzT3ZlcjRcIiksIDUpXG4jIHBzMDQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXCJwc092ZXIwXCIsIFwicHNPdmVyNFwiKSwgNSlcblxuXG5cbnAgPC0gZ2dwbG90KHRlbXBEb3duLCBhZXMoeCA9IHBwT3ZlciwgeSA9IGxvZzJGb2xkQ2hhbmdlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IHBwT3ZlciksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBwcE92ZXIpLCBmdW4gPSBtZWFuLCBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFwicmVkXCIsIGNvbG9yID0gXCJibGFja1wiKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApXG4gICMgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAxLCB5ID0gLTAuNSwgbGFiZWwgPSBwYXN0ZTAoXCJwczAxOiBcIiwgY29udlB2YWx1ZShwczAxKSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczEyOiBcIiwgY29udlB2YWx1ZShwczEyKSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczIzOiBcIiwgY29udlB2YWx1ZShwczIzKSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczM0OiBcIiwgY29udlB2YWx1ZShwczM0KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczI0OiBcIiwgY29udlB2YWx1ZShwczI0KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczE0OiBcIiwgY29udlB2YWx1ZShwczE0KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczA0OiBcIiwgY29udlB2YWx1ZShwczA0KSwgXCJcXG5cIiksIFxuICAjICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygtMSwgMCkpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJsb2cyRkNfYmFycGxvdF9wcEdyb3VwX0E0ODVfdnNfRE1TT19kb3duXCIpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cblxudGVtcFVwIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPiAwKVxuIyAgXG4jIHBzMDEgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFwicHNPdmVyMFwiLCBcInBzT3ZlcjFcIiksIDUpXG4jIHBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFwicHNPdmVyMVwiLCBcInBzT3ZlcjJcIiksIDUpXG4jIHBzMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFwicHNPdmVyMlwiLCBcInBzT3ZlcjNcIiksIDUpXG4jIHBzMzQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFwicHNPdmVyM1wiLCBcInBzT3ZlcjRcIiksIDUpXG4jIHBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFwicHNPdmVyMlwiLCBcInBzT3ZlcjRcIiksIDUpXG4jIHBzMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFwicHNPdmVyMVwiLCBcInBzT3ZlcjRcIiksIDUpXG4jIHBzMDQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFwicHNPdmVyMFwiLCBcInBzT3ZlcjRcIiksIDUpXG4jIFxuIyBcblxuXG5cbnAgPC0gZ2dwbG90KHRlbXBVcCwgYWVzKHggPSBwcE92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwcE92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcHBPdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcInJlZFwiLCBjb2xvciA9IFwiYmxhY2tcIikgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKVxuICAjIGFubm90YXRlKFwidGV4dFwiLCB4ID0gMSwgeSA9IDAuNSwgbGFiZWwgPSBwYXN0ZTAoXCJwczAxOiBcIiwgY29udlB2YWx1ZShwczAxKSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczEyOiBcIiwgY29udlB2YWx1ZShwczEyKSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczIzOiBcIiwgY29udlB2YWx1ZShwczIzKSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczM0OiBcIiwgY29udlB2YWx1ZShwczM0KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczI0OiBcIiwgY29udlB2YWx1ZShwczI0KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczE0OiBcIiwgY29udlB2YWx1ZShwczE0KSwgXCJcXG5cIixcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczA0OiBcIiwgY29udlB2YWx1ZShwczA0KSwgXCJcXG5cIiksIFxuICAjICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygwLCAxKSlcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcImxvZzJGQ19iYXJwbG90X3BwR3JvdXBfQTQ4NV92c19ETVNPX3VwXCIpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgIn0= -->\n\n```r\n#\n#  getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n#  \n# ps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\n# ps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\n# ps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\n# ps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\n# ps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\n# ps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n# ps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\n\np <- ggplot(tempDown, aes(x = ppOver, y = log2FoldChange)) + geom_violin(aes(fill = ppOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = ppOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n  #                                               \\ps12: \\, convPvalue(ps12), \\\\n\\,\n  #                                               \\ps23: \\, convPvalue(ps23), \\\\n\\,\n  #                                               \\ps34: \\, convPvalue(ps34), \\\\n\\,\n  #                                               \\ps24: \\, convPvalue(ps24), \\\\n\\,\n  #                                               \\ps14: \\, convPvalue(ps14), \\\\n\\,\n  #                                               \\ps04: \\, convPvalue(ps04), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))\n\n  \nfileName <- paste0(\\log2FC_barplot_ppGroup_A485_vs_DMSO_down\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n#  \n# ps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\n# ps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\n# ps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\n# ps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\n# ps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\n# ps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\n# ps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n# \n# \n\n\n\np <- ggplot(tempUp, aes(x = ppOver, y = log2FoldChange)) + geom_violin(aes(fill = ppOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = ppOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n  #                                               \\ps12: \\, convPvalue(ps12), \\\\n\\,\n  #                                               \\ps23: \\, convPvalue(ps23), \\\\n\\,\n  #                                               \\ps34: \\, convPvalue(ps34), \\\\n\\,\n  #                                               \\ps24: \\, convPvalue(ps24), \\\\n\\,\n  #                                               \\ps14: \\, convPvalue(ps14), \\\\n\\,\n  #                                               \\ps04: \\, convPvalue(ps04), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_ppGroup_A485_vs_DMSO_up\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
#
#  getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
#  
# ps01 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(tempDown, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver4\), 5)



p <- ggplot(tempDown, aes(x = ppOver, y = log2FoldChange)) + geom_violin(aes(fill = ppOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = ppOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = -0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0(\log2FC_barplot_ppGroup_A485_vs_DMSO_down\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
#  
# ps01 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(tempUp, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver4\), 5)
# 
# 



p <- ggplot(tempUp, aes(x = ppOver, y = log2FoldChange)) + geom_violin(aes(fill = ppOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = ppOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_ppGroup_A485_vs_DMSO_up\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuI1xuIyAgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBzT3ZlciA9PWdyb3VwMSkgKSRsb2cyRm9sZENoYW5nZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG5cbnRlbXBEb3duIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPCAwKVxuIyAgXG4jIHBzMDEgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbiMgcHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjNcXCksIDUpXG4jIHBzMzQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMDQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIwXFwsIFxccHNPdmVyNFxcKSwgNSlcblxuXG5cbnAgPC0gZ2dwbG90KHRlbXBEb3duLCBhZXMoeCA9IHBwT3ZlciwgeSA9IGxvZzJGb2xkQ2hhbmdlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IHBwT3ZlciksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBwcE92ZXIpLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApXG4gICMgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gLTAuNSwgbGFiZWwgPSBwYXN0ZTAoXFxwczAxOiBcXCwgY29udlB2YWx1ZShwczAxKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczIzOiBcXCwgY29udlB2YWx1ZShwczIzKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczM0OiBcXCwgY29udlB2YWx1ZShwczM0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczE0OiBcXCwgY29udlB2YWx1ZShwczE0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygtMSwgMCkpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxsb2cyRkNfYmFycGxvdF9wcEdyb3VwX0E0ODVfdnNfRE1TT19kb3duXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cblxudGVtcFVwIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPiAwKVxuIyAgXG4jIHBzMDEgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjFcXCksIDUpXG4jIHBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjJcXCksIDUpXG4jIHBzMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjNcXCksIDUpXG4jIHBzMzQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyM1xcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMDQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIFxuIyBcblxuXG5cbnAgPC0gZ2dwbG90KHRlbXBVcCwgYWVzKHggPSBwcE92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwcE92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcHBPdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKVxuICAjIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDAuNSwgbGFiZWwgPSBwYXN0ZTAoXFxwczAxOiBcXCwgY29udlB2YWx1ZShwczAxKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczIzOiBcXCwgY29udlB2YWx1ZShwczIzKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczM0OiBcXCwgY29udlB2YWx1ZShwczM0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczE0OiBcXCwgY29udlB2YWx1ZShwczE0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygwLCAxKSlcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXGxvZzJGQ19iYXJwbG90X3BwR3JvdXBfQTQ4NV92c19ETVNPX3VwXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n#\n#  getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange\n#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n\ntempDown <- temp %>% dplyr::filter(log2FoldChange < 0)\n#  \n# ps01 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver1\\), 5)\n# ps12 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver2\\), 5)\n# ps23 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver3\\), 5)\n# ps34 <- round(getPvalWilcox(tempDown, \\psOver3\\, \\psOver4\\), 5)\n# ps24 <- round(getPvalWilcox(tempDown, \\psOver2\\, \\psOver4\\), 5)\n# ps14 <- round(getPvalWilcox(tempDown, \\psOver1\\, \\psOver4\\), 5)\n# ps04 <- round(getPvalWilcox(tempDown, \\psOver0\\, \\psOver4\\), 5)\n\n\n\np <- ggplot(tempDown, aes(x = ppOver, y = log2FoldChange)) + geom_violin(aes(fill = ppOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = ppOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = -0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n  #                                               \\ps12: \\, convPvalue(ps12), \\\\n\\,\n  #                                               \\ps23: \\, convPvalue(ps23), \\\\n\\,\n  #                                               \\ps34: \\, convPvalue(ps34), \\\\n\\,\n  #                                               \\ps24: \\, convPvalue(ps24), \\\\n\\,\n  #                                               \\ps14: \\, convPvalue(ps14), \\\\n\\,\n  #                                               \\ps04: \\, convPvalue(ps04), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))\n\n  \nfileName <- paste0(\\log2FC_barplot_ppGroup_A485_vs_DMSO_down\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\ntempUp <- temp %>% dplyr::filter(log2FoldChange > 0)\n#  \n# ps01 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver1\\), 5)\n# ps12 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver2\\), 5)\n# ps23 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver3\\), 5)\n# ps34 <- round(getPvalWilcox(tempUp, \\psOver3\\, \\psOver4\\), 5)\n# ps24 <- round(getPvalWilcox(tempUp, \\psOver2\\, \\psOver4\\), 5)\n# ps14 <- round(getPvalWilcox(tempUp, \\psOver1\\, \\psOver4\\), 5)\n# ps04 <- round(getPvalWilcox(tempUp, \\psOver0\\, \\psOver4\\), 5)\n# \n# \n\n\n\np <- ggplot(tempUp, aes(x = ppOver, y = log2FoldChange)) + geom_violin(aes(fill = ppOver), show.legend = FALSE) +\n  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + \n  stat_summary(aes(group = ppOver), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  geom_hline(yintercept = 0)\n  # annotate(\\text\\, x = 1, y = 0.5, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n  #                                               \\ps12: \\, convPvalue(ps12), \\\\n\\,\n  #                                               \\ps23: \\, convPvalue(ps23), \\\\n\\,\n  #                                               \\ps34: \\, convPvalue(ps34), \\\\n\\,\n  #                                               \\ps24: \\, convPvalue(ps24), \\\\n\\,\n  #                                               \\ps14: \\, convPvalue(ps14), \\\\n\\,\n  #                                               \\ps04: \\, convPvalue(ps04), \\\\n\\), \n  #          color = \\black\\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))\n\n  \nfileName <- paste0(\\log2FC_barplot_ppGroup_A485_vs_DMSO_up\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuI1xuIyAgZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4jICAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHBzT3ZlciA9PWdyb3VwMSkgKSRsb2cyRm9sZENoYW5nZVxuIyAgIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwc092ZXIgPT1ncm91cDIpICkkbG9nMkZvbGRDaGFuZ2VcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG5cbnRlbXBEb3duIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPCAwKVxuIyAgXG4jIHBzMDEgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIwXFwsIFxccHNPdmVyMVxcKSwgNSlcbiMgcHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjFcXCwgXFxwc092ZXIyXFwpLCA1KVxuIyBwczIzIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjNcXCksIDUpXG4jIHBzMzQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIzXFwsIFxccHNPdmVyNFxcKSwgNSlcbiMgcHMyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXBEb3duLCBcXHBzT3ZlcjJcXCwgXFxwc092ZXI0XFwpLCA1KVxuIyBwczE0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcERvd24sIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMDQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wRG93biwgXFxwc092ZXIwXFwsIFxccHNPdmVyNFxcKSwgNSlcblxuXG5cbnAgPC0gZ2dwbG90KHRlbXBEb3duLCBhZXMoeCA9IHBwT3ZlciwgeSA9IGxvZzJGb2xkQ2hhbmdlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IHBwT3ZlciksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgdGhlbWVfY2xhc3NpYygpICsgXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBwcE92ZXIpLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApXG4gICMgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gLTAuNSwgbGFiZWwgPSBwYXN0ZTAoXFxwczAxOiBcXCwgY29udlB2YWx1ZShwczAxKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczIzOiBcXCwgY29udlB2YWx1ZShwczIzKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczM0OiBcXCwgY29udlB2YWx1ZShwczM0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczE0OiBcXCwgY29udlB2YWx1ZShwczE0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygtMSwgMCkpXG5cbiAgXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxsb2cyRkNfYmFycGxvdF9wcEdyb3VwX0E0ODVfdnNfRE1TT19kb3duXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cblxudGVtcFVwIDwtIHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIobG9nMkZvbGRDaGFuZ2UgPiAwKVxuIyAgXG4jIHBzMDEgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjFcXCksIDUpXG4jIHBzMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjJcXCksIDUpXG4jIHBzMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjNcXCksIDUpXG4jIHBzMzQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyM1xcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyMlxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyMVxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIHBzMDQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wVXAsIFxccHNPdmVyMFxcLCBcXHBzT3ZlcjRcXCksIDUpXG4jIFxuIyBcblxuXG5cbnAgPC0gZ2dwbG90KHRlbXBVcCwgYWVzKHggPSBwcE92ZXIsIHkgPSBsb2cyRm9sZENoYW5nZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBwcE92ZXIpLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIFxuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gcHBPdmVyKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwKVxuICAjIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDAuNSwgbGFiZWwgPSBwYXN0ZTAoXFxwczAxOiBcXCwgY29udlB2YWx1ZShwczAxKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczIzOiBcXCwgY29udlB2YWx1ZShwczIzKSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczM0OiBcXCwgY29udlB2YWx1ZShwczM0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczE0OiBcXCwgY29udlB2YWx1ZShwczE0KSwgXFxcXG5cXCxcbiAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygwLCAxKSlcblxuICBcbmZpbGVOYW1lIDwtIHBhc3RlMChcXGxvZzJGQ19iYXJwbG90X3BwR3JvdXBfQTQ4NV92c19ETVNPX3VwXFwpXG5oZWlnaHQgPC0gM1xud2lkdGggPC0gM1xucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
#
#  getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
#  
# ps01 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(tempDown, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(tempDown, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(tempDown, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(tempDown, \psOver0\, \psOver4\), 5)



p <- ggplot(tempDown, aes(x = ppOver, y = log2FoldChange)) + geom_violin(aes(fill = ppOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = ppOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = -0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0(\log2FC_barplot_ppGroup_A485_vs_DMSO_down\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
#  
# ps01 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver1\), 5)
# ps12 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver2\), 5)
# ps23 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver3\), 5)
# ps34 <- round(getPvalWilcox(tempUp, \psOver3\, \psOver4\), 5)
# ps24 <- round(getPvalWilcox(tempUp, \psOver2\, \psOver4\), 5)
# ps14 <- round(getPvalWilcox(tempUp, \psOver1\, \psOver4\), 5)
# ps04 <- round(getPvalWilcox(tempUp, \psOver0\, \psOver4\), 5)
# 
# 



p <- ggplot(tempUp, aes(x = ppOver, y = log2FoldChange)) + geom_violin(aes(fill = ppOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = ppOver), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  geom_hline(yintercept = 0)
  # annotate(\text\, x = 1, y = 0.5, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
  #                                               \ps12: \, convPvalue(ps12), \\n\,
  #                                               \ps23: \, convPvalue(ps23), \\n\,
  #                                               \ps34: \, convPvalue(ps34), \\n\,
  #                                               \ps24: \, convPvalue(ps24), \\n\,
  #                                               \ps14: \, convPvalue(ps14), \\n\,
  #                                               \ps04: \, convPvalue(ps04), \\n\), 
  #          color = \black\, hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0(\log2FC_barplot_ppGroup_A485_vs_DMSO_up\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### loop score

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n# IMPORTING GENE ANNO DATA FOR P-N LOOPS\nname <- \"chromo_cons_annoHierarchy\"\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                 diffCutoff = 0.2,\n                                 annoList = c(\"P-P\", \"P-E\", \"P-S\", \"P-X\")) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27, 28))\n\ndata <- fread(here(consensusDir, paste0(name, \".tsv\"))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>%\n  dplyr::mutate(binSize = end1 - start1,\n                adj_start1 = ifelse(binSize == 5000, start1,\n                                    ifelse(binSize == 10000, start1,\n                                           start1 + 10000)),\n                adj_end1 = adj_start1 + 5000,\n                adj_start2 = ifelse(binSize == 5000, start2,\n                                    ifelse(binSize == 10000, start2,\n                                           start2 + 10000)),\n                adj_end2 = adj_start2 + 5000,\n                anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \"_\"),\n                anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \"_\"))\n\n# data <- fread(here(consensusDir, paste0(name, \".tsv\"))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>% \n#   dplyr::mutate(binSize = end1 - start1,\n#                 adj_start1 = ifelse(binSize == 5000, start1,\n#                                     ifelse(binSize == 10000, start1+5000,\n#                                            start1 + 10000)),\n#                 adj_end1 = adj_start1 + 5000,\n#                 adj_start2 = ifelse(binSize == 5000, start2,\n#                                     ifelse(binSize == 10000, start2 + 5000,\n#                                            start2 + 10000)),\n#                 adj_end2 = adj_start2 + 5000,\n#                 anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \"_\"),\n#                 anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \"_\"))\n\ndata.reg <- data %>% dplyr::filter(Anno2 %in% c(\"P-P\", \"P-E\", \"P-S\", \"P-X\", \"E-E\", \"E-S\", \"E-X\"))\n\n## Graph\n#install.packages(\"igraph\")\nlibrary(igraph)\n\n# To be able to construct a graph, each anchor need to have same resolution.\n# Shink the size to 10 kb\n# If the anchor is 25kb, choose the middle 5kb bin\n# If the anchor is 10kb, choose the left 5kb bin\n\ngraph <- graph_from_data_frame(data.reg %>% dplyr::select(anchor1, anchor2))\ncomponents <- components(graph)\ndata.reg$hub <- components$membership[data.reg$anchor1]\n\ntemp.bedpe <- data.reg %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \"_regulatory_5kbAdj.bedpe\")), \n       col.names = FALSE,row.names = FALSE, sep = \"\\t\")  \n\nhubNum <- data.reg %>% group_by(hub) %>% summarise(count = n())\n\n# Hub size distribution\np <- ggplot(hubNum, aes(x = count)) + geom_histogram(binwidth  = 1) + theme_classic() + \n  scale_y_log10()\n\nsvglite(here(figDir, \"hub_size_distribution.svg\"), height = 2, width = 2)\nprint(p)\ndev.off()\n\ndata.reg <- data.reg %>% dplyr::left_join(hubNum, by = \"hub\") \ndata.reg <- data.reg %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \"_\"))\n\n# Exporting regulatory loops with specific hub size\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 3) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \"_regulatory_5kbAdj_hub3.bedpe\")), \n       col.names = FALSE,row.names = FALSE, sep = \"\\t\")  \n\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 5) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \"_regulatory_5kbAdj_hub5.bedpe\")), \n       col.names = FALSE,row.names = FALSE, sep = \"\\t\")\n\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 10) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \"_regulatory_5kbAdj_hub10.bedpe\")), \n       col.names = FALSE,row.names = FALSE, sep = \"\\t\")\n\n\n# Adding gene annotation to hubs\ngenePeakPair <- geneAnnoData %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \"_\")) %>% dplyr::select(peakID, gene)\ndata.reg <- data.reg %>% dplyr::left_join(genePeakPair, by = \"peakID\")\n\n# During unnesting, E-N loops without gene annotated are removed\ndata.reg <- data.reg %>% unnest(gene) %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \"group1\",\n                 ifelse(gene %in% gene.group2, \"group2\",\n                        ifelse(gene %in% gene.group3, \"group3\",\n                               ifelse(gene %in% gene.group4, \"group4\",\n                                      ifelse(gene %in% gene.group5, \"group5\",\n                                             ifelse(gene %in% gene.group6, \"group6\",\n                                                    ifelse(gene %in% gene.group7, \"group7\",\n                                                           ifelse(gene %in% gene.group8, \"group8\",\n                                                                  ifelse(gene %in% gene.group9, \"group9\", NA)))))))))\n)\n\n\ntemp <- data.reg %>% dplyr::select(gene, hub, count, group) %>%\n  group_by(gene) %>% slice_max(count, with_ties = FALSE) %>%\n  dplyr::filter(group %in% c(\"group1\", \"group2\", \"group5\", \"group8\"))\n\n\n# TEMP START\n# TEMP START\ngeneList.group1 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\"))\ngeneList.group1.temp <- geneList.group1 %>% dplyr::left_join(temp, by = c(\"gene\"))\n# TEMP END\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$count\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$count\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\npv12 <- round(getPvalWilcox(tempSum,\"group1\", \"group2\"), 5)\npv15 <- round(getPvalWilcox(tempSum,\"group1\", \"group5\"), 5)\npv18 <- round(getPvalWilcox(tempSum,\"group1\", \"group8\"), 5)\npv25 <- round(getPvalWilcox(tempSum,\"group2\", \"group5\"), 5)\npv28 <- round(getPvalWilcox(tempSum,\"group2\", \"group8\"), 5)\npv58 <- round(getPvalWilcox(tempSum,\"group5\", \"group8\"), 5)\n\n\np <- ggplot(temp, aes(x = group, y = count, fill = group)) + \n  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() + \n    scale_y_continuous(breaks = seq(0, 30, by = 5), limits = c(0, 30)) + \n\n  stat_summary(aes(group = group), fun = mean, geom = \"point\", shape = 21, size = 2, fill = \"red\", color = \"black\")  +\n  annotate(\"text\", x = 1, y = 3, label = paste0(\"pv12: \", pv12, \"\\n\",\n                                                \"pv15: \", pv15, \"\\n\",\n                                                \"pv18: \", pv18, \"\\n\",\n                                                \"pv25: \", pv25, \"\\n\",\n                                                \"pv28: \", pv28, \"\\n\",\n                                                \"pv58: \", pv58, \"\\n\"), \n           color = \"black\", hjust = 0, size = 1) +  theme(legend.position = \"none\")\n\n\nfileName <- paste0(\"countHub_barplot_diffGroup_dTAG_vs_DMSO\")\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n```"} -->\n\n```r\n# IMPORTING GENE ANNO DATA FOR P-N LOOPS\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                 diffCutoff = 0.2,\n                                 annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27, 28))\n\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>%\n  dplyr::mutate(binSize = end1 - start1,\n                adj_start1 = ifelse(binSize == 5000, start1,\n                                    ifelse(binSize == 10000, start1,\n                                           start1 + 10000)),\n                adj_end1 = adj_start1 + 5000,\n                adj_start2 = ifelse(binSize == 5000, start2,\n                                    ifelse(binSize == 10000, start2,\n                                           start2 + 10000)),\n                adj_end2 = adj_start2 + 5000,\n                anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \\_\\),\n                anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \\_\\))\n\n# data <- fread(here(consensusDir, paste0(name, \\.tsv\\))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>% \n#   dplyr::mutate(binSize = end1 - start1,\n#                 adj_start1 = ifelse(binSize == 5000, start1,\n#                                     ifelse(binSize == 10000, start1+5000,\n#                                            start1 + 10000)),\n#                 adj_end1 = adj_start1 + 5000,\n#                 adj_start2 = ifelse(binSize == 5000, start2,\n#                                     ifelse(binSize == 10000, start2 + 5000,\n#                                            start2 + 10000)),\n#                 adj_end2 = adj_start2 + 5000,\n#                 anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \\_\\),\n#                 anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \\_\\))\n\ndata.reg <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\, \\E-E\\, \\E-S\\, \\E-X\\))\n\n## Graph\n#install.packages(\\igraph\\)\nlibrary(igraph)\n\n# To be able to construct a graph, each anchor need to have same resolution.\n# Shink the size to 10 kb\n# If the anchor is 25kb, choose the middle 5kb bin\n# If the anchor is 10kb, choose the left 5kb bin\n\ngraph <- graph_from_data_frame(data.reg %>% dplyr::select(anchor1, anchor2))\ncomponents <- components(graph)\ndata.reg$hub <- components$membership[data.reg$anchor1]\n\ntemp.bedpe <- data.reg %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)  \n\nhubNum <- data.reg %>% group_by(hub) %>% summarise(count = n())\n\n# Hub size distribution\np <- ggplot(hubNum, aes(x = count)) + geom_histogram(binwidth  = 1) + theme_classic() + \n  scale_y_log10()\n\nsvglite(here(figDir, \\hub_size_distribution.svg\\), height = 2, width = 2)\nprint(p)\ndev.off()\n\ndata.reg <- data.reg %>% dplyr::left_join(hubNum, by = \\hub\\) \ndata.reg <- data.reg %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n# Exporting regulatory loops with specific hub size\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 3) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj_hub3.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)  \n\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 5) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj_hub5.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)\n\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 10) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj_hub10.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)\n\n\n# Adding gene annotation to hubs\ngenePeakPair <- geneAnnoData %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \\_\\)) %>% dplyr::select(peakID, gene)\ndata.reg <- data.reg %>% dplyr::left_join(genePeakPair, by = \\peakID\\)\n\n# During unnesting, E-N loops without gene annotated are removed\ndata.reg <- data.reg %>% unnest(gene) %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\,\n                        ifelse(gene %in% gene.group3, \\group3\\,\n                               ifelse(gene %in% gene.group4, \\group4\\,\n                                      ifelse(gene %in% gene.group5, \\group5\\,\n                                             ifelse(gene %in% gene.group6, \\group6\\,\n                                                    ifelse(gene %in% gene.group7, \\group7\\,\n                                                           ifelse(gene %in% gene.group8, \\group8\\,\n                                                                  ifelse(gene %in% gene.group9, \\group9\\, NA)))))))))\n)\n\n\ntemp <- data.reg %>% dplyr::select(gene, hub, count, group) %>%\n  group_by(gene) %>% slice_max(count, with_ties = FALSE) %>%\n  dplyr::filter(group %in% c(\\group1\\, \\group2\\, \\group5\\, \\group8\\))\n\n\n# TEMP START\n# TEMP START\ngeneList.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))\ngeneList.group1.temp <- geneList.group1 %>% dplyr::left_join(temp, by = c(\\gene\\))\n# TEMP END\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$count\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$count\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\npv12 <- round(getPvalWilcox(tempSum,\\group1\\, \\group2\\), 5)\npv15 <- round(getPvalWilcox(tempSum,\\group1\\, \\group5\\), 5)\npv18 <- round(getPvalWilcox(tempSum,\\group1\\, \\group8\\), 5)\npv25 <- round(getPvalWilcox(tempSum,\\group2\\, \\group5\\), 5)\npv28 <- round(getPvalWilcox(tempSum,\\group2\\, \\group8\\), 5)\npv58 <- round(getPvalWilcox(tempSum,\\group5\\, \\group8\\), 5)\n\n\np <- ggplot(temp, aes(x = group, y = count, fill = group)) + \n  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() + \n    scale_y_continuous(breaks = seq(0, 30, by = 5), limits = c(0, 30)) + \n\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)  +\n  annotate(\\text\\, x = 1, y = 3, label = paste0(\\pv12: \\, pv12, \\\\n\\,\n                                                \\pv15: \\, pv15, \\\\n\\,\n                                                \\pv18: \\, pv18, \\\\n\\,\n                                                \\pv25: \\, pv25, \\\\n\\,\n                                                \\pv28: \\, pv28, \\\\n\\,\n                                                \\pv58: \\, pv58, \\\\n\\), \n           color = \\black\\, hjust = 0, size = 1) +  theme(legend.position = \\none\\)\n\n\nfileName <- paste0(\\countHub_barplot_diffGroup_dTAG_vs_DMSO\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
# IMPORTING GENE ANNO DATA FOR P-N LOOPS
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                 diffCutoff = 0.2,
                                 annoList = c(\P-P\, \P-E\, \P-S\, \P-X\)) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27, 28))

data <- fread(here(consensusDir, paste0(name, \.tsv\))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>%
  dplyr::mutate(binSize = end1 - start1,
                adj_start1 = ifelse(binSize == 5000, start1,
                                    ifelse(binSize == 10000, start1,
                                           start1 + 10000)),
                adj_end1 = adj_start1 + 5000,
                adj_start2 = ifelse(binSize == 5000, start2,
                                    ifelse(binSize == 10000, start2,
                                           start2 + 10000)),
                adj_end2 = adj_start2 + 5000,
                anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \_\),
                anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \_\))

# data <- fread(here(consensusDir, paste0(name, \.tsv\))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>% 
#   dplyr::mutate(binSize = end1 - start1,
#                 adj_start1 = ifelse(binSize == 5000, start1,
#                                     ifelse(binSize == 10000, start1+5000,
#                                            start1 + 10000)),
#                 adj_end1 = adj_start1 + 5000,
#                 adj_start2 = ifelse(binSize == 5000, start2,
#                                     ifelse(binSize == 10000, start2 + 5000,
#                                            start2 + 10000)),
#                 adj_end2 = adj_start2 + 5000,
#                 anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \_\),
#                 anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \_\))

data.reg <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \P-S\, \P-X\, \E-E\, \E-S\, \E-X\))

## Graph
#install.packages(\igraph\)
library(igraph)

# To be able to construct a graph, each anchor need to have same resolution.
# Shink the size to 10 kb
# If the anchor is 25kb, choose the middle 5kb bin
# If the anchor is 10kb, choose the left 5kb bin

graph <- graph_from_data_frame(data.reg %>% dplyr::select(anchor1, anchor2))
components <- components(graph)
data.reg$hub <- components$membership[data.reg$anchor1]

temp.bedpe <- data.reg %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)
fwrite(temp.bedpe, here(consensusDir, paste0(name, \_regulatory_5kbAdj.bedpe\)), 
       col.names = FALSE,row.names = FALSE, sep = \\t\)  

hubNum <- data.reg %>% group_by(hub) %>% summarise(count = n())

# Hub size distribution
p <- ggplot(hubNum, aes(x = count)) + geom_histogram(binwidth  = 1) + theme_classic() + 
  scale_y_log10()

svglite(here(figDir, \hub_size_distribution.svg\), height = 2, width = 2)
print(p)
dev.off()

data.reg <- data.reg %>% dplyr::left_join(hubNum, by = \hub\) 
data.reg <- data.reg %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \_\))

# Exporting regulatory loops with specific hub size
temp.bedpe <- data.reg %>% dplyr::filter(count >= 3) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)
fwrite(temp.bedpe, here(consensusDir, paste0(name, \_regulatory_5kbAdj_hub3.bedpe\)), 
       col.names = FALSE,row.names = FALSE, sep = \\t\)  

temp.bedpe <- data.reg %>% dplyr::filter(count >= 5) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)
fwrite(temp.bedpe, here(consensusDir, paste0(name, \_regulatory_5kbAdj_hub5.bedpe\)), 
       col.names = FALSE,row.names = FALSE, sep = \\t\)

temp.bedpe <- data.reg %>% dplyr::filter(count >= 10) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)
fwrite(temp.bedpe, here(consensusDir, paste0(name, \_regulatory_5kbAdj_hub10.bedpe\)), 
       col.names = FALSE,row.names = FALSE, sep = \\t\)


# Adding gene annotation to hubs
genePeakPair <- geneAnnoData %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \_\)) %>% dplyr::select(peakID, gene)
data.reg <- data.reg %>% dplyr::left_join(genePeakPair, by = \peakID\)

# During unnesting, E-N loops without gene annotated are removed
data.reg <- data.reg %>% unnest(gene) %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\,
                        ifelse(gene %in% gene.group3, \group3\,
                               ifelse(gene %in% gene.group4, \group4\,
                                      ifelse(gene %in% gene.group5, \group5\,
                                             ifelse(gene %in% gene.group6, \group6\,
                                                    ifelse(gene %in% gene.group7, \group7\,
                                                           ifelse(gene %in% gene.group8, \group8\,
                                                                  ifelse(gene %in% gene.group9, \group9\, NA)))))))))
)


temp <- data.reg %>% dplyr::select(gene, hub, count, group) %>%
  group_by(gene) %>% slice_max(count, with_ties = FALSE) %>%
  dplyr::filter(group %in% c(\group1\, \group2\, \group5\, \group8\))


# TEMP START
# TEMP START
geneList.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))
geneList.group1.temp <- geneList.group1 %>% dplyr::left_join(temp, by = c(\gene\))
# TEMP END

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$count
  distance2 <- (data %>% dplyr::filter(group ==group2) )$count
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


pv12 <- round(getPvalWilcox(tempSum,\group1\, \group2\), 5)
pv15 <- round(getPvalWilcox(tempSum,\group1\, \group5\), 5)
pv18 <- round(getPvalWilcox(tempSum,\group1\, \group8\), 5)
pv25 <- round(getPvalWilcox(tempSum,\group2\, \group5\), 5)
pv28 <- round(getPvalWilcox(tempSum,\group2\, \group8\), 5)
pv58 <- round(getPvalWilcox(tempSum,\group5\, \group8\), 5)


p <- ggplot(temp, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() + 
    scale_y_continuous(breaks = seq(0, 30, by = 5), limits = c(0, 30)) + 

  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
                                                \pv15: \, pv15, \\n\,
                                                \pv18: \, pv18, \\n\,
                                                \pv25: \, pv25, \\n\,
                                                \pv28: \, pv28, \\n\,
                                                \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 1) +  theme(legend.position = \none\)


fileName <- paste0(\countHub_barplot_diffGroup_dTAG_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n# IMPORTING GENE ANNO DATA FOR P-N LOOPS\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                 diffCutoff = 0.2,\n                                 annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27, 28))\n\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>%\n  dplyr::mutate(binSize = end1 - start1,\n                adj_start1 = ifelse(binSize == 5000, start1,\n                                    ifelse(binSize == 10000, start1,\n                                           start1 + 10000)),\n                adj_end1 = adj_start1 + 5000,\n                adj_start2 = ifelse(binSize == 5000, start2,\n                                    ifelse(binSize == 10000, start2,\n                                           start2 + 10000)),\n                adj_end2 = adj_start2 + 5000,\n                anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \\_\\),\n                anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \\_\\))\n\n# data <- fread(here(consensusDir, paste0(name, \\.tsv\\))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>% \n#   dplyr::mutate(binSize = end1 - start1,\n#                 adj_start1 = ifelse(binSize == 5000, start1,\n#                                     ifelse(binSize == 10000, start1+5000,\n#                                            start1 + 10000)),\n#                 adj_end1 = adj_start1 + 5000,\n#                 adj_start2 = ifelse(binSize == 5000, start2,\n#                                     ifelse(binSize == 10000, start2 + 5000,\n#                                            start2 + 10000)),\n#                 adj_end2 = adj_start2 + 5000,\n#                 anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \\_\\),\n#                 anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \\_\\))\n\ndata.reg <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\, \\E-E\\, \\E-S\\, \\E-X\\))\n\n## Graph\n#install.packages(\\igraph\\)\nlibrary(igraph)\n\n# To be able to construct a graph, each anchor need to have same resolution.\n# Shink the size to 10 kb\n# If the anchor is 25kb, choose the middle 5kb bin\n# If the anchor is 10kb, choose the left 5kb bin\n\ngraph <- graph_from_data_frame(data.reg %>% dplyr::select(anchor1, anchor2))\ncomponents <- components(graph)\ndata.reg$hub <- components$membership[data.reg$anchor1]\n\ntemp.bedpe <- data.reg %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)  \n\nhubNum <- data.reg %>% group_by(hub) %>% summarise(count = n())\n\n# Hub size distribution\np <- ggplot(hubNum, aes(x = count)) + geom_histogram(binwidth  = 1) + theme_classic() + \n  scale_y_log10()\n\nsvglite(here(figDir, \\hub_size_distribution.svg\\), height = 2, width = 2)\nprint(p)\ndev.off()\n\ndata.reg <- data.reg %>% dplyr::left_join(hubNum, by = \\hub\\) \ndata.reg <- data.reg %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n# Exporting regulatory loops with specific hub size\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 3) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj_hub3.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)  \n\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 5) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj_hub5.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)\n\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 10) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj_hub10.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)\n\n\n# Adding gene annotation to hubs\ngenePeakPair <- geneAnnoData %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \\_\\)) %>% dplyr::select(peakID, gene)\ndata.reg <- data.reg %>% dplyr::left_join(genePeakPair, by = \\peakID\\)\n\n# During unnesting, E-N loops without gene annotated are removed\ndata.reg <- data.reg %>% unnest(gene) %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\,\n                        ifelse(gene %in% gene.group3, \\group3\\,\n                               ifelse(gene %in% gene.group4, \\group4\\,\n                                      ifelse(gene %in% gene.group5, \\group5\\,\n                                             ifelse(gene %in% gene.group6, \\group6\\,\n                                                    ifelse(gene %in% gene.group7, \\group7\\,\n                                                           ifelse(gene %in% gene.group8, \\group8\\,\n                                                                  ifelse(gene %in% gene.group9, \\group9\\, NA)))))))))\n)\n\n\ntemp <- data.reg %>% dplyr::select(gene, hub, count, group) %>%\n  group_by(gene) %>% slice_max(count, with_ties = FALSE) %>%\n  dplyr::filter(group %in% c(\\group1\\, \\group2\\, \\group5\\, \\group8\\))\n\n\n# TEMP START\n# TEMP START\ngeneList.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))\ngeneList.group1.temp <- geneList.group1 %>% dplyr::left_join(temp, by = c(\\gene\\))\n# TEMP END\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$count\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$count\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\npv12 <- round(getPvalWilcox(tempSum,\\group1\\, \\group2\\), 5)\npv15 <- round(getPvalWilcox(tempSum,\\group1\\, \\group5\\), 5)\npv18 <- round(getPvalWilcox(tempSum,\\group1\\, \\group8\\), 5)\npv25 <- round(getPvalWilcox(tempSum,\\group2\\, \\group5\\), 5)\npv28 <- round(getPvalWilcox(tempSum,\\group2\\, \\group8\\), 5)\npv58 <- round(getPvalWilcox(tempSum,\\group5\\, \\group8\\), 5)\n\n\np <- ggplot(temp, aes(x = group, y = count, fill = group)) + \n  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() + \n    scale_y_continuous(breaks = seq(0, 30, by = 5), limits = c(0, 30)) + \n\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)  +\n  annotate(\\text\\, x = 1, y = 3, label = paste0(\\pv12: \\, pv12, \\\\n\\,\n                                                \\pv15: \\, pv15, \\\\n\\,\n                                                \\pv18: \\, pv18, \\\\n\\,\n                                                \\pv25: \\, pv25, \\\\n\\,\n                                                \\pv28: \\, pv28, \\\\n\\,\n                                                \\pv58: \\, pv58, \\\\n\\), \n           color = \\black\\, hjust = 0, size = 1) +  theme(legend.position = \\none\\)\n\n\nfileName <- paste0(\\countHub_barplot_diffGroup_dTAG_vs_DMSO\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n```\n```"} -->\n\n```r\n```r\n# IMPORTING GENE ANNO DATA FOR P-N LOOPS\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                 diffCutoff = 0.2,\n                                 annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27, 28))\n\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>%\n  dplyr::mutate(binSize = end1 - start1,\n                adj_start1 = ifelse(binSize == 5000, start1,\n                                    ifelse(binSize == 10000, start1,\n                                           start1 + 10000)),\n                adj_end1 = adj_start1 + 5000,\n                adj_start2 = ifelse(binSize == 5000, start2,\n                                    ifelse(binSize == 10000, start2,\n                                           start2 + 10000)),\n                adj_end2 = adj_start2 + 5000,\n                anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \\_\\),\n                anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \\_\\))\n\n# data <- fread(here(consensusDir, paste0(name, \\.tsv\\))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>% \n#   dplyr::mutate(binSize = end1 - start1,\n#                 adj_start1 = ifelse(binSize == 5000, start1,\n#                                     ifelse(binSize == 10000, start1+5000,\n#                                            start1 + 10000)),\n#                 adj_end1 = adj_start1 + 5000,\n#                 adj_start2 = ifelse(binSize == 5000, start2,\n#                                     ifelse(binSize == 10000, start2 + 5000,\n#                                            start2 + 10000)),\n#                 adj_end2 = adj_start2 + 5000,\n#                 anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \\_\\),\n#                 anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \\_\\))\n\ndata.reg <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\, \\E-E\\, \\E-S\\, \\E-X\\))\n\n## Graph\n#install.packages(\\igraph\\)\nlibrary(igraph)\n\n# To be able to construct a graph, each anchor need to have same resolution.\n# Shink the size to 10 kb\n# If the anchor is 25kb, choose the middle 5kb bin\n# If the anchor is 10kb, choose the left 5kb bin\n\ngraph <- graph_from_data_frame(data.reg %>% dplyr::select(anchor1, anchor2))\ncomponents <- components(graph)\ndata.reg$hub <- components$membership[data.reg$anchor1]\n\ntemp.bedpe <- data.reg %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)  \n\nhubNum <- data.reg %>% group_by(hub) %>% summarise(count = n())\n\n# Hub size distribution\np <- ggplot(hubNum, aes(x = count)) + geom_histogram(binwidth  = 1) + theme_classic() + \n  scale_y_log10()\n\nsvglite(here(figDir, \\hub_size_distribution.svg\\), height = 2, width = 2)\nprint(p)\ndev.off()\n\ndata.reg <- data.reg %>% dplyr::left_join(hubNum, by = \\hub\\) \ndata.reg <- data.reg %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n# Exporting regulatory loops with specific hub size\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 3) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj_hub3.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)  \n\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 5) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj_hub5.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)\n\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 10) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj_hub10.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)\n\n\n# Adding gene annotation to hubs\ngenePeakPair <- geneAnnoData %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \\_\\)) %>% dplyr::select(peakID, gene)\ndata.reg <- data.reg %>% dplyr::left_join(genePeakPair, by = \\peakID\\)\n\n# During unnesting, E-N loops without gene annotated are removed\ndata.reg <- data.reg %>% unnest(gene) %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\,\n                        ifelse(gene %in% gene.group3, \\group3\\,\n                               ifelse(gene %in% gene.group4, \\group4\\,\n                                      ifelse(gene %in% gene.group5, \\group5\\,\n                                             ifelse(gene %in% gene.group6, \\group6\\,\n                                                    ifelse(gene %in% gene.group7, \\group7\\,\n                                                           ifelse(gene %in% gene.group8, \\group8\\,\n                                                                  ifelse(gene %in% gene.group9, \\group9\\, NA)))))))))\n)\n\n\ntemp <- data.reg %>% dplyr::select(gene, hub, count, group) %>%\n  group_by(gene) %>% slice_max(count, with_ties = FALSE) %>%\n  dplyr::filter(group %in% c(\\group1\\, \\group2\\, \\group5\\, \\group8\\))\n\n\n# TEMP START\n# TEMP START\ngeneList.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))\ngeneList.group1.temp <- geneList.group1 %>% dplyr::left_join(temp, by = c(\\gene\\))\n# TEMP END\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$count\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$count\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\npv12 <- round(getPvalWilcox(tempSum,\\group1\\, \\group2\\), 5)\npv15 <- round(getPvalWilcox(tempSum,\\group1\\, \\group5\\), 5)\npv18 <- round(getPvalWilcox(tempSum,\\group1\\, \\group8\\), 5)\npv25 <- round(getPvalWilcox(tempSum,\\group2\\, \\group5\\), 5)\npv28 <- round(getPvalWilcox(tempSum,\\group2\\, \\group8\\), 5)\npv58 <- round(getPvalWilcox(tempSum,\\group5\\, \\group8\\), 5)\n\n\np <- ggplot(temp, aes(x = group, y = count, fill = group)) + \n  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() + \n    scale_y_continuous(breaks = seq(0, 30, by = 5), limits = c(0, 30)) + \n\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)  +\n  annotate(\\text\\, x = 1, y = 3, label = paste0(\\pv12: \\, pv12, \\\\n\\,\n                                                \\pv15: \\, pv15, \\\\n\\,\n                                                \\pv18: \\, pv18, \\\\n\\,\n                                                \\pv25: \\, pv25, \\\\n\\,\n                                                \\pv28: \\, pv28, \\\\n\\,\n                                                \\pv58: \\, pv58, \\\\n\\), \n           color = \\black\\, hjust = 0, size = 1) +  theme(legend.position = \\none\\)\n\n\nfileName <- paste0(\\countHub_barplot_diffGroup_dTAG_vs_DMSO\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n# IMPORTING GENE ANNO DATA FOR P-N LOOPS\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                 diffCutoff = 0.2,\n                                 annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27, 28))\n\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>%\n  dplyr::mutate(binSize = end1 - start1,\n                adj_start1 = ifelse(binSize == 5000, start1,\n                                    ifelse(binSize == 10000, start1,\n                                           start1 + 10000)),\n                adj_end1 = adj_start1 + 5000,\n                adj_start2 = ifelse(binSize == 5000, start2,\n                                    ifelse(binSize == 10000, start2,\n                                           start2 + 10000)),\n                adj_end2 = adj_start2 + 5000,\n                anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \\_\\),\n                anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \\_\\))\n\n# data <- fread(here(consensusDir, paste0(name, \\.tsv\\))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>% \n#   dplyr::mutate(binSize = end1 - start1,\n#                 adj_start1 = ifelse(binSize == 5000, start1,\n#                                     ifelse(binSize == 10000, start1+5000,\n#                                            start1 + 10000)),\n#                 adj_end1 = adj_start1 + 5000,\n#                 adj_start2 = ifelse(binSize == 5000, start2,\n#                                     ifelse(binSize == 10000, start2 + 5000,\n#                                            start2 + 10000)),\n#                 adj_end2 = adj_start2 + 5000,\n#                 anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \\_\\),\n#                 anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \\_\\))\n\ndata.reg <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\, \\E-E\\, \\E-S\\, \\E-X\\))\n\n## Graph\n#install.packages(\\igraph\\)\nlibrary(igraph)\n\n# To be able to construct a graph, each anchor need to have same resolution.\n# Shink the size to 10 kb\n# If the anchor is 25kb, choose the middle 5kb bin\n# If the anchor is 10kb, choose the left 5kb bin\n\ngraph <- graph_from_data_frame(data.reg %>% dplyr::select(anchor1, anchor2))\ncomponents <- components(graph)\ndata.reg$hub <- components$membership[data.reg$anchor1]\n\ntemp.bedpe <- data.reg %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)  \n\nhubNum <- data.reg %>% group_by(hub) %>% summarise(count = n())\n\n# Hub size distribution\np <- ggplot(hubNum, aes(x = count)) + geom_histogram(binwidth  = 1) + theme_classic() + \n  scale_y_log10()\n\nsvglite(here(figDir, \\hub_size_distribution.svg\\), height = 2, width = 2)\nprint(p)\ndev.off()\n\ndata.reg <- data.reg %>% dplyr::left_join(hubNum, by = \\hub\\) \ndata.reg <- data.reg %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n# Exporting regulatory loops with specific hub size\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 3) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj_hub3.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)  \n\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 5) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj_hub5.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)\n\ntemp.bedpe <- data.reg %>% dplyr::filter(count >= 10) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)\nfwrite(temp.bedpe, here(consensusDir, paste0(name, \\_regulatory_5kbAdj_hub10.bedpe\\)), \n       col.names = FALSE,row.names = FALSE, sep = \\\\t\\)\n\n\n# Adding gene annotation to hubs\ngenePeakPair <- geneAnnoData %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \\_\\)) %>% dplyr::select(peakID, gene)\ndata.reg <- data.reg %>% dplyr::left_join(genePeakPair, by = \\peakID\\)\n\n# During unnesting, E-N loops without gene annotated are removed\ndata.reg <- data.reg %>% unnest(gene) %>% dplyr::mutate(\n  group = ifelse(gene %in% gene.group1, \\group1\\,\n                 ifelse(gene %in% gene.group2, \\group2\\,\n                        ifelse(gene %in% gene.group3, \\group3\\,\n                               ifelse(gene %in% gene.group4, \\group4\\,\n                                      ifelse(gene %in% gene.group5, \\group5\\,\n                                             ifelse(gene %in% gene.group6, \\group6\\,\n                                                    ifelse(gene %in% gene.group7, \\group7\\,\n                                                           ifelse(gene %in% gene.group8, \\group8\\,\n                                                                  ifelse(gene %in% gene.group9, \\group9\\, NA)))))))))\n)\n\n\ntemp <- data.reg %>% dplyr::select(gene, hub, count, group) %>%\n  group_by(gene) %>% slice_max(count, with_ties = FALSE) %>%\n  dplyr::filter(group %in% c(\\group1\\, \\group2\\, \\group5\\, \\group8\\))\n\n\n# TEMP START\n# TEMP START\ngeneList.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))\ngeneList.group1.temp <- geneList.group1 %>% dplyr::left_join(temp, by = c(\\gene\\))\n# TEMP END\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$count\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$count\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\npv12 <- round(getPvalWilcox(tempSum,\\group1\\, \\group2\\), 5)\npv15 <- round(getPvalWilcox(tempSum,\\group1\\, \\group5\\), 5)\npv18 <- round(getPvalWilcox(tempSum,\\group1\\, \\group8\\), 5)\npv25 <- round(getPvalWilcox(tempSum,\\group2\\, \\group5\\), 5)\npv28 <- round(getPvalWilcox(tempSum,\\group2\\, \\group8\\), 5)\npv58 <- round(getPvalWilcox(tempSum,\\group5\\, \\group8\\), 5)\n\n\np <- ggplot(temp, aes(x = group, y = count, fill = group)) + \n  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() + \n    scale_y_continuous(breaks = seq(0, 30, by = 5), limits = c(0, 30)) + \n\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)  +\n  annotate(\\text\\, x = 1, y = 3, label = paste0(\\pv12: \\, pv12, \\\\n\\,\n                                                \\pv15: \\, pv15, \\\\n\\,\n                                                \\pv18: \\, pv18, \\\\n\\,\n                                                \\pv25: \\, pv25, \\\\n\\,\n                                                \\pv28: \\, pv28, \\\\n\\,\n                                                \\pv58: \\, pv58, \\\\n\\), \n           color = \\black\\, hjust = 0, size = 1) +  theme(legend.position = \\none\\)\n\n\nfileName <- paste0(\\countHub_barplot_diffGroup_dTAG_vs_DMSO\\)\nheight <- 3\nwidth <- 3\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n```\n```"} -->

```r
```r
# IMPORTING GENE ANNO DATA FOR P-N LOOPS
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                 diffCutoff = 0.2,
                                 annoList = c(\P-P\, \P-E\, \P-S\, \P-X\)) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27, 28))

data <- fread(here(consensusDir, paste0(name, \.tsv\))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>%
  dplyr::mutate(binSize = end1 - start1,
                adj_start1 = ifelse(binSize == 5000, start1,
                                    ifelse(binSize == 10000, start1,
                                           start1 + 10000)),
                adj_end1 = adj_start1 + 5000,
                adj_start2 = ifelse(binSize == 5000, start2,
                                    ifelse(binSize == 10000, start2,
                                           start2 + 10000)),
                adj_end2 = adj_start2 + 5000,
                anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \_\),
                anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \_\))

# data <- fread(here(consensusDir, paste0(name, \.tsv\))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>% 
#   dplyr::mutate(binSize = end1 - start1,
#                 adj_start1 = ifelse(binSize == 5000, start1,
#                                     ifelse(binSize == 10000, start1+5000,
#                                            start1 + 10000)),
#                 adj_end1 = adj_start1 + 5000,
#                 adj_start2 = ifelse(binSize == 5000, start2,
#                                     ifelse(binSize == 10000, start2 + 5000,
#                                            start2 + 10000)),
#                 adj_end2 = adj_start2 + 5000,
#                 anchor1 = paste(chrom1, adj_start1, adj_end1, sep = \_\),
#                 anchor2 = paste(chrom2, adj_start2, adj_end2, sep = \_\))

data.reg <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \P-S\, \P-X\, \E-E\, \E-S\, \E-X\))

## Graph
#install.packages(\igraph\)
library(igraph)

# To be able to construct a graph, each anchor need to have same resolution.
# Shink the size to 10 kb
# If the anchor is 25kb, choose the middle 5kb bin
# If the anchor is 10kb, choose the left 5kb bin

graph <- graph_from_data_frame(data.reg %>% dplyr::select(anchor1, anchor2))
components <- components(graph)
data.reg$hub <- components$membership[data.reg$anchor1]

temp.bedpe <- data.reg %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)
fwrite(temp.bedpe, here(consensusDir, paste0(name, \_regulatory_5kbAdj.bedpe\)), 
       col.names = FALSE,row.names = FALSE, sep = \\t\)  

hubNum <- data.reg %>% group_by(hub) %>% summarise(count = n())

# Hub size distribution
p <- ggplot(hubNum, aes(x = count)) + geom_histogram(binwidth  = 1) + theme_classic() + 
  scale_y_log10()

svglite(here(figDir, \hub_size_distribution.svg\), height = 2, width = 2)
print(p)
dev.off()

data.reg <- data.reg %>% dplyr::left_join(hubNum, by = \hub\) 
data.reg <- data.reg %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \_\))

# Exporting regulatory loops with specific hub size
temp.bedpe <- data.reg %>% dplyr::filter(count >= 3) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)
fwrite(temp.bedpe, here(consensusDir, paste0(name, \_regulatory_5kbAdj_hub3.bedpe\)), 
       col.names = FALSE,row.names = FALSE, sep = \\t\)  

temp.bedpe <- data.reg %>% dplyr::filter(count >= 5) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)
fwrite(temp.bedpe, here(consensusDir, paste0(name, \_regulatory_5kbAdj_hub5.bedpe\)), 
       col.names = FALSE,row.names = FALSE, sep = \\t\)

temp.bedpe <- data.reg %>% dplyr::filter(count >= 10) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)
fwrite(temp.bedpe, here(consensusDir, paste0(name, \_regulatory_5kbAdj_hub10.bedpe\)), 
       col.names = FALSE,row.names = FALSE, sep = \\t\)


# Adding gene annotation to hubs
genePeakPair <- geneAnnoData %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = \_\)) %>% dplyr::select(peakID, gene)
data.reg <- data.reg %>% dplyr::left_join(genePeakPair, by = \peakID\)

# During unnesting, E-N loops without gene annotated are removed
data.reg <- data.reg %>% unnest(gene) %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, \group1\,
                 ifelse(gene %in% gene.group2, \group2\,
                        ifelse(gene %in% gene.group3, \group3\,
                               ifelse(gene %in% gene.group4, \group4\,
                                      ifelse(gene %in% gene.group5, \group5\,
                                             ifelse(gene %in% gene.group6, \group6\,
                                                    ifelse(gene %in% gene.group7, \group7\,
                                                           ifelse(gene %in% gene.group8, \group8\,
                                                                  ifelse(gene %in% gene.group9, \group9\, NA)))))))))
)


temp <- data.reg %>% dplyr::select(gene, hub, count, group) %>%
  group_by(gene) %>% slice_max(count, with_ties = FALSE) %>%
  dplyr::filter(group %in% c(\group1\, \group2\, \group5\, \group8\))


# TEMP START
# TEMP START
geneList.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))
geneList.group1.temp <- geneList.group1 %>% dplyr::left_join(temp, by = c(\gene\))
# TEMP END

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$count
  distance2 <- (data %>% dplyr::filter(group ==group2) )$count
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


pv12 <- round(getPvalWilcox(tempSum,\group1\, \group2\), 5)
pv15 <- round(getPvalWilcox(tempSum,\group1\, \group5\), 5)
pv18 <- round(getPvalWilcox(tempSum,\group1\, \group8\), 5)
pv25 <- round(getPvalWilcox(tempSum,\group2\, \group5\), 5)
pv28 <- round(getPvalWilcox(tempSum,\group2\, \group8\), 5)
pv58 <- round(getPvalWilcox(tempSum,\group5\, \group8\), 5)


p <- ggplot(temp, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() + 
    scale_y_continuous(breaks = seq(0, 30, by = 5), limits = c(0, 30)) + 

  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)  +
  annotate(\text\, x = 1, y = 3, label = paste0(\pv12: \, pv12, \\n\,
                                                \pv15: \, pv15, \\n\,
                                                \pv18: \, pv18, \\n\,
                                                \pv25: \, pv25, \\n\,
                                                \pv28: \, pv28, \\n\,
                                                \pv58: \, pv58, \\n\), 
           color = \black\, hjust = 0, size = 1) +  theme(legend.position = \none\)


fileName <- paste0(\countHub_barplot_diffGroup_dTAG_vs_DMSO\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### log2FC

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJKYlhCdmNuUWdhVzV6ZFd4aGRHbHZiaUJ6WTI5eVpTQmpZV3hqZFd4aGRHVmtJSGRwZEdnZ2NIbDBhRzl1WEc1eVpYTjFiSFJFYVhJZ1BDMGdhR1Z5WlNoY0lpNHVMeTR1TDNKbGMzVnNkRndpS1Z4dWFXNXpVMk52Y21VdVJFMVRUeUE4TFNCbWNtVmhaQ2hvWlhKbEtISmxjM1ZzZEVScGNpd2dYQ0pVUVVSY0lpd2dYQ0pwYm5OMWJHRjBhVzl1VTJOdmNtVmZNalZyWWw5SE1VUk5VMDh1ZEhOMlhDSXBLU0FsUGlVZ1hHNGdJR1J3YkhseU9qcHpaV3hsWTNRb1l5aGNJbU5vY205dFhDSXNJRndpYzNSaGNuUmNJaXdnWENKbGJtUmNJaXdnWENKc2IyY3lYMmx1YzNWc1lYUnBiMjVmYzJOdmNtVmZNVEkxTURBd1hDSXBLU0FsUGlWY2JpQWdaSEJzZVhJNk9tMTFkR0YwWlNoaWFXNUpSQ0E5SUhCaGMzUmxLR05vY205dExDQnpkR0Z5ZEN3Z1pXNWtMQ0J6WlhBZ1BTQmNJbDljSWlrcFhHNWpiMnh1WVcxbGN5aHBibk5UWTI5eVpTNUVUVk5QS1NBOExTQmpLRndpWTJoeWIyMWNJaXdnWENKemRHRnlkRndpTENCY0ltVnVaRndpTENCY0ltbHVjM1ZzWVhScGIyNVRZMjl5WlZ3aUxDQmNJbUpwYmtsRVhDSXBYRzVwYm5OVFkyOXlaUzVrVkVGSElEd3RJR1p5WldGa0tHaGxjbVVvY21WemRXeDBSR2x5TENCY0lsUkJSRndpTENCY0ltbHVjM1ZzWVhScGIyNVRZMjl5WlY4eU5XdGlYMGN4WkZSQlJ5NTBjM1pjSWlrcElDVStKU0JjYmlBZ1pIQnNlWEk2T25ObGJHVmpkQ2hqS0Z3aVkyaHliMjFjSWl3Z1hDSnpkR0Z5ZEZ3aUxDQmNJbVZ1WkZ3aUxDQmNJbXh2WnpKZmFXNXpkV3hoZEdsdmJsOXpZMjl5WlY4eE1qVXdNREJjSWlrcElDVStKVnh1SUNCa2NHeDVjam82YlhWMFlYUmxLR0pwYmtsRUlEMGdjR0Z6ZEdVb1kyaHliMjBzSUhOMFlYSjBMQ0JsYm1Rc0lITmxjQ0E5SUZ3aVgxd2lLU2xjYm1OdmJHNWhiV1Z6S0dsdWMxTmpiM0psTG1SVVFVY3BJRHd0SUdNb1hDSmphSEp2YlZ3aUxDQmNJbk4wWVhKMFhDSXNJRndpWlc1a1hDSXNJRndpYVc1emRXeGhkR2x2YmxOamIzSmxYQ0lzSUZ3aVltbHVTVVJjSWlsY2JseHVJMmx1YzFOamIzSmxJRHd0SUdaMWJHeGZhbTlwYmlocGJuTlRZMjl5WlM1RVRWTlBMQ0JwYm5OVFkyOXlaUzVrVkVGSExDQmllU0E5SUdNb1hDSmlhVzVKUkZ3aUtTa2dKVDRsWEc0aklDQmtjR3g1Y2pvNmMyVnNaV04wS0dKcGJrbEVMQ0JqYUhKdmJTNTRMQ0J6ZEdGeWRDNTRMQ0JsYm1RdWVDd2dhVzV6ZFd4aGRHbHZibE5qYjNKbExuZ3NJR2x1YzNWc1lYUnBiMjVUWTI5eVpTNTVLU0JjYmx4dUkyTnZiRzVoYldWektHbHVjMU5qYjNKbEtTQThMU0JqS0Z3aVltbHVTVVJjSWl3Z1hDSmphSEpjSWl3Z1hDSnpkR0Z5ZEZ3aUxDQmNJbVZ1WkZ3aUxDQmNJbWx1YzNWc1lYUnBiMjVmYzJOdmNtVmZSRTFUVDF3aUxDQmNJbWx1YzNWc1lYUnBiMjVmYzJOdllYSmxYMlJVUVVkY0lpbGNibHh1STFacFpYY29hVzV6VTJOdmNtVXBYRzVjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbiMgSW1wb3J0IGluc3VsYXRpb24gc2NvcmUgY2FsY3VsYXRlZCB3aXRoIHB5dGhvblxucmVzdWx0RGlyIDwtIGhlcmUoXFwuLi8uLi9yZXN1bHRcXClcbmluc1Njb3JlLkRNU08gPC0gZnJlYWQoaGVyZShyZXN1bHREaXIsIFxcVEFEXFwsIFxcaW5zdWxhdGlvblNjb3JlXzI1a2JfRzFETVNPLnRzdlxcKSkgJT4lIFxuICBkcGx5cjo6c2VsZWN0KGMoXFxjaHJvbVxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcbG9nMl9pbnN1bGF0aW9uX3Njb3JlXzEyNTAwMFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoYmluSUQgPSBwYXN0ZShjaHJvbSwgc3RhcnQsIGVuZCwgc2VwID0gXFxfXFwpKVxuY29sbmFtZXMoaW5zU2NvcmUuRE1TTykgPC0gYyhcXGNocm9tXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxpbnN1bGF0aW9uU2NvcmVcXCwgXFxiaW5JRFxcKVxuaW5zU2NvcmUuZFRBRyA8LSBmcmVhZChoZXJlKHJlc3VsdERpciwgXFxUQURcXCwgXFxpbnN1bGF0aW9uU2NvcmVfMjVrYl9HMWRUQUcudHN2XFwpKSAlPiUgXG4gIGRwbHlyOjpzZWxlY3QoYyhcXGNocm9tXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxsb2cyX2luc3VsYXRpb25fc2NvcmVfMTI1MDAwXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShiaW5JRCA9IHBhc3RlKGNocm9tLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCkpXG5jb2xuYW1lcyhpbnNTY29yZS5kVEFHKSA8LSBjKFxcY2hyb21cXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGluc3VsYXRpb25TY29yZVxcLCBcXGJpbklEXFwpXG5cbiNpbnNTY29yZSA8LSBmdWxsX2pvaW4oaW5zU2NvcmUuRE1TTywgaW5zU2NvcmUuZFRBRywgYnkgPSBjKFxcYmluSURcXCkpICU+JVxuIyAgZHBseXI6OnNlbGVjdChiaW5JRCwgY2hyb20ueCwgc3RhcnQueCwgZW5kLngsIGluc3VsYXRpb25TY29yZS54LCBpbnN1bGF0aW9uU2NvcmUueSkgXG5cbiNjb2xuYW1lcyhpbnNTY29yZSkgPC0gYyhcXGJpbklEXFwsIFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxpbnN1bGF0aW9uX3Njb3JlX0RNU09cXCwgXFxpbnN1bGF0aW9uX3Njb2FyZV9kVEFHXFwpXG5cbiNWaWV3KGluc1Njb3JlKVxuXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
# Import insulation score calculated with python
resultDir <- here(\../../result\)
insScore.DMSO <- fread(here(resultDir, \TAD\, \insulationScore_25kb_G1DMSO.tsv\)) %>% 
  dplyr::select(c(\chrom\, \start\, \end\, \log2_insulation_score_125000\)) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = \_\))
colnames(insScore.DMSO) <- c(\chrom\, \start\, \end\, \insulationScore\, \binID\)
insScore.dTAG <- fread(here(resultDir, \TAD\, \insulationScore_25kb_G1dTAG.tsv\)) %>% 
  dplyr::select(c(\chrom\, \start\, \end\, \log2_insulation_score_125000\)) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = \_\))
colnames(insScore.dTAG) <- c(\chrom\, \start\, \end\, \insulationScore\, \binID\)

#insScore <- full_join(insScore.DMSO, insScore.dTAG, by = c(\binID\)) %>%
#  dplyr::select(binID, chrom.x, start.x, end.x, insulationScore.x, insulationScore.y) 

#colnames(insScore) <- c(\binID\, \chr\, \start\, \end\, \insulation_score_DMSO\, \insulation_scoare_dTAG\)

#View(insScore)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QkpiWEJ2Y25RZ2FXNXpkV3hoZEdsdmJpQnpZMjl5WlNCallXeGpkV3hoZEdWa0lIZHBkR2dnY0hsMGFHOXVYRzV5WlhOMWJIUkVhWElnUEMwZ2FHVnlaU2hjWEM0dUx5NHVMM0psYzNWc2RGeGNLVnh1YVc1elUyTnZjbVV1UkUxVFR5QThMU0JtY21WaFpDaG9aWEpsS0hKbGMzVnNkRVJwY2l3Z1hGeFVRVVJjWEN3Z1hGeHBibk4xYkdGMGFXOXVVMk52Y21WZk1qVnJZbDlITVVSTlUwOHVkSE4yWEZ3cEtTQWxQaVVnWEc0Z0lHUndiSGx5T2pwelpXeGxZM1FvWXloY1hHTm9jbTl0WEZ3c0lGeGNjM1JoY25SY1hDd2dYRnhsYm1SY1hDd2dYRnhzYjJjeVgybHVjM1ZzWVhScGIyNWZjMk52Y21WZk1USTFNREF3WEZ3cEtTQWxQaVZjYmlBZ1pIQnNlWEk2T20xMWRHRjBaU2hpYVc1SlJDQTlJSEJoYzNSbEtHTm9jbTl0TENCemRHRnlkQ3dnWlc1a0xDQnpaWEFnUFNCY1hGOWNYQ2twWEc1amIyeHVZVzFsY3locGJuTlRZMjl5WlM1RVRWTlBLU0E4TFNCaktGeGNZMmh5YjIxY1hDd2dYRnh6ZEdGeWRGeGNMQ0JjWEdWdVpGeGNMQ0JjWEdsdWMzVnNZWFJwYjI1VFkyOXlaVnhjTENCY1hHSnBia2xFWEZ3cFhHNXBibk5UWTI5eVpTNWtWRUZISUR3dElHWnlaV0ZrS0dobGNtVW9jbVZ6ZFd4MFJHbHlMQ0JjWEZSQlJGeGNMQ0JjWEdsdWMzVnNZWFJwYjI1VFkyOXlaVjh5Tld0aVgwY3haRlJCUnk1MGMzWmNYQ2twSUNVK0pTQmNiaUFnWkhCc2VYSTZPbk5sYkdWamRDaGpLRnhjWTJoeWIyMWNYQ3dnWEZ4emRHRnlkRnhjTENCY1hHVnVaRnhjTENCY1hHeHZaekpmYVc1emRXeGhkR2x2Ymw5elkyOXlaVjh4TWpVd01EQmNYQ2twSUNVK0pWeHVJQ0JrY0d4NWNqbzZiWFYwWVhSbEtHSnBia2xFSUQwZ2NHRnpkR1VvWTJoeWIyMHNJSE4wWVhKMExDQmxibVFzSUhObGNDQTlJRnhjWDF4Y0tTbGNibU52Ykc1aGJXVnpLR2x1YzFOamIzSmxMbVJVUVVjcElEd3RJR01vWEZ4amFISnZiVnhjTENCY1hITjBZWEowWEZ3c0lGeGNaVzVrWEZ3c0lGeGNhVzV6ZFd4aGRHbHZibE5qYjNKbFhGd3NJRnhjWW1sdVNVUmNYQ2xjYmx4dUkybHVjMU5qYjNKbElEd3RJR1oxYkd4ZmFtOXBiaWhwYm5OVFkyOXlaUzVFVFZOUExDQnBibk5UWTI5eVpTNWtWRUZITENCaWVTQTlJR01vWEZ4aWFXNUpSRnhjS1NrZ0pUNGxYRzRqSUNCa2NHeDVjam82YzJWc1pXTjBLR0pwYmtsRUxDQmphSEp2YlM1NExDQnpkR0Z5ZEM1NExDQmxibVF1ZUN3Z2FXNXpkV3hoZEdsdmJsTmpiM0psTG5nc0lHbHVjM1ZzWVhScGIyNVRZMjl5WlM1NUtTQmNibHh1STJOdmJHNWhiV1Z6S0dsdWMxTmpiM0psS1NBOExTQmpLRnhjWW1sdVNVUmNYQ3dnWEZ4amFISmNYQ3dnWEZ4emRHRnlkRnhjTENCY1hHVnVaRnhjTENCY1hHbHVjM1ZzWVhScGIyNWZjMk52Y21WZlJFMVRUMXhjTENCY1hHbHVjM1ZzWVhScGIyNWZjMk52WVhKbFgyUlVRVWRjWENsY2JseHVJMVpwWlhjb2FXNXpVMk52Y21VcFhHNWNibUJnWUZ4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG5gYGByXG4jIEltcG9ydCBpbnN1bGF0aW9uIHNjb3JlIGNhbGN1bGF0ZWQgd2l0aCBweXRob25cbnJlc3VsdERpciA8LSBoZXJlKFxcLi4vLi4vcmVzdWx0XFwpXG5pbnNTY29yZS5ETVNPIDwtIGZyZWFkKGhlcmUocmVzdWx0RGlyLCBcXFRBRFxcLCBcXGluc3VsYXRpb25TY29yZV8yNWtiX0cxRE1TTy50c3ZcXCkpICU+JSBcbiAgZHBseXI6OnNlbGVjdChjKFxcY2hyb21cXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGxvZzJfaW5zdWxhdGlvbl9zY29yZV8xMjUwMDBcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGJpbklEID0gcGFzdGUoY2hyb20sIHN0YXJ0LCBlbmQsIHNlcCA9IFxcX1xcKSlcbmNvbG5hbWVzKGluc1Njb3JlLkRNU08pIDwtIGMoXFxjaHJvbVxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcaW5zdWxhdGlvblNjb3JlXFwsIFxcYmluSURcXClcbmluc1Njb3JlLmRUQUcgPC0gZnJlYWQoaGVyZShyZXN1bHREaXIsIFxcVEFEXFwsIFxcaW5zdWxhdGlvblNjb3JlXzI1a2JfRzFkVEFHLnRzdlxcKSkgJT4lIFxuICBkcGx5cjo6c2VsZWN0KGMoXFxjaHJvbVxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcbG9nMl9pbnN1bGF0aW9uX3Njb3JlXzEyNTAwMFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoYmluSUQgPSBwYXN0ZShjaHJvbSwgc3RhcnQsIGVuZCwgc2VwID0gXFxfXFwpKVxuY29sbmFtZXMoaW5zU2NvcmUuZFRBRykgPC0gYyhcXGNocm9tXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxpbnN1bGF0aW9uU2NvcmVcXCwgXFxiaW5JRFxcKVxuXG4jaW5zU2NvcmUgPC0gZnVsbF9qb2luKGluc1Njb3JlLkRNU08sIGluc1Njb3JlLmRUQUcsIGJ5ID0gYyhcXGJpbklEXFwpKSAlPiVcbiMgIGRwbHlyOjpzZWxlY3QoYmluSUQsIGNocm9tLngsIHN0YXJ0LngsIGVuZC54LCBpbnN1bGF0aW9uU2NvcmUueCwgaW5zdWxhdGlvblNjb3JlLnkpIFxuXG4jY29sbmFtZXMoaW5zU2NvcmUpIDwtIGMoXFxiaW5JRFxcLCBcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcaW5zdWxhdGlvbl9zY29yZV9ETVNPXFwsIFxcaW5zdWxhdGlvbl9zY29hcmVfZFRBR1xcKVxuXG4jVmlldyhpbnNTY29yZSlcblxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBJbXBvcnQgaW5zdWxhdGlvbiBzY29yZSBjYWxjdWxhdGVkIHdpdGggcHl0aG9uXG5yZXN1bHREaXIgPC0gaGVyZShcXC4uLy4uL3Jlc3VsdFxcKVxuaW5zU2NvcmUuRE1TTyA8LSBmcmVhZChoZXJlKHJlc3VsdERpciwgXFxUQURcXCwgXFxpbnN1bGF0aW9uU2NvcmVfMjVrYl9HMURNU08udHN2XFwpKSAlPiUgXG4gIGRwbHlyOjpzZWxlY3QoYyhcXGNocm9tXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxsb2cyX2luc3VsYXRpb25fc2NvcmVfMTI1MDAwXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShiaW5JRCA9IHBhc3RlKGNocm9tLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCkpXG5jb2xuYW1lcyhpbnNTY29yZS5ETVNPKSA8LSBjKFxcY2hyb21cXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGluc3VsYXRpb25TY29yZVxcLCBcXGJpbklEXFwpXG5pbnNTY29yZS5kVEFHIDwtIGZyZWFkKGhlcmUocmVzdWx0RGlyLCBcXFRBRFxcLCBcXGluc3VsYXRpb25TY29yZV8yNWtiX0cxZFRBRy50c3ZcXCkpICU+JSBcbiAgZHBseXI6OnNlbGVjdChjKFxcY2hyb21cXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGxvZzJfaW5zdWxhdGlvbl9zY29yZV8xMjUwMDBcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGJpbklEID0gcGFzdGUoY2hyb20sIHN0YXJ0LCBlbmQsIHNlcCA9IFxcX1xcKSlcbmNvbG5hbWVzKGluc1Njb3JlLmRUQUcpIDwtIGMoXFxjaHJvbVxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcaW5zdWxhdGlvblNjb3JlXFwsIFxcYmluSURcXClcblxuI2luc1Njb3JlIDwtIGZ1bGxfam9pbihpbnNTY29yZS5ETVNPLCBpbnNTY29yZS5kVEFHLCBieSA9IGMoXFxiaW5JRFxcKSkgJT4lXG4jICBkcGx5cjo6c2VsZWN0KGJpbklELCBjaHJvbS54LCBzdGFydC54LCBlbmQueCwgaW5zdWxhdGlvblNjb3JlLngsIGluc3VsYXRpb25TY29yZS55KSBcblxuI2NvbG5hbWVzKGluc1Njb3JlKSA8LSBjKFxcYmluSURcXCwgXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGluc3VsYXRpb25fc2NvcmVfRE1TT1xcLCBcXGluc3VsYXRpb25fc2NvYXJlX2RUQUdcXClcblxuI1ZpZXcoaW5zU2NvcmUpXG5cbmBgYFxuYGBgIn0= -->

```r
```r
# Import insulation score calculated with python
resultDir <- here(\../../result\)
insScore.DMSO <- fread(here(resultDir, \TAD\, \insulationScore_25kb_G1DMSO.tsv\)) %>% 
  dplyr::select(c(\chrom\, \start\, \end\, \log2_insulation_score_125000\)) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = \_\))
colnames(insScore.DMSO) <- c(\chrom\, \start\, \end\, \insulationScore\, \binID\)
insScore.dTAG <- fread(here(resultDir, \TAD\, \insulationScore_25kb_G1dTAG.tsv\)) %>% 
  dplyr::select(c(\chrom\, \start\, \end\, \log2_insulation_score_125000\)) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = \_\))
colnames(insScore.dTAG) <- c(\chrom\, \start\, \end\, \insulationScore\, \binID\)

#insScore <- full_join(insScore.DMSO, insScore.dTAG, by = c(\binID\)) %>%
#  dplyr::select(binID, chrom.x, start.x, end.x, insulationScore.x, insulationScore.y) 

#colnames(insScore) <- c(\binID\, \chr\, \start\, \end\, \insulation_score_DMSO\, \insulation_scoare_dTAG\)

#View(insScore)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


## [2.13] How to define multiconnected hub using regulatory loops?

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVaMlZ1WlM1VVUxTXVkR0lnUEMwZ1puSmxZV1FvYUdWeVpTaHlaV1pFYVhJc0lGd2liVzB4TUY5SFVrTnRNemd1Y0RaZloyVnVaVjl6YjNKMFpXUXVZbVZrWENJcEtTQWxQaVZjYmlBZ1pIQnNlWEk2T20xMWRHRjBaU2hVVTFNZ1BTQnBabVZzYzJVb1ZqUWdQVDBnWENJclhDSXNJRll5TENCV015a3BJQ1UrSlZ4dUlDQmtjR3g1Y2pvNmMyVnNaV04wS0ZZMkxDQldOU3dnVmpFc0lGUlRVeWxjYm1OdmJHNWhiV1Z6S0dkbGJtVXVWRk5UTG5SaUtTQThMU0JqS0Z3aVpXNXpaVzFpYkZ3aUxDQmNJbWRsYm1WY0lpd2dYQ0pqYUhKY0lpd2dYQ0pVVTFOY0lpbGNibHh1WjJWMFNXNXpkV3hoZEdsdmJsTmpiM0psSUR3dElHWjFibU4wYVc5dUtHTm9jaXdnVkZOVExDQnBibk5UWTI5eVpTNTBZaWw3WEc0Z0lIUmxiWEF1ZEdJZ1BDMGdhVzV6VTJOdmNtVXVkR0lnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWTJoeWIyMGdQVDBnWTJoeUxDQnpkR0Z5ZENBOElGUlRVeXdnWlc1a0lENGdWRk5US1Z4dUlDQnZkWFFnUEMwZ2RHVnRjQzUwWWlScGJuTjFiR0YwYVc5dVUyTnZjbVZjYmlBZ2FXWW9iR1Z1WjNSb0tHOTFkQ2tnUENBeEtYdGNiaUFnSUNCeVpYUjFjbTRvVGtFcFhHNGdJSDFsYkhObGUxeHVJQ0FnSUhKbGRIVnliaWgwWlcxd0xuUmlKR2x1YzNWc1lYUnBiMjVUWTI5eVpTbGNiaUFnZlZ4dWZWeHVYRzVuWlc1bExtbHVjMU5qYjNKbExtRnNiQ0E4TFNCblpXNWxMbFJUVXk1MFlpQWxQaVVnY205M2QybHpaU2dwSUNVK0pTQmtjR3g1Y2pvNmJYVjBZWFJsS0Z4dUlDQnNiMmN5WDJsdWMxTmpiM0psWDBSTlUwOGdQU0JuWlhSSmJuTjFiR0YwYVc5dVUyTnZjbVVvWTJoeUxDQlVVMU1zSUdsdWMxTmpiM0psTGtSTlUwOHBMRnh1SUNCcGJuTlRZMjl5WlY5RVRWTlBJRDBnTWw1c2IyY3lYMmx1YzFOamIzSmxYMFJOVTA4c1hHNGdJR3h2WnpKZmFXNXpVMk52Y21WZlpGUkJSeUE5SUdkbGRFbHVjM1ZzWVhScGIyNVRZMjl5WlNoamFISXNJRlJUVXl3Z2FXNXpVMk52Y21VdVpGUkJSeWtzWEc0Z0lHbHVjMU5qYjNKbFgyUlVRVWNnUFNBeVhteHZaekpmYVc1elUyTnZjbVZmWkZSQlJ5eGNiaUFnWkdsbVpsOXBibk5UWTI5eVpTQTlJR2x1YzFOamIzSmxYMlJVUVVjZ0xTQnBibk5UWTI5eVpWOUVUVk5QS1Z4dVhHNWNibUJnWUNKOSAtLT5cblxuYGBgclxuZ2VuZS5UU1MudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXFwrXFwsIFYyLCBWMykpICU+JVxuICBkcGx5cjo6c2VsZWN0KFY2LCBWNSwgVjEsIFRTUylcbmNvbG5hbWVzKGdlbmUuVFNTLnRiKSA8LSBjKFxcZW5zZW1ibFxcLCBcXGdlbmVcXCwgXFxjaHJcXCwgXFxUU1NcXClcblxuZ2V0SW5zdWxhdGlvblNjb3JlIDwtIGZ1bmN0aW9uKGNociwgVFNTLCBpbnNTY29yZS50Yil7XG4gIHRlbXAudGIgPC0gaW5zU2NvcmUudGIgJT4lIGRwbHlyOjpmaWx0ZXIoY2hyb20gPT0gY2hyLCBzdGFydCA8IFRTUywgZW5kID4gVFNTKVxuICBvdXQgPC0gdGVtcC50YiRpbnN1bGF0aW9uU2NvcmVcbiAgaWYobGVuZ3RoKG91dCkgPCAxKXtcbiAgICByZXR1cm4oTkEpXG4gIH1lbHNle1xuICAgIHJldHVybih0ZW1wLnRiJGluc3VsYXRpb25TY29yZSlcbiAgfVxufVxuXG5nZW5lLmluc1Njb3JlLmFsbCA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBsb2cyX2luc1Njb3JlX0RNU08gPSBnZXRJbnN1bGF0aW9uU2NvcmUoY2hyLCBUU1MsIGluc1Njb3JlLkRNU08pLFxuICBpbnNTY29yZV9ETVNPID0gMl5sb2cyX2luc1Njb3JlX0RNU08sXG4gIGxvZzJfaW5zU2NvcmVfZFRBRyA9IGdldEluc3VsYXRpb25TY29yZShjaHIsIFRTUywgaW5zU2NvcmUuZFRBRyksXG4gIGluc1Njb3JlX2RUQUcgPSAyXmxvZzJfaW5zU2NvcmVfZFRBRyxcbiAgZGlmZl9pbnNTY29yZSA9IGluc1Njb3JlX2RUQUcgLSBpbnNTY29yZV9ETVNPKVxuXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, V5, V1, TSS)
colnames(gene.TSS.tb) <- c(\ensembl\, \gene\, \chr\, \TSS\)

getInsulationScore <- function(chr, TSS, insScore.tb){
  temp.tb <- insScore.tb %>% dplyr::filter(chrom == chr, start < TSS, end > TSS)
  out <- temp.tb$insulationScore
  if(length(out) < 1){
    return(NA)
  }else{
    return(temp.tb$insulationScore)
  }
}

gene.insScore.all <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  log2_insScore_DMSO = getInsulationScore(chr, TSS, insScore.DMSO),
  insScore_DMSO = 2^log2_insScore_DMSO,
  log2_insScore_dTAG = getInsulationScore(chr, TSS, insScore.dTAG),
  insScore_dTAG = 2^log2_insScore_dTAG,
  diff_insScore = insScore_dTAG - insScore_DMSO)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVoyVnVaUzVVVTFNdWRHSWdQQzBnWm5KbFlXUW9hR1Z5WlNoeVpXWkVhWElzSUZ4Y2JXMHhNRjlIVWtOdE16Z3VjRFpmWjJWdVpWOXpiM0owWldRdVltVmtYRndwS1NBbFBpVmNiaUFnWkhCc2VYSTZPbTExZEdGMFpTaFVVMU1nUFNCcFptVnNjMlVvVmpRZ1BUMGdYRndyWEZ3c0lGWXlMQ0JXTXlrcElDVStKVnh1SUNCa2NHeDVjam82YzJWc1pXTjBLRlkyTENCV05Td2dWakVzSUZSVFV5bGNibU52Ykc1aGJXVnpLR2RsYm1VdVZGTlRMblJpS1NBOExTQmpLRnhjWlc1elpXMWliRnhjTENCY1hHZGxibVZjWEN3Z1hGeGphSEpjWEN3Z1hGeFVVMU5jWENsY2JseHVaMlYwU1c1emRXeGhkR2x2YmxOamIzSmxJRHd0SUdaMWJtTjBhVzl1S0dOb2Npd2dWRk5UTENCcGJuTlRZMjl5WlM1MFlpbDdYRzRnSUhSbGJYQXVkR0lnUEMwZ2FXNXpVMk52Y21VdWRHSWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9ZMmh5YjIwZ1BUMGdZMmh5TENCemRHRnlkQ0E4SUZSVFV5d2daVzVrSUQ0Z1ZGTlRLVnh1SUNCdmRYUWdQQzBnZEdWdGNDNTBZaVJwYm5OMWJHRjBhVzl1VTJOdmNtVmNiaUFnYVdZb2JHVnVaM1JvS0c5MWRDa2dQQ0F4S1h0Y2JpQWdJQ0J5WlhSMWNtNG9Ua0VwWEc0Z0lIMWxiSE5sZTF4dUlDQWdJSEpsZEhWeWJpaDBaVzF3TG5SaUpHbHVjM1ZzWVhScGIyNVRZMjl5WlNsY2JpQWdmVnh1ZlZ4dVhHNW5aVzVsTG1sdWMxTmpiM0psTG1Gc2JDQThMU0JuWlc1bExsUlRVeTUwWWlBbFBpVWdjbTkzZDJselpTZ3BJQ1UrSlNCa2NHeDVjam82YlhWMFlYUmxLRnh1SUNCc2IyY3lYMmx1YzFOamIzSmxYMFJOVTA4Z1BTQm5aWFJKYm5OMWJHRjBhVzl1VTJOdmNtVW9ZMmh5TENCVVUxTXNJR2x1YzFOamIzSmxMa1JOVTA4cExGeHVJQ0JwYm5OVFkyOXlaVjlFVFZOUElEMGdNbDVzYjJjeVgybHVjMU5qYjNKbFgwUk5VMDhzWEc0Z0lHeHZaekpmYVc1elUyTnZjbVZmWkZSQlJ5QTlJR2RsZEVsdWMzVnNZWFJwYjI1VFkyOXlaU2hqYUhJc0lGUlRVeXdnYVc1elUyTnZjbVV1WkZSQlJ5a3NYRzRnSUdsdWMxTmpiM0psWDJSVVFVY2dQU0F5WG14dlp6SmZhVzV6VTJOdmNtVmZaRlJCUnl4Y2JpQWdaR2xtWmw5cGJuTlRZMjl5WlNBOUlHbHVjMU5qYjNKbFgyUlVRVWNnTFNCcGJuTlRZMjl5WlY5RVRWTlBLVnh1WEc1Y2JtQmdZRnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbmBgYHJcbmdlbmUuVFNTLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWNiwgVjUsIFYxLCBUU1MpXG5jb2xuYW1lcyhnZW5lLlRTUy50YikgPC0gYyhcXGVuc2VtYmxcXCwgXFxnZW5lXFwsIFxcY2hyXFwsIFxcVFNTXFwpXG5cbmdldEluc3VsYXRpb25TY29yZSA8LSBmdW5jdGlvbihjaHIsIFRTUywgaW5zU2NvcmUudGIpe1xuICB0ZW1wLnRiIDwtIGluc1Njb3JlLnRiICU+JSBkcGx5cjo6ZmlsdGVyKGNocm9tID09IGNociwgc3RhcnQgPCBUU1MsIGVuZCA+IFRTUylcbiAgb3V0IDwtIHRlbXAudGIkaW5zdWxhdGlvblNjb3JlXG4gIGlmKGxlbmd0aChvdXQpIDwgMSl7XG4gICAgcmV0dXJuKE5BKVxuICB9ZWxzZXtcbiAgICByZXR1cm4odGVtcC50YiRpbnN1bGF0aW9uU2NvcmUpXG4gIH1cbn1cblxuZ2VuZS5pbnNTY29yZS5hbGwgPC0gZ2VuZS5UU1MudGIgJT4lIHJvd3dpc2UoKSAlPiUgZHBseXI6Om11dGF0ZShcbiAgbG9nMl9pbnNTY29yZV9ETVNPID0gZ2V0SW5zdWxhdGlvblNjb3JlKGNociwgVFNTLCBpbnNTY29yZS5ETVNPKSxcbiAgaW5zU2NvcmVfRE1TTyA9IDJebG9nMl9pbnNTY29yZV9ETVNPLFxuICBsb2cyX2luc1Njb3JlX2RUQUcgPSBnZXRJbnN1bGF0aW9uU2NvcmUoY2hyLCBUU1MsIGluc1Njb3JlLmRUQUcpLFxuICBpbnNTY29yZV9kVEFHID0gMl5sb2cyX2luc1Njb3JlX2RUQUcsXG4gIGRpZmZfaW5zU2NvcmUgPSBpbnNTY29yZV9kVEFHIC0gaW5zU2NvcmVfRE1TTylcblxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2VuZS5UU1MudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXFwrXFwsIFYyLCBWMykpICU+JVxuICBkcGx5cjo6c2VsZWN0KFY2LCBWNSwgVjEsIFRTUylcbmNvbG5hbWVzKGdlbmUuVFNTLnRiKSA8LSBjKFxcZW5zZW1ibFxcLCBcXGdlbmVcXCwgXFxjaHJcXCwgXFxUU1NcXClcblxuZ2V0SW5zdWxhdGlvblNjb3JlIDwtIGZ1bmN0aW9uKGNociwgVFNTLCBpbnNTY29yZS50Yil7XG4gIHRlbXAudGIgPC0gaW5zU2NvcmUudGIgJT4lIGRwbHlyOjpmaWx0ZXIoY2hyb20gPT0gY2hyLCBzdGFydCA8IFRTUywgZW5kID4gVFNTKVxuICBvdXQgPC0gdGVtcC50YiRpbnN1bGF0aW9uU2NvcmVcbiAgaWYobGVuZ3RoKG91dCkgPCAxKXtcbiAgICByZXR1cm4oTkEpXG4gIH1lbHNle1xuICAgIHJldHVybih0ZW1wLnRiJGluc3VsYXRpb25TY29yZSlcbiAgfVxufVxuXG5nZW5lLmluc1Njb3JlLmFsbCA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBsb2cyX2luc1Njb3JlX0RNU08gPSBnZXRJbnN1bGF0aW9uU2NvcmUoY2hyLCBUU1MsIGluc1Njb3JlLkRNU08pLFxuICBpbnNTY29yZV9ETVNPID0gMl5sb2cyX2luc1Njb3JlX0RNU08sXG4gIGxvZzJfaW5zU2NvcmVfZFRBRyA9IGdldEluc3VsYXRpb25TY29yZShjaHIsIFRTUywgaW5zU2NvcmUuZFRBRyksXG4gIGluc1Njb3JlX2RUQUcgPSAyXmxvZzJfaW5zU2NvcmVfZFRBRyxcbiAgZGlmZl9pbnNTY29yZSA9IGluc1Njb3JlX2RUQUcgLSBpbnNTY29yZV9ETVNPKVxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, V5, V1, TSS)
colnames(gene.TSS.tb) <- c(\ensembl\, \gene\, \chr\, \TSS\)

getInsulationScore <- function(chr, TSS, insScore.tb){
  temp.tb <- insScore.tb %>% dplyr::filter(chrom == chr, start < TSS, end > TSS)
  out <- temp.tb$insulationScore
  if(length(out) < 1){
    return(NA)
  }else{
    return(temp.tb$insulationScore)
  }
}

gene.insScore.all <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  log2_insScore_DMSO = getInsulationScore(chr, TSS, insScore.DMSO),
  insScore_DMSO = 2^log2_insScore_DMSO,
  log2_insScore_dTAG = getInsulationScore(chr, TSS, insScore.dTAG),
  insScore_dTAG = 2^log2_insScore_dTAG,
  diff_insScore = insScore_dTAG - insScore_DMSO)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



## [2.14] Looking deeper into TAD and insulation
### Insulation score of TSS?
#### Importing insulation score

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJKYlhCdmNuUnBibWNnVkVGRUlHSnZkVzVrWVhKcFpYTmNiblJoWkY5aWIzVnVaR0Z5ZVNBOExTQm1jbVZoWkNob1pYSmxLRndpTGk0dkxpNHZjbVZ6ZFd4MEwxUkJSRndpTENCY0lsUkJSRjh5Tld0aVh6RXlOV3RpWDI5MGMzVmZZbTkxYm1SaGNtbGxjMTlITVVSTlUwOHVZbVZrWENJcEtWeHVZMjlzYm1GdFpYTW9kR0ZrWDJKdmRXNWtZWEo1S1NBOExTQmpLRndpWTJoeVhDSXNJRndpYzNSaGNuUmNJaXdnWENKbGJtUmNJaWxjYm5SaFpGOWliM1Z1WkdGeWVTQThMU0IwWVdSZlltOTFibVJoY25rZ0pUNGxJR1J3YkhseU9qcHRkWFJoZEdVb2RHRmtYMmxrSUQwZ2NHRnpkR1VvWTJoeUxDQnpkR0Z5ZEN3Z1pXNWtMQ0J6WlhBZ1BTQmNJbDljSWlrc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR05sYm5SbGNpQTlJQ2h6ZEdGeWRDQXJJR1Z1WkNrdk1pbGNibHh1Wm1sdVpFTnNiM05sYzNSVVFVUkNiM1Z1WkdGeWVTQThMU0JtZFc1amRHbHZiaWhqYUhKdmJTd2dWRk5UTENCMFlXUmZZbTkxYm1SaGNua3BlMXh1SUNCMFpXMXdJRHd0SUhSaFpGOWliM1Z1WkdGeWVTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaGphSElnUFQwZ1kyaHliMjBwSUNVK0pWeHVJQ0FnSUdSd2JIbHlPanB0ZFhSaGRHVW9aR2x6ZEdGdVkyVWdQU0JoWW5Nb1kyVnVkR1Z5SUMwZ1ZGTlRLU2tnSlQ0bFhHNGdJQ0FnYzJ4cFkyVmZiV2x1S0dScGMzUmhibU5sS1Z4dUlDQnBaaWh1Y205M0tIUmxiWEFwSUQwOUlERXBlMXh1SUNBZ0lDQWdjbVYwZFhKdUtIUmxiWEFrWTJWdWRHVnlLVnh1SUNCOVpXeHpaWHRjYmlBZ0lDQnlaWFIxY200b1RrRXBYRzRnSUgxY2JuMWNibHh1WEc1blpXNWxMbWx1YzFOamIzSmxMbUZzYkNBOExTQm5aVzVsTG1sdWMxTmpiM0psTG1Gc2JDQWxQaVVnY205M2QybHpaU2dwSUNVK0pWeHVJQ0JrY0d4NWNqbzZiWFYwWVhSbEtHTnNiM05sYzNSQ2IzVnVaR0Z5ZVNBOUlHWnBibVJEYkc5elpYTjBWRUZFUW05MWJtUmhjbmtvWTJoeUxDQlVVMU1zSUhSaFpGOWliM1Z1WkdGeWVTa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiRzluTWw5aWIzVnVaR0Z5ZVVsdWMxTmpiM0psWDBSTlUwOGdQU0JuWlhSSmJuTjFiR0YwYVc5dVUyTnZjbVVvWTJoeUxDQmpiRzl6WlhOMFFtOTFibVJoY25rc0lHbHVjMU5qYjNKbExrUk5VMDhwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdKdmRXNWtZWEo1U1c1elUyTnZjbVZmUkUxVFR5QTlJREplYkc5bk1sOWliM1Z1WkdGeWVVbHVjMU5qYjNKbFgwUk5VMDhzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYkc5bk1sOWliM1Z1WkdGeWVVbHVjMU5qYjNKbFgyUlVRVWNnUFNCblpYUkpibk4xYkdGMGFXOXVVMk52Y21Vb1kyaHlMQ0JqYkc5elpYTjBRbTkxYm1SaGNua3NJR2x1YzFOamIzSmxMbVJVUVVjcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHSnZkVzVrWVhKNVNXNXpVMk52Y21WZlpGUkJSeUE5SURKZWJHOW5NbDlpYjNWdVpHRnllVWx1YzFOamIzSmxYMlJVUVVjc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1pHbG1abDlpYjNWdVpHRnllVWx1YzFOamIzSmxJRDBnWW05MWJtUmhjbmxKYm5OVFkyOXlaVjlrVkVGSElDMGdZbTkxYm1SaGNubEpibk5UWTI5eVpWOUVUVk5QS1Z4dVhHNXpZWFpsVWtSVEtHZGxibVV1YVc1elUyTnZjbVV1WVd4c0xDQm9aWEpsS0hKbGMzVnNkRVJwY2l3Z1hDSm5aVzVsTG1sdWMxTmpiM0psTG1Gc2JDNXlaSE5jSWlrcFhHNW5aVzVsTG1sdWMxTmpiM0psTG1Gc2JDQThMU0J5WldGa1VrUlRLR2hsY21Vb2NtVnpkV3gwUkdseUxDQmNJbWRsYm1VdWFXNXpVMk52Y21VdVlXeHNMbkprYzF3aUtTbGNibUJnWUNKOSAtLT5cblxuYGBgclxuIyBJbXBvcnRpbmcgVEFEIGJvdW5kYXJpZXNcbnRhZF9ib3VuZGFyeSA8LSBmcmVhZChoZXJlKFxcLi4vLi4vcmVzdWx0L1RBRFxcLCBcXFRBRF8yNWtiXzEyNWtiX290c3VfYm91bmRhcmllc19HMURNU08uYmVkXFwpKVxuY29sbmFtZXModGFkX2JvdW5kYXJ5KSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnRhZF9ib3VuZGFyeSA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjptdXRhdGUodGFkX2lkID0gcGFzdGUoY2hyLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNlbnRlciA9IChzdGFydCArIGVuZCkvMilcblxuZmluZENsb3Nlc3RUQURCb3VuZGFyeSA8LSBmdW5jdGlvbihjaHJvbSwgVFNTLCB0YWRfYm91bmRhcnkpe1xuICB0ZW1wIDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6OmZpbHRlcihjaHIgPT0gY2hyb20pICU+JVxuICAgIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBhYnMoY2VudGVyIC0gVFNTKSkgJT4lXG4gICAgc2xpY2VfbWluKGRpc3RhbmNlKVxuICBpZihucm93KHRlbXApID09IDEpe1xuICAgICAgcmV0dXJuKHRlbXAkY2VudGVyKVxuICB9ZWxzZXtcbiAgICByZXR1cm4oTkEpXG4gIH1cbn1cblxuXG5nZW5lLmluc1Njb3JlLmFsbCA8LSBnZW5lLmluc1Njb3JlLmFsbCAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKGNsb3Nlc3RCb3VuZGFyeSA9IGZpbmRDbG9zZXN0VEFEQm91bmRhcnkoY2hyLCBUU1MsIHRhZF9ib3VuZGFyeSksXG4gICAgICAgICAgICAgICAgbG9nMl9ib3VuZGFyeUluc1Njb3JlX0RNU08gPSBnZXRJbnN1bGF0aW9uU2NvcmUoY2hyLCBjbG9zZXN0Qm91bmRhcnksIGluc1Njb3JlLkRNU08pLFxuICAgICAgICAgICAgICAgIGJvdW5kYXJ5SW5zU2NvcmVfRE1TTyA9IDJebG9nMl9ib3VuZGFyeUluc1Njb3JlX0RNU08sXG4gICAgICAgICAgICAgICAgbG9nMl9ib3VuZGFyeUluc1Njb3JlX2RUQUcgPSBnZXRJbnN1bGF0aW9uU2NvcmUoY2hyLCBjbG9zZXN0Qm91bmRhcnksIGluc1Njb3JlLmRUQUcpLFxuICAgICAgICAgICAgICAgIGJvdW5kYXJ5SW5zU2NvcmVfZFRBRyA9IDJebG9nMl9ib3VuZGFyeUluc1Njb3JlX2RUQUcsXG4gICAgICAgICAgICAgICAgZGlmZl9ib3VuZGFyeUluc1Njb3JlID0gYm91bmRhcnlJbnNTY29yZV9kVEFHIC0gYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuXG5zYXZlUkRTKGdlbmUuaW5zU2NvcmUuYWxsLCBoZXJlKHJlc3VsdERpciwgXFxnZW5lLmluc1Njb3JlLmFsbC5yZHNcXCkpXG5nZW5lLmluc1Njb3JlLmFsbCA8LSByZWFkUkRTKGhlcmUocmVzdWx0RGlyLCBcXGdlbmUuaW5zU2NvcmUuYWxsLnJkc1xcKSlcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
# Importing TAD boundaries
tad_boundary <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\))
colnames(tad_boundary) <- c(\chr\, \start\, \end\)
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = \_\),
                                               center = (start + end)/2)

findClosestTADBoundary <- function(chrom, TSS, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom) %>%
    dplyr::mutate(distance = abs(center - TSS)) %>%
    slice_min(distance)
  if(nrow(temp) == 1){
      return(temp$center)
  }else{
    return(NA)
  }
}


gene.insScore.all <- gene.insScore.all %>% rowwise() %>%
  dplyr::mutate(closestBoundary = findClosestTADBoundary(chr, TSS, tad_boundary),
                log2_boundaryInsScore_DMSO = getInsulationScore(chr, closestBoundary, insScore.DMSO),
                boundaryInsScore_DMSO = 2^log2_boundaryInsScore_DMSO,
                log2_boundaryInsScore_dTAG = getInsulationScore(chr, closestBoundary, insScore.dTAG),
                boundaryInsScore_dTAG = 2^log2_boundaryInsScore_dTAG,
                diff_boundaryInsScore = boundaryInsScore_dTAG - boundaryInsScore_DMSO)

saveRDS(gene.insScore.all, here(resultDir, \gene.insScore.all.rds\))
gene.insScore.all <- readRDS(here(resultDir, \gene.insScore.all.rds\))



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QkpiWEJ2Y25ScGJtY2dWRUZFSUdKdmRXNWtZWEpwWlhOY2JuUmhaRjlpYjNWdVpHRnllU0E4TFNCbWNtVmhaQ2hvWlhKbEtGeGNMaTR2TGk0dmNtVnpkV3gwTDFSQlJGeGNMQ0JjWEZSQlJGOHlOV3RpWHpFeU5XdGlYMjkwYzNWZlltOTFibVJoY21sbGMxOUhNVVJOVTA4dVltVmtYRndwS1Z4dVkyOXNibUZ0WlhNb2RHRmtYMkp2ZFc1a1lYSjVLU0E4TFNCaktGeGNZMmh5WEZ3c0lGeGNjM1JoY25SY1hDd2dYRnhsYm1SY1hDbGNiblJoWkY5aWIzVnVaR0Z5ZVNBOExTQjBZV1JmWW05MWJtUmhjbmtnSlQ0bElHUndiSGx5T2pwdGRYUmhkR1VvZEdGa1gybGtJRDBnY0dGemRHVW9ZMmh5TENCemRHRnlkQ3dnWlc1a0xDQnpaWEFnUFNCY1hGOWNYQ2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHTmxiblJsY2lBOUlDaHpkR0Z5ZENBcklHVnVaQ2t2TWlsY2JseHVabWx1WkVOc2IzTmxjM1JVUVVSQ2IzVnVaR0Z5ZVNBOExTQm1kVzVqZEdsdmJpaGphSEp2YlN3Z1ZGTlRMQ0IwWVdSZlltOTFibVJoY25rcGUxeHVJQ0IwWlcxd0lEd3RJSFJoWkY5aWIzVnVaR0Z5ZVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2loamFISWdQVDBnWTJoeWIyMHBJQ1UrSlZ4dUlDQWdJR1J3YkhseU9qcHRkWFJoZEdVb1pHbHpkR0Z1WTJVZ1BTQmhZbk1vWTJWdWRHVnlJQzBnVkZOVEtTa2dKVDRsWEc0Z0lDQWdjMnhwWTJWZmJXbHVLR1JwYzNSaGJtTmxLVnh1SUNCcFppaHVjbTkzS0hSbGJYQXBJRDA5SURFcGUxeHVJQ0FnSUNBZ2NtVjBkWEp1S0hSbGJYQWtZMlZ1ZEdWeUtWeHVJQ0I5Wld4elpYdGNiaUFnSUNCeVpYUjFjbTRvVGtFcFhHNGdJSDFjYm4xY2JseHVYRzVuWlc1bExtbHVjMU5qYjNKbExtRnNiQ0E4TFNCblpXNWxMbWx1YzFOamIzSmxMbUZzYkNBbFBpVWdjbTkzZDJselpTZ3BJQ1UrSlZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0dOc2IzTmxjM1JDYjNWdVpHRnllU0E5SUdacGJtUkRiRzl6WlhOMFZFRkVRbTkxYm1SaGNua29ZMmh5TENCVVUxTXNJSFJoWkY5aWIzVnVaR0Z5ZVNrc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JHOW5NbDlpYjNWdVpHRnllVWx1YzFOamIzSmxYMFJOVTA4Z1BTQm5aWFJKYm5OMWJHRjBhVzl1VTJOdmNtVW9ZMmh5TENCamJHOXpaWE4wUW05MWJtUmhjbmtzSUdsdWMxTmpiM0psTGtSTlUwOHBMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR0p2ZFc1a1lYSjVTVzV6VTJOdmNtVmZSRTFUVHlBOUlESmViRzluTWw5aWIzVnVaR0Z5ZVVsdWMxTmpiM0psWDBSTlUwOHNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiRzluTWw5aWIzVnVaR0Z5ZVVsdWMxTmpiM0psWDJSVVFVY2dQU0JuWlhSSmJuTjFiR0YwYVc5dVUyTnZjbVVvWTJoeUxDQmpiRzl6WlhOMFFtOTFibVJoY25rc0lHbHVjMU5qYjNKbExtUlVRVWNwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdKdmRXNWtZWEo1U1c1elUyTnZjbVZmWkZSQlJ5QTlJREplYkc5bk1sOWliM1Z1WkdGeWVVbHVjMU5qYjNKbFgyUlVRVWNzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWkdsbVpsOWliM1Z1WkdGeWVVbHVjMU5qYjNKbElEMGdZbTkxYm1SaGNubEpibk5UWTI5eVpWOWtWRUZISUMwZ1ltOTFibVJoY25sSmJuTlRZMjl5WlY5RVRWTlBLVnh1WEc1ellYWmxVa1JUS0dkbGJtVXVhVzV6VTJOdmNtVXVZV3hzTENCb1pYSmxLSEpsYzNWc2RFUnBjaXdnWEZ4blpXNWxMbWx1YzFOamIzSmxMbUZzYkM1eVpITmNYQ2twWEc1blpXNWxMbWx1YzFOamIzSmxMbUZzYkNBOExTQnlaV0ZrVWtSVEtHaGxjbVVvY21WemRXeDBSR2x5TENCY1hHZGxibVV1YVc1elUyTnZjbVV1WVd4c0xuSmtjMXhjS1NsY2JtQmdZRnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbmBgYHJcbiMgSW1wb3J0aW5nIFRBRCBib3VuZGFyaWVzXG50YWRfYm91bmRhcnkgPC0gZnJlYWQoaGVyZShcXC4uLy4uL3Jlc3VsdC9UQURcXCwgXFxUQURfMjVrYl8xMjVrYl9vdHN1X2JvdW5kYXJpZXNfRzFETVNPLmJlZFxcKSlcbmNvbG5hbWVzKHRhZF9ib3VuZGFyeSkgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG50YWRfYm91bmRhcnkgPC0gdGFkX2JvdW5kYXJ5ICU+JSBkcGx5cjo6bXV0YXRlKHRhZF9pZCA9IHBhc3RlKGNociwgc3RhcnQsIGVuZCwgc2VwID0gXFxfXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjZW50ZXIgPSAoc3RhcnQgKyBlbmQpLzIpXG5cbmZpbmRDbG9zZXN0VEFEQm91bmRhcnkgPC0gZnVuY3Rpb24oY2hyb20sIFRTUywgdGFkX2JvdW5kYXJ5KXtcbiAgdGVtcCA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjpmaWx0ZXIoY2hyID09IGNocm9tKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gYWJzKGNlbnRlciAtIFRTUykpICU+JVxuICAgIHNsaWNlX21pbihkaXN0YW5jZSlcbiAgaWYobnJvdyh0ZW1wKSA9PSAxKXtcbiAgICAgIHJldHVybih0ZW1wJGNlbnRlcilcbiAgfWVsc2V7XG4gICAgcmV0dXJuKE5BKVxuICB9XG59XG5cblxuZ2VuZS5pbnNTY29yZS5hbGwgPC0gZ2VuZS5pbnNTY29yZS5hbGwgJT4lIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjbG9zZXN0Qm91bmRhcnkgPSBmaW5kQ2xvc2VzdFRBREJvdW5kYXJ5KGNociwgVFNTLCB0YWRfYm91bmRhcnkpLFxuICAgICAgICAgICAgICAgIGxvZzJfYm91bmRhcnlJbnNTY29yZV9ETVNPID0gZ2V0SW5zdWxhdGlvblNjb3JlKGNociwgY2xvc2VzdEJvdW5kYXJ5LCBpbnNTY29yZS5ETVNPKSxcbiAgICAgICAgICAgICAgICBib3VuZGFyeUluc1Njb3JlX0RNU08gPSAyXmxvZzJfYm91bmRhcnlJbnNTY29yZV9ETVNPLFxuICAgICAgICAgICAgICAgIGxvZzJfYm91bmRhcnlJbnNTY29yZV9kVEFHID0gZ2V0SW5zdWxhdGlvblNjb3JlKGNociwgY2xvc2VzdEJvdW5kYXJ5LCBpbnNTY29yZS5kVEFHKSxcbiAgICAgICAgICAgICAgICBib3VuZGFyeUluc1Njb3JlX2RUQUcgPSAyXmxvZzJfYm91bmRhcnlJbnNTY29yZV9kVEFHLFxuICAgICAgICAgICAgICAgIGRpZmZfYm91bmRhcnlJbnNTY29yZSA9IGJvdW5kYXJ5SW5zU2NvcmVfZFRBRyAtIGJvdW5kYXJ5SW5zU2NvcmVfRE1TTylcblxuc2F2ZVJEUyhnZW5lLmluc1Njb3JlLmFsbCwgaGVyZShyZXN1bHREaXIsIFxcZ2VuZS5pbnNTY29yZS5hbGwucmRzXFwpKVxuZ2VuZS5pbnNTY29yZS5hbGwgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXFxnZW5lLmluc1Njb3JlLmFsbC5yZHNcXCkpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBJbXBvcnRpbmcgVEFEIGJvdW5kYXJpZXNcbnRhZF9ib3VuZGFyeSA8LSBmcmVhZChoZXJlKFxcLi4vLi4vcmVzdWx0L1RBRFxcLCBcXFRBRF8yNWtiXzEyNWtiX290c3VfYm91bmRhcmllc19HMURNU08uYmVkXFwpKVxuY29sbmFtZXModGFkX2JvdW5kYXJ5KSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnRhZF9ib3VuZGFyeSA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjptdXRhdGUodGFkX2lkID0gcGFzdGUoY2hyLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNlbnRlciA9IChzdGFydCArIGVuZCkvMilcblxuZmluZENsb3Nlc3RUQURCb3VuZGFyeSA8LSBmdW5jdGlvbihjaHJvbSwgVFNTLCB0YWRfYm91bmRhcnkpe1xuICB0ZW1wIDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6OmZpbHRlcihjaHIgPT0gY2hyb20pICU+JVxuICAgIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBhYnMoY2VudGVyIC0gVFNTKSkgJT4lXG4gICAgc2xpY2VfbWluKGRpc3RhbmNlKVxuICBpZihucm93KHRlbXApID09IDEpe1xuICAgICAgcmV0dXJuKHRlbXAkY2VudGVyKVxuICB9ZWxzZXtcbiAgICByZXR1cm4oTkEpXG4gIH1cbn1cblxuXG5nZW5lLmluc1Njb3JlLmFsbCA8LSBnZW5lLmluc1Njb3JlLmFsbCAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKGNsb3Nlc3RCb3VuZGFyeSA9IGZpbmRDbG9zZXN0VEFEQm91bmRhcnkoY2hyLCBUU1MsIHRhZF9ib3VuZGFyeSksXG4gICAgICAgICAgICAgICAgbG9nMl9ib3VuZGFyeUluc1Njb3JlX0RNU08gPSBnZXRJbnN1bGF0aW9uU2NvcmUoY2hyLCBjbG9zZXN0Qm91bmRhcnksIGluc1Njb3JlLkRNU08pLFxuICAgICAgICAgICAgICAgIGJvdW5kYXJ5SW5zU2NvcmVfRE1TTyA9IDJebG9nMl9ib3VuZGFyeUluc1Njb3JlX0RNU08sXG4gICAgICAgICAgICAgICAgbG9nMl9ib3VuZGFyeUluc1Njb3JlX2RUQUcgPSBnZXRJbnN1bGF0aW9uU2NvcmUoY2hyLCBjbG9zZXN0Qm91bmRhcnksIGluc1Njb3JlLmRUQUcpLFxuICAgICAgICAgICAgICAgIGJvdW5kYXJ5SW5zU2NvcmVfZFRBRyA9IDJebG9nMl9ib3VuZGFyeUluc1Njb3JlX2RUQUcsXG4gICAgICAgICAgICAgICAgZGlmZl9ib3VuZGFyeUluc1Njb3JlID0gYm91bmRhcnlJbnNTY29yZV9kVEFHIC0gYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuXG5zYXZlUkRTKGdlbmUuaW5zU2NvcmUuYWxsLCBoZXJlKHJlc3VsdERpciwgXFxnZW5lLmluc1Njb3JlLmFsbC5yZHNcXCkpXG5nZW5lLmluc1Njb3JlLmFsbCA8LSByZWFkUkRTKGhlcmUocmVzdWx0RGlyLCBcXGdlbmUuaW5zU2NvcmUuYWxsLnJkc1xcKSlcbmBgYFxuYGBgIn0= -->

```r
```r
# Importing TAD boundaries
tad_boundary <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\))
colnames(tad_boundary) <- c(\chr\, \start\, \end\)
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = \_\),
                                               center = (start + end)/2)

findClosestTADBoundary <- function(chrom, TSS, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom) %>%
    dplyr::mutate(distance = abs(center - TSS)) %>%
    slice_min(distance)
  if(nrow(temp) == 1){
      return(temp$center)
  }else{
    return(NA)
  }
}


gene.insScore.all <- gene.insScore.all %>% rowwise() %>%
  dplyr::mutate(closestBoundary = findClosestTADBoundary(chr, TSS, tad_boundary),
                log2_boundaryInsScore_DMSO = getInsulationScore(chr, closestBoundary, insScore.DMSO),
                boundaryInsScore_DMSO = 2^log2_boundaryInsScore_DMSO,
                log2_boundaryInsScore_dTAG = getInsulationScore(chr, closestBoundary, insScore.dTAG),
                boundaryInsScore_dTAG = 2^log2_boundaryInsScore_dTAG,
                diff_boundaryInsScore = boundaryInsScore_dTAG - boundaryInsScore_DMSO)

saveRDS(gene.insScore.all, here(resultDir, \gene.insScore.all.rds\))
gene.insScore.all <- readRDS(here(resultDir, \gene.insScore.all.rds\))
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Linking to gene

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XCIpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcIikpJGdlbmVcblxuXG5nZW5lLmluc1Njb3JlIDwtIGdlbmUuaW5zU2NvcmUuYWxsICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBncm91cDEsIFwiZ3JvdXAxXCIsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAyLCBcImdyb3VwMlwiLCBOQSkpKSAlPiUgXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSlcblxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJHNjb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRzY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuXG5wbG90X2luc1Njb3JlIDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAtMS41LCB5bWF4ID0gMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwiZ3JvdXAxXCIsIFwiZ3JvdXAyXCIpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBcIi5cIiwgZmlsbCA9IGdyb3VwLCB5ID0gLXNjb3JlKSkgKyBcbiAgICBsYWJzKHggPSBOVUxMLCB5ID0gXCItIEluc3VsYXRpb24gc2NvcmVcIikgKyAgIyBSZW1vdmUgeC1heGlzIHRpdGxlXG4gICAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gcmV2KChjKFwiIzc3Nzc3N1wiLCBcIiNGMjhFMkNcIikpKSkgK1xuXG4gICAgaW50cm9kYXRhdml6OjpnZW9tX3NwbGl0X3Zpb2xpbihsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFscGhhID0gLjQpICtcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXCJibGFja1wiLFxuICAgICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIixcbiAgICAgICAgICAgICAgICAgb3V0bGllci5zaGFwZSA9IE5BLCAgYWxwaGEgPSAwLjYsIHNob3cubGVnZW5kID0gRkFMU0UpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgICBzdGF0X3N1bW1hcnkoXG4gICAgICBhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sXG4gICAgICBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgICAgZmlsbCA9IFwiYmxhY2tcIiwgY29sb3IgPSBcImJsYWNrXCIsIHBvc2l0aW9uID0gcG9zaXRpb25fZG9kZ2UoLjMpXG4gICAgKSArXG4gICAgXG4gICAgIyBcbiAgICAjIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBjb2xvciA9IFwiYmxhY2tcIiwgbGluZXdpZHRoID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCIsIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgIyBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsICBjb2xvciA9IFwiYmxhY2tcIiwgbGluZXdpZHRoID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCIsXG4gICAgIyAgICAgICAgICAgICAgb3V0bGllci5zaXplID0gMSwgb3V0bGllci5zdHJva2UgPSBOQSkgK1xuICAgICMgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDEsIGZpbGwgPSBcInJlZFwiLCBjb2xvciA9IFwiYmxhY2tcIikgKyBcbiAgICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0KSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFwicDEyOiBcIiwgY29udlB2YWx1ZShwMTIpKSxcbiAgICAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICAgIHRoZW1lKFxuICAgICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgICAgc2l6ZSA9IGZvbnRTaXplTSxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplTSxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCAgICAgICMgUm90YXRlIHgtYXhpcyBsYWJlbHMgNDUgZGVncmVlc1xuICAgICAgaGp1c3QgPSAxLCAgICAgICAjIEFkanVzdCBob3Jpem9udGFsIGp1c3RpZmljYXRpb25cbiAgICAgIHZqdXN0ID0gMSAgICAgICAgIyBBZGp1c3QgdmVydGljYWwganVzdGlmaWNhdGlvblxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXCJ0cmFuc3BhcmVudFwiKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICAgICkrICAgZ3VpZGVzKFxuICAgICAgZmlsbCA9IGd1aWRlX2xlZ2VuZChcbiAgICAgICAga2V5d2lkdGggPSAwLjIsICAjIEFkanVzdCB0aGUgd2lkdGggb2YgdGhlIGxlZ2VuZCBrZXlzXG4gICAgICAgIGtleWhlaWdodCA9IDAuMiAgIyBBZGp1c3QgdGhlIGhlaWdodCBvZiB0aGUgbGVnZW5kIGtleXNcbiAgICAgICkpXG4gICAgICBcbiAgICAgIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXCJpbnN1bGF0aW9uX3Njb3JlX2JpbmFyeUdyb3VwX1wiLCBub3RlKVxuICB3aWR0aCA8LSBwYW5lbFNpemUoMS41NSkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS4yKSptbVRvSW5jaFxuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG4jIERNU09cbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcImdyb3VwXCIsIFwic2NvcmVcIilcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXCJuZWFyZXN0Qm91bmRhcnlfRE1TT19iaW5hcnlHcm91cFwiLCB5bWluID0gLTEuMSwgeW1heCA9IC0wLjUpXG5cbiMgZFRBR1xudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBib3VuZGFyeUluc1Njb3JlX2RUQUcpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFwiZ3JvdXBcIiwgXCJzY29yZVwiKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcIm5lYXJlc3RCb3VuZGFyeV9kVEFHX2JpbmFyeUdyb3VwXCIsIHltaW4gPSAgLTEuMSwgeW1heCA9IC0wLjUpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFwiZ3JvdXBcIiwgXCJzY29yZVwiKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcIm5lYXJlc3RCb3VuZGFyeV9kaWZmX2JpbmFyeUdyb3VwXCIsIHltaW4gPSAtMC4zLCB5bWF4ID0gMC4xKVxuYGBgIn0= -->\n\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\ngene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\, NA))) %>% \n  dplyr::filter(!is.na(group))\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$score\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_insScore <- function(temp.tb, note, ymin = -1.5, ymax = 0){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \\.\\, fill = group, y = -score)) + \n    labs(x = NULL, y = \\- Insulation score\\) +  # Remove x-axis title\n    scale_fill_manual(values = rev((c(\\#777777\\, \\#F28E2C\\)))) +\n\n    introdataviz::geom_split_violin(linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n                                    alpha = .4) +\n    geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + theme_classic() +\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    \n    # \n    # geom_violin(aes(fill = group), color = \\black\\, linewidth = lineThick*mmToLineUnit, lineend = \\square\\, show.legend = FALSE) + \n    # geom_boxplot(width = 0.1,  color = \\black\\, linewidth = lineThick*mmToLineUnit, lineend = \\square\\,\n    #              outlier.size = 1, outlier.stroke = NA) +\n    # stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 1, fill = \\red\\, color = \\black\\) + \n    geom_hline(yintercept = 0, linewidth = lineThick*mmToLineUnit) +\n    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +\n    annotate(\\text\\, x = 1, y = ymin + 1, label = paste0(\\p12: \\, convPvalue(p12)),\n             color = \\black\\, hjust = 0, size = 3) +\n    theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )+   guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      ))\n      \n      \n  fileName <- paste0(\\insulation_score_binaryGroup_\\, note)\n  width <- panelSize(1.55)*mmToInch\nheight <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# DMSO\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_DMSO_binaryGroup\\, ymin = -1.1, ymax = -0.5)\n\n# dTAG\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_dTAG_binaryGroup\\, ymin =  -1.1, ymax = -0.5)\n\n# diff\ntemp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_diff_binaryGroup\\, ymin = -0.3, ymax = 0.1)\n```\n\n<!-- rnb-source-end -->\n"} -->
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\, NA))) %>% 
  dplyr::filter(!is.na(group))


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_insScore <- function(temp.tb, note, ymin = -1.5, ymax = 0){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = \.\, fill = group, y = -score)) + 
    labs(x = NULL, y = \- Insulation score\) +  # Remove x-axis title
    scale_fill_manual(values = rev((c(\#777777\, \#F28E2C\)))) +

    introdataviz::geom_split_violin(linewidth = lineMedium * mmToLineUnit, lineend = \square\,
                                    alpha = .4) +
    geom_boxplot(width = 0.3, color = \black\,
                 linewidth = lineMedium * mmToLineUnit, lineend = \square\,
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + theme_classic() +
    stat_summary(
      aes(group = group), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) +
    
    # 
    # geom_violin(aes(fill = group), color = \black\, linewidth = lineThick*mmToLineUnit, lineend = \square\, show.legend = FALSE) + 
    # geom_boxplot(width = 0.1,  color = \black\, linewidth = lineThick*mmToLineUnit, lineend = \square\,
    #              outlier.size = 1, outlier.stroke = NA) +
    # stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 1, fill = \red\, color = \black\) + 
    geom_hline(yintercept = 0, linewidth = lineThick*mmToLineUnit) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p12: \, convPvalue(p12)),
             color = \black\, hjust = 0, size = 3) +
    theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )+   guides(
      fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
      ))
      
      
  fileName <- paste0(\insulation_score_binaryGroup_\, note)
  width <- panelSize(1.55)*mmToInch
height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO_binaryGroup\, ymin = -1.1, ymax = -0.5)

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_dTAG_binaryGroup\, ymin =  -1.1, ymax = -0.5)

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_diff_binaryGroup\, ymin = -0.3, ymax = 0.1)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuXG5nZW5lLmluc1Njb3JlIDwtIGdlbmUuaW5zU2NvcmUuYWxsICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBncm91cDEsIFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAyLCBcXGdyb3VwMlxcLCBOQSkpKSAlPiUgXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSlcblxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJHNjb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRzY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuXG5wbG90X2luc1Njb3JlIDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAtMS41LCB5bWF4ID0gMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBcXC5cXCwgZmlsbCA9IGdyb3VwLCB5ID0gLXNjb3JlKSkgKyBcbiAgICBsYWJzKHggPSBOVUxMLCB5ID0gXFwtIEluc3VsYXRpb24gc2NvcmVcXCkgKyAgIyBSZW1vdmUgeC1heGlzIHRpdGxlXG4gICAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gcmV2KChjKFxcIzc3Nzc3N1xcLCBcXCNGMjhFMkNcXCkpKSkgK1xuXG4gICAgaW50cm9kYXRhdml6OjpnZW9tX3NwbGl0X3Zpb2xpbihsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFscGhhID0gLjQpICtcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgICAgb3V0bGllci5zaGFwZSA9IE5BLCAgYWxwaGEgPSAwLjYsIHNob3cubGVnZW5kID0gRkFMU0UpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgICBzdGF0X3N1bW1hcnkoXG4gICAgICBhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sXG4gICAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgICAgZmlsbCA9IFxcYmxhY2tcXCwgY29sb3IgPSBcXGJsYWNrXFwsIHBvc2l0aW9uID0gcG9zaXRpb25fZG9kZ2UoLjMpXG4gICAgKSArXG4gICAgXG4gICAgIyBcbiAgICAjIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBjb2xvciA9IFxcYmxhY2tcXCwgbGluZXdpZHRoID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgIyBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsICBjb2xvciA9IFxcYmxhY2tcXCwgbGluZXdpZHRoID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsXG4gICAgIyAgICAgICAgICAgICAgb3V0bGllci5zaXplID0gMSwgb3V0bGllci5zdHJva2UgPSBOQSkgK1xuICAgICMgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDEsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgKyBcbiAgICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0KSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDEyOiBcXCwgY29udlB2YWx1ZShwMTIpKSxcbiAgICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICAgIHRoZW1lKFxuICAgICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgICAgc2l6ZSA9IGZvbnRTaXplTSxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplTSxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCAgICAgICMgUm90YXRlIHgtYXhpcyBsYWJlbHMgNDUgZGVncmVlc1xuICAgICAgaGp1c3QgPSAxLCAgICAgICAjIEFkanVzdCBob3Jpem9udGFsIGp1c3RpZmljYXRpb25cbiAgICAgIHZqdXN0ID0gMSAgICAgICAgIyBBZGp1c3QgdmVydGljYWwganVzdGlmaWNhdGlvblxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICAgICkrICAgZ3VpZGVzKFxuICAgICAgZmlsbCA9IGd1aWRlX2xlZ2VuZChcbiAgICAgICAga2V5d2lkdGggPSAwLjIsICAjIEFkanVzdCB0aGUgd2lkdGggb2YgdGhlIGxlZ2VuZCBrZXlzXG4gICAgICAgIGtleWhlaWdodCA9IDAuMiAgIyBBZGp1c3QgdGhlIGhlaWdodCBvZiB0aGUgbGVnZW5kIGtleXNcbiAgICAgICkpXG4gICAgICBcbiAgICAgIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxpbnN1bGF0aW9uX3Njb3JlX2JpbmFyeUdyb3VwX1xcLCBub3RlKVxuICB3aWR0aCA8LSBwYW5lbFNpemUoMS41NSkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS4yKSptbVRvSW5jaFxuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG4jIERNU09cbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcXGdyb3VwXFwsIFxcc2NvcmVcXClcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXFxuZWFyZXN0Qm91bmRhcnlfRE1TT19iaW5hcnlHcm91cFxcLCB5bWluID0gLTEuMSwgeW1heCA9IC0wLjUpXG5cbiMgZFRBR1xudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBib3VuZGFyeUluc1Njb3JlX2RUQUcpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kVEFHX2JpbmFyeUdyb3VwXFwsIHltaW4gPSAgLTEuMSwgeW1heCA9IC0wLjUpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kaWZmX2JpbmFyeUdyb3VwXFwsIHltaW4gPSAtMC4zLCB5bWF4ID0gMC4xKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\ngene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\, NA))) %>% \n  dplyr::filter(!is.na(group))\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$score\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_insScore <- function(temp.tb, note, ymin = -1.5, ymax = 0){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \\.\\, fill = group, y = -score)) + \n    labs(x = NULL, y = \\- Insulation score\\) +  # Remove x-axis title\n    scale_fill_manual(values = rev((c(\\#777777\\, \\#F28E2C\\)))) +\n\n    introdataviz::geom_split_violin(linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n                                    alpha = .4) +\n    geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + theme_classic() +\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    \n    # \n    # geom_violin(aes(fill = group), color = \\black\\, linewidth = lineThick*mmToLineUnit, lineend = \\square\\, show.legend = FALSE) + \n    # geom_boxplot(width = 0.1,  color = \\black\\, linewidth = lineThick*mmToLineUnit, lineend = \\square\\,\n    #              outlier.size = 1, outlier.stroke = NA) +\n    # stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 1, fill = \\red\\, color = \\black\\) + \n    geom_hline(yintercept = 0, linewidth = lineThick*mmToLineUnit) +\n    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +\n    annotate(\\text\\, x = 1, y = ymin + 1, label = paste0(\\p12: \\, convPvalue(p12)),\n             color = \\black\\, hjust = 0, size = 3) +\n    theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )+   guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      ))\n      \n      \n  fileName <- paste0(\\insulation_score_binaryGroup_\\, note)\n  width <- panelSize(1.55)*mmToInch\nheight <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# DMSO\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_DMSO_binaryGroup\\, ymin = -1.1, ymax = -0.5)\n\n# dTAG\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_dTAG_binaryGroup\\, ymin =  -1.1, ymax = -0.5)\n\n# diff\ntemp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_diff_binaryGroup\\, ymin = -0.3, ymax = 0.1)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuXG5nZW5lLmluc1Njb3JlIDwtIGdlbmUuaW5zU2NvcmUuYWxsICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBncm91cDEsIFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAyLCBcXGdyb3VwMlxcLCBOQSkpKSAlPiUgXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSlcblxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJHNjb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRzY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuXG5wbG90X2luc1Njb3JlIDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAtMS41LCB5bWF4ID0gMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBcXC5cXCwgZmlsbCA9IGdyb3VwLCB5ID0gLXNjb3JlKSkgKyBcbiAgICBsYWJzKHggPSBOVUxMLCB5ID0gXFwtIEluc3VsYXRpb24gc2NvcmVcXCkgKyAgIyBSZW1vdmUgeC1heGlzIHRpdGxlXG4gICAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gcmV2KChjKFxcIzc3Nzc3N1xcLCBcXCNGMjhFMkNcXCkpKSkgK1xuXG4gICAgaW50cm9kYXRhdml6OjpnZW9tX3NwbGl0X3Zpb2xpbihsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFscGhhID0gLjQpICtcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgICAgb3V0bGllci5zaGFwZSA9IE5BLCAgYWxwaGEgPSAwLjYsIHNob3cubGVnZW5kID0gRkFMU0UpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgICBzdGF0X3N1bW1hcnkoXG4gICAgICBhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sXG4gICAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgICAgZmlsbCA9IFxcYmxhY2tcXCwgY29sb3IgPSBcXGJsYWNrXFwsIHBvc2l0aW9uID0gcG9zaXRpb25fZG9kZ2UoLjMpXG4gICAgKSArXG4gICAgXG4gICAgIyBcbiAgICAjIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBjb2xvciA9IFxcYmxhY2tcXCwgbGluZXdpZHRoID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgIyBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsICBjb2xvciA9IFxcYmxhY2tcXCwgbGluZXdpZHRoID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsXG4gICAgIyAgICAgICAgICAgICAgb3V0bGllci5zaXplID0gMSwgb3V0bGllci5zdHJva2UgPSBOQSkgK1xuICAgICMgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDEsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgKyBcbiAgICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0KSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDEyOiBcXCwgY29udlB2YWx1ZShwMTIpKSxcbiAgICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMykgK1xuICAgIHRoZW1lKFxuICAgICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgICAgc2l6ZSA9IGZvbnRTaXplTSxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplTSxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCAgICAgICMgUm90YXRlIHgtYXhpcyBsYWJlbHMgNDUgZGVncmVlc1xuICAgICAgaGp1c3QgPSAxLCAgICAgICAjIEFkanVzdCBob3Jpem9udGFsIGp1c3RpZmljYXRpb25cbiAgICAgIHZqdXN0ID0gMSAgICAgICAgIyBBZGp1c3QgdmVydGljYWwganVzdGlmaWNhdGlvblxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICAgICkrICAgZ3VpZGVzKFxuICAgICAgZmlsbCA9IGd1aWRlX2xlZ2VuZChcbiAgICAgICAga2V5d2lkdGggPSAwLjIsICAjIEFkanVzdCB0aGUgd2lkdGggb2YgdGhlIGxlZ2VuZCBrZXlzXG4gICAgICAgIGtleWhlaWdodCA9IDAuMiAgIyBBZGp1c3QgdGhlIGhlaWdodCBvZiB0aGUgbGVnZW5kIGtleXNcbiAgICAgICkpXG4gICAgICBcbiAgICAgIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxpbnN1bGF0aW9uX3Njb3JlX2JpbmFyeUdyb3VwX1xcLCBub3RlKVxuICB3aWR0aCA8LSBwYW5lbFNpemUoMS41NSkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS4yKSptbVRvSW5jaFxuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG4jIERNU09cbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcXGdyb3VwXFwsIFxcc2NvcmVcXClcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXFxuZWFyZXN0Qm91bmRhcnlfRE1TT19iaW5hcnlHcm91cFxcLCB5bWluID0gLTEuMSwgeW1heCA9IC0wLjUpXG5cbiMgZFRBR1xudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBib3VuZGFyeUluc1Njb3JlX2RUQUcpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kVEFHX2JpbmFyeUdyb3VwXFwsIHltaW4gPSAgLTEuMSwgeW1heCA9IC0wLjUpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kaWZmX2JpbmFyeUdyb3VwXFwsIHltaW4gPSAtMC4zLCB5bWF4ID0gMC4xKVxuYGBgXG5gYGAifQ== -->

```r
```r
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\, NA))) %>% 
  dplyr::filter(!is.na(group))


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_insScore <- function(temp.tb, note, ymin = -1.5, ymax = 0){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = \.\, fill = group, y = -score)) + 
    labs(x = NULL, y = \- Insulation score\) +  # Remove x-axis title
    scale_fill_manual(values = rev((c(\#777777\, \#F28E2C\)))) +

    introdataviz::geom_split_violin(linewidth = lineMedium * mmToLineUnit, lineend = \square\,
                                    alpha = .4) +
    geom_boxplot(width = 0.3, color = \black\,
                 linewidth = lineMedium * mmToLineUnit, lineend = \square\,
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + theme_classic() +
    stat_summary(
      aes(group = group), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) +
    
    # 
    # geom_violin(aes(fill = group), color = \black\, linewidth = lineThick*mmToLineUnit, lineend = \square\, show.legend = FALSE) + 
    # geom_boxplot(width = 0.1,  color = \black\, linewidth = lineThick*mmToLineUnit, lineend = \square\,
    #              outlier.size = 1, outlier.stroke = NA) +
    # stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 1, fill = \red\, color = \black\) + 
    geom_hline(yintercept = 0, linewidth = lineThick*mmToLineUnit) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p12: \, convPvalue(p12)),
             color = \black\, hjust = 0, size = 3) +
    theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )+   guides(
      fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
      ))
      
      
  fileName <- paste0(\insulation_score_binaryGroup_\, note)
  width <- panelSize(1.55)*mmToInch
height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO_binaryGroup\, ymin = -1.1, ymax = -0.5)

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_dTAG_binaryGroup\, ymin =  -1.1, ymax = -0.5)

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_diff_binaryGroup\, ymin = -0.3, ymax = 0.1)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Checking insulation score of the nearest TAD

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XCIpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcIikpJGdlbmVcbmdyb3VwNSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlwiKSkkZ2VuZVxuZ3JvdXA4IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XCIpKSRnZW5lXG5cblxuZ2VuZS5pbnNTY29yZSA8LSBnZW5lLmluc1Njb3JlLmFsbCAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAxLCBcImdyb3VwMVwiLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMiwgXCJncm91cDJcIixcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA1LCBcImdyb3VwNVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA4LCBcImdyb3VwOFwiLCBOQSkpKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDEpICkkc2NvcmVcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJHNjb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfaW5zU2NvcmUgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAxLjUpe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMVwiLCBcImdyb3VwMlwiKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJncm91cDFcIiwgXCJncm91cDVcIiksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwiZ3JvdXAxXCIsIFwiZ3JvdXA4XCIpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMlwiLCBcImdyb3VwNVwiKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJncm91cDJcIiwgXCJncm91cDhcIiksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwiZ3JvdXA1XCIsIFwiZ3JvdXA4XCIpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IHNjb3JlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcInBvaW50XCIsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCIpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoeW1pbiwgeW1heCkpICtcbiAgICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IDEsIHkgPSB5bWluICsgMSwgbGFiZWwgPSBwYXN0ZTAoXCJwMTI6IFwiLCBjb252UHZhbHVlKHAxMiksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAxNTogXCIsIGNvbnZQdmFsdWUocDE1KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDE4OiBcIiwgY29udlB2YWx1ZShwMTgpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMjU6IFwiLCBjb252UHZhbHVlKHAyNSksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAyODogXCIsIGNvbnZQdmFsdWUocDI4KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDU4OiBcIixjb252UHZhbHVlKCBwNTgpLCBcIlxcblwiKSxcbiAgICAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXCJpbnN1bGF0aW9uX3Njb3JlX1wiLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5cbiMgRE1TT1xudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBib3VuZGFyeUluc1Njb3JlX0RNU08pXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFwiZ3JvdXBcIiwgXCJzY29yZVwiKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcIm5lYXJlc3RCb3VuZGFyeV9ETVNPXCIpXG5cbiMgZFRBR1xudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBib3VuZGFyeUluc1Njb3JlX2RUQUcpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFwiZ3JvdXBcIiwgXCJzY29yZVwiKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcIm5lYXJlc3RCb3VuZGFyeV9kVEFHXCIpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFwiZ3JvdXBcIiwgXCJzY29yZVwiKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcIm5lYXJlc3RCb3VuZGFyeV9kaWZmXCIsIHltaW4gPSAtMC41LCB5bWF4ID0gMSlcbmBgYCJ9 -->\n\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\))$gene\n\n\ngene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\,\n                        ifelse(ensembl %in% group5, \\group5\\,\n                               ifelse(ensembl %in% group8, \\group8\\, NA))))) %>% \n  dplyr::filter(!is.na(group))\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$score\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +\n    annotate(\\text\\, x = 1, y = ymin + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p15: \\, convPvalue(p15), \\\\n\\,\n                                                         \\p18: \\, convPvalue(p18), \\\\n\\,\n                                                         \\p25: \\, convPvalue(p25), \\\\n\\,\n                                                         \\p28: \\, convPvalue(p28), \\\\n\\,\n                                                         \\p58: \\,convPvalue( p58), \\\\n\\),\n             color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\insulation_score_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# DMSO\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_DMSO\\)\n\n# dTAG\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_dTAG\\)\n\n# diff\ntemp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_diff\\, ymin = -0.5, ymax = 1)\n```\n\n<!-- rnb-source-end -->\n"} -->
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\,
                        ifelse(ensembl %in% group5, \group5\,
                               ifelse(ensembl %in% group8, \group8\, NA))))) %>% 
  dplyr::filter(!is.na(group))


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO\)

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_dTAG\)

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_diff\, ymin = -0.5, ymax = 1)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcXCkpJGdlbmVcbmdyb3VwNSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlxcKSkkZ2VuZVxuZ3JvdXA4IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XFwpKSRnZW5lXG5cblxuZ2VuZS5pbnNTY29yZSA8LSBnZW5lLmluc1Njb3JlLmFsbCAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAxLCBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMiwgXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA1LCBcXGdyb3VwNVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA4LCBcXGdyb3VwOFxcLCBOQSkpKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDEpICkkc2NvcmVcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJHNjb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfaW5zU2NvcmUgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAxLjUpe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IHNjb3JlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoeW1pbiwgeW1heCkpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSB5bWluICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNTogXFwsIGNvbnZQdmFsdWUocDE1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE4OiBcXCwgY29udlB2YWx1ZShwMTgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjU6IFxcLCBjb252UHZhbHVlKHAyNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyODogXFwsIGNvbnZQdmFsdWUocDI4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDU4OiBcXCxjb252UHZhbHVlKCBwNTgpLCBcXFxcblxcKSxcbiAgICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxpbnN1bGF0aW9uX3Njb3JlX1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5cbiMgRE1TT1xudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBib3VuZGFyeUluc1Njb3JlX0RNU08pXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9ETVNPXFwpXG5cbiMgZFRBR1xudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBib3VuZGFyeUluc1Njb3JlX2RUQUcpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kVEFHXFwpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kaWZmXFwsIHltaW4gPSAtMC41LCB5bWF4ID0gMSlcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\))$gene\n\n\ngene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\,\n                        ifelse(ensembl %in% group5, \\group5\\,\n                               ifelse(ensembl %in% group8, \\group8\\, NA))))) %>% \n  dplyr::filter(!is.na(group))\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$score\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +\n    annotate(\\text\\, x = 1, y = ymin + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p15: \\, convPvalue(p15), \\\\n\\,\n                                                         \\p18: \\, convPvalue(p18), \\\\n\\,\n                                                         \\p25: \\, convPvalue(p25), \\\\n\\,\n                                                         \\p28: \\, convPvalue(p28), \\\\n\\,\n                                                         \\p58: \\,convPvalue( p58), \\\\n\\),\n             color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\insulation_score_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# DMSO\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_DMSO\\)\n\n# dTAG\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_dTAG\\)\n\n# diff\ntemp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_diff\\, ymin = -0.5, ymax = 1)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcXCkpJGdlbmVcbmdyb3VwNSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlxcKSkkZ2VuZVxuZ3JvdXA4IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XFwpKSRnZW5lXG5cblxuZ2VuZS5pbnNTY29yZSA8LSBnZW5lLmluc1Njb3JlLmFsbCAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAxLCBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMiwgXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA1LCBcXGdyb3VwNVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA4LCBcXGdyb3VwOFxcLCBOQSkpKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDEpICkkc2NvcmVcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJHNjb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfaW5zU2NvcmUgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAxLjUpe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IHNjb3JlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoeW1pbiwgeW1heCkpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSB5bWluICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNTogXFwsIGNvbnZQdmFsdWUocDE1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE4OiBcXCwgY29udlB2YWx1ZShwMTgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjU6IFxcLCBjb252UHZhbHVlKHAyNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyODogXFwsIGNvbnZQdmFsdWUocDI4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDU4OiBcXCxjb252UHZhbHVlKCBwNTgpLCBcXFxcblxcKSxcbiAgICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxpbnN1bGF0aW9uX3Njb3JlX1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5cbiMgRE1TT1xudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBib3VuZGFyeUluc1Njb3JlX0RNU08pXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9ETVNPXFwpXG5cbiMgZFRBR1xudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBib3VuZGFyeUluc1Njb3JlX2RUQUcpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kVEFHXFwpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kaWZmXFwsIHltaW4gPSAtMC41LCB5bWF4ID0gMSlcbmBgYFxuYGBgIn0= -->

```r
```r
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\,
                        ifelse(ensembl %in% group5, \group5\,
                               ifelse(ensembl %in% group8, \group8\, NA))))) %>% 
  dplyr::filter(!is.na(group))


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO\)

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_dTAG\)

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_diff\, ymin = -0.5, ymax = 1)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### Plotting for binary groups

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXCJnZW5lX2xvb3BfbGluay5yZHNcIikpXG5cbnBuT3ZlcjggPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsID49IDgpKSRnZW5lXG5wbk92ZXI2IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA2LCB0b3RhbCA8IDgpKSRnZW5lXG5wbk92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA0LCB0b3RhbCA8IDYpKSRnZW5lXG5wbk92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSAyLCB0b3RhbCA8IDQpKSRnZW5lXG5wbk92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA8IDIpKSRnZW5lXG5cblxuZ2VuZS5pbnNTY29yZSA8LSBnZW5lLmluc1Njb3JlLmFsbCAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgcG5PdmVyOCwgXCJwOFwiLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIHBuT3ZlcjYsIFwicDZcIixcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcG5PdmVyNCwgXCJwNFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcG5PdmVyMiwgXCJwMlwiLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwbk92ZXIwLCBcInAwXCIsIE5BKSkpKSkpICAlPiUgXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSlcblxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMSkgKSRzY29yZVxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDIpICkkc2NvcmVcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnBsb3RfaW5zU2NvcmUgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAxLjUpe1xuICBwMDIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcInAwXCIsIFwicDJcIiksIDUpXG4gIHAyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwicDJcIiwgXCJwNFwiKSwgNSlcbiAgcDQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJwNFwiLCBcInA2XCIpLCA1KVxuICBwNjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcInA2XCIsIFwicDhcIiksIDUpXG4gIHA0OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwicDRcIiwgXCJwOFwiKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJwMlwiLCBcInA4XCIpLCA1KVxuICBwMDggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcInAwXCIsIFwicDhcIiksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcInJlZFwiLCBjb2xvciA9IFwiYmxhY2tcIikgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYyh5bWluLCB5bWF4KSkgK1xuICAgIGFubm90YXRlKFwidGV4dFwiLCB4ID0gMSwgeSA9IHltaW4gKyAxLCBsYWJlbCA9IHBhc3RlMChcInAwMjogXCIsIGNvbnZQdmFsdWUocDAyKSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDI0OiBcIiwgY29udlB2YWx1ZShwMjQpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwNDY6IFwiLCBjb252UHZhbHVlKHA0NiksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInA2ODogXCIsIGNvbnZQdmFsdWUocDY4KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDQ4OiBcIiwgY29udlB2YWx1ZShwNDgpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMjg6IFwiLGNvbnZQdmFsdWUoIHAyOCksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAwODogXCIsY29udlB2YWx1ZSggcDA4KSwgXCJcXG5cIiksXG4gICAgICAgICAgICAgY29sb3IgPSBcImJsYWNrXCIsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICArXG4gICAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcIiNkOWQ5ZDlcIiwgXCIjYmRiZGJkXCIsIFwiIzk2OTY5NlwiLCBcIiM3MzczNzNcIiwgXCIjNTI1MjUyXCIpKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcImluc3VsYXRpb25fc2NvcmVfXCIsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cblxuIyBETVNPXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfRE1TTylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXCJncm91cFwiLCBcInNjb3JlXCIpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFwibmVhcmVzdEJvdW5kYXJ5X0RNU09fUC1OXCIpXG5cbiMgZFRBR1xudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBib3VuZGFyeUluc1Njb3JlX2RUQUcpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFwiZ3JvdXBcIiwgXCJzY29yZVwiKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcIm5lYXJlc3RCb3VuZGFyeV9kVEFHX1AtTlwiKVxuXG4jIGRpZmZcbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgZGlmZl9ib3VuZGFyeUluc1Njb3JlKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcImdyb3VwXCIsIFwic2NvcmVcIilcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXCJuZWFyZXN0Qm91bmRhcnlfZGlmZl9QLU5cIiwgeW1pbiA9IC0wLjUsIHltYXggPSAxKVxuXG5gYGAifQ== -->\n\n```r\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene\npnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene\npnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene\npnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene\npnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene\n\n\ngene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% pnOver8, \\p8\\,\n                 ifelse(ensembl %in% pnOver6, \\p6\\,\n                        ifelse(ensembl %in% pnOver4, \\p4\\,\n                               ifelse(ensembl %in% pnOver2, \\p2\\, \n                                      ifelse(ensembl %in% pnOver0, \\p0\\, NA))))))  %>% \n  dplyr::filter(!is.na(group))\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$score\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nplot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){\n  p02 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p2\\), 5)\n  p24 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p4\\), 5)\n  p46 <- round(getPvalWilcox(temp.tb, \\p4\\, \\p6\\), 5)\n  p68 <- round(getPvalWilcox(temp.tb, \\p6\\, \\p8\\), 5)\n  p48 <- round(getPvalWilcox(temp.tb, \\p4\\, \\p8\\), 5)\n  p28 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p8\\), 5)\n  p08 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +\n    annotate(\\text\\, x = 1, y = ymin + 1, label = paste0(\\p02: \\, convPvalue(p02), \\\\n\\,\n                                                         \\p24: \\, convPvalue(p24), \\\\n\\,\n                                                         \\p46: \\, convPvalue(p46), \\\\n\\,\n                                                         \\p68: \\, convPvalue(p68), \\\\n\\,\n                                                         \\p48: \\, convPvalue(p48), \\\\n\\,\n                                                         \\p28: \\,convPvalue( p28), \\\\n\\,\n                                                         \\p08: \\,convPvalue( p08), \\\\n\\),\n             color = \\black\\, hjust = 0, size = 3)  +\n    scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n  \n  \n  fileName <- paste0(\\insulation_score_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# DMSO\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_DMSO_P-N\\)\n\n# dTAG\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_dTAG_P-N\\)\n\n# diff\ntemp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_diff_P-N\\, ymin = -0.5, ymax = 1)\n\n```\n\n<!-- rnb-source-end -->\n"} -->
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

pnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene
pnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene
pnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene
pnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene
pnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% pnOver8, \p8\,
                 ifelse(ensembl %in% pnOver6, \p6\,
                        ifelse(ensembl %in% pnOver4, \p4\,
                               ifelse(ensembl %in% pnOver2, \p2\, 
                                      ifelse(ensembl %in% pnOver0, \p0\, NA))))))  %>% 
  dplyr::filter(!is.na(group))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p02 <- round(getPvalWilcox(temp.tb, \p0\, \p2\), 5)
  p24 <- round(getPvalWilcox(temp.tb, \p2\, \p4\), 5)
  p46 <- round(getPvalWilcox(temp.tb, \p4\, \p6\), 5)
  p68 <- round(getPvalWilcox(temp.tb, \p6\, \p8\), 5)
  p48 <- round(getPvalWilcox(temp.tb, \p4\, \p8\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \p2\, \p8\), 5)
  p08 <- round(getPvalWilcox(temp.tb, \p0\, \p8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p02: \, convPvalue(p02), \\n\,
                                                         \p24: \, convPvalue(p24), \\n\,
                                                         \p46: \, convPvalue(p46), \\n\,
                                                         \p68: \, convPvalue(p68), \\n\,
                                                         \p48: \, convPvalue(p48), \\n\,
                                                         \p28: \,convPvalue( p28), \\n\,
                                                         \p08: \,convPvalue( p08), \\n\),
             color = \black\, hjust = 0, size = 3)  +
    scale_fill_manual(values = c(\#d9d9d9\, \#bdbdbd\, \#969696\, \#737373\, \#525252\))
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO_P-N\)

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_dTAG_P-N\)

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_diff_P-N\, ymin = -0.5, ymax = 1)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXFxnZW5lX2xvb3BfbGluay5yZHNcXCkpXG5cbnBuT3ZlcjggPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsID49IDgpKSRnZW5lXG5wbk92ZXI2IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA2LCB0b3RhbCA8IDgpKSRnZW5lXG5wbk92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA0LCB0b3RhbCA8IDYpKSRnZW5lXG5wbk92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSAyLCB0b3RhbCA8IDQpKSRnZW5lXG5wbk92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA8IDIpKSRnZW5lXG5cblxuZ2VuZS5pbnNTY29yZSA8LSBnZW5lLmluc1Njb3JlLmFsbCAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgcG5PdmVyOCwgXFxwOFxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIHBuT3ZlcjYsIFxccDZcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcG5PdmVyNCwgXFxwNFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcG5PdmVyMiwgXFxwMlxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwbk92ZXIwLCBcXHAwXFwsIE5BKSkpKSkpICAlPiUgXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSlcblxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMSkgKSRzY29yZVxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDIpICkkc2NvcmVcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnBsb3RfaW5zU2NvcmUgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAxLjUpe1xuICBwMDIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAwXFwsIFxccDJcXCksIDUpXG4gIHAyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDJcXCwgXFxwNFxcKSwgNSlcbiAgcDQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwNFxcLCBcXHA2XFwpLCA1KVxuICBwNjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHA2XFwsIFxccDhcXCksIDUpXG4gIHA0OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDRcXCwgXFxwOFxcKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMlxcLCBcXHA4XFwpLCA1KVxuICBwMDggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAwXFwsIFxccDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYyh5bWluLCB5bWF4KSkgK1xuICAgIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IHltaW4gKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAwMjogXFwsIGNvbnZQdmFsdWUocDAyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI0OiBcXCwgY29udlB2YWx1ZShwMjQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwNDY6IFxcLCBjb252UHZhbHVlKHA0NiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHA2ODogXFwsIGNvbnZQdmFsdWUocDY4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDQ4OiBcXCwgY29udlB2YWx1ZShwNDgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjg6IFxcLGNvbnZQdmFsdWUoIHAyOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAwODogXFwsY29udlB2YWx1ZSggcDA4KSwgXFxcXG5cXCksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICArXG4gICAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcXCNkOWQ5ZDlcXCwgXFwjYmRiZGJkXFwsIFxcIzk2OTY5NlxcLCBcXCM3MzczNzNcXCwgXFwjNTI1MjUyXFwpKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGluc3VsYXRpb25fc2NvcmVfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cblxuIyBETVNPXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfRE1TTylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXFxncm91cFxcLCBcXHNjb3JlXFwpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFxcbmVhcmVzdEJvdW5kYXJ5X0RNU09fUC1OXFwpXG5cbiMgZFRBR1xudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBib3VuZGFyeUluc1Njb3JlX2RUQUcpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kVEFHX1AtTlxcKVxuXG4jIGRpZmZcbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgZGlmZl9ib3VuZGFyeUluc1Njb3JlKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcXGdyb3VwXFwsIFxcc2NvcmVcXClcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXFxuZWFyZXN0Qm91bmRhcnlfZGlmZl9QLU5cXCwgeW1pbiA9IC0wLjUsIHltYXggPSAxKVxuXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene\npnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene\npnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene\npnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene\npnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene\n\n\ngene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% pnOver8, \\p8\\,\n                 ifelse(ensembl %in% pnOver6, \\p6\\,\n                        ifelse(ensembl %in% pnOver4, \\p4\\,\n                               ifelse(ensembl %in% pnOver2, \\p2\\, \n                                      ifelse(ensembl %in% pnOver0, \\p0\\, NA))))))  %>% \n  dplyr::filter(!is.na(group))\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$score\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nplot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){\n  p02 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p2\\), 5)\n  p24 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p4\\), 5)\n  p46 <- round(getPvalWilcox(temp.tb, \\p4\\, \\p6\\), 5)\n  p68 <- round(getPvalWilcox(temp.tb, \\p6\\, \\p8\\), 5)\n  p48 <- round(getPvalWilcox(temp.tb, \\p4\\, \\p8\\), 5)\n  p28 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p8\\), 5)\n  p08 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +\n    annotate(\\text\\, x = 1, y = ymin + 1, label = paste0(\\p02: \\, convPvalue(p02), \\\\n\\,\n                                                         \\p24: \\, convPvalue(p24), \\\\n\\,\n                                                         \\p46: \\, convPvalue(p46), \\\\n\\,\n                                                         \\p68: \\, convPvalue(p68), \\\\n\\,\n                                                         \\p48: \\, convPvalue(p48), \\\\n\\,\n                                                         \\p28: \\,convPvalue( p28), \\\\n\\,\n                                                         \\p08: \\,convPvalue( p08), \\\\n\\),\n             color = \\black\\, hjust = 0, size = 3)  +\n    scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n  \n  \n  fileName <- paste0(\\insulation_score_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# DMSO\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_DMSO_P-N\\)\n\n# dTAG\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_dTAG_P-N\\)\n\n# diff\ntemp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_diff_P-N\\, ymin = -0.5, ymax = 1)\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXFxnZW5lX2xvb3BfbGluay5yZHNcXCkpXG5cbnBuT3ZlcjggPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKHRvdGFsID49IDgpKSRnZW5lXG5wbk92ZXI2IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA2LCB0b3RhbCA8IDgpKSRnZW5lXG5wbk92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSA0LCB0b3RhbCA8IDYpKSRnZW5lXG5wbk92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA+PSAyLCB0b3RhbCA8IDQpKSRnZW5lXG5wbk92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcih0b3RhbCA8IDIpKSRnZW5lXG5cblxuZ2VuZS5pbnNTY29yZSA8LSBnZW5lLmluc1Njb3JlLmFsbCAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgcG5PdmVyOCwgXFxwOFxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIHBuT3ZlcjYsIFxccDZcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcG5PdmVyNCwgXFxwNFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcG5PdmVyMiwgXFxwMlxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwbk92ZXIwLCBcXHAwXFwsIE5BKSkpKSkpICAlPiUgXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSlcblxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMSkgKSRzY29yZVxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT1ncm91cDIpICkkc2NvcmVcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnBsb3RfaW5zU2NvcmUgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAxLjUpe1xuICBwMDIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAwXFwsIFxccDJcXCksIDUpXG4gIHAyNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDJcXCwgXFxwNFxcKSwgNSlcbiAgcDQ2IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwNFxcLCBcXHA2XFwpLCA1KVxuICBwNjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHA2XFwsIFxccDhcXCksIDUpXG4gIHA0OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDRcXCwgXFxwOFxcKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMlxcLCBcXHA4XFwpLCA1KVxuICBwMDggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAwXFwsIFxccDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYyh5bWluLCB5bWF4KSkgK1xuICAgIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IHltaW4gKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAwMjogXFwsIGNvbnZQdmFsdWUocDAyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI0OiBcXCwgY29udlB2YWx1ZShwMjQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwNDY6IFxcLCBjb252UHZhbHVlKHA0NiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHA2ODogXFwsIGNvbnZQdmFsdWUocDY4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDQ4OiBcXCwgY29udlB2YWx1ZShwNDgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjg6IFxcLGNvbnZQdmFsdWUoIHAyOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAwODogXFwsY29udlB2YWx1ZSggcDA4KSwgXFxcXG5cXCksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICArXG4gICAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcXCNkOWQ5ZDlcXCwgXFwjYmRiZGJkXFwsIFxcIzk2OTY5NlxcLCBcXCM3MzczNzNcXCwgXFwjNTI1MjUyXFwpKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGluc3VsYXRpb25fc2NvcmVfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cblxuIyBETVNPXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfRE1TTylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXFxncm91cFxcLCBcXHNjb3JlXFwpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFxcbmVhcmVzdEJvdW5kYXJ5X0RNU09fUC1OXFwpXG5cbiMgZFRBR1xudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBib3VuZGFyeUluc1Njb3JlX2RUQUcpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kVEFHX1AtTlxcKVxuXG4jIGRpZmZcbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgZGlmZl9ib3VuZGFyeUluc1Njb3JlKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcXGdyb3VwXFwsIFxcc2NvcmVcXClcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXFxuZWFyZXN0Qm91bmRhcnlfZGlmZl9QLU5cXCwgeW1pbiA9IC0wLjUsIHltYXggPSAxKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

pnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene
pnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene
pnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene
pnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene
pnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% pnOver8, \p8\,
                 ifelse(ensembl %in% pnOver6, \p6\,
                        ifelse(ensembl %in% pnOver4, \p4\,
                               ifelse(ensembl %in% pnOver2, \p2\, 
                                      ifelse(ensembl %in% pnOver0, \p0\, NA))))))  %>% 
  dplyr::filter(!is.na(group))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p02 <- round(getPvalWilcox(temp.tb, \p0\, \p2\), 5)
  p24 <- round(getPvalWilcox(temp.tb, \p2\, \p4\), 5)
  p46 <- round(getPvalWilcox(temp.tb, \p4\, \p6\), 5)
  p68 <- round(getPvalWilcox(temp.tb, \p6\, \p8\), 5)
  p48 <- round(getPvalWilcox(temp.tb, \p4\, \p8\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \p2\, \p8\), 5)
  p08 <- round(getPvalWilcox(temp.tb, \p0\, \p8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p02: \, convPvalue(p02), \\n\,
                                                         \p24: \, convPvalue(p24), \\n\,
                                                         \p46: \, convPvalue(p46), \\n\,
                                                         \p68: \, convPvalue(p68), \\n\,
                                                         \p48: \, convPvalue(p48), \\n\,
                                                         \p28: \,convPvalue( p28), \\n\,
                                                         \p08: \,convPvalue( p08), \\n\),
             color = \black\, hjust = 0, size = 3)  +
    scale_fill_manual(values = c(\#d9d9d9\, \#bdbdbd\, \#969696\, \#737373\, \#525252\))
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO_P-N\)

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_dTAG_P-N\)

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_diff_P-N\, ymin = -0.5, ymax = 1)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### Plotting for groups

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXCJnZW5lX2xvb3BfbGluay5yZHNcIikpXG5cbnBzT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSA0KSkkZ2VuZVxucHNPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDMsIG51bV9wcyA8IDQpKSRnZW5lXG5wc092ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMiwgbnVtX3BzIDwgMykpJGdlbmVcbnBzT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAxLCBudW1fcHMgPCAyKSkkZ2VuZVxucHNPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzIDwgMSkpJGdlbmVcblxuXG5nZW5lLmluc1Njb3JlIDwtIGdlbmUuaW5zU2NvcmUuYWxsICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBwc092ZXI0LCBcInA0XCIsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcHNPdmVyMywgXCJwM1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwc092ZXIyLCBcInAyXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwc092ZXIxLCBcInAxXCIsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIHBzT3ZlcjAsIFwicDBcIiwgTkEpKSkpKSkgICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJHNjb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRzY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxucGxvdF9pbnNTY29yZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEuNSl7XG4gIHAwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwicDBcIiwgXCJwMVwiKSwgNSlcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJwMVwiLCBcInAyXCIpLCA1KVxuICBwMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcInAyXCIsIFwicDNcIiksIDUpXG4gIHAzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwicDNcIiwgXCJwNFwiKSwgNSlcbiAgcDI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJwMlwiLCBcInA0XCIpLCA1KVxuICBwMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcInAxXCIsIFwicDRcIiksIDUpXG4gIHAwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwicDBcIiwgXCJwNFwiKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBzY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFwicmVkXCIsIGNvbG9yID0gXCJibGFja1wiKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFwicDAxOiBcIiwgY29udlB2YWx1ZShwMDEpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMTI6IFwiLCBjb252UHZhbHVlKHAxMiksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAyMzogXCIsIGNvbnZQdmFsdWUocDIzKSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDM0OiBcIiwgY29udlB2YWx1ZShwMzQpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMjQ6IFwiLCBjb252UHZhbHVlKHAyNCksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAxNDogXCIsY29udlB2YWx1ZSggcDE0KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDA0OiBcIixjb252UHZhbHVlKCBwMDQpLCBcIlxcblwiKSwgXG4gICAgICAgICAgICAgY29sb3IgPSBcImJsYWNrXCIsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFwiI2Q5ZDlkOVwiLCBcIiNiZGJkYmRcIiwgXCIjOTY5Njk2XCIsIFwiIzczNzM3M1wiLCBcIiM1MjUyNTJcIikpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFwiaW5zdWxhdGlvbl9zY29yZV9cIiwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG4jIERNU09cbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcImdyb3VwXCIsIFwic2NvcmVcIilcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXCJuZWFyZXN0Qm91bmRhcnlfRE1TT19QLVNcIilcblxuIyBkVEFHXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfZFRBRylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXCJncm91cFwiLCBcInNjb3JlXCIpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFwibmVhcmVzdEJvdW5kYXJ5X2RUQUdfUC1TXCIpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFwiZ3JvdXBcIiwgXCJzY29yZVwiKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcIm5lYXJlc3RCb3VuZGFyeV9kaWZmX1AtU1wiLCB5bWluID0gLTAuNSwgeW1heCA9IDEpXG5gYGAifQ== -->\n\n```r\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\n\ngene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% psOver4, \\p4\\,\n                 ifelse(ensembl %in% psOver3, \\p3\\,\n                        ifelse(ensembl %in% psOver2, \\p2\\,\n                               ifelse(ensembl %in% psOver1, \\p1\\, \n                                      ifelse(ensembl %in% psOver0, \\p0\\, NA))))))  %>% \n  dplyr::filter(!is.na(group))\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$score\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nplot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){\n  p01 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p1\\), 5)\n  p12 <- round(getPvalWilcox(temp.tb, \\p1\\, \\p2\\), 5)\n  p23 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p3\\), 5)\n  p34 <- round(getPvalWilcox(temp.tb, \\p3\\, \\p4\\), 5)\n  p24 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p4\\), 5)\n  p14 <- round(getPvalWilcox(temp.tb, \\p1\\, \\p4\\), 5)\n  p04 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p4\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +\n    annotate(\\text\\, x = 1, y = ymin + 1, label = paste0(\\p01: \\, convPvalue(p01), \\\\n\\,\n                                                         \\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p23: \\, convPvalue(p23), \\\\n\\,\n                                                         \\p34: \\, convPvalue(p34), \\\\n\\,\n                                                         \\p24: \\, convPvalue(p24), \\\\n\\,\n                                                         \\p14: \\,convPvalue( p14), \\\\n\\,\n                                                         \\p04: \\,convPvalue( p04), \\\\n\\), \n             color = \\black\\, hjust = 0, size = 3) +\n    scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n  \n  \n  fileName <- paste0(\\insulation_score_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# DMSO\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_DMSO_P-S\\)\n\n# dTAG\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_dTAG_P-S\\)\n\n# diff\ntemp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_diff_P-S\\, ymin = -0.5, ymax = 1)\n```\n\n<!-- rnb-source-end -->\n"} -->
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% psOver4, \p4\,
                 ifelse(ensembl %in% psOver3, \p3\,
                        ifelse(ensembl %in% psOver2, \p2\,
                               ifelse(ensembl %in% psOver1, \p1\, 
                                      ifelse(ensembl %in% psOver0, \p0\, NA))))))  %>% 
  dplyr::filter(!is.na(group))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p01 <- round(getPvalWilcox(temp.tb, \p0\, \p1\), 5)
  p12 <- round(getPvalWilcox(temp.tb, \p1\, \p2\), 5)
  p23 <- round(getPvalWilcox(temp.tb, \p2\, \p3\), 5)
  p34 <- round(getPvalWilcox(temp.tb, \p3\, \p4\), 5)
  p24 <- round(getPvalWilcox(temp.tb, \p2\, \p4\), 5)
  p14 <- round(getPvalWilcox(temp.tb, \p1\, \p4\), 5)
  p04 <- round(getPvalWilcox(temp.tb, \p0\, \p4\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p01: \, convPvalue(p01), \\n\,
                                                         \p12: \, convPvalue(p12), \\n\,
                                                         \p23: \, convPvalue(p23), \\n\,
                                                         \p34: \, convPvalue(p34), \\n\,
                                                         \p24: \, convPvalue(p24), \\n\,
                                                         \p14: \,convPvalue( p14), \\n\,
                                                         \p04: \,convPvalue( p04), \\n\), 
             color = \black\, hjust = 0, size = 3) +
    scale_fill_manual(values = c(\#d9d9d9\, \#bdbdbd\, \#969696\, \#737373\, \#525252\))
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO_P-S\)

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_dTAG_P-S\)

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_diff_P-S\, ymin = -0.5, ymax = 1)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXFxnZW5lX2xvb3BfbGluay5yZHNcXCkpXG5cbnBzT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSA0KSkkZ2VuZVxucHNPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDMsIG51bV9wcyA8IDQpKSRnZW5lXG5wc092ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMiwgbnVtX3BzIDwgMykpJGdlbmVcbnBzT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAxLCBudW1fcHMgPCAyKSkkZ2VuZVxucHNPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzIDwgMSkpJGdlbmVcblxuXG5nZW5lLmluc1Njb3JlIDwtIGdlbmUuaW5zU2NvcmUuYWxsICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBwc092ZXI0LCBcXHA0XFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcHNPdmVyMywgXFxwM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwc092ZXIyLCBcXHAyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwc092ZXIxLCBcXHAxXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIHBzT3ZlcjAsIFxccDBcXCwgTkEpKSkpKSkgICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJHNjb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRzY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxucGxvdF9pbnNTY29yZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEuNSl7XG4gIHAwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDBcXCwgXFxwMVxcKSwgNSlcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMVxcLCBcXHAyXFwpLCA1KVxuICBwMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAyXFwsIFxccDNcXCksIDUpXG4gIHAzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDNcXCwgXFxwNFxcKSwgNSlcbiAgcDI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMlxcLCBcXHA0XFwpLCA1KVxuICBwMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAxXFwsIFxccDRcXCksIDUpXG4gIHAwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDBcXCwgXFxwNFxcKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBzY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDAxOiBcXCwgY29udlB2YWx1ZShwMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyMzogXFwsIGNvbnZQdmFsdWUocDIzKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDM0OiBcXCwgY29udlB2YWx1ZShwMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjQ6IFxcLCBjb252UHZhbHVlKHAyNCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNDogXFwsY29udlB2YWx1ZSggcDE0KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDA0OiBcXCxjb252UHZhbHVlKCBwMDQpLCBcXFxcblxcKSwgXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFxcI2Q5ZDlkOVxcLCBcXCNiZGJkYmRcXCwgXFwjOTY5Njk2XFwsIFxcIzczNzM3M1xcLCBcXCM1MjUyNTJcXCkpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcaW5zdWxhdGlvbl9zY29yZV9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG4jIERNU09cbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcXGdyb3VwXFwsIFxcc2NvcmVcXClcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXFxuZWFyZXN0Qm91bmRhcnlfRE1TT19QLVNcXClcblxuIyBkVEFHXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfZFRBRylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXFxncm91cFxcLCBcXHNjb3JlXFwpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFxcbmVhcmVzdEJvdW5kYXJ5X2RUQUdfUC1TXFwpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kaWZmX1AtU1xcLCB5bWluID0gLTAuNSwgeW1heCA9IDEpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\n\ngene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% psOver4, \\p4\\,\n                 ifelse(ensembl %in% psOver3, \\p3\\,\n                        ifelse(ensembl %in% psOver2, \\p2\\,\n                               ifelse(ensembl %in% psOver1, \\p1\\, \n                                      ifelse(ensembl %in% psOver0, \\p0\\, NA))))))  %>% \n  dplyr::filter(!is.na(group))\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$score\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nplot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){\n  p01 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p1\\), 5)\n  p12 <- round(getPvalWilcox(temp.tb, \\p1\\, \\p2\\), 5)\n  p23 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p3\\), 5)\n  p34 <- round(getPvalWilcox(temp.tb, \\p3\\, \\p4\\), 5)\n  p24 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p4\\), 5)\n  p14 <- round(getPvalWilcox(temp.tb, \\p1\\, \\p4\\), 5)\n  p04 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p4\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +\n    annotate(\\text\\, x = 1, y = ymin + 1, label = paste0(\\p01: \\, convPvalue(p01), \\\\n\\,\n                                                         \\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p23: \\, convPvalue(p23), \\\\n\\,\n                                                         \\p34: \\, convPvalue(p34), \\\\n\\,\n                                                         \\p24: \\, convPvalue(p24), \\\\n\\,\n                                                         \\p14: \\,convPvalue( p14), \\\\n\\,\n                                                         \\p04: \\,convPvalue( p04), \\\\n\\), \n             color = \\black\\, hjust = 0, size = 3) +\n    scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n  \n  \n  fileName <- paste0(\\insulation_score_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# DMSO\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_DMSO_P-S\\)\n\n# dTAG\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_dTAG_P-S\\)\n\n# diff\ntemp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_diff_P-S\\, ymin = -0.5, ymax = 1)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXFxnZW5lX2xvb3BfbGluay5yZHNcXCkpXG5cbnBzT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSA0KSkkZ2VuZVxucHNPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDMsIG51bV9wcyA8IDQpKSRnZW5lXG5wc092ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMiwgbnVtX3BzIDwgMykpJGdlbmVcbnBzT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAxLCBudW1fcHMgPCAyKSkkZ2VuZVxucHNPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzIDwgMSkpJGdlbmVcblxuXG5nZW5lLmluc1Njb3JlIDwtIGdlbmUuaW5zU2NvcmUuYWxsICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBwc092ZXI0LCBcXHA0XFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcHNPdmVyMywgXFxwM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwc092ZXIyLCBcXHAyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwc092ZXIxLCBcXHAxXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIHBzT3ZlcjAsIFxccDBcXCwgTkEpKSkpKSkgICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJHNjb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRzY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxucGxvdF9pbnNTY29yZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEuNSl7XG4gIHAwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDBcXCwgXFxwMVxcKSwgNSlcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMVxcLCBcXHAyXFwpLCA1KVxuICBwMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAyXFwsIFxccDNcXCksIDUpXG4gIHAzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDNcXCwgXFxwNFxcKSwgNSlcbiAgcDI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMlxcLCBcXHA0XFwpLCA1KVxuICBwMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAxXFwsIFxccDRcXCksIDUpXG4gIHAwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDBcXCwgXFxwNFxcKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBzY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDAxOiBcXCwgY29udlB2YWx1ZShwMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyMzogXFwsIGNvbnZQdmFsdWUocDIzKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDM0OiBcXCwgY29udlB2YWx1ZShwMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjQ6IFxcLCBjb252UHZhbHVlKHAyNCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNDogXFwsY29udlB2YWx1ZSggcDE0KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDA0OiBcXCxjb252UHZhbHVlKCBwMDQpLCBcXFxcblxcKSwgXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFxcI2Q5ZDlkOVxcLCBcXCNiZGJkYmRcXCwgXFwjOTY5Njk2XFwsIFxcIzczNzM3M1xcLCBcXCM1MjUyNTJcXCkpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcaW5zdWxhdGlvbl9zY29yZV9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG4jIERNU09cbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcXGdyb3VwXFwsIFxcc2NvcmVcXClcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXFxuZWFyZXN0Qm91bmRhcnlfRE1TT19QLVNcXClcblxuIyBkVEFHXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfZFRBRylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXFxncm91cFxcLCBcXHNjb3JlXFwpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFxcbmVhcmVzdEJvdW5kYXJ5X2RUQUdfUC1TXFwpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kaWZmX1AtU1xcLCB5bWluID0gLTAuNSwgeW1heCA9IDEpXG5gYGBcbmBgYCJ9 -->

```r
```r
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% psOver4, \p4\,
                 ifelse(ensembl %in% psOver3, \p3\,
                        ifelse(ensembl %in% psOver2, \p2\,
                               ifelse(ensembl %in% psOver1, \p1\, 
                                      ifelse(ensembl %in% psOver0, \p0\, NA))))))  %>% 
  dplyr::filter(!is.na(group))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p01 <- round(getPvalWilcox(temp.tb, \p0\, \p1\), 5)
  p12 <- round(getPvalWilcox(temp.tb, \p1\, \p2\), 5)
  p23 <- round(getPvalWilcox(temp.tb, \p2\, \p3\), 5)
  p34 <- round(getPvalWilcox(temp.tb, \p3\, \p4\), 5)
  p24 <- round(getPvalWilcox(temp.tb, \p2\, \p4\), 5)
  p14 <- round(getPvalWilcox(temp.tb, \p1\, \p4\), 5)
  p04 <- round(getPvalWilcox(temp.tb, \p0\, \p4\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p01: \, convPvalue(p01), \\n\,
                                                         \p12: \, convPvalue(p12), \\n\,
                                                         \p23: \, convPvalue(p23), \\n\,
                                                         \p34: \, convPvalue(p34), \\n\,
                                                         \p24: \, convPvalue(p24), \\n\,
                                                         \p14: \,convPvalue( p14), \\n\,
                                                         \p04: \,convPvalue( p04), \\n\), 
             color = \black\, hjust = 0, size = 3) +
    scale_fill_manual(values = c(\#d9d9d9\, \#bdbdbd\, \#969696\, \#737373\, \#525252\))
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO_P-S\)

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_dTAG_P-S\)

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_diff_P-S\, ymin = -0.5, ymax = 1)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### Plotting for P-N

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXCJnZW5lX2xvb3BfbGluay5yZHNcIikpXG5cbnBlT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSA0KSkkZ2VuZVxucGVPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDMsIG51bV9wZSA8IDQpKSRnZW5lXG5wZU92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMiwgbnVtX3BlIDwgMykpJGdlbmVcbnBlT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAxLCBudW1fcGUgPCAyKSkkZ2VuZVxucGVPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlIDwgMSkpJGdlbmVcblxuXG5nZW5lLmluc1Njb3JlIDwtIGdlbmUuaW5zU2NvcmUuYWxsICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBwZU92ZXI0LCBcInA0XCIsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcGVPdmVyMywgXCJwM1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwZU92ZXIyLCBcInAyXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwZU92ZXIxLCBcInAxXCIsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIHBlT3ZlcjAsIFwicDBcIiwgTkEpKSkpKSkgICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJHNjb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRzY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxucGxvdF9pbnNTY29yZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEuNSl7XG4gIHAwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwicDBcIiwgXCJwMVwiKSwgNSlcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJwMVwiLCBcInAyXCIpLCA1KVxuICBwMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcInAyXCIsIFwicDNcIiksIDUpXG4gIHAzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwicDNcIiwgXCJwNFwiKSwgNSlcbiAgcDI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJwMlwiLCBcInA0XCIpLCA1KVxuICBwMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcInAxXCIsIFwicDRcIiksIDUpXG4gIHAwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwicDBcIiwgXCJwNFwiKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBzY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFwicmVkXCIsIGNvbG9yID0gXCJibGFja1wiKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFwicDAxOiBcIiwgY29udlB2YWx1ZShwMDEpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMTI6IFwiLCBjb252UHZhbHVlKHAxMiksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAyMzogXCIsIGNvbnZQdmFsdWUocDIzKSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDM0OiBcIiwgY29udlB2YWx1ZShwMzQpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMjQ6IFwiLCBjb252UHZhbHVlKHAyNCksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAxNDogXCIsY29udlB2YWx1ZSggcDE0KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDA0OiBcIixjb252UHZhbHVlKCBwMDQpLCBcIlxcblwiKSwgXG4gICAgICAgICAgICAgY29sb3IgPSBcImJsYWNrXCIsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFwiI2Q5ZDlkOVwiLCBcIiNiZGJkYmRcIiwgXCIjOTY5Njk2XCIsIFwiIzczNzM3M1wiLCBcIiM1MjUyNTJcIikpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFwiaW5zdWxhdGlvbl9zY29yZV9cIiwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG4jIERNU09cbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcImdyb3VwXCIsIFwic2NvcmVcIilcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXCJuZWFyZXN0Qm91bmRhcnlfRE1TT19QLUVcIilcblxuIyBkVEFHXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfZFRBRylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXCJncm91cFwiLCBcInNjb3JlXCIpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFwibmVhcmVzdEJvdW5kYXJ5X2RUQUdfUC1FXCIpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFwiZ3JvdXBcIiwgXCJzY29yZVwiKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcIm5lYXJlc3RCb3VuZGFyeV9kaWZmX1AtRVwiLCB5bWluID0gLTAuNSwgeW1heCA9IDEpXG5gYGAifQ== -->\n\n```r\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\n\ngene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% peOver4, \\p4\\,\n                 ifelse(ensembl %in% peOver3, \\p3\\,\n                        ifelse(ensembl %in% peOver2, \\p2\\,\n                               ifelse(ensembl %in% peOver1, \\p1\\, \n                                      ifelse(ensembl %in% peOver0, \\p0\\, NA))))))  %>% \n  dplyr::filter(!is.na(group))\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$score\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nplot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){\n  p01 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p1\\), 5)\n  p12 <- round(getPvalWilcox(temp.tb, \\p1\\, \\p2\\), 5)\n  p23 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p3\\), 5)\n  p34 <- round(getPvalWilcox(temp.tb, \\p3\\, \\p4\\), 5)\n  p24 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p4\\), 5)\n  p14 <- round(getPvalWilcox(temp.tb, \\p1\\, \\p4\\), 5)\n  p04 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p4\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +\n    annotate(\\text\\, x = 1, y = ymin + 1, label = paste0(\\p01: \\, convPvalue(p01), \\\\n\\,\n                                                         \\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p23: \\, convPvalue(p23), \\\\n\\,\n                                                         \\p34: \\, convPvalue(p34), \\\\n\\,\n                                                         \\p24: \\, convPvalue(p24), \\\\n\\,\n                                                         \\p14: \\,convPvalue( p14), \\\\n\\,\n                                                         \\p04: \\,convPvalue( p04), \\\\n\\), \n             color = \\black\\, hjust = 0, size = 3) +\n    scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n  \n  \n  fileName <- paste0(\\insulation_score_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# DMSO\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_DMSO_P-E\\)\n\n# dTAG\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_dTAG_P-E\\)\n\n# diff\ntemp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_diff_P-E\\, ymin = -0.5, ymax = 1)\n```\n\n<!-- rnb-source-end -->\n"} -->
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% peOver4, \p4\,
                 ifelse(ensembl %in% peOver3, \p3\,
                        ifelse(ensembl %in% peOver2, \p2\,
                               ifelse(ensembl %in% peOver1, \p1\, 
                                      ifelse(ensembl %in% peOver0, \p0\, NA))))))  %>% 
  dplyr::filter(!is.na(group))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p01 <- round(getPvalWilcox(temp.tb, \p0\, \p1\), 5)
  p12 <- round(getPvalWilcox(temp.tb, \p1\, \p2\), 5)
  p23 <- round(getPvalWilcox(temp.tb, \p2\, \p3\), 5)
  p34 <- round(getPvalWilcox(temp.tb, \p3\, \p4\), 5)
  p24 <- round(getPvalWilcox(temp.tb, \p2\, \p4\), 5)
  p14 <- round(getPvalWilcox(temp.tb, \p1\, \p4\), 5)
  p04 <- round(getPvalWilcox(temp.tb, \p0\, \p4\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p01: \, convPvalue(p01), \\n\,
                                                         \p12: \, convPvalue(p12), \\n\,
                                                         \p23: \, convPvalue(p23), \\n\,
                                                         \p34: \, convPvalue(p34), \\n\,
                                                         \p24: \, convPvalue(p24), \\n\,
                                                         \p14: \,convPvalue( p14), \\n\,
                                                         \p04: \,convPvalue( p04), \\n\), 
             color = \black\, hjust = 0, size = 3) +
    scale_fill_manual(values = c(\#d9d9d9\, \#bdbdbd\, \#969696\, \#737373\, \#525252\))
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO_P-E\)

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_dTAG_P-E\)

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_diff_P-E\, ymin = -0.5, ymax = 1)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXFxnZW5lX2xvb3BfbGluay5yZHNcXCkpXG5cbnBlT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSA0KSkkZ2VuZVxucGVPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDMsIG51bV9wZSA8IDQpKSRnZW5lXG5wZU92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMiwgbnVtX3BlIDwgMykpJGdlbmVcbnBlT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAxLCBudW1fcGUgPCAyKSkkZ2VuZVxucGVPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlIDwgMSkpJGdlbmVcblxuXG5nZW5lLmluc1Njb3JlIDwtIGdlbmUuaW5zU2NvcmUuYWxsICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBwZU92ZXI0LCBcXHA0XFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcGVPdmVyMywgXFxwM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwZU92ZXIyLCBcXHAyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwZU92ZXIxLCBcXHAxXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIHBlT3ZlcjAsIFxccDBcXCwgTkEpKSkpKSkgICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJHNjb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRzY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxucGxvdF9pbnNTY29yZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEuNSl7XG4gIHAwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDBcXCwgXFxwMVxcKSwgNSlcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMVxcLCBcXHAyXFwpLCA1KVxuICBwMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAyXFwsIFxccDNcXCksIDUpXG4gIHAzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDNcXCwgXFxwNFxcKSwgNSlcbiAgcDI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMlxcLCBcXHA0XFwpLCA1KVxuICBwMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAxXFwsIFxccDRcXCksIDUpXG4gIHAwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDBcXCwgXFxwNFxcKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBzY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDAxOiBcXCwgY29udlB2YWx1ZShwMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyMzogXFwsIGNvbnZQdmFsdWUocDIzKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDM0OiBcXCwgY29udlB2YWx1ZShwMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjQ6IFxcLCBjb252UHZhbHVlKHAyNCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNDogXFwsY29udlB2YWx1ZSggcDE0KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDA0OiBcXCxjb252UHZhbHVlKCBwMDQpLCBcXFxcblxcKSwgXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFxcI2Q5ZDlkOVxcLCBcXCNiZGJkYmRcXCwgXFwjOTY5Njk2XFwsIFxcIzczNzM3M1xcLCBcXCM1MjUyNTJcXCkpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcaW5zdWxhdGlvbl9zY29yZV9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG4jIERNU09cbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcXGdyb3VwXFwsIFxcc2NvcmVcXClcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXFxuZWFyZXN0Qm91bmRhcnlfRE1TT19QLUVcXClcblxuIyBkVEFHXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfZFRBRylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXFxncm91cFxcLCBcXHNjb3JlXFwpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFxcbmVhcmVzdEJvdW5kYXJ5X2RUQUdfUC1FXFwpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kaWZmX1AtRVxcLCB5bWluID0gLTAuNSwgeW1heCA9IDEpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\n\ngene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% peOver4, \\p4\\,\n                 ifelse(ensembl %in% peOver3, \\p3\\,\n                        ifelse(ensembl %in% peOver2, \\p2\\,\n                               ifelse(ensembl %in% peOver1, \\p1\\, \n                                      ifelse(ensembl %in% peOver0, \\p0\\, NA))))))  %>% \n  dplyr::filter(!is.na(group))\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$score\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nplot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){\n  p01 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p1\\), 5)\n  p12 <- round(getPvalWilcox(temp.tb, \\p1\\, \\p2\\), 5)\n  p23 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p3\\), 5)\n  p34 <- round(getPvalWilcox(temp.tb, \\p3\\, \\p4\\), 5)\n  p24 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p4\\), 5)\n  p14 <- round(getPvalWilcox(temp.tb, \\p1\\, \\p4\\), 5)\n  p04 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p4\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +\n    annotate(\\text\\, x = 1, y = ymin + 1, label = paste0(\\p01: \\, convPvalue(p01), \\\\n\\,\n                                                         \\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p23: \\, convPvalue(p23), \\\\n\\,\n                                                         \\p34: \\, convPvalue(p34), \\\\n\\,\n                                                         \\p24: \\, convPvalue(p24), \\\\n\\,\n                                                         \\p14: \\,convPvalue( p14), \\\\n\\,\n                                                         \\p04: \\,convPvalue( p04), \\\\n\\), \n             color = \\black\\, hjust = 0, size = 3) +\n    scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n  \n  \n  fileName <- paste0(\\insulation_score_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# DMSO\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_DMSO_P-E\\)\n\n# dTAG\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_dTAG_P-E\\)\n\n# diff\ntemp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_diff_P-E\\, ymin = -0.5, ymax = 1)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXFxnZW5lX2xvb3BfbGluay5yZHNcXCkpXG5cbnBlT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSA0KSkkZ2VuZVxucGVPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDMsIG51bV9wZSA8IDQpKSRnZW5lXG5wZU92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMiwgbnVtX3BlIDwgMykpJGdlbmVcbnBlT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAxLCBudW1fcGUgPCAyKSkkZ2VuZVxucGVPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlIDwgMSkpJGdlbmVcblxuXG5nZW5lLmluc1Njb3JlIDwtIGdlbmUuaW5zU2NvcmUuYWxsICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBwZU92ZXI0LCBcXHA0XFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcGVPdmVyMywgXFxwM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwZU92ZXIyLCBcXHAyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwZU92ZXIxLCBcXHAxXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIHBlT3ZlcjAsIFxccDBcXCwgTkEpKSkpKSkgICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJHNjb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRzY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxucGxvdF9pbnNTY29yZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEuNSl7XG4gIHAwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDBcXCwgXFxwMVxcKSwgNSlcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMVxcLCBcXHAyXFwpLCA1KVxuICBwMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAyXFwsIFxccDNcXCksIDUpXG4gIHAzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDNcXCwgXFxwNFxcKSwgNSlcbiAgcDI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMlxcLCBcXHA0XFwpLCA1KVxuICBwMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAxXFwsIFxccDRcXCksIDUpXG4gIHAwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDBcXCwgXFxwNFxcKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBzY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDAxOiBcXCwgY29udlB2YWx1ZShwMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyMzogXFwsIGNvbnZQdmFsdWUocDIzKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDM0OiBcXCwgY29udlB2YWx1ZShwMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjQ6IFxcLCBjb252UHZhbHVlKHAyNCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNDogXFwsY29udlB2YWx1ZSggcDE0KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDA0OiBcXCxjb252UHZhbHVlKCBwMDQpLCBcXFxcblxcKSwgXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFxcI2Q5ZDlkOVxcLCBcXCNiZGJkYmRcXCwgXFwjOTY5Njk2XFwsIFxcIzczNzM3M1xcLCBcXCM1MjUyNTJcXCkpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcaW5zdWxhdGlvbl9zY29yZV9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG4jIERNU09cbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcXGdyb3VwXFwsIFxcc2NvcmVcXClcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXFxuZWFyZXN0Qm91bmRhcnlfRE1TT19QLUVcXClcblxuIyBkVEFHXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfZFRBRylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXFxncm91cFxcLCBcXHNjb3JlXFwpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFxcbmVhcmVzdEJvdW5kYXJ5X2RUQUdfUC1FXFwpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kaWZmX1AtRVxcLCB5bWluID0gLTAuNSwgeW1heCA9IDEpXG5gYGBcbmBgYCJ9 -->

```r
```r
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% peOver4, \p4\,
                 ifelse(ensembl %in% peOver3, \p3\,
                        ifelse(ensembl %in% peOver2, \p2\,
                               ifelse(ensembl %in% peOver1, \p1\, 
                                      ifelse(ensembl %in% peOver0, \p0\, NA))))))  %>% 
  dplyr::filter(!is.na(group))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p01 <- round(getPvalWilcox(temp.tb, \p0\, \p1\), 5)
  p12 <- round(getPvalWilcox(temp.tb, \p1\, \p2\), 5)
  p23 <- round(getPvalWilcox(temp.tb, \p2\, \p3\), 5)
  p34 <- round(getPvalWilcox(temp.tb, \p3\, \p4\), 5)
  p24 <- round(getPvalWilcox(temp.tb, \p2\, \p4\), 5)
  p14 <- round(getPvalWilcox(temp.tb, \p1\, \p4\), 5)
  p04 <- round(getPvalWilcox(temp.tb, \p0\, \p4\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p01: \, convPvalue(p01), \\n\,
                                                         \p12: \, convPvalue(p12), \\n\,
                                                         \p23: \, convPvalue(p23), \\n\,
                                                         \p34: \, convPvalue(p34), \\n\,
                                                         \p24: \, convPvalue(p24), \\n\,
                                                         \p14: \,convPvalue( p14), \\n\,
                                                         \p04: \,convPvalue( p04), \\n\), 
             color = \black\, hjust = 0, size = 3) +
    scale_fill_manual(values = c(\#d9d9d9\, \#bdbdbd\, \#969696\, \#737373\, \#525252\))
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO_P-E\)

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_dTAG_P-E\)

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_diff_P-E\, ymin = -0.5, ymax = 1)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### Plotting for P-S

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXCJnZW5lX2xvb3BfbGluay5yZHNcIikpXG5cbnBwT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSA0KSkkZ2VuZVxucHBPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDMsIG51bV9wcCA8IDQpKSRnZW5lXG5wcE92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMiwgbnVtX3BwIDwgMykpJGdlbmVcbnBwT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAxLCBudW1fcHAgPCAyKSkkZ2VuZVxucHBPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwIDwgMSkpJGdlbmVcblxuXG5nZW5lLmluc1Njb3JlIDwtIGdlbmUuaW5zU2NvcmUuYWxsICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBwcE92ZXI0LCBcInA0XCIsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcHBPdmVyMywgXCJwM1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwcE92ZXIyLCBcInAyXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwcE92ZXIxLCBcInAxXCIsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIHBwT3ZlcjAsIFwicDBcIiwgTkEpKSkpKSkgICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJHNjb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRzY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxucGxvdF9pbnNTY29yZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEuNSl7XG4gIHAwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwicDBcIiwgXCJwMVwiKSwgNSlcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJwMVwiLCBcInAyXCIpLCA1KVxuICBwMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcInAyXCIsIFwicDNcIiksIDUpXG4gIHAzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwicDNcIiwgXCJwNFwiKSwgNSlcbiAgcDI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJwMlwiLCBcInA0XCIpLCA1KVxuICBwMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcInAxXCIsIFwicDRcIiksIDUpXG4gIHAwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwicDBcIiwgXCJwNFwiKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBzY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFwicmVkXCIsIGNvbG9yID0gXCJibGFja1wiKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFwicDAxOiBcIiwgY29udlB2YWx1ZShwMDEpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMTI6IFwiLCBjb252UHZhbHVlKHAxMiksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAyMzogXCIsIGNvbnZQdmFsdWUocDIzKSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDM0OiBcIiwgY29udlB2YWx1ZShwMzQpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMjQ6IFwiLCBjb252UHZhbHVlKHAyNCksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAxNDogXCIsY29udlB2YWx1ZSggcDE0KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDA0OiBcIixjb252UHZhbHVlKCBwMDQpLCBcIlxcblwiKSwgXG4gICAgICAgICAgICAgY29sb3IgPSBcImJsYWNrXCIsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFwiI2Q5ZDlkOVwiLCBcIiNiZGJkYmRcIiwgXCIjOTY5Njk2XCIsIFwiIzczNzM3M1wiLCBcIiM1MjUyNTJcIikpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFwiaW5zdWxhdGlvbl9zY29yZV9cIiwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG4jIERNU09cbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcImdyb3VwXCIsIFwic2NvcmVcIilcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXCJuZWFyZXN0Qm91bmRhcnlfRE1TT19QLVBcIilcblxuIyBkVEFHXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfZFRBRylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXCJncm91cFwiLCBcInNjb3JlXCIpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFwibmVhcmVzdEJvdW5kYXJ5X2RUQUdfUC1QXCIpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFwiZ3JvdXBcIiwgXCJzY29yZVwiKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcIm5lYXJlc3RCb3VuZGFyeV9kaWZmX1AtUFwiLCB5bWluID0gLTAuNSwgeW1heCA9IDEpXG5gYGAifQ== -->\n\n```r\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\n\ngene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% ppOver4, \\p4\\,\n                 ifelse(ensembl %in% ppOver3, \\p3\\,\n                        ifelse(ensembl %in% ppOver2, \\p2\\,\n                               ifelse(ensembl %in% ppOver1, \\p1\\, \n                                      ifelse(ensembl %in% ppOver0, \\p0\\, NA))))))  %>% \n  dplyr::filter(!is.na(group))\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$score\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nplot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){\n  p01 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p1\\), 5)\n  p12 <- round(getPvalWilcox(temp.tb, \\p1\\, \\p2\\), 5)\n  p23 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p3\\), 5)\n  p34 <- round(getPvalWilcox(temp.tb, \\p3\\, \\p4\\), 5)\n  p24 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p4\\), 5)\n  p14 <- round(getPvalWilcox(temp.tb, \\p1\\, \\p4\\), 5)\n  p04 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p4\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +\n    annotate(\\text\\, x = 1, y = ymin + 1, label = paste0(\\p01: \\, convPvalue(p01), \\\\n\\,\n                                                         \\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p23: \\, convPvalue(p23), \\\\n\\,\n                                                         \\p34: \\, convPvalue(p34), \\\\n\\,\n                                                         \\p24: \\, convPvalue(p24), \\\\n\\,\n                                                         \\p14: \\,convPvalue( p14), \\\\n\\,\n                                                         \\p04: \\,convPvalue( p04), \\\\n\\), \n             color = \\black\\, hjust = 0, size = 3) +\n    scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n  \n  \n  fileName <- paste0(\\insulation_score_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# DMSO\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_DMSO_P-P\\)\n\n# dTAG\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_dTAG_P-P\\)\n\n# diff\ntemp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_diff_P-P\\, ymin = -0.5, ymax = 1)\n```\n\n<!-- rnb-source-end -->\n"} -->
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% ppOver4, \p4\,
                 ifelse(ensembl %in% ppOver3, \p3\,
                        ifelse(ensembl %in% ppOver2, \p2\,
                               ifelse(ensembl %in% ppOver1, \p1\, 
                                      ifelse(ensembl %in% ppOver0, \p0\, NA))))))  %>% 
  dplyr::filter(!is.na(group))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p01 <- round(getPvalWilcox(temp.tb, \p0\, \p1\), 5)
  p12 <- round(getPvalWilcox(temp.tb, \p1\, \p2\), 5)
  p23 <- round(getPvalWilcox(temp.tb, \p2\, \p3\), 5)
  p34 <- round(getPvalWilcox(temp.tb, \p3\, \p4\), 5)
  p24 <- round(getPvalWilcox(temp.tb, \p2\, \p4\), 5)
  p14 <- round(getPvalWilcox(temp.tb, \p1\, \p4\), 5)
  p04 <- round(getPvalWilcox(temp.tb, \p0\, \p4\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p01: \, convPvalue(p01), \\n\,
                                                         \p12: \, convPvalue(p12), \\n\,
                                                         \p23: \, convPvalue(p23), \\n\,
                                                         \p34: \, convPvalue(p34), \\n\,
                                                         \p24: \, convPvalue(p24), \\n\,
                                                         \p14: \,convPvalue( p14), \\n\,
                                                         \p04: \,convPvalue( p04), \\n\), 
             color = \black\, hjust = 0, size = 3) +
    scale_fill_manual(values = c(\#d9d9d9\, \#bdbdbd\, \#969696\, \#737373\, \#525252\))
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO_P-P\)

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_dTAG_P-P\)

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_diff_P-P\, ymin = -0.5, ymax = 1)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXFxnZW5lX2xvb3BfbGluay5yZHNcXCkpXG5cbnBwT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSA0KSkkZ2VuZVxucHBPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDMsIG51bV9wcCA8IDQpKSRnZW5lXG5wcE92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMiwgbnVtX3BwIDwgMykpJGdlbmVcbnBwT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAxLCBudW1fcHAgPCAyKSkkZ2VuZVxucHBPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwIDwgMSkpJGdlbmVcblxuXG5nZW5lLmluc1Njb3JlIDwtIGdlbmUuaW5zU2NvcmUuYWxsICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBwcE92ZXI0LCBcXHA0XFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcHBPdmVyMywgXFxwM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwcE92ZXIyLCBcXHAyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwcE92ZXIxLCBcXHAxXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIHBwT3ZlcjAsIFxccDBcXCwgTkEpKSkpKSkgICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJHNjb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRzY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxucGxvdF9pbnNTY29yZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEuNSl7XG4gIHAwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDBcXCwgXFxwMVxcKSwgNSlcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMVxcLCBcXHAyXFwpLCA1KVxuICBwMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAyXFwsIFxccDNcXCksIDUpXG4gIHAzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDNcXCwgXFxwNFxcKSwgNSlcbiAgcDI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMlxcLCBcXHA0XFwpLCA1KVxuICBwMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAxXFwsIFxccDRcXCksIDUpXG4gIHAwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDBcXCwgXFxwNFxcKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBzY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDAxOiBcXCwgY29udlB2YWx1ZShwMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyMzogXFwsIGNvbnZQdmFsdWUocDIzKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDM0OiBcXCwgY29udlB2YWx1ZShwMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjQ6IFxcLCBjb252UHZhbHVlKHAyNCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNDogXFwsY29udlB2YWx1ZSggcDE0KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDA0OiBcXCxjb252UHZhbHVlKCBwMDQpLCBcXFxcblxcKSwgXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFxcI2Q5ZDlkOVxcLCBcXCNiZGJkYmRcXCwgXFwjOTY5Njk2XFwsIFxcIzczNzM3M1xcLCBcXCM1MjUyNTJcXCkpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcaW5zdWxhdGlvbl9zY29yZV9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG4jIERNU09cbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcXGdyb3VwXFwsIFxcc2NvcmVcXClcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXFxuZWFyZXN0Qm91bmRhcnlfRE1TT19QLVBcXClcblxuIyBkVEFHXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfZFRBRylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXFxncm91cFxcLCBcXHNjb3JlXFwpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFxcbmVhcmVzdEJvdW5kYXJ5X2RUQUdfUC1QXFwpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kaWZmX1AtUFxcLCB5bWluID0gLTAuNSwgeW1heCA9IDEpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\n\ngene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% ppOver4, \\p4\\,\n                 ifelse(ensembl %in% ppOver3, \\p3\\,\n                        ifelse(ensembl %in% ppOver2, \\p2\\,\n                               ifelse(ensembl %in% ppOver1, \\p1\\, \n                                      ifelse(ensembl %in% ppOver0, \\p0\\, NA))))))  %>% \n  dplyr::filter(!is.na(group))\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$score\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nplot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){\n  p01 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p1\\), 5)\n  p12 <- round(getPvalWilcox(temp.tb, \\p1\\, \\p2\\), 5)\n  p23 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p3\\), 5)\n  p34 <- round(getPvalWilcox(temp.tb, \\p3\\, \\p4\\), 5)\n  p24 <- round(getPvalWilcox(temp.tb, \\p2\\, \\p4\\), 5)\n  p14 <- round(getPvalWilcox(temp.tb, \\p1\\, \\p4\\), 5)\n  p04 <- round(getPvalWilcox(temp.tb, \\p0\\, \\p4\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +\n    annotate(\\text\\, x = 1, y = ymin + 1, label = paste0(\\p01: \\, convPvalue(p01), \\\\n\\,\n                                                         \\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p23: \\, convPvalue(p23), \\\\n\\,\n                                                         \\p34: \\, convPvalue(p34), \\\\n\\,\n                                                         \\p24: \\, convPvalue(p24), \\\\n\\,\n                                                         \\p14: \\,convPvalue( p14), \\\\n\\,\n                                                         \\p04: \\,convPvalue( p04), \\\\n\\), \n             color = \\black\\, hjust = 0, size = 3) +\n    scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n  \n  \n  fileName <- paste0(\\insulation_score_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# DMSO\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_DMSO_P-P\\)\n\n# dTAG\ntemp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_dTAG_P-P\\)\n\n# diff\ntemp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)\ncolnames(temp.tb) <- c(\\group\\, \\score\\)\nplot_insScore(temp.tb, \\nearestBoundary_diff_P-P\\, ymin = -0.5, ymax = 1)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudGVtcDIgPC0gcmVhZFJEUyhoZXJlKHJlc3VsdERpciwgXFxnZW5lX2xvb3BfbGluay5yZHNcXCkpXG5cbnBwT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSA0KSkkZ2VuZVxucHBPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDMsIG51bV9wcCA8IDQpKSRnZW5lXG5wcE92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMiwgbnVtX3BwIDwgMykpJGdlbmVcbnBwT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAxLCBudW1fcHAgPCAyKSkkZ2VuZVxucHBPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwIDwgMSkpJGdlbmVcblxuXG5nZW5lLmluc1Njb3JlIDwtIGdlbmUuaW5zU2NvcmUuYWxsICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBwcE92ZXI0LCBcXHA0XFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgcHBPdmVyMywgXFxwM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwcE92ZXIyLCBcXHAyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBwcE92ZXIxLCBcXHAxXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIHBwT3ZlcjAsIFxccDBcXCwgTkEpKSkpKSkgICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJHNjb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRzY29yZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxucGxvdF9pbnNTY29yZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEuNSl7XG4gIHAwMSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDBcXCwgXFxwMVxcKSwgNSlcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMVxcLCBcXHAyXFwpLCA1KVxuICBwMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAyXFwsIFxccDNcXCksIDUpXG4gIHAzNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDNcXCwgXFxwNFxcKSwgNSlcbiAgcDI0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxwMlxcLCBcXHA0XFwpLCA1KVxuICBwMTQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXHAxXFwsIFxccDRcXCksIDUpXG4gIHAwNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxccDBcXCwgXFxwNFxcKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBzY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDAxOiBcXCwgY29udlB2YWx1ZShwMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyMzogXFwsIGNvbnZQdmFsdWUocDIzKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDM0OiBcXCwgY29udlB2YWx1ZShwMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjQ6IFxcLCBjb252UHZhbHVlKHAyNCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNDogXFwsY29udlB2YWx1ZSggcDE0KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDA0OiBcXCxjb252UHZhbHVlKCBwMDQpLCBcXFxcblxcKSwgXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpICtcbiAgICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFxcI2Q5ZDlkOVxcLCBcXCNiZGJkYmRcXCwgXFwjOTY5Njk2XFwsIFxcIzczNzM3M1xcLCBcXCM1MjUyNTJcXCkpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcaW5zdWxhdGlvbl9zY29yZV9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxuXG4jIERNU09cbnRlbXAudGIgPC0gZ2VuZS5pbnNTY29yZSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYm91bmRhcnlJbnNTY29yZV9ETVNPKVxuY29sbmFtZXModGVtcC50YikgPC0gYyhcXGdyb3VwXFwsIFxcc2NvcmVcXClcbnBsb3RfaW5zU2NvcmUodGVtcC50YiwgXFxuZWFyZXN0Qm91bmRhcnlfRE1TT19QLVBcXClcblxuIyBkVEFHXG50ZW1wLnRiIDwtIGdlbmUuaW5zU2NvcmUgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGJvdW5kYXJ5SW5zU2NvcmVfZFRBRylcbmNvbG5hbWVzKHRlbXAudGIpIDwtIGMoXFxncm91cFxcLCBcXHNjb3JlXFwpXG5wbG90X2luc1Njb3JlKHRlbXAudGIsIFxcbmVhcmVzdEJvdW5kYXJ5X2RUQUdfUC1QXFwpXG5cbiMgZGlmZlxudGVtcC50YiA8LSBnZW5lLmluc1Njb3JlICU+JSBkcGx5cjo6c2VsZWN0KGdyb3VwLCBkaWZmX2JvdW5kYXJ5SW5zU2NvcmUpXG5jb2xuYW1lcyh0ZW1wLnRiKSA8LSBjKFxcZ3JvdXBcXCwgXFxzY29yZVxcKVxucGxvdF9pbnNTY29yZSh0ZW1wLnRiLCBcXG5lYXJlc3RCb3VuZGFyeV9kaWZmX1AtUFxcLCB5bWluID0gLTAuNSwgeW1heCA9IDEpXG5gYGBcbmBgYCJ9 -->

```r
```r
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% ppOver4, \p4\,
                 ifelse(ensembl %in% ppOver3, \p3\,
                        ifelse(ensembl %in% ppOver2, \p2\,
                               ifelse(ensembl %in% ppOver1, \p1\, 
                                      ifelse(ensembl %in% ppOver0, \p0\, NA))))))  %>% 
  dplyr::filter(!is.na(group))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p01 <- round(getPvalWilcox(temp.tb, \p0\, \p1\), 5)
  p12 <- round(getPvalWilcox(temp.tb, \p1\, \p2\), 5)
  p23 <- round(getPvalWilcox(temp.tb, \p2\, \p3\), 5)
  p34 <- round(getPvalWilcox(temp.tb, \p3\, \p4\), 5)
  p24 <- round(getPvalWilcox(temp.tb, \p2\, \p4\), 5)
  p14 <- round(getPvalWilcox(temp.tb, \p1\, \p4\), 5)
  p04 <- round(getPvalWilcox(temp.tb, \p0\, \p4\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p01: \, convPvalue(p01), \\n\,
                                                         \p12: \, convPvalue(p12), \\n\,
                                                         \p23: \, convPvalue(p23), \\n\,
                                                         \p34: \, convPvalue(p34), \\n\,
                                                         \p24: \, convPvalue(p24), \\n\,
                                                         \p14: \,convPvalue( p14), \\n\,
                                                         \p04: \,convPvalue( p04), \\n\), 
             color = \black\, hjust = 0, size = 3) +
    scale_fill_manual(values = c(\#d9d9d9\, \#bdbdbd\, \#969696\, \#737373\, \#525252\))
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_DMSO_P-P\)

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_dTAG_P-P\)

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c(\group\, \score\)
plot_insScore(temp.tb, \nearestBoundary_diff_P-P\, ymin = -0.5, ymax = 1)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### Plotting for P-E

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjbVZtUkdseUlEd3RJR2hsY21Vb1hDSXVMaTh1TGx3aUxDQmNJbkpsWm1WeVpXNWpaVndpS1Z4dVhHNGpJRWx0Y0c5eWRHbHVaeUJVUVVRZ1ltOTFibVJoY25sY2JuUmhaRjlpYjNWdVpHRnllU0E4TFNCbWNtVmhaQ2hvWlhKbEtGd2lMaTR2TGk0dmNtVnpkV3gwTDFSQlJGd2lMQ0JjSWxSQlJGOHlOV3RpWHpFeU5XdGlYMjkwYzNWZlltOTFibVJoY21sbGMxOUhNVVJOVTA4dVltVmtYQ0lwS1Z4dVkyOXNibUZ0WlhNb2RHRmtYMkp2ZFc1a1lYSjVLU0E4TFNCaktGd2lZMmh5WENJc0lGd2ljM1JoY25SY0lpd2dYQ0psYm1SY0lpbGNiblJoWkY5aWIzVnVaR0Z5ZVNBOExTQjBZV1JmWW05MWJtUmhjbmtnSlQ0bElHUndiSGx5T2pwdGRYUmhkR1VvZEdGa1gybGtJRDBnY0dGemRHVW9ZMmh5TENCemRHRnlkQ3dnWlc1a0xDQnpaWEFnUFNCY0lsOWNJaWtzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHTmxiblJsY2lBOUlDaHpkR0Z5ZENBcklHVnVaQ2t2TWlsY2JseHVJeUJKYlhCdmNuUnBibWNnVkVGRVhHNTBZV1FnUEMwZ1puSmxZV1FvYUdWeVpTaGNJaTR1THk0dUwzSmxjM1ZzZEM5VVFVUmNJaXdnWENKVVFVUmZNalZyWWw4eE1qVnJZbDl2ZEhOMVgwY3hSRTFUVHk1aVpXUndaVndpS1NsY2JtTnZiRzVoYldWektIUmhaQ2tnUEMwZ1l5aGNJbU5vY2pGY0lpd2dYQ0p6ZEdGeWRERmNJaXdnWENKbGJtUXhYQ0lzSUZ3aVkyaHlNbHdpTENCY0luTjBZWEowTWx3aUxDQmNJbVZ1WkRKY0lpbGNiblJoWkNBOExTQjBZV1FnSlQ0bElHUndiSGx5T2pwdGRYUmhkR1VvZEdGa1NVUWdQU0J3WVhOMFpTaGphSEl4TENCemRHRnlkREVzSUdWdVpERXNJSE5sY0NBOUlGd2lYMXdpS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdkR0ZrVTJsNlpTQTlJR1Z1WkRFZ0xTQnpkR0Z5ZERFcFhHNWNiaU1nU1cxd2IzSjBhVzVuSUdkbGJtVmNibWRsYm1VdVZGTlRMblJpSUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNJbTF0TVRCZlIxSkRiVE00TG5BMlgyZGxibVZmYzI5eWRHVmtMbUpsWkZ3aUtTa2dKVDRsWEc0Z0lHUndiSGx5T2pwdGRYUmhkR1VvVkZOVElEMGdhV1psYkhObEtGWTBJRDA5SUZ3aUsxd2lMQ0JXTWl3Z1ZqTXBLU0FsUGlWY2JpQWdaSEJzZVhJNk9uTmxiR1ZqZENoV05pd2dWalVzSUZZeExDQlVVMU1wWEc1amIyeHVZVzFsY3loblpXNWxMbFJUVXk1MFlpa2dQQzBnWXloY0ltVnVjMlZ0WW14Y0lpd2dYQ0puWlc1bFhDSXNJRndpWTJoeVhDSXNJRndpVkZOVFhDSXBYRzVjYmlNZ1JuVnVZM1JwYjI1elhHNW1hVzVrUkdsemRHRnVZMlZVYjFSQlJDQThMU0JtZFc1amRHbHZiaWhqYUhKdmJTd2dWRk5UTENCMFlXUmZZbTkxYm1SaGNua3BlMXh1SUNCMFpXMXdJRHd0SUhSaFpGOWliM1Z1WkdGeWVTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaGphSElnUFQwZ1kyaHliMjBwSUNVK0pWeHVJQ0FnSUdSd2JIbHlPanB0ZFhSaGRHVW9aR2x6ZEdGdVkyVWdQU0JoWW5Nb1kyVnVkR1Z5SUMwZ1ZGTlRLU2tnSlQ0bElITnNhV05sWDIxcGJpaGthWE4wWVc1alpTbGNiaUFnYVdZb2JuSnZkeWgwWlcxd0tTQTlQU0F4S1h0Y2JpQWdJQ0J5WlhSMWNtNG9kR1Z0Y0NSa2FYTjBZVzVqWlNsY2JpQWdmV1ZzYzJWN1hHNGdJQ0FnY21WMGRYSnVLRTVCS1Z4dUlDQjlYRzU5WEc1Y2JtWnBibVJKZEhOVVFVUWdQQzBnWm5WdVkzUnBiMjRvWTJoeWIyMHNJRlJUVXl3Z2RHRmtLWHRjYmlBZ2RHVnRjQ0E4TFNCMFlXUWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9ZMmh5TVNBOVBTQmphSEp2YlN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYzNSaGNuUXhJRHdnVkZOVExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCbGJtUXhJRDRnVkZOVEtWeHVJQ0JwWmlodWNtOTNLSFJsYlhBcElEMDlJREVwZTF4dUlDQWdJSEpsZEhWeWJpaDBaVzF3SkhSaFpFbEVLVnh1SUNCOVpXeHpaWHRjYmlBZ0lDQnlaWFIxY200b1RrRXBYRzRnSUgxY2JuMWNibHh1Wm1sdVpGUkJSRk5wZW1VZ1BDMW1kVzVqZEdsdmJpaGphSEp2YlN3Z1ZGTlRMQ0IwWVdRcGUxeHVJQ0IwWlcxd0lEd3RJSFJoWkNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2loamFISXhJRDA5SUdOb2NtOXRMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnpkR0Z5ZERFZ1BDQlVVMU1zWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR1Z1WkRFZ1BpQlVVMU1wWEc0Z0lHbG1LRzV5YjNjb2RHVnRjQ2tnUFQwZ01TbDdYRzRnSUNBZ2NtVjBkWEp1S0hSbGJYQWtkR0ZrVTJsNlpTbGNiaUFnZldWc2MyVjdYRzRnSUNBZ2NtVjBkWEp1S0U1QktWeHVJQ0I5WEc1OVhHNWNibWRsYm1VdVZGTlRMblJpSUR3dElHZGxibVV1VkZOVExuUmlJQ1UrSlNCeWIzZDNhWE5sS0NrZ0pUNGxYRzRnSUdSd2JIbHlPanB0ZFhSaGRHVW9aR2x6ZEdGdVkyVWdQU0JtYVc1a1JHbHpkR0Z1WTJWVWIxUkJSQ2hqYUhJc0lGUlRVeXdnZEdGa1gySnZkVzVrWVhKNUtTeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQlVRVVFnUFNCbWFXNWtTWFJ6VkVGRUtHTm9jaXdnVkZOVExDQjBZV1FwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZSQlJITnBlbVVnUFNCbWFXNWtWRUZFVTJsNlpTaGphSElzSUZSVFV5d2dkR0ZrS1NsY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5yZWZEaXIgPC0gaGVyZShcXC4uLy4uXFwsIFxccmVmZXJlbmNlXFwpXG5cbiMgSW1wb3J0aW5nIFRBRCBib3VuZGFyeVxudGFkX2JvdW5kYXJ5IDwtIGZyZWFkKGhlcmUoXFwuLi8uLi9yZXN1bHQvVEFEXFwsIFxcVEFEXzI1a2JfMTI1a2Jfb3RzdV9ib3VuZGFyaWVzX0cxRE1TTy5iZWRcXCkpXG5jb2xuYW1lcyh0YWRfYm91bmRhcnkpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6Om11dGF0ZSh0YWRfaWQgPSBwYXN0ZShjaHIsIHN0YXJ0LCBlbmQsIHNlcCA9IFxcX1xcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyID0gKHN0YXJ0ICsgZW5kKS8yKVxuXG4jIEltcG9ydGluZyBUQURcbnRhZCA8LSBmcmVhZChoZXJlKFxcLi4vLi4vcmVzdWx0L1RBRFxcLCBcXFRBRF8yNWtiXzEyNWtiX290c3VfRzFETVNPLmJlZHBlXFwpKVxuY29sbmFtZXModGFkKSA8LSBjKFxcY2hyMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHIyXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcKVxudGFkIDwtIHRhZCAlPiUgZHBseXI6Om11dGF0ZSh0YWRJRCA9IHBhc3RlKGNocjEsIHN0YXJ0MSwgZW5kMSwgc2VwID0gXFxfXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0YWRTaXplID0gZW5kMSAtIHN0YXJ0MSlcblxuIyBJbXBvcnRpbmcgZ2VuZVxuZ2VuZS5UU1MudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXFwrXFwsIFYyLCBWMykpICU+JVxuICBkcGx5cjo6c2VsZWN0KFY2LCBWNSwgVjEsIFRTUylcbmNvbG5hbWVzKGdlbmUuVFNTLnRiKSA8LSBjKFxcZW5zZW1ibFxcLCBcXGdlbmVcXCwgXFxjaHJcXCwgXFxUU1NcXClcblxuIyBGdW5jdGlvbnNcbmZpbmREaXN0YW5jZVRvVEFEIDwtIGZ1bmN0aW9uKGNocm9tLCBUU1MsIHRhZF9ib3VuZGFyeSl7XG4gIHRlbXAgPC0gdGFkX2JvdW5kYXJ5ICU+JSBkcGx5cjo6ZmlsdGVyKGNociA9PSBjaHJvbSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IGFicyhjZW50ZXIgLSBUU1MpKSAlPiUgc2xpY2VfbWluKGRpc3RhbmNlKVxuICBpZihucm93KHRlbXApID09IDEpe1xuICAgIHJldHVybih0ZW1wJGRpc3RhbmNlKVxuICB9ZWxzZXtcbiAgICByZXR1cm4oTkEpXG4gIH1cbn1cblxuZmluZEl0c1RBRCA8LSBmdW5jdGlvbihjaHJvbSwgVFNTLCB0YWQpe1xuICB0ZW1wIDwtIHRhZCAlPiUgZHBseXI6OmZpbHRlcihjaHIxID09IGNocm9tLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdGFydDEgPCBUU1MsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZDEgPiBUU1MpXG4gIGlmKG5yb3codGVtcCkgPT0gMSl7XG4gICAgcmV0dXJuKHRlbXAkdGFkSUQpXG4gIH1lbHNle1xuICAgIHJldHVybihOQSlcbiAgfVxufVxuXG5maW5kVEFEU2l6ZSA8LWZ1bmN0aW9uKGNocm9tLCBUU1MsIHRhZCl7XG4gIHRlbXAgPC0gdGFkICU+JSBkcGx5cjo6ZmlsdGVyKGNocjEgPT0gY2hyb20sXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHN0YXJ0MSA8IFRTUyxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZW5kMSA+IFRTUylcbiAgaWYobnJvdyh0ZW1wKSA9PSAxKXtcbiAgICByZXR1cm4odGVtcCR0YWRTaXplKVxuICB9ZWxzZXtcbiAgICByZXR1cm4oTkEpXG4gIH1cbn1cblxuZ2VuZS5UU1MudGIgPC0gZ2VuZS5UU1MudGIgJT4lIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IGZpbmREaXN0YW5jZVRvVEFEKGNociwgVFNTLCB0YWRfYm91bmRhcnkpLFxuICAgICAgICAgICAgICAgIFRBRCA9IGZpbmRJdHNUQUQoY2hyLCBUU1MsIHRhZCksXG4gICAgICAgICAgICAgICAgVEFEc2l6ZSA9IGZpbmRUQURTaXplKGNociwgVFNTLCB0YWQpKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
refDir <- here(\../..\, \reference\)

# Importing TAD boundary
tad_boundary <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\))
colnames(tad_boundary) <- c(\chr\, \start\, \end\)
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = \_\),
                                               center = (start + end)/2)

# Importing TAD
tad <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_G1DMSO.bedpe\))
colnames(tad) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\)
tad <- tad %>% dplyr::mutate(tadID = paste(chr1, start1, end1, sep = \_\),
                             tadSize = end1 - start1)

# Importing gene
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, V5, V1, TSS)
colnames(gene.TSS.tb) <- c(\ensembl\, \gene\, \chr\, \TSS\)

# Functions
findDistanceToTAD <- function(chrom, TSS, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom) %>%
    dplyr::mutate(distance = abs(center - TSS)) %>% slice_min(distance)
  if(nrow(temp) == 1){
    return(temp$distance)
  }else{
    return(NA)
  }
}

findItsTAD <- function(chrom, TSS, tad){
  temp <- tad %>% dplyr::filter(chr1 == chrom,
                                start1 < TSS,
                                end1 > TSS)
  if(nrow(temp) == 1){
    return(temp$tadID)
  }else{
    return(NA)
  }
}

findTADSize <-function(chrom, TSS, tad){
  temp <- tad %>% dplyr::filter(chr1 == chrom,
                                start1 < TSS,
                                end1 > TSS)
  if(nrow(temp) == 1){
    return(temp$tadSize)
  }else{
    return(NA)
  }
}

gene.TSS.tb <- gene.TSS.tb %>% rowwise() %>%
  dplyr::mutate(distance = findDistanceToTAD(chr, TSS, tad_boundary),
                TAD = findItsTAD(chr, TSS, tad),
                TADsize = findTADSize(chr, TSS, tad))



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWNtVm1SR2x5SUR3dElHaGxjbVVvWEZ3dUxpOHVMbHhjTENCY1hISmxabVZ5Wlc1alpWeGNLVnh1WEc0aklFbHRjRzl5ZEdsdVp5QlVRVVFnWW05MWJtUmhjbmxjYm5SaFpGOWliM1Z1WkdGeWVTQThMU0JtY21WaFpDaG9aWEpsS0Z4Y0xpNHZMaTR2Y21WemRXeDBMMVJCUkZ4Y0xDQmNYRlJCUkY4eU5XdGlYekV5Tld0aVgyOTBjM1ZmWW05MWJtUmhjbWxsYzE5SE1VUk5VMDh1WW1Wa1hGd3BLVnh1WTI5c2JtRnRaWE1vZEdGa1gySnZkVzVrWVhKNUtTQThMU0JqS0Z4Y1kyaHlYRndzSUZ4Y2MzUmhjblJjWEN3Z1hGeGxibVJjWENsY2JuUmhaRjlpYjNWdVpHRnllU0E4TFNCMFlXUmZZbTkxYm1SaGNua2dKVDRsSUdSd2JIbHlPanB0ZFhSaGRHVW9kR0ZrWDJsa0lEMGdjR0Z6ZEdVb1kyaHlMQ0J6ZEdGeWRDd2daVzVrTENCelpYQWdQU0JjWEY5Y1hDa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdObGJuUmxjaUE5SUNoemRHRnlkQ0FySUdWdVpDa3ZNaWxjYmx4dUl5QkpiWEJ2Y25ScGJtY2dWRUZFWEc1MFlXUWdQQzBnWm5KbFlXUW9hR1Z5WlNoY1hDNHVMeTR1TDNKbGMzVnNkQzlVUVVSY1hDd2dYRnhVUVVSZk1qVnJZbDh4TWpWcllsOXZkSE4xWDBjeFJFMVRUeTVpWldSd1pWeGNLU2xjYm1OdmJHNWhiV1Z6S0hSaFpDa2dQQzBnWXloY1hHTm9jakZjWEN3Z1hGeHpkR0Z5ZERGY1hDd2dYRnhsYm1ReFhGd3NJRnhjWTJoeU1seGNMQ0JjWEhOMFlYSjBNbHhjTENCY1hHVnVaREpjWENsY2JuUmhaQ0E4TFNCMFlXUWdKVDRsSUdSd2JIbHlPanB0ZFhSaGRHVW9kR0ZrU1VRZ1BTQndZWE4wWlNoamFISXhMQ0J6ZEdGeWRERXNJR1Z1WkRFc0lITmxjQ0E5SUZ4Y1gxeGNLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2RHRmtVMmw2WlNBOUlHVnVaREVnTFNCemRHRnlkREVwWEc1Y2JpTWdTVzF3YjNKMGFXNW5JR2RsYm1WY2JtZGxibVV1VkZOVExuUmlJRHd0SUdaeVpXRmtLR2hsY21Vb2NtVm1SR2x5TENCY1hHMXRNVEJmUjFKRGJUTTRMbkEyWDJkbGJtVmZjMjl5ZEdWa0xtSmxaRnhjS1NrZ0pUNGxYRzRnSUdSd2JIbHlPanB0ZFhSaGRHVW9WRk5USUQwZ2FXWmxiSE5sS0ZZMElEMDlJRnhjSzF4Y0xDQldNaXdnVmpNcEtTQWxQaVZjYmlBZ1pIQnNlWEk2T25ObGJHVmpkQ2hXTml3Z1ZqVXNJRll4TENCVVUxTXBYRzVqYjJ4dVlXMWxjeWhuWlc1bExsUlRVeTUwWWlrZ1BDMGdZeWhjWEdWdWMyVnRZbXhjWEN3Z1hGeG5aVzVsWEZ3c0lGeGNZMmh5WEZ3c0lGeGNWRk5UWEZ3cFhHNWNiaU1nUm5WdVkzUnBiMjV6WEc1bWFXNWtSR2x6ZEdGdVkyVlViMVJCUkNBOExTQm1kVzVqZEdsdmJpaGphSEp2YlN3Z1ZGTlRMQ0IwWVdSZlltOTFibVJoY25rcGUxeHVJQ0IwWlcxd0lEd3RJSFJoWkY5aWIzVnVaR0Z5ZVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2loamFISWdQVDBnWTJoeWIyMHBJQ1UrSlZ4dUlDQWdJR1J3YkhseU9qcHRkWFJoZEdVb1pHbHpkR0Z1WTJVZ1BTQmhZbk1vWTJWdWRHVnlJQzBnVkZOVEtTa2dKVDRsSUhOc2FXTmxYMjFwYmloa2FYTjBZVzVqWlNsY2JpQWdhV1lvYm5KdmR5aDBaVzF3S1NBOVBTQXhLWHRjYmlBZ0lDQnlaWFIxY200b2RHVnRjQ1JrYVhOMFlXNWpaU2xjYmlBZ2ZXVnNjMlY3WEc0Z0lDQWdjbVYwZFhKdUtFNUJLVnh1SUNCOVhHNTlYRzVjYm1acGJtUkpkSE5VUVVRZ1BDMGdablZ1WTNScGIyNG9ZMmh5YjIwc0lGUlRVeXdnZEdGa0tYdGNiaUFnZEdWdGNDQThMU0IwWVdRZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1kyaHlNU0E5UFNCamFISnZiU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdjM1JoY25ReElEd2dWRk5UTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JsYm1ReElENGdWRk5US1Z4dUlDQnBaaWh1Y205M0tIUmxiWEFwSUQwOUlERXBlMXh1SUNBZ0lISmxkSFZ5YmloMFpXMXdKSFJoWkVsRUtWeHVJQ0I5Wld4elpYdGNiaUFnSUNCeVpYUjFjbTRvVGtFcFhHNGdJSDFjYm4xY2JseHVabWx1WkZSQlJGTnBlbVVnUEMxbWRXNWpkR2x2YmloamFISnZiU3dnVkZOVExDQjBZV1FwZTF4dUlDQjBaVzF3SUR3dElIUmhaQ0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhqYUhJeElEMDlJR05vY205dExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCemRHRnlkREVnUENCVVUxTXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHVnVaREVnUGlCVVUxTXBYRzRnSUdsbUtHNXliM2NvZEdWdGNDa2dQVDBnTVNsN1hHNGdJQ0FnY21WMGRYSnVLSFJsYlhBa2RHRmtVMmw2WlNsY2JpQWdmV1ZzYzJWN1hHNGdJQ0FnY21WMGRYSnVLRTVCS1Z4dUlDQjlYRzU5WEc1Y2JtZGxibVV1VkZOVExuUmlJRHd0SUdkbGJtVXVWRk5UTG5SaUlDVStKU0J5YjNkM2FYTmxLQ2tnSlQ0bFhHNGdJR1J3YkhseU9qcHRkWFJoZEdVb1pHbHpkR0Z1WTJVZ1BTQm1hVzVrUkdsemRHRnVZMlZVYjFSQlJDaGphSElzSUZSVFV5d2dkR0ZrWDJKdmRXNWtZWEo1S1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCVVFVUWdQU0JtYVc1a1NYUnpWRUZFS0dOb2Npd2dWRk5UTENCMFlXUXBMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRlJCUkhOcGVtVWdQU0JtYVc1a1ZFRkVVMmw2WlNoamFISXNJRlJUVXl3Z2RHRmtLU2xjYm1CZ1lGeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYGBgclxucmVmRGlyIDwtIGhlcmUoXFwuLi8uLlxcLCBcXHJlZmVyZW5jZVxcKVxuXG4jIEltcG9ydGluZyBUQUQgYm91bmRhcnlcbnRhZF9ib3VuZGFyeSA8LSBmcmVhZChoZXJlKFxcLi4vLi4vcmVzdWx0L1RBRFxcLCBcXFRBRF8yNWtiXzEyNWtiX290c3VfYm91bmRhcmllc19HMURNU08uYmVkXFwpKVxuY29sbmFtZXModGFkX2JvdW5kYXJ5KSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnRhZF9ib3VuZGFyeSA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjptdXRhdGUodGFkX2lkID0gcGFzdGUoY2hyLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNlbnRlciA9IChzdGFydCArIGVuZCkvMilcblxuIyBJbXBvcnRpbmcgVEFEXG50YWQgPC0gZnJlYWQoaGVyZShcXC4uLy4uL3Jlc3VsdC9UQURcXCwgXFxUQURfMjVrYl8xMjVrYl9vdHN1X0cxRE1TTy5iZWRwZVxcKSlcbmNvbG5hbWVzKHRhZCkgPC0gYyhcXGNocjFcXCwgXFxzdGFydDFcXCwgXFxlbmQxXFwsIFxcY2hyMlxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXClcbnRhZCA8LSB0YWQgJT4lIGRwbHlyOjptdXRhdGUodGFkSUQgPSBwYXN0ZShjaHIxLCBzdGFydDEsIGVuZDEsIHNlcCA9IFxcX1xcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGFkU2l6ZSA9IGVuZDEgLSBzdGFydDEpXG5cbiMgSW1wb3J0aW5nIGdlbmVcbmdlbmUuVFNTLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWNiwgVjUsIFYxLCBUU1MpXG5jb2xuYW1lcyhnZW5lLlRTUy50YikgPC0gYyhcXGVuc2VtYmxcXCwgXFxnZW5lXFwsIFxcY2hyXFwsIFxcVFNTXFwpXG5cbiMgRnVuY3Rpb25zXG5maW5kRGlzdGFuY2VUb1RBRCA8LSBmdW5jdGlvbihjaHJvbSwgVFNTLCB0YWRfYm91bmRhcnkpe1xuICB0ZW1wIDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6OmZpbHRlcihjaHIgPT0gY2hyb20pICU+JVxuICAgIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBhYnMoY2VudGVyIC0gVFNTKSkgJT4lIHNsaWNlX21pbihkaXN0YW5jZSlcbiAgaWYobnJvdyh0ZW1wKSA9PSAxKXtcbiAgICByZXR1cm4odGVtcCRkaXN0YW5jZSlcbiAgfWVsc2V7XG4gICAgcmV0dXJuKE5BKVxuICB9XG59XG5cbmZpbmRJdHNUQUQgPC0gZnVuY3Rpb24oY2hyb20sIFRTUywgdGFkKXtcbiAgdGVtcCA8LSB0YWQgJT4lIGRwbHlyOjpmaWx0ZXIoY2hyMSA9PSBjaHJvbSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3RhcnQxIDwgVFNTLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmQxID4gVFNTKVxuICBpZihucm93KHRlbXApID09IDEpe1xuICAgIHJldHVybih0ZW1wJHRhZElEKVxuICB9ZWxzZXtcbiAgICByZXR1cm4oTkEpXG4gIH1cbn1cblxuZmluZFRBRFNpemUgPC1mdW5jdGlvbihjaHJvbSwgVFNTLCB0YWQpe1xuICB0ZW1wIDwtIHRhZCAlPiUgZHBseXI6OmZpbHRlcihjaHIxID09IGNocm9tLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdGFydDEgPCBUU1MsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZDEgPiBUU1MpXG4gIGlmKG5yb3codGVtcCkgPT0gMSl7XG4gICAgcmV0dXJuKHRlbXAkdGFkU2l6ZSlcbiAgfWVsc2V7XG4gICAgcmV0dXJuKE5BKVxuICB9XG59XG5cbmdlbmUuVFNTLnRiIDwtIGdlbmUuVFNTLnRiICU+JSByb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBmaW5kRGlzdGFuY2VUb1RBRChjaHIsIFRTUywgdGFkX2JvdW5kYXJ5KSxcbiAgICAgICAgICAgICAgICBUQUQgPSBmaW5kSXRzVEFEKGNociwgVFNTLCB0YWQpLFxuICAgICAgICAgICAgICAgIFRBRHNpemUgPSBmaW5kVEFEU2l6ZShjaHIsIFRTUywgdGFkKSlcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxucmVmRGlyIDwtIGhlcmUoXFwuLi8uLlxcLCBcXHJlZmVyZW5jZVxcKVxuXG4jIEltcG9ydGluZyBUQUQgYm91bmRhcnlcbnRhZF9ib3VuZGFyeSA8LSBmcmVhZChoZXJlKFxcLi4vLi4vcmVzdWx0L1RBRFxcLCBcXFRBRF8yNWtiXzEyNWtiX290c3VfYm91bmRhcmllc19HMURNU08uYmVkXFwpKVxuY29sbmFtZXModGFkX2JvdW5kYXJ5KSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnRhZF9ib3VuZGFyeSA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjptdXRhdGUodGFkX2lkID0gcGFzdGUoY2hyLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNlbnRlciA9IChzdGFydCArIGVuZCkvMilcblxuIyBJbXBvcnRpbmcgVEFEXG50YWQgPC0gZnJlYWQoaGVyZShcXC4uLy4uL3Jlc3VsdC9UQURcXCwgXFxUQURfMjVrYl8xMjVrYl9vdHN1X0cxRE1TTy5iZWRwZVxcKSlcbmNvbG5hbWVzKHRhZCkgPC0gYyhcXGNocjFcXCwgXFxzdGFydDFcXCwgXFxlbmQxXFwsIFxcY2hyMlxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXClcbnRhZCA8LSB0YWQgJT4lIGRwbHlyOjptdXRhdGUodGFkSUQgPSBwYXN0ZShjaHIxLCBzdGFydDEsIGVuZDEsIHNlcCA9IFxcX1xcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGFkU2l6ZSA9IGVuZDEgLSBzdGFydDEpXG5cbiMgSW1wb3J0aW5nIGdlbmVcbmdlbmUuVFNTLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWNiwgVjUsIFYxLCBUU1MpXG5jb2xuYW1lcyhnZW5lLlRTUy50YikgPC0gYyhcXGVuc2VtYmxcXCwgXFxnZW5lXFwsIFxcY2hyXFwsIFxcVFNTXFwpXG5cbiMgRnVuY3Rpb25zXG5maW5kRGlzdGFuY2VUb1RBRCA8LSBmdW5jdGlvbihjaHJvbSwgVFNTLCB0YWRfYm91bmRhcnkpe1xuICB0ZW1wIDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6OmZpbHRlcihjaHIgPT0gY2hyb20pICU+JVxuICAgIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBhYnMoY2VudGVyIC0gVFNTKSkgJT4lIHNsaWNlX21pbihkaXN0YW5jZSlcbiAgaWYobnJvdyh0ZW1wKSA9PSAxKXtcbiAgICByZXR1cm4odGVtcCRkaXN0YW5jZSlcbiAgfWVsc2V7XG4gICAgcmV0dXJuKE5BKVxuICB9XG59XG5cbmZpbmRJdHNUQUQgPC0gZnVuY3Rpb24oY2hyb20sIFRTUywgdGFkKXtcbiAgdGVtcCA8LSB0YWQgJT4lIGRwbHlyOjpmaWx0ZXIoY2hyMSA9PSBjaHJvbSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3RhcnQxIDwgVFNTLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmQxID4gVFNTKVxuICBpZihucm93KHRlbXApID09IDEpe1xuICAgIHJldHVybih0ZW1wJHRhZElEKVxuICB9ZWxzZXtcbiAgICByZXR1cm4oTkEpXG4gIH1cbn1cblxuZmluZFRBRFNpemUgPC1mdW5jdGlvbihjaHJvbSwgVFNTLCB0YWQpe1xuICB0ZW1wIDwtIHRhZCAlPiUgZHBseXI6OmZpbHRlcihjaHIxID09IGNocm9tLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdGFydDEgPCBUU1MsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZDEgPiBUU1MpXG4gIGlmKG5yb3codGVtcCkgPT0gMSl7XG4gICAgcmV0dXJuKHRlbXAkdGFkU2l6ZSlcbiAgfWVsc2V7XG4gICAgcmV0dXJuKE5BKVxuICB9XG59XG5cbmdlbmUuVFNTLnRiIDwtIGdlbmUuVFNTLnRiICU+JSByb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBmaW5kRGlzdGFuY2VUb1RBRChjaHIsIFRTUywgdGFkX2JvdW5kYXJ5KSxcbiAgICAgICAgICAgICAgICBUQUQgPSBmaW5kSXRzVEFEKGNociwgVFNTLCB0YWQpLFxuICAgICAgICAgICAgICAgIFRBRHNpemUgPSBmaW5kVEFEU2l6ZShjaHIsIFRTUywgdGFkKSlcbmBgYFxuYGBgIn0= -->

```r
```r
refDir <- here(\../..\, \reference\)

# Importing TAD boundary
tad_boundary <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\))
colnames(tad_boundary) <- c(\chr\, \start\, \end\)
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = \_\),
                                               center = (start + end)/2)

# Importing TAD
tad <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_G1DMSO.bedpe\))
colnames(tad) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\)
tad <- tad %>% dplyr::mutate(tadID = paste(chr1, start1, end1, sep = \_\),
                             tadSize = end1 - start1)

# Importing gene
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, V5, V1, TSS)
colnames(gene.TSS.tb) <- c(\ensembl\, \gene\, \chr\, \TSS\)

# Functions
findDistanceToTAD <- function(chrom, TSS, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom) %>%
    dplyr::mutate(distance = abs(center - TSS)) %>% slice_min(distance)
  if(nrow(temp) == 1){
    return(temp$distance)
  }else{
    return(NA)
  }
}

findItsTAD <- function(chrom, TSS, tad){
  temp <- tad %>% dplyr::filter(chr1 == chrom,
                                start1 < TSS,
                                end1 > TSS)
  if(nrow(temp) == 1){
    return(temp$tadID)
  }else{
    return(NA)
  }
}

findTADSize <-function(chrom, TSS, tad){
  temp <- tad %>% dplyr::filter(chr1 == chrom,
                                start1 < TSS,
                                end1 > TSS)
  if(nrow(temp) == 1){
    return(temp$tadSize)
  }else{
    return(NA)
  }
}

gene.TSS.tb <- gene.TSS.tb %>% rowwise() %>%
  dplyr::mutate(distance = findDistanceToTAD(chr, TSS, tad_boundary),
                TAD = findItsTAD(chr, TSS, tad),
                TADsize = findTADSize(chr, TSS, tad))
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### Plotting for P-P

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ngroup1 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\"))$gene\ngroup2 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\"))$gene\n\n\ngene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \"group1\",\n                 ifelse(ensembl %in% group2, \"group2\", NA))) %>% \n  dplyr::filter(!is.na(group))\n\n\n## Plot distance\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$distance\n  distance2 <- (data %>% dplyr::filter(group == group2) )$distance\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \"group1\", \"group2\"), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \".\", fill = group, y = distance)) +\n    # Set axis labels (no x-axis title)\n    scale_fill_manual(values = ((c(\"#777777\", \"#F28E2C\")))) +\n    labs(x = NULL, y = \"Distance from TAD boundary\") +\n    # Violin plot with black outline, customized line width and end\n    introdataviz::geom_split_violin(\n     color = \"black\", alpha = 0.4,\n      linewidth = lineMedium * mmToLineUnit, lineend = \"square\"\n    ) +\n    # Box plot with customized line width, square end, and outlier size\n    geom_boxplot(\n      width = 0.3, color = \"black\", alpha = 0.6,\n      linewidth = lineMedium * mmToLineUnit, lineend = \"square\",\n      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE\n    ) +\n    \n    # Mean point in each group\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \"point\", shape = 21, size = 0.5,\n      fill = \"black\", color = \"black\", position = position_dodge(.3)\n    ) +\n    \n    # Horizontal line at y = 0\n    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n    \n    # Coordinate limits and custom y-axis labels\n    coord_cartesian(ylim = c(ymin, ymax)) +\n    scale_y_continuous(labels = label_kb_mb) +\n    \n    # Annotate p-value text\n    annotate(\n      \"text\", x = 1, y = ymin + 1,\n      label = paste0(\"p12: \", convPvalue(p12)),\n      color = \"black\", hjust = 0, size = 3\n    ) +\n    \n    # Theme customization\n    theme_classic() +\n    theme(\n      axis.title = element_text(\n        size = fontSizeM, family = fontType, color = \"#000000\"\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \"#000000\"\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n      ),\n      axis.ticks = element_line(\n        color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n      ),\n      panel.background = element_rect(fill = \"transparent\"),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)) +\n    guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      )\n    )\n  \n  \n  fileName <- paste0(\"distance_to_boundary_\", note)\n  width <- panelSize(1.55)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\nplot_TADdistance(gene.TSS.tb.plot, \"group_binayGroup\", ymax = 1000000)\n\n\n## Plot TAD size\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize\n  distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \"group1\", \"group2\"), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \".\", fill = group, y = TADsize)) +\n    # Set axis labels (no x-axis title)\n    labs(x = NULL, y = \"Size of TAD\") +\n        scale_fill_manual(values = ((c(\"#777777\", \"#F28E2C\")))) +\n\n    # Violin plot with black outline, customized line width and end\n    introdataviz::geom_split_violin(\n      color = \"black\",\n      linewidth = lineMedium* mmToLineUnit, lineend = \"square\", alpha = .4\n    ) +\n    \n    # Box plot with customized line width, square end, and outlier size\n    geom_boxplot(\n      width = 0.3, color = \"black\",\n      linewidth = lineMedium* mmToLineUnit, lineend = \"square\",\n      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE\n    ) +\n    \n    # Mean point in each group\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \"point\", shape = 21, size = 0.5,\n      fill = \"black\", color = \"black\", position = position_dodge(.3)\n    ) +\n    \n    # Horizontal line at y = 0\n    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n    \n    # Coordinate limits and custom y-axis labels\n    coord_cartesian(ylim = c(ymin, ymax)) +\n    scale_y_continuous(labels = label_kb_mb) +\n    \n    # Annotate p-value text\n    annotate(\n      \"text\", x = 1, y = ymin + 1,\n      label = paste0(\"p12: \", convPvalue(p12)),\n      color = \"black\", hjust = 0, size = 3\n    ) +\n    \n    # Theme customization\n  theme_classic() +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) + guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      ))\n  \n  \n  \n  fileName <- paste0(\"size_of_boundary_\", note)\n  width <- panelSize(1.55)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\n  print(p)\n  dev.off()\n}\nplot_TADsize(gene.TSS.tb.plot, \"group_binaryGroup\", ymax = 3e6)\n```"} -->\n\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\ngene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\, NA))) %>% \n  dplyr::filter(!is.na(group))\n\n\n## Plot distance\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$distance\n  distance2 <- (data %>% dplyr::filter(group == group2) )$distance\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \\.\\, fill = group, y = distance)) +\n    # Set axis labels (no x-axis title)\n    scale_fill_manual(values = ((c(\\#777777\\, \\#F28E2C\\)))) +\n    labs(x = NULL, y = \\Distance from TAD boundary\\) +\n    # Violin plot with black outline, customized line width and end\n    introdataviz::geom_split_violin(\n     color = \\black\\, alpha = 0.4,\n      linewidth = lineMedium * mmToLineUnit, lineend = \\square\\\n    ) +\n    # Box plot with customized line width, square end, and outlier size\n    geom_boxplot(\n      width = 0.3, color = \\black\\, alpha = 0.6,\n      linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE\n    ) +\n    \n    # Mean point in each group\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    \n    # Horizontal line at y = 0\n    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n    \n    # Coordinate limits and custom y-axis labels\n    coord_cartesian(ylim = c(ymin, ymax)) +\n    scale_y_continuous(labels = label_kb_mb) +\n    \n    # Annotate p-value text\n    annotate(\n      \\text\\, x = 1, y = ymin + 1,\n      label = paste0(\\p12: \\, convPvalue(p12)),\n      color = \\black\\, hjust = 0, size = 3\n    ) +\n    \n    # Theme customization\n    theme_classic() +\n    theme(\n      axis.title = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)) +\n    guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      )\n    )\n  \n  \n  fileName <- paste0(\\distance_to_boundary_\\, note)\n  width <- panelSize(1.55)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\nplot_TADdistance(gene.TSS.tb.plot, \\group_binayGroup\\, ymax = 1000000)\n\n\n## Plot TAD size\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize\n  distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \\.\\, fill = group, y = TADsize)) +\n    # Set axis labels (no x-axis title)\n    labs(x = NULL, y = \\Size of TAD\\) +\n        scale_fill_manual(values = ((c(\\#777777\\, \\#F28E2C\\)))) +\n\n    # Violin plot with black outline, customized line width and end\n    introdataviz::geom_split_violin(\n      color = \\black\\,\n      linewidth = lineMedium* mmToLineUnit, lineend = \\square\\, alpha = .4\n    ) +\n    \n    # Box plot with customized line width, square end, and outlier size\n    geom_boxplot(\n      width = 0.3, color = \\black\\,\n      linewidth = lineMedium* mmToLineUnit, lineend = \\square\\,\n      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE\n    ) +\n    \n    # Mean point in each group\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    \n    # Horizontal line at y = 0\n    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n    \n    # Coordinate limits and custom y-axis labels\n    coord_cartesian(ylim = c(ymin, ymax)) +\n    scale_y_continuous(labels = label_kb_mb) +\n    \n    # Annotate p-value text\n    annotate(\n      \\text\\, x = 1, y = ymin + 1,\n      label = paste0(\\p12: \\, convPvalue(p12)),\n      color = \\black\\, hjust = 0, size = 3\n    ) +\n    \n    # Theme customization\n  theme_classic() +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) + guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      ))\n  \n  \n  \n  fileName <- paste0(\\size_of_boundary_\\, note)\n  width <- panelSize(1.55)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\nplot_TADsize(gene.TSS.tb.plot, \\group_binaryGroup\\, ymax = 3e6)\n```\n\n<!-- rnb-source-end -->\n"} -->
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\, NA))) %>% 
  dplyr::filter(!is.na(group))


## Plot distance
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$distance
  distance2 <- (data %>% dplyr::filter(group == group2) )$distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = \.\, fill = group, y = distance)) +
    # Set axis labels (no x-axis title)
    scale_fill_manual(values = ((c(\#777777\, \#F28E2C\)))) +
    labs(x = NULL, y = \Distance from TAD boundary\) +
    # Violin plot with black outline, customized line width and end
    introdataviz::geom_split_violin(
     color = \black\, alpha = 0.4,
      linewidth = lineMedium * mmToLineUnit, lineend = \square\
    ) +
    # Box plot with customized line width, square end, and outlier size
    geom_boxplot(
      width = 0.3, color = \black\, alpha = 0.6,
      linewidth = lineMedium * mmToLineUnit, lineend = \square\,
      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE
    ) +
    
    # Mean point in each group
    stat_summary(
      aes(group = group), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) +
    
    # Horizontal line at y = 0
    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
    
    # Coordinate limits and custom y-axis labels
    coord_cartesian(ylim = c(ymin, ymax)) +
    scale_y_continuous(labels = label_kb_mb) +
    
    # Annotate p-value text
    annotate(
      \text\, x = 1, y = ymin + 1,
      label = paste0(\p12: \, convPvalue(p12)),
      color = \black\, hjust = 0, size = 3
    ) +
    
    # Theme customization
    theme_classic() +
    theme(
      axis.title = element_text(
        size = fontSizeM, family = fontType, color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS, family = fontType, color = \#000000\
      ),
      axis.text.x = element_text(
        angle = 45, hjust = 1, vjust = 1
      ),
      axis.line = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)) +
    guides(
      fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
      )
    )
  
  
  fileName <- paste0(\distance_to_boundary_\, note)
  width <- panelSize(1.55)*mmToInch
  height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

plot_TADdistance(gene.TSS.tb.plot, \group_binayGroup\, ymax = 1000000)


## Plot TAD size
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize
  distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = \.\, fill = group, y = TADsize)) +
    # Set axis labels (no x-axis title)
    labs(x = NULL, y = \Size of TAD\) +
        scale_fill_manual(values = ((c(\#777777\, \#F28E2C\)))) +

    # Violin plot with black outline, customized line width and end
    introdataviz::geom_split_violin(
      color = \black\,
      linewidth = lineMedium* mmToLineUnit, lineend = \square\, alpha = .4
    ) +
    
    # Box plot with customized line width, square end, and outlier size
    geom_boxplot(
      width = 0.3, color = \black\,
      linewidth = lineMedium* mmToLineUnit, lineend = \square\,
      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE
    ) +
    
    # Mean point in each group
    stat_summary(
      aes(group = group), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) +
    
    # Horizontal line at y = 0
    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
    
    # Coordinate limits and custom y-axis labels
    coord_cartesian(ylim = c(ymin, ymax)) +
    scale_y_continuous(labels = label_kb_mb) +
    
    # Annotate p-value text
    annotate(
      \text\, x = 1, y = ymin + 1,
      label = paste0(\p12: \, convPvalue(p12)),
      color = \black\, hjust = 0, size = 3
    ) +
    
    # Theme customization
  theme_classic() +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) + guides(
      fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
      ))
  
  
  
  fileName <- paste0(\size_of_boundary_\, note)
  width <- panelSize(1.55)*mmToInch
  height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_TADsize(gene.TSS.tb.plot, \group_binaryGroup\, ymax = 3e6)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\ngene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\, NA))) %>% \n  dplyr::filter(!is.na(group))\n\n\n## Plot distance\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$distance\n  distance2 <- (data %>% dplyr::filter(group == group2) )$distance\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \\.\\, fill = group, y = distance)) +\n    # Set axis labels (no x-axis title)\n    scale_fill_manual(values = ((c(\\#777777\\, \\#F28E2C\\)))) +\n    labs(x = NULL, y = \\Distance from TAD boundary\\) +\n    # Violin plot with black outline, customized line width and end\n    introdataviz::geom_split_violin(\n     color = \\black\\, alpha = 0.4,\n      linewidth = lineMedium * mmToLineUnit, lineend = \\square\\\n    ) +\n    # Box plot with customized line width, square end, and outlier size\n    geom_boxplot(\n      width = 0.3, color = \\black\\, alpha = 0.6,\n      linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE\n    ) +\n    \n    # Mean point in each group\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    \n    # Horizontal line at y = 0\n    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n    \n    # Coordinate limits and custom y-axis labels\n    coord_cartesian(ylim = c(ymin, ymax)) +\n    scale_y_continuous(labels = label_kb_mb) +\n    \n    # Annotate p-value text\n    annotate(\n      \\text\\, x = 1, y = ymin + 1,\n      label = paste0(\\p12: \\, convPvalue(p12)),\n      color = \\black\\, hjust = 0, size = 3\n    ) +\n    \n    # Theme customization\n    theme_classic() +\n    theme(\n      axis.title = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)) +\n    guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      )\n    )\n  \n  \n  fileName <- paste0(\\distance_to_boundary_\\, note)\n  width <- panelSize(1.55)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\nplot_TADdistance(gene.TSS.tb.plot, \\group_binayGroup\\, ymax = 1000000)\n\n\n## Plot TAD size\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize\n  distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \\.\\, fill = group, y = TADsize)) +\n    # Set axis labels (no x-axis title)\n    labs(x = NULL, y = \\Size of TAD\\) +\n        scale_fill_manual(values = ((c(\\#777777\\, \\#F28E2C\\)))) +\n\n    # Violin plot with black outline, customized line width and end\n    introdataviz::geom_split_violin(\n      color = \\black\\,\n      linewidth = lineMedium* mmToLineUnit, lineend = \\square\\, alpha = .4\n    ) +\n    \n    # Box plot with customized line width, square end, and outlier size\n    geom_boxplot(\n      width = 0.3, color = \\black\\,\n      linewidth = lineMedium* mmToLineUnit, lineend = \\square\\,\n      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE\n    ) +\n    \n    # Mean point in each group\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    \n    # Horizontal line at y = 0\n    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n    \n    # Coordinate limits and custom y-axis labels\n    coord_cartesian(ylim = c(ymin, ymax)) +\n    scale_y_continuous(labels = label_kb_mb) +\n    \n    # Annotate p-value text\n    annotate(\n      \\text\\, x = 1, y = ymin + 1,\n      label = paste0(\\p12: \\, convPvalue(p12)),\n      color = \\black\\, hjust = 0, size = 3\n    ) +\n    \n    # Theme customization\n  theme_classic() +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) + guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      ))\n  \n  \n  \n  fileName <- paste0(\\size_of_boundary_\\, note)\n  width <- panelSize(1.55)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\nplot_TADsize(gene.TSS.tb.plot, \\group_binaryGroup\\, ymax = 3e6)\n```\n```"} -->\n\n```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\ngene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\, NA))) %>% \n  dplyr::filter(!is.na(group))\n\n\n## Plot distance\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$distance\n  distance2 <- (data %>% dplyr::filter(group == group2) )$distance\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \\.\\, fill = group, y = distance)) +\n    # Set axis labels (no x-axis title)\n    scale_fill_manual(values = ((c(\\#777777\\, \\#F28E2C\\)))) +\n    labs(x = NULL, y = \\Distance from TAD boundary\\) +\n    # Violin plot with black outline, customized line width and end\n    introdataviz::geom_split_violin(\n     color = \\black\\, alpha = 0.4,\n      linewidth = lineMedium * mmToLineUnit, lineend = \\square\\\n    ) +\n    # Box plot with customized line width, square end, and outlier size\n    geom_boxplot(\n      width = 0.3, color = \\black\\, alpha = 0.6,\n      linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE\n    ) +\n    \n    # Mean point in each group\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    \n    # Horizontal line at y = 0\n    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n    \n    # Coordinate limits and custom y-axis labels\n    coord_cartesian(ylim = c(ymin, ymax)) +\n    scale_y_continuous(labels = label_kb_mb) +\n    \n    # Annotate p-value text\n    annotate(\n      \\text\\, x = 1, y = ymin + 1,\n      label = paste0(\\p12: \\, convPvalue(p12)),\n      color = \\black\\, hjust = 0, size = 3\n    ) +\n    \n    # Theme customization\n    theme_classic() +\n    theme(\n      axis.title = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)) +\n    guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      )\n    )\n  \n  \n  fileName <- paste0(\\distance_to_boundary_\\, note)\n  width <- panelSize(1.55)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\nplot_TADdistance(gene.TSS.tb.plot, \\group_binayGroup\\, ymax = 1000000)\n\n\n## Plot TAD size\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize\n  distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \\.\\, fill = group, y = TADsize)) +\n    # Set axis labels (no x-axis title)\n    labs(x = NULL, y = \\Size of TAD\\) +\n        scale_fill_manual(values = ((c(\\#777777\\, \\#F28E2C\\)))) +\n\n    # Violin plot with black outline, customized line width and end\n    introdataviz::geom_split_violin(\n      color = \\black\\,\n      linewidth = lineMedium* mmToLineUnit, lineend = \\square\\, alpha = .4\n    ) +\n    \n    # Box plot with customized line width, square end, and outlier size\n    geom_boxplot(\n      width = 0.3, color = \\black\\,\n      linewidth = lineMedium* mmToLineUnit, lineend = \\square\\,\n      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE\n    ) +\n    \n    # Mean point in each group\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    \n    # Horizontal line at y = 0\n    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n    \n    # Coordinate limits and custom y-axis labels\n    coord_cartesian(ylim = c(ymin, ymax)) +\n    scale_y_continuous(labels = label_kb_mb) +\n    \n    # Annotate p-value text\n    annotate(\n      \\text\\, x = 1, y = ymin + 1,\n      label = paste0(\\p12: \\, convPvalue(p12)),\n      color = \\black\\, hjust = 0, size = 3\n    ) +\n    \n    # Theme customization\n  theme_classic() +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) + guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      ))\n  \n  \n  \n  fileName <- paste0(\\size_of_boundary_\\, note)\n  width <- panelSize(1.55)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\nplot_TADsize(gene.TSS.tb.plot, \\group_binaryGroup\\, ymax = 3e6)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\ngene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\, NA))) %>% \n  dplyr::filter(!is.na(group))\n\n\n## Plot distance\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$distance\n  distance2 <- (data %>% dplyr::filter(group == group2) )$distance\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \\.\\, fill = group, y = distance)) +\n    # Set axis labels (no x-axis title)\n    scale_fill_manual(values = ((c(\\#777777\\, \\#F28E2C\\)))) +\n    labs(x = NULL, y = \\Distance from TAD boundary\\) +\n    # Violin plot with black outline, customized line width and end\n    introdataviz::geom_split_violin(\n     color = \\black\\, alpha = 0.4,\n      linewidth = lineMedium * mmToLineUnit, lineend = \\square\\\n    ) +\n    # Box plot with customized line width, square end, and outlier size\n    geom_boxplot(\n      width = 0.3, color = \\black\\, alpha = 0.6,\n      linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE\n    ) +\n    \n    # Mean point in each group\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    \n    # Horizontal line at y = 0\n    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n    \n    # Coordinate limits and custom y-axis labels\n    coord_cartesian(ylim = c(ymin, ymax)) +\n    scale_y_continuous(labels = label_kb_mb) +\n    \n    # Annotate p-value text\n    annotate(\n      \\text\\, x = 1, y = ymin + 1,\n      label = paste0(\\p12: \\, convPvalue(p12)),\n      color = \\black\\, hjust = 0, size = 3\n    ) +\n    \n    # Theme customization\n    theme_classic() +\n    theme(\n      axis.title = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)) +\n    guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      )\n    )\n  \n  \n  fileName <- paste0(\\distance_to_boundary_\\, note)\n  width <- panelSize(1.55)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\nplot_TADdistance(gene.TSS.tb.plot, \\group_binayGroup\\, ymax = 1000000)\n\n\n## Plot TAD size\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize\n  distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \\.\\, fill = group, y = TADsize)) +\n    # Set axis labels (no x-axis title)\n    labs(x = NULL, y = \\Size of TAD\\) +\n        scale_fill_manual(values = ((c(\\#777777\\, \\#F28E2C\\)))) +\n\n    # Violin plot with black outline, customized line width and end\n    introdataviz::geom_split_violin(\n      color = \\black\\,\n      linewidth = lineMedium* mmToLineUnit, lineend = \\square\\, alpha = .4\n    ) +\n    \n    # Box plot with customized line width, square end, and outlier size\n    geom_boxplot(\n      width = 0.3, color = \\black\\,\n      linewidth = lineMedium* mmToLineUnit, lineend = \\square\\,\n      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE\n    ) +\n    \n    # Mean point in each group\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    \n    # Horizontal line at y = 0\n    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n    \n    # Coordinate limits and custom y-axis labels\n    coord_cartesian(ylim = c(ymin, ymax)) +\n    scale_y_continuous(labels = label_kb_mb) +\n    \n    # Annotate p-value text\n    annotate(\n      \\text\\, x = 1, y = ymin + 1,\n      label = paste0(\\p12: \\, convPvalue(p12)),\n      color = \\black\\, hjust = 0, size = 3\n    ) +\n    \n    # Theme customization\n  theme_classic() +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) + guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      ))\n  \n  \n  \n  fileName <- paste0(\\size_of_boundary_\\, note)\n  width <- panelSize(1.55)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\nplot_TADsize(gene.TSS.tb.plot, \\group_binaryGroup\\, ymax = 3e6)\n```\n```"} -->

```r
```r
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\, NA))) %>% 
  dplyr::filter(!is.na(group))


## Plot distance
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$distance
  distance2 <- (data %>% dplyr::filter(group == group2) )$distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = \.\, fill = group, y = distance)) +
    # Set axis labels (no x-axis title)
    scale_fill_manual(values = ((c(\#777777\, \#F28E2C\)))) +
    labs(x = NULL, y = \Distance from TAD boundary\) +
    # Violin plot with black outline, customized line width and end
    introdataviz::geom_split_violin(
     color = \black\, alpha = 0.4,
      linewidth = lineMedium * mmToLineUnit, lineend = \square\
    ) +
    # Box plot with customized line width, square end, and outlier size
    geom_boxplot(
      width = 0.3, color = \black\, alpha = 0.6,
      linewidth = lineMedium * mmToLineUnit, lineend = \square\,
      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE
    ) +
    
    # Mean point in each group
    stat_summary(
      aes(group = group), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) +
    
    # Horizontal line at y = 0
    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
    
    # Coordinate limits and custom y-axis labels
    coord_cartesian(ylim = c(ymin, ymax)) +
    scale_y_continuous(labels = label_kb_mb) +
    
    # Annotate p-value text
    annotate(
      \text\, x = 1, y = ymin + 1,
      label = paste0(\p12: \, convPvalue(p12)),
      color = \black\, hjust = 0, size = 3
    ) +
    
    # Theme customization
    theme_classic() +
    theme(
      axis.title = element_text(
        size = fontSizeM, family = fontType, color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS, family = fontType, color = \#000000\
      ),
      axis.text.x = element_text(
        angle = 45, hjust = 1, vjust = 1
      ),
      axis.line = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)) +
    guides(
      fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
      )
    )
  
  
  fileName <- paste0(\distance_to_boundary_\, note)
  width <- panelSize(1.55)*mmToInch
  height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

plot_TADdistance(gene.TSS.tb.plot, \group_binayGroup\, ymax = 1000000)


## Plot TAD size
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize
  distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = \.\, fill = group, y = TADsize)) +
    # Set axis labels (no x-axis title)
    labs(x = NULL, y = \Size of TAD\) +
        scale_fill_manual(values = ((c(\#777777\, \#F28E2C\)))) +

    # Violin plot with black outline, customized line width and end
    introdataviz::geom_split_violin(
      color = \black\,
      linewidth = lineMedium* mmToLineUnit, lineend = \square\, alpha = .4
    ) +
    
    # Box plot with customized line width, square end, and outlier size
    geom_boxplot(
      width = 0.3, color = \black\,
      linewidth = lineMedium* mmToLineUnit, lineend = \square\,
      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE
    ) +
    
    # Mean point in each group
    stat_summary(
      aes(group = group), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) +
    
    # Horizontal line at y = 0
    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
    
    # Coordinate limits and custom y-axis labels
    coord_cartesian(ylim = c(ymin, ymax)) +
    scale_y_continuous(labels = label_kb_mb) +
    
    # Annotate p-value text
    annotate(
      \text\, x = 1, y = ymin + 1,
      label = paste0(\p12: \, convPvalue(p12)),
      color = \black\, hjust = 0, size = 3
    ) +
    
    # Theme customization
  theme_classic() +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) + guides(
      fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
      ))
  
  
  
  fileName <- paste0(\size_of_boundary_\, note)
  width <- panelSize(1.55)*mmToInch
  height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_TADsize(gene.TSS.tb.plot, \group_binaryGroup\, ymax = 3e6)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



## [2.15] TAD distance/size
#### Link TAD

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XCIpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcIikpJGdlbmVcbmdyb3VwNSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlwiKSkkZ2VuZVxuZ3JvdXA4IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XCIpKSRnZW5lXG5cblxuZ2VuZS5UU1MudGIucGxvdCA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAxLCBcImdyb3VwMVwiLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMiwgXCJncm91cDJcIixcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA1LCBcImdyb3VwNVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA4LCBcImdyb3VwOFwiLCBOQSkpKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbiMjIFBsb3QgZGlzdGFuY2VcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGRpc3RhbmNlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZGlzdGFuY2VcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9UQURkaXN0YW5jZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMVwiLCBcImdyb3VwMlwiKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJncm91cDFcIiwgXCJncm91cDVcIiksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwiZ3JvdXAxXCIsIFwiZ3JvdXA4XCIpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMlwiLCBcImdyb3VwNVwiKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJncm91cDJcIiwgXCJncm91cDhcIiksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwiZ3JvdXA1XCIsIFwiZ3JvdXA4XCIpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IGRpc3RhbmNlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcInBvaW50XCIsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCIpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpICtcbiAgICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcInAxMjogXCIsIGNvbnZQdmFsdWUocDEyKSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDE1OiBcIiwgY29udlB2YWx1ZShwMTUpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMTg6IFwiLCBjb252UHZhbHVlKHAxOCksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAyNTogXCIsIGNvbnZQdmFsdWUocDI1KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDI4OiBcIiwgY29udlB2YWx1ZShwMjgpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwNTg6IFwiLGNvbnZQdmFsdWUoIHA1OCksIFwiXFxuXCIpLFxuICAgICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcImRpc3RhbmNlX3RvX2JvdW5kYXJ5X1wiLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5cbnBsb3RfVEFEZGlzdGFuY2UoZ2VuZS5UU1MudGIucGxvdCwgXCJncm91cFwiKVxuXG5cbiMjIFBsb3QgVEFEIHNpemVcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJFRBRHNpemVcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRUQURzaXplXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfVEFEc2l6ZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMVwiLCBcImdyb3VwMlwiKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJncm91cDFcIiwgXCJncm91cDVcIiksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwiZ3JvdXAxXCIsIFwiZ3JvdXA4XCIpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMlwiLCBcImdyb3VwNVwiKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJncm91cDJcIiwgXCJncm91cDhcIiksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwiZ3JvdXA1XCIsIFwiZ3JvdXA4XCIpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IFRBRHNpemUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcInJlZFwiLCBjb2xvciA9IFwiYmxhY2tcIikgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgK1xuICAgIGFubm90YXRlKFwidGV4dFwiLCB4ID0gMSwgeSA9ICh5bWluICsgeW1heCkvMiArIDEsIGxhYmVsID0gcGFzdGUwKFwicDEyOiBcIiwgY29udlB2YWx1ZShwMTIpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMTU6IFwiLCBjb252UHZhbHVlKHAxNSksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAxODogXCIsIGNvbnZQdmFsdWUocDE4KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDI1OiBcIiwgY29udlB2YWx1ZShwMjUpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMjg6IFwiLCBjb252UHZhbHVlKHAyOCksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInA1ODogXCIsY29udlB2YWx1ZSggcDU4KSwgXCJcXG5cIiksXG4gICAgICAgICAgICAgY29sb3IgPSBcImJsYWNrXCIsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFwic2l6ZV9vZl9ib3VuZGFyeV9cIiwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxucGxvdF9UQURzaXplKGdlbmUuVFNTLnRiLnBsb3QsIFwiZ3JvdXBcIiwgeW1heCA9IDZlNilcbmBgYCJ9 -->\n\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\))$gene\n\n\ngene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\,\n                        ifelse(ensembl %in% group5, \\group5\\,\n                               ifelse(ensembl %in% group8, \\group8\\, NA))))) %>% \n  dplyr::filter(!is.na(group))\n\n\n## Plot distance\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$distance\n  distance2 <- (data %>% dplyr::filter(group == group2) )$distance\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = distance)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n    annotate(\\text\\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p15: \\, convPvalue(p15), \\\\n\\,\n                                                         \\p18: \\, convPvalue(p18), \\\\n\\,\n                                                         \\p25: \\, convPvalue(p25), \\\\n\\,\n                                                         \\p28: \\, convPvalue(p28), \\\\n\\,\n                                                         \\p58: \\,convPvalue( p58), \\\\n\\),\n             color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\distance_to_boundary_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\nplot_TADdistance(gene.TSS.tb.plot, \\group\\)\n\n\n## Plot TAD size\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize\n  distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = TADsize)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n    annotate(\\text\\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p15: \\, convPvalue(p15), \\\\n\\,\n                                                         \\p18: \\, convPvalue(p18), \\\\n\\,\n                                                         \\p25: \\, convPvalue(p25), \\\\n\\,\n                                                         \\p28: \\, convPvalue(p28), \\\\n\\,\n                                                         \\p58: \\,convPvalue( p58), \\\\n\\),\n             color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\size_of_boundary_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\nplot_TADsize(gene.TSS.tb.plot, \\group\\, ymax = 6e6)\n```\n\n<!-- rnb-source-end -->\n"} -->
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\,
                        ifelse(ensembl %in% group5, \group5\,
                               ifelse(ensembl %in% group8, \group8\, NA))))) %>% 
  dplyr::filter(!is.na(group))


## Plot distance
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$distance
  distance2 <- (data %>% dplyr::filter(group == group2) )$distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = distance)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + scale_y_continuous(labels = label_kb_mb) +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\distance_to_boundary_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

plot_TADdistance(gene.TSS.tb.plot, \group\)


## Plot TAD size
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize
  distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = TADsize)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + scale_y_continuous(labels = label_kb_mb) +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\size_of_boundary_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_TADsize(gene.TSS.tb.plot, \group\, ymax = 6e6)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcXCkpJGdlbmVcbmdyb3VwNSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlxcKSkkZ2VuZVxuZ3JvdXA4IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XFwpKSRnZW5lXG5cblxuZ2VuZS5UU1MudGIucGxvdCA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAxLCBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMiwgXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA1LCBcXGdyb3VwNVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA4LCBcXGdyb3VwOFxcLCBOQSkpKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbiMjIFBsb3QgZGlzdGFuY2VcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGRpc3RhbmNlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZGlzdGFuY2VcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9UQURkaXN0YW5jZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IGRpc3RhbmNlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE1OiBcXCwgY29udlB2YWx1ZShwMTUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTg6IFxcLCBjb252UHZhbHVlKHAxOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyNTogXFwsIGNvbnZQdmFsdWUocDI1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI4OiBcXCwgY29udlB2YWx1ZShwMjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwNTg6IFxcLGNvbnZQdmFsdWUoIHA1OCksIFxcXFxuXFwpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGRpc3RhbmNlX3RvX2JvdW5kYXJ5X1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5cbnBsb3RfVEFEZGlzdGFuY2UoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cFxcKVxuXG5cbiMjIFBsb3QgVEFEIHNpemVcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJFRBRHNpemVcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRUQURzaXplXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfVEFEc2l6ZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IFRBRHNpemUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgK1xuICAgIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9ICh5bWluICsgeW1heCkvMiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDEyOiBcXCwgY29udlB2YWx1ZShwMTIpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTU6IFxcLCBjb252UHZhbHVlKHAxNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxODogXFwsIGNvbnZQdmFsdWUocDE4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI1OiBcXCwgY29udlB2YWx1ZShwMjUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjg6IFxcLCBjb252UHZhbHVlKHAyOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHA1ODogXFwsY29udlB2YWx1ZSggcDU4KSwgXFxcXG5cXCksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcc2l6ZV9vZl9ib3VuZGFyeV9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxucGxvdF9UQURzaXplKGdlbmUuVFNTLnRiLnBsb3QsIFxcZ3JvdXBcXCwgeW1heCA9IDZlNilcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\))$gene\n\n\ngene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\,\n                        ifelse(ensembl %in% group5, \\group5\\,\n                               ifelse(ensembl %in% group8, \\group8\\, NA))))) %>% \n  dplyr::filter(!is.na(group))\n\n\n## Plot distance\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$distance\n  distance2 <- (data %>% dplyr::filter(group == group2) )$distance\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = distance)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n    annotate(\\text\\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p15: \\, convPvalue(p15), \\\\n\\,\n                                                         \\p18: \\, convPvalue(p18), \\\\n\\,\n                                                         \\p25: \\, convPvalue(p25), \\\\n\\,\n                                                         \\p28: \\, convPvalue(p28), \\\\n\\,\n                                                         \\p58: \\,convPvalue( p58), \\\\n\\),\n             color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\distance_to_boundary_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\nplot_TADdistance(gene.TSS.tb.plot, \\group\\)\n\n\n## Plot TAD size\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize\n  distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = TADsize)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n    annotate(\\text\\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p15: \\, convPvalue(p15), \\\\n\\,\n                                                         \\p18: \\, convPvalue(p18), \\\\n\\,\n                                                         \\p25: \\, convPvalue(p25), \\\\n\\,\n                                                         \\p28: \\, convPvalue(p28), \\\\n\\,\n                                                         \\p58: \\,convPvalue( p58), \\\\n\\),\n             color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\size_of_boundary_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\nplot_TADsize(gene.TSS.tb.plot, \\group\\, ymax = 6e6)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcXCkpJGdlbmVcbmdyb3VwNSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlxcKSkkZ2VuZVxuZ3JvdXA4IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XFwpKSRnZW5lXG5cblxuZ2VuZS5UU1MudGIucGxvdCA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAxLCBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMiwgXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA1LCBcXGdyb3VwNVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA4LCBcXGdyb3VwOFxcLCBOQSkpKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbiMjIFBsb3QgZGlzdGFuY2VcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGRpc3RhbmNlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZGlzdGFuY2VcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9UQURkaXN0YW5jZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IGRpc3RhbmNlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE1OiBcXCwgY29udlB2YWx1ZShwMTUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTg6IFxcLCBjb252UHZhbHVlKHAxOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyNTogXFwsIGNvbnZQdmFsdWUocDI1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI4OiBcXCwgY29udlB2YWx1ZShwMjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwNTg6IFxcLGNvbnZQdmFsdWUoIHA1OCksIFxcXFxuXFwpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGRpc3RhbmNlX3RvX2JvdW5kYXJ5X1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5cbnBsb3RfVEFEZGlzdGFuY2UoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cFxcKVxuXG5cbiMjIFBsb3QgVEFEIHNpemVcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJFRBRHNpemVcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRUQURzaXplXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfVEFEc2l6ZSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IFRBRHNpemUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgK1xuICAgIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9ICh5bWluICsgeW1heCkvMiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDEyOiBcXCwgY29udlB2YWx1ZShwMTIpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTU6IFxcLCBjb252UHZhbHVlKHAxNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxODogXFwsIGNvbnZQdmFsdWUocDE4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI1OiBcXCwgY29udlB2YWx1ZShwMjUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjg6IFxcLCBjb252UHZhbHVlKHAyOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHA1ODogXFwsY29udlB2YWx1ZSggcDU4KSwgXFxcXG5cXCksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcc2l6ZV9vZl9ib3VuZGFyeV9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxucGxvdF9UQURzaXplKGdlbmUuVFNTLnRiLnBsb3QsIFxcZ3JvdXBcXCwgeW1heCA9IDZlNilcbmBgYFxuYGBgIn0= -->

```r
```r
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\,
                        ifelse(ensembl %in% group5, \group5\,
                               ifelse(ensembl %in% group8, \group8\, NA))))) %>% 
  dplyr::filter(!is.na(group))


## Plot distance
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$distance
  distance2 <- (data %>% dplyr::filter(group == group2) )$distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = distance)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + scale_y_continuous(labels = label_kb_mb) +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\distance_to_boundary_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

plot_TADdistance(gene.TSS.tb.plot, \group\)


## Plot TAD size
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize
  distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = TADsize)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + scale_y_continuous(labels = label_kb_mb) +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\size_of_boundary_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_TADsize(gene.TSS.tb.plot, \group\, ymax = 6e6)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### dTAG - binaryGroup

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XCIpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcIikpJGdlbmVcbmdyb3VwMyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAzLnRzdlwiKSkkZ2VuZVxuZ3JvdXA0IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDQudHN2XCIpKSRnZW5lXG5ncm91cDUgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwNS50c3ZcIikpJGdlbmVcbmdyb3VwNiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA2LnRzdlwiKSkkZ2VuZVxuZ3JvdXA3IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDcudHN2XCIpKSRnZW5lXG5ncm91cDggPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwOC50c3ZcIikpJGdlbmVcbmdyb3VwOSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA5LnRzdlwiKSkkZ2VuZVxuXG5cbmdlbmUuVFNTLnRiLnBsb3QgPC0gZ2VuZS5UU1MudGIgJT4lXG4gIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBncm91cCA9IGRwbHlyOjpjYXNlX3doZW4oXG4gICAgICBlbnNlbWJsICVpbiUgZ3JvdXAxIH4gXCJncm91cDFcIixcbiAgICAgIGVuc2VtYmwgJWluJSBncm91cDIgfiBcImdyb3VwMlwiLFxuICAgICAgZW5zZW1ibCAlaW4lIGdyb3VwMyB+IFwiZ3JvdXAzXCIsXG4gICAgICBlbnNlbWJsICVpbiUgZ3JvdXA0IH4gXCJncm91cDRcIixcbiAgICAgIGVuc2VtYmwgJWluJSBncm91cDUgfiBcImdyb3VwNVwiLFxuICAgICAgZW5zZW1ibCAlaW4lIGdyb3VwNiB+IFwiZ3JvdXA2XCIsXG4gICAgICBlbnNlbWJsICVpbiUgZ3JvdXA3IH4gXCJncm91cDdcIixcbiAgICAgIGVuc2VtYmwgJWluJSBncm91cDggfiBcImdyb3VwOFwiLFxuICAgICAgZW5zZW1ibCAlaW4lIGdyb3VwOSB+IFwiZ3JvdXA5XCIsXG4gICAgICBUUlVFIH4gTkFfY2hhcmFjdGVyX1xuICAgIClcbiAgKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG4jIyBQbG90IGRpc3RhbmNlXG4jIGdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuIyAgIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZGlzdGFuY2VcbiMgICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJGRpc3RhbmNlXG4jICAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuIyAgIHJldHVybih3aWwkcC52YWx1ZSlcbiMgfVxuXG5cbnBsb3RfVEFEZGlzdGFuY2UgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAyMDAwMDAwKXtcbiAgIyBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMVwiLCBcImdyb3VwMlwiKSwgNSlcbiAgIyBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMVwiLCBcImdyb3VwNVwiKSwgNSlcbiAgIyBwMTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMVwiLCBcImdyb3VwOFwiKSwgNSlcbiAgIyBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMlwiLCBcImdyb3VwNVwiKSwgNSlcbiAgIyBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMlwiLCBcImdyb3VwOFwiKSwgNSlcbiAgIyBwNTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwNVwiLCBcImdyb3VwOFwiKSwgNSlcbiAgIyBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IGRpc3RhbmNlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcInBvaW50XCIsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCIpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpXG4gICAgIyBhbm5vdGF0ZShcInRleHRcIiwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcInAxMjogXCIsIGNvbnZQdmFsdWUocDEyKSwgXCJcXG5cIixcbiAgICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMTU6IFwiLCBjb252UHZhbHVlKHAxNSksIFwiXFxuXCIsXG4gICAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDE4OiBcIiwgY29udlB2YWx1ZShwMTgpLCBcIlxcblwiLFxuICAgICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAyNTogXCIsIGNvbnZQdmFsdWUocDI1KSwgXCJcXG5cIixcbiAgICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMjg6IFwiLCBjb252UHZhbHVlKHAyOCksIFwiXFxuXCIsXG4gICAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDU4OiBcIixjb252UHZhbHVlKCBwNTgpLCBcIlxcblwiKSxcbiAgICAjICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcImRpc3RhbmNlX3RvX2JvdW5kYXJ5X1wiLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5cbnBsb3RfVEFEZGlzdGFuY2UoZ2VuZS5UU1MudGIucGxvdCwgXCJncm91cF9BNDg1XCIpXG5cblxuIyMgUGxvdCBUQUQgc2l6ZVxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJFRBRHNpemVcbiMgICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJFRBRHNpemVcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxuXG5wbG90X1RBRHNpemUgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAyMDAwMDAwKXtcbiAgIyBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMVwiLCBcImdyb3VwMlwiKSwgNSlcbiAgIyBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMVwiLCBcImdyb3VwNVwiKSwgNSlcbiAgIyBwMTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMVwiLCBcImdyb3VwOFwiKSwgNSlcbiAgIyBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMlwiLCBcImdyb3VwNVwiKSwgNSlcbiAgIyBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMlwiLCBcImdyb3VwOFwiKSwgNSlcbiAgIyBwNTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwNVwiLCBcImdyb3VwOFwiKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBUQURzaXplKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcInBvaW50XCIsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCIpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpIFxuICAgICMgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAxLCB5ID0gKHltaW4gKyB5bWF4KS8yICsgMSwgbGFiZWwgPSBwYXN0ZTAoXCJwMTI6IFwiLCBjb252UHZhbHVlKHAxMiksIFwiXFxuXCIsXG4gICAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDE1OiBcIiwgY29udlB2YWx1ZShwMTUpLCBcIlxcblwiLFxuICAgICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAxODogXCIsIGNvbnZQdmFsdWUocDE4KSwgXCJcXG5cIixcbiAgICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMjU6IFwiLCBjb252UHZhbHVlKHAyNSksIFwiXFxuXCIsXG4gICAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDI4OiBcIiwgY29udlB2YWx1ZShwMjgpLCBcIlxcblwiLFxuICAgICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInA1ODogXCIsY29udlB2YWx1ZSggcDU4KSwgXCJcXG5cIiksXG4gICAgIyAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXCJzaXplX29mX2JvdW5kYXJ5X1wiLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X1RBRHNpemUoZ2VuZS5UU1MudGIucGxvdCwgXCJncm91cF9BNDg1XCIsIHltYXggPSA2ZTYpXG5gYGAifQ== -->\n\n```r\ngroup1 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup3 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group3.tsv\\))$gene\ngroup4 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group4.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup6 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group6.tsv\\))$gene\ngroup7 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group7.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group8.tsv\\))$gene\ngroup9 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group9.tsv\\))$gene\n\n\ngene.TSS.tb.plot <- gene.TSS.tb %>%\n  rowwise() %>%\n  dplyr::mutate(\n    group = dplyr::case_when(\n      ensembl %in% group1 ~ \\group1\\,\n      ensembl %in% group2 ~ \\group2\\,\n      ensembl %in% group3 ~ \\group3\\,\n      ensembl %in% group4 ~ \\group4\\,\n      ensembl %in% group5 ~ \\group5\\,\n      ensembl %in% group6 ~ \\group6\\,\n      ensembl %in% group7 ~ \\group7\\,\n      ensembl %in% group8 ~ \\group8\\,\n      ensembl %in% group9 ~ \\group9\\,\n      TRUE ~ NA_character_\n    )\n  ) %>%\n  dplyr::filter(!is.na(group))\n\n## Plot distance\n# getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(group == group1) )$distance\n#   distance2 <- (data %>% dplyr::filter(group == group2) )$distance\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n\n\nplot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  # p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  # p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  # p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  # p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  # p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  # p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  # \n  p <- ggplot(temp.tb, aes(x = group, y = distance)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + scale_y_continuous(labels = label_kb_mb)\n    # annotate(\\text\\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n    #                                                      \\p15: \\, convPvalue(p15), \\\\n\\,\n    #                                                      \\p18: \\, convPvalue(p18), \\\\n\\,\n    #                                                      \\p25: \\, convPvalue(p25), \\\\n\\,\n    #                                                      \\p28: \\, convPvalue(p28), \\\\n\\,\n    #                                                      \\p58: \\,convPvalue( p58), \\\\n\\),\n    #          color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\distance_to_boundary_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\nplot_TADdistance(gene.TSS.tb.plot, \\group_A485\\)\n\n\n## Plot TAD size\n# getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize\n#   distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n# \n\nplot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  # p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  # p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  # p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  # p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  # p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  # p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = TADsize)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + scale_y_continuous(labels = label_kb_mb) \n    # annotate(\\text\\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n    #                                                      \\p15: \\, convPvalue(p15), \\\\n\\,\n    #                                                      \\p18: \\, convPvalue(p18), \\\\n\\,\n    #                                                      \\p25: \\, convPvalue(p25), \\\\n\\,\n    #                                                      \\p28: \\, convPvalue(p28), \\\\n\\,\n    #                                                      \\p58: \\,convPvalue( p58), \\\\n\\),\n    #          color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\size_of_boundary_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\nplot_TADsize(gene.TSS.tb.plot, \\group_A485\\, ymax = 6e6)\n```\n\n<!-- rnb-source-end -->\n"} -->
group1 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group2.tsv\))$gene
group3 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group3.tsv\))$gene
group4 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group4.tsv\))$gene
group5 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group5.tsv\))$gene
group6 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group6.tsv\))$gene
group7 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group7.tsv\))$gene
group8 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group8.tsv\))$gene
group9 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group9.tsv\))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>%
  rowwise() %>%
  dplyr::mutate(
    group = dplyr::case_when(
      ensembl %in% group1 ~ \group1\,
      ensembl %in% group2 ~ \group2\,
      ensembl %in% group3 ~ \group3\,
      ensembl %in% group4 ~ \group4\,
      ensembl %in% group5 ~ \group5\,
      ensembl %in% group6 ~ \group6\,
      ensembl %in% group7 ~ \group7\,
      ensembl %in% group8 ~ \group8\,
      ensembl %in% group9 ~ \group9\,
      TRUE ~ NA_character_
    )
  ) %>%
  dplyr::filter(!is.na(group))

## Plot distance
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group == group1) )$distance
#   distance2 <- (data %>% dplyr::filter(group == group2) )$distance
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }


plot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  # p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  # p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  # p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  # p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  # p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  # p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  # 
  p <- ggplot(temp.tb, aes(x = group, y = distance)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + scale_y_continuous(labels = label_kb_mb)
    # annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
    #                                                      \p15: \, convPvalue(p15), \\n\,
    #                                                      \p18: \, convPvalue(p18), \\n\,
    #                                                      \p25: \, convPvalue(p25), \\n\,
    #                                                      \p28: \, convPvalue(p28), \\n\,
    #                                                      \p58: \,convPvalue( p58), \\n\),
    #          color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\distance_to_boundary_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

plot_TADdistance(gene.TSS.tb.plot, \group_A485\)


## Plot TAD size
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize
#   distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 

plot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  # p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  # p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  # p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  # p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  # p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  # p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = TADsize)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + scale_y_continuous(labels = label_kb_mb) 
    # annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
    #                                                      \p15: \, convPvalue(p15), \\n\,
    #                                                      \p18: \, convPvalue(p18), \\n\,
    #                                                      \p25: \, convPvalue(p25), \\n\,
    #                                                      \p28: \, convPvalue(p28), \\n\,
    #                                                      \p58: \,convPvalue( p58), \\n\),
    #          color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\size_of_boundary_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_TADsize(gene.TSS.tb.plot, \group_A485\, ymax = 6e6)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcXCkpJGdlbmVcbmdyb3VwMyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAzLnRzdlxcKSkkZ2VuZVxuZ3JvdXA0IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDQudHN2XFwpKSRnZW5lXG5ncm91cDUgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwNS50c3ZcXCkpJGdlbmVcbmdyb3VwNiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA2LnRzdlxcKSkkZ2VuZVxuZ3JvdXA3IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDcudHN2XFwpKSRnZW5lXG5ncm91cDggPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwOC50c3ZcXCkpJGdlbmVcbmdyb3VwOSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA5LnRzdlxcKSkkZ2VuZVxuXG5cbmdlbmUuVFNTLnRiLnBsb3QgPC0gZ2VuZS5UU1MudGIgJT4lXG4gIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBncm91cCA9IGRwbHlyOjpjYXNlX3doZW4oXG4gICAgICBlbnNlbWJsICVpbiUgZ3JvdXAxIH4gXFxncm91cDFcXCxcbiAgICAgIGVuc2VtYmwgJWluJSBncm91cDIgfiBcXGdyb3VwMlxcLFxuICAgICAgZW5zZW1ibCAlaW4lIGdyb3VwMyB+IFxcZ3JvdXAzXFwsXG4gICAgICBlbnNlbWJsICVpbiUgZ3JvdXA0IH4gXFxncm91cDRcXCxcbiAgICAgIGVuc2VtYmwgJWluJSBncm91cDUgfiBcXGdyb3VwNVxcLFxuICAgICAgZW5zZW1ibCAlaW4lIGdyb3VwNiB+IFxcZ3JvdXA2XFwsXG4gICAgICBlbnNlbWJsICVpbiUgZ3JvdXA3IH4gXFxncm91cDdcXCxcbiAgICAgIGVuc2VtYmwgJWluJSBncm91cDggfiBcXGdyb3VwOFxcLFxuICAgICAgZW5zZW1ibCAlaW4lIGdyb3VwOSB+IFxcZ3JvdXA5XFwsXG4gICAgICBUUlVFIH4gTkFfY2hhcmFjdGVyX1xuICAgIClcbiAgKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG4jIyBQbG90IGRpc3RhbmNlXG4jIGdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuIyAgIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZGlzdGFuY2VcbiMgICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJGRpc3RhbmNlXG4jICAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuIyAgIHJldHVybih3aWwkcC52YWx1ZSlcbiMgfVxuXG5cbnBsb3RfVEFEZGlzdGFuY2UgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAyMDAwMDAwKXtcbiAgIyBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgIyBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgIyBwMTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgIyBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgIyBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgIyBwNTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgIyBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IGRpc3RhbmNlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpXG4gICAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSwgXFxcXG5cXCxcbiAgICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTU6IFxcLCBjb252UHZhbHVlKHAxNSksIFxcXFxuXFwsXG4gICAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE4OiBcXCwgY29udlB2YWx1ZShwMTgpLCBcXFxcblxcLFxuICAgICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyNTogXFwsIGNvbnZQdmFsdWUocDI1KSwgXFxcXG5cXCxcbiAgICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjg6IFxcLCBjb252UHZhbHVlKHAyOCksIFxcXFxuXFwsXG4gICAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDU4OiBcXCxjb252UHZhbHVlKCBwNTgpLCBcXFxcblxcKSxcbiAgICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGRpc3RhbmNlX3RvX2JvdW5kYXJ5X1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5cbnBsb3RfVEFEZGlzdGFuY2UoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cF9BNDg1XFwpXG5cblxuIyMgUGxvdCBUQUQgc2l6ZVxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJFRBRHNpemVcbiMgICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJFRBRHNpemVcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxuXG5wbG90X1RBRHNpemUgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAyMDAwMDAwKXtcbiAgIyBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgIyBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgIyBwMTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgIyBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgIyBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgIyBwNTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBUQURzaXplKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpIFxuICAgICMgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gKHltaW4gKyB5bWF4KS8yICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE1OiBcXCwgY29udlB2YWx1ZShwMTUpLCBcXFxcblxcLFxuICAgICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxODogXFwsIGNvbnZQdmFsdWUocDE4KSwgXFxcXG5cXCxcbiAgICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjU6IFxcLCBjb252UHZhbHVlKHAyNSksIFxcXFxuXFwsXG4gICAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI4OiBcXCwgY29udlB2YWx1ZShwMjgpLCBcXFxcblxcLFxuICAgICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHA1ODogXFwsY29udlB2YWx1ZSggcDU4KSwgXFxcXG5cXCksXG4gICAgIyAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxzaXplX29mX2JvdW5kYXJ5X1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X1RBRHNpemUoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cF9BNDg1XFwsIHltYXggPSA2ZTYpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup3 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group3.tsv\\))$gene\ngroup4 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group4.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup6 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group6.tsv\\))$gene\ngroup7 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group7.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group8.tsv\\))$gene\ngroup9 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group9.tsv\\))$gene\n\n\ngene.TSS.tb.plot <- gene.TSS.tb %>%\n  rowwise() %>%\n  dplyr::mutate(\n    group = dplyr::case_when(\n      ensembl %in% group1 ~ \\group1\\,\n      ensembl %in% group2 ~ \\group2\\,\n      ensembl %in% group3 ~ \\group3\\,\n      ensembl %in% group4 ~ \\group4\\,\n      ensembl %in% group5 ~ \\group5\\,\n      ensembl %in% group6 ~ \\group6\\,\n      ensembl %in% group7 ~ \\group7\\,\n      ensembl %in% group8 ~ \\group8\\,\n      ensembl %in% group9 ~ \\group9\\,\n      TRUE ~ NA_character_\n    )\n  ) %>%\n  dplyr::filter(!is.na(group))\n\n## Plot distance\n# getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(group == group1) )$distance\n#   distance2 <- (data %>% dplyr::filter(group == group2) )$distance\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n\n\nplot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  # p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  # p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  # p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  # p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  # p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  # p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  # \n  p <- ggplot(temp.tb, aes(x = group, y = distance)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + scale_y_continuous(labels = label_kb_mb)\n    # annotate(\\text\\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n    #                                                      \\p15: \\, convPvalue(p15), \\\\n\\,\n    #                                                      \\p18: \\, convPvalue(p18), \\\\n\\,\n    #                                                      \\p25: \\, convPvalue(p25), \\\\n\\,\n    #                                                      \\p28: \\, convPvalue(p28), \\\\n\\,\n    #                                                      \\p58: \\,convPvalue( p58), \\\\n\\),\n    #          color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\distance_to_boundary_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\nplot_TADdistance(gene.TSS.tb.plot, \\group_A485\\)\n\n\n## Plot TAD size\n# getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize\n#   distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n# \n\nplot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  # p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  # p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  # p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  # p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  # p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  # p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = TADsize)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + scale_y_continuous(labels = label_kb_mb) \n    # annotate(\\text\\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n    #                                                      \\p15: \\, convPvalue(p15), \\\\n\\,\n    #                                                      \\p18: \\, convPvalue(p18), \\\\n\\,\n    #                                                      \\p25: \\, convPvalue(p25), \\\\n\\,\n    #                                                      \\p28: \\, convPvalue(p28), \\\\n\\,\n    #                                                      \\p58: \\,convPvalue( p58), \\\\n\\),\n    #          color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\size_of_boundary_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\nplot_TADsize(gene.TSS.tb.plot, \\group_A485\\, ymax = 6e6)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcXCkpJGdlbmVcbmdyb3VwMyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAzLnRzdlxcKSkkZ2VuZVxuZ3JvdXA0IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDQudHN2XFwpKSRnZW5lXG5ncm91cDUgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwNS50c3ZcXCkpJGdlbmVcbmdyb3VwNiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA2LnRzdlxcKSkkZ2VuZVxuZ3JvdXA3IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDcudHN2XFwpKSRnZW5lXG5ncm91cDggPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwOC50c3ZcXCkpJGdlbmVcbmdyb3VwOSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA5LnRzdlxcKSkkZ2VuZVxuXG5cbmdlbmUuVFNTLnRiLnBsb3QgPC0gZ2VuZS5UU1MudGIgJT4lXG4gIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBncm91cCA9IGRwbHlyOjpjYXNlX3doZW4oXG4gICAgICBlbnNlbWJsICVpbiUgZ3JvdXAxIH4gXFxncm91cDFcXCxcbiAgICAgIGVuc2VtYmwgJWluJSBncm91cDIgfiBcXGdyb3VwMlxcLFxuICAgICAgZW5zZW1ibCAlaW4lIGdyb3VwMyB+IFxcZ3JvdXAzXFwsXG4gICAgICBlbnNlbWJsICVpbiUgZ3JvdXA0IH4gXFxncm91cDRcXCxcbiAgICAgIGVuc2VtYmwgJWluJSBncm91cDUgfiBcXGdyb3VwNVxcLFxuICAgICAgZW5zZW1ibCAlaW4lIGdyb3VwNiB+IFxcZ3JvdXA2XFwsXG4gICAgICBlbnNlbWJsICVpbiUgZ3JvdXA3IH4gXFxncm91cDdcXCxcbiAgICAgIGVuc2VtYmwgJWluJSBncm91cDggfiBcXGdyb3VwOFxcLFxuICAgICAgZW5zZW1ibCAlaW4lIGdyb3VwOSB+IFxcZ3JvdXA5XFwsXG4gICAgICBUUlVFIH4gTkFfY2hhcmFjdGVyX1xuICAgIClcbiAgKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG4jIyBQbG90IGRpc3RhbmNlXG4jIGdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuIyAgIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZGlzdGFuY2VcbiMgICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJGRpc3RhbmNlXG4jICAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuIyAgIHJldHVybih3aWwkcC52YWx1ZSlcbiMgfVxuXG5cbnBsb3RfVEFEZGlzdGFuY2UgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAyMDAwMDAwKXtcbiAgIyBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgIyBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgIyBwMTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgIyBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgIyBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgIyBwNTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgIyBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IGRpc3RhbmNlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpXG4gICAgIyBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSwgXFxcXG5cXCxcbiAgICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTU6IFxcLCBjb252UHZhbHVlKHAxNSksIFxcXFxuXFwsXG4gICAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE4OiBcXCwgY29udlB2YWx1ZShwMTgpLCBcXFxcblxcLFxuICAgICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyNTogXFwsIGNvbnZQdmFsdWUocDI1KSwgXFxcXG5cXCxcbiAgICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjg6IFxcLCBjb252UHZhbHVlKHAyOCksIFxcXFxuXFwsXG4gICAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDU4OiBcXCxjb252UHZhbHVlKCBwNTgpLCBcXFxcblxcKSxcbiAgICAjICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGRpc3RhbmNlX3RvX2JvdW5kYXJ5X1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5cbnBsb3RfVEFEZGlzdGFuY2UoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cF9BNDg1XFwpXG5cblxuIyMgUGxvdCBUQUQgc2l6ZVxuIyBnZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiMgICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJFRBRHNpemVcbiMgICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJFRBRHNpemVcbiMgICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4jICAgcmV0dXJuKHdpbCRwLnZhbHVlKVxuIyB9XG4jIFxuXG5wbG90X1RBRHNpemUgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAyMDAwMDAwKXtcbiAgIyBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgIyBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgIyBwMTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgIyBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgIyBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgIyBwNTggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwNVxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBUQURzaXplKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpIFxuICAgICMgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gKHltaW4gKyB5bWF4KS8yICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE1OiBcXCwgY29udlB2YWx1ZShwMTUpLCBcXFxcblxcLFxuICAgICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxODogXFwsIGNvbnZQdmFsdWUocDE4KSwgXFxcXG5cXCxcbiAgICAjICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjU6IFxcLCBjb252UHZhbHVlKHAyNSksIFxcXFxuXFwsXG4gICAgIyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI4OiBcXCwgY29udlB2YWx1ZShwMjgpLCBcXFxcblxcLFxuICAgICMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHA1ODogXFwsY29udlB2YWx1ZSggcDU4KSwgXFxcXG5cXCksXG4gICAgIyAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxzaXplX29mX2JvdW5kYXJ5X1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X1RBRHNpemUoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cF9BNDg1XFwsIHltYXggPSA2ZTYpXG5gYGBcbmBgYCJ9 -->

```r
```r
group1 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group2.tsv\))$gene
group3 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group3.tsv\))$gene
group4 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group4.tsv\))$gene
group5 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group5.tsv\))$gene
group6 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group6.tsv\))$gene
group7 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group7.tsv\))$gene
group8 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group8.tsv\))$gene
group9 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group9.tsv\))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>%
  rowwise() %>%
  dplyr::mutate(
    group = dplyr::case_when(
      ensembl %in% group1 ~ \group1\,
      ensembl %in% group2 ~ \group2\,
      ensembl %in% group3 ~ \group3\,
      ensembl %in% group4 ~ \group4\,
      ensembl %in% group5 ~ \group5\,
      ensembl %in% group6 ~ \group6\,
      ensembl %in% group7 ~ \group7\,
      ensembl %in% group8 ~ \group8\,
      ensembl %in% group9 ~ \group9\,
      TRUE ~ NA_character_
    )
  ) %>%
  dplyr::filter(!is.na(group))

## Plot distance
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group == group1) )$distance
#   distance2 <- (data %>% dplyr::filter(group == group2) )$distance
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }


plot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  # p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  # p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  # p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  # p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  # p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  # p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  # 
  p <- ggplot(temp.tb, aes(x = group, y = distance)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + scale_y_continuous(labels = label_kb_mb)
    # annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
    #                                                      \p15: \, convPvalue(p15), \\n\,
    #                                                      \p18: \, convPvalue(p18), \\n\,
    #                                                      \p25: \, convPvalue(p25), \\n\,
    #                                                      \p28: \, convPvalue(p28), \\n\,
    #                                                      \p58: \,convPvalue( p58), \\n\),
    #          color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\distance_to_boundary_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

plot_TADdistance(gene.TSS.tb.plot, \group_A485\)


## Plot TAD size
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize
#   distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 

plot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  # p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  # p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  # p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  # p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  # p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  # p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = TADsize)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + scale_y_continuous(labels = label_kb_mb) 
    # annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
    #                                                      \p15: \, convPvalue(p15), \\n\,
    #                                                      \p18: \, convPvalue(p18), \\n\,
    #                                                      \p25: \, convPvalue(p25), \\n\,
    #                                                      \p28: \, convPvalue(p28), \\n\,
    #                                                      \p58: \,convPvalue( p58), \\n\),
    #          color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\size_of_boundary_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_TADsize(gene.TSS.tb.plot, \group_A485\, ymax = 6e6)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### dTAG - Plotting for groups

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjbVZtUkdseUlEd3RJR2hsY21Vb1hDSXVMaTh1TGx3aUxDQmNJbkpsWm1WeVpXNWpaVndpS1Z4dVhHNGpJRWx0Y0c5eWRHbHVaeUJVUVVRZ1ltOTFibVJoY25sY2JuUmhaRjlpYjNWdVpHRnllU0E4TFNCbWNtVmhaQ2hvWlhKbEtGd2lMaTR2TGk0dmNtVnpkV3gwTDFSQlJGd2lMQ0JjSWxSQlJGOHlOV3RpWHpFeU5XdGlYMjkwYzNWZlltOTFibVJoY21sbGMxOUhNVVJOVTA4dVltVmtYQ0lwS1Z4dVkyOXNibUZ0WlhNb2RHRmtYMkp2ZFc1a1lYSjVLU0E4TFNCaktGd2lZMmh5WENJc0lGd2ljM1JoY25SY0lpd2dYQ0psYm1SY0lpbGNiblJoWkY5aWIzVnVaR0Z5ZVNBOExTQjBZV1JmWW05MWJtUmhjbmtnSlQ0bElHUndiSGx5T2pwdGRYUmhkR1VvZEdGa1gybGtJRDBnY0dGemRHVW9ZMmh5TENCemRHRnlkQ3dnWlc1a0xDQnpaWEFnUFNCY0lsOWNJaWtzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lITjBZWEowSUQwZ2MzUmhjblFnTFRFM05UQXdNQzh5TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmxibVFnUFNCbGJtUWdLeUF4TnpVd01EQXZNaXhjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1kyVnVkR1Z5SUQwZ0tITjBZWEowSUNzZ1pXNWtLUzh5S1Z4dVhHNGpJRWx0Y0c5eWRHbHVaeUJTUVVReU1TQmlhV2QzYVdjZ2RISmhZMnRjYm1KM0xsSkJSREl4SUR3dElHbHRjRzl5ZENob1pYSmxLSEpsWmtScGNpd2dYQ0l6TXpJMU1GOVNRVVF5TVY5aFlqazVNbDlDY25WalpTMDBYM1J5YVcxZmNUSXdYMlJsWkhWd1gySnNZV05yWDJSbGNIUm9UbTl5YlY5aWFXNDFNR0p3TG1KM1hDSXBLVnh1WEc0aklFTnlaV0YwWlNCSFVtRnVaMlZ6SUc5aWFtVmpkQ0JtYjNJZ1ZFRkVJR0p2ZFc1a1lYSnBaWE5jYm5SaFpGOXlZVzVuWlhNZ1BDMGdiV0ZyWlVkU1lXNW5aWE5HY205dFJHRjBZVVp5WVcxbEtIUmhaRjlpYjNWdVpHRnllU3dnYTJWbGNDNWxlSFJ5WVM1amIyeDFiVzV6SUQwZ1ZGSlZSU2xjYmx4dUl5QkdhVzVrSUc5MlpYSnNZWEJ6SUdKbGRIZGxaVzRnWVd4c0lGUkJSQ0JpYjNWdVpHRnlhV1Z6SUdGdVpDQlNRVVF5TVNCaWFXZDNhV2NnWkdGMFlWeHViM1psY214aGNITWdQQzBnWm1sdVpFOTJaWEpzWVhCektIUmhaRjl5WVc1blpYTXNJR0ozTGxKQlJESXhLVnh1WEc0aklFVjRkSEpoWTNRZ2IzWmxjbXhoY0hCcGJtY2djbVZuYVc5dWN5QmhibVFnYzJOdmNtVnpJR1p5YjIwZ2RHaGxJRUpwWjFkcFoxeHViM1psY214aGNIQnBibWRmWW5jZ1BDMGdZbmN1VWtGRU1qRmJjM1ZpYW1WamRFaHBkSE1vYjNabGNteGhjSE1wWFZ4dWIzWmxjbXhoY0hCcGJtZGZkR0ZrY3lBOExTQjBZV1JmY21GdVoyVnpXM0YxWlhKNVNHbDBjeWh2ZG1WeWJHRndjeWxkWEc1Y2JpTWdRV2RuY21WbllYUmxJSE5qYjNKbGN5QmllU0JVUVVRZ1ltOTFibVJoY25rZ2NtVm5hVzl1YzF4dVhHNWNibk5qYjNKbGN5QThMU0JoYzE5MGFXSmliR1VvYjNabGNteGhjSEJwYm1kZlluY3BJQ1UrSlZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0hSaFpGOXBaQ0E5SUhSaFpGOXlZVzVuWlhOYmNYVmxjbmxJYVhSektHOTJaWEpzWVhCektWMGtkR0ZrWDJsa0tTQWxQaVZjYmlBZ1ozSnZkWEJmWW5rb2RHRmtYMmxrS1NBbFBpVmNiaUFnYzNWdGJXRnlhWE5sS0hKaFpESXhVMk52Y21VZ1BTQnpkVzBvYzJOdmNtVXBLVnh1WEc1MFlXUmZZbTkxYm1SaGNua2dQQzBnZEdGa1gySnZkVzVrWVhKNUlDVStKVnh1SUNCc1pXWjBYMnB2YVc0b2MyTnZjbVZ6TENCaWVTQTlJRndpZEdGa1gybGtYQ0lwWEc1Y2JseHVYRzVjYmx4dUl5QkpiWEJ2Y25ScGJtY2daMlZ1WlZ4dVoyVnVaUzVVVTFNdWRHSWdQQzBnWm5KbFlXUW9hR1Z5WlNoeVpXWkVhWElzSUZ3aWJXMHhNRjlIVWtOdE16Z3VjRFpmWjJWdVpWOXpiM0owWldRdVltVmtYQ0lwS1NBbFBpVmNiaUFnWkhCc2VYSTZPbTExZEdGMFpTaFVVMU1nUFNCcFptVnNjMlVvVmpRZ1BUMGdYQ0lyWENJc0lGWXlMQ0JXTXlrcElDVStKVnh1SUNCa2NHeDVjam82YzJWc1pXTjBLRlkyTENCV05Td2dWakVzSUZSVFV5bGNibU52Ykc1aGJXVnpLR2RsYm1VdVZGTlRMblJpS1NBOExTQmpLRndpWlc1elpXMWliRndpTENCY0ltZGxibVZjSWl3Z1hDSmphSEpjSWl3Z1hDSlVVMU5jSWlsY2JseHVYRzRqSUVacGJtUWdibVZoY21WemRDQlVRVVFnWW05MWJtUmhjbmxjYm1acGJtUkRiRzl6WlhOMFZFRkVRbTkxYm1SaGNubEpSQ0E4TFNCbWRXNWpkR2x2YmloamFISnZiU3dnVkZOVExDQjBZV1JmWW05MWJtUmhjbmtwZTF4dUlDQjBaVzF3SUR3dElIUmhaRjlpYjNWdVpHRnllU0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhqYUhJZ1BUMGdZMmh5YjIwcElDVStKVnh1SUNBZ0lHUndiSGx5T2pwdGRYUmhkR1VvWkdsemRHRnVZMlVnUFNCaFluTW9ZMlZ1ZEdWeUlDMGdWRk5US1NrZ0pUNGxYRzRnSUNBZ2MyeHBZMlZmYldsdUtHUnBjM1JoYm1ObEtWeHVJQ0JwWmlodWNtOTNLSFJsYlhBcElEMDlJREVwZTF4dUlDQWdJQ0FnY21WMGRYSnVLSFJsYlhBa2RHRmtYMmxrS1Z4dUlDQjlaV3h6Wlh0Y2JpQWdJQ0J5WlhSMWNtNG9Ua0VwWEc0Z0lIMWNibjFjYm1kbGJtVXVWRk5UTG5SaUlEd3RJR2RsYm1VdVZGTlRMblJpSUNVK0pTQnliM2QzYVhObEtDa2dKVDRsWEc0Z0lHUndiSGx5T2pwdGRYUmhkR1VvWTJ4dmMyVnpkRUp2ZFc1a1lYSjVJRDBnWm1sdVpFTnNiM05sYzNSVVFVUkNiM1Z1WkdGeWVVbEVLR05vY2l3Z1ZGTlRMQ0IwWVdSZlltOTFibVJoY25rcEtWeHVYRzUwWlcxd0lEd3RJSFJoWkY5aWIzVnVaR0Z5ZVNBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoMFlXUmZhV1FzSUhKaFpESXhVMk52Y21VcFhHNWNibWRsYm1VdVZGTlRMblJpSUR3dElHZGxibVV1VkZOVExuUmlJQ1UrSlNCc1pXWjBYMnB2YVc0b2RHVnRjQ3dnWW5rZ1BTQmpLRndpWTJ4dmMyVnpkRUp2ZFc1a1lYSjVYQ0lnUFNCY0luUmhaRjlwWkZ3aUtTQXBYRzVjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbnJlZkRpciA8LSBoZXJlKFxcLi4vLi5cXCwgXFxyZWZlcmVuY2VcXClcblxuIyBJbXBvcnRpbmcgVEFEIGJvdW5kYXJ5XG50YWRfYm91bmRhcnkgPC0gZnJlYWQoaGVyZShcXC4uLy4uL3Jlc3VsdC9UQURcXCwgXFxUQURfMjVrYl8xMjVrYl9vdHN1X2JvdW5kYXJpZXNfRzFETVNPLmJlZFxcKSlcbmNvbG5hbWVzKHRhZF9ib3VuZGFyeSkgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG50YWRfYm91bmRhcnkgPC0gdGFkX2JvdW5kYXJ5ICU+JSBkcGx5cjo6bXV0YXRlKHRhZF9pZCA9IHBhc3RlKGNociwgc3RhcnQsIGVuZCwgc2VwID0gXFxfXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdGFydCA9IHN0YXJ0IC0xNzUwMDAvMixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZW5kID0gZW5kICsgMTc1MDAwLzIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNlbnRlciA9IChzdGFydCArIGVuZCkvMilcblxuIyBJbXBvcnRpbmcgUkFEMjEgYmlnd2lnIHRyYWNrXG5idy5SQUQyMSA8LSBpbXBvcnQoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF90cmltX3EyMF9kZWR1cF9ibGFja19kZXB0aE5vcm1fYmluNTBicC5id1xcKSlcblxuIyBDcmVhdGUgR1JhbmdlcyBvYmplY3QgZm9yIFRBRCBib3VuZGFyaWVzXG50YWRfcmFuZ2VzIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0YWRfYm91bmRhcnksIGtlZXAuZXh0cmEuY29sdW1ucyA9IFRSVUUpXG5cbiMgRmluZCBvdmVybGFwcyBiZXR3ZWVuIGFsbCBUQUQgYm91bmRhcmllcyBhbmQgUkFEMjEgYmlnd2lnIGRhdGFcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyh0YWRfcmFuZ2VzLCBidy5SQUQyMSlcblxuIyBFeHRyYWN0IG92ZXJsYXBwaW5nIHJlZ2lvbnMgYW5kIHNjb3JlcyBmcm9tIHRoZSBCaWdXaWdcbm92ZXJsYXBwaW5nX2J3IDwtIGJ3LlJBRDIxW3N1YmplY3RIaXRzKG92ZXJsYXBzKV1cbm92ZXJsYXBwaW5nX3RhZHMgPC0gdGFkX3Jhbmdlc1txdWVyeUhpdHMob3ZlcmxhcHMpXVxuXG4jIEFnZ3JlZ2F0ZSBzY29yZXMgYnkgVEFEIGJvdW5kYXJ5IHJlZ2lvbnNcblxuXG5zY29yZXMgPC0gYXNfdGliYmxlKG92ZXJsYXBwaW5nX2J3KSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YWRfaWQgPSB0YWRfcmFuZ2VzW3F1ZXJ5SGl0cyhvdmVybGFwcyldJHRhZF9pZCkgJT4lXG4gIGdyb3VwX2J5KHRhZF9pZCkgJT4lXG4gIHN1bW1hcmlzZShyYWQyMVNjb3JlID0gc3VtKHNjb3JlKSlcblxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiVcbiAgbGVmdF9qb2luKHNjb3JlcywgYnkgPSBcXHRhZF9pZFxcKVxuXG5cblxuXG5cbiMgSW1wb3J0aW5nIGdlbmVcbmdlbmUuVFNTLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWNiwgVjUsIFYxLCBUU1MpXG5jb2xuYW1lcyhnZW5lLlRTUy50YikgPC0gYyhcXGVuc2VtYmxcXCwgXFxnZW5lXFwsIFxcY2hyXFwsIFxcVFNTXFwpXG5cblxuIyBGaW5kIG5lYXJlc3QgVEFEIGJvdW5kYXJ5XG5maW5kQ2xvc2VzdFRBREJvdW5kYXJ5SUQgPC0gZnVuY3Rpb24oY2hyb20sIFRTUywgdGFkX2JvdW5kYXJ5KXtcbiAgdGVtcCA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjpmaWx0ZXIoY2hyID09IGNocm9tKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gYWJzKGNlbnRlciAtIFRTUykpICU+JVxuICAgIHNsaWNlX21pbihkaXN0YW5jZSlcbiAgaWYobnJvdyh0ZW1wKSA9PSAxKXtcbiAgICAgIHJldHVybih0ZW1wJHRhZF9pZClcbiAgfWVsc2V7XG4gICAgcmV0dXJuKE5BKVxuICB9XG59XG5nZW5lLlRTUy50YiA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKGNsb3Nlc3RCb3VuZGFyeSA9IGZpbmRDbG9zZXN0VEFEQm91bmRhcnlJRChjaHIsIFRTUywgdGFkX2JvdW5kYXJ5KSlcblxudGVtcCA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjpzZWxlY3QodGFkX2lkLCByYWQyMVNjb3JlKVxuXG5nZW5lLlRTUy50YiA8LSBnZW5lLlRTUy50YiAlPiUgbGVmdF9qb2luKHRlbXAsIGJ5ID0gYyhcXGNsb3Nlc3RCb3VuZGFyeVxcID0gXFx0YWRfaWRcXCkgKVxuXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
refDir <- here(\../..\, \reference\)

# Importing TAD boundary
tad_boundary <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\))
colnames(tad_boundary) <- c(\chr\, \start\, \end\)
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = \_\),
                                               start = start -175000/2,
                                               end = end + 175000/2,
                                               center = (start + end)/2)

# Importing RAD21 bigwig track
bw.RAD21 <- import(here(refDir, \33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm_bin50bp.bw\))

# Create GRanges object for TAD boundaries
tad_ranges <- makeGRangesFromDataFrame(tad_boundary, keep.extra.columns = TRUE)

# Find overlaps between all TAD boundaries and RAD21 bigwig data
overlaps <- findOverlaps(tad_ranges, bw.RAD21)

# Extract overlapping regions and scores from the BigWig
overlapping_bw <- bw.RAD21[subjectHits(overlaps)]
overlapping_tads <- tad_ranges[queryHits(overlaps)]

# Aggregate scores by TAD boundary regions


scores <- as_tibble(overlapping_bw) %>%
  dplyr::mutate(tad_id = tad_ranges[queryHits(overlaps)]$tad_id) %>%
  group_by(tad_id) %>%
  summarise(rad21Score = sum(score))

tad_boundary <- tad_boundary %>%
  left_join(scores, by = \tad_id\)





# Importing gene
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, V5, V1, TSS)
colnames(gene.TSS.tb) <- c(\ensembl\, \gene\, \chr\, \TSS\)


# Find nearest TAD boundary
findClosestTADBoundaryID <- function(chrom, TSS, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom) %>%
    dplyr::mutate(distance = abs(center - TSS)) %>%
    slice_min(distance)
  if(nrow(temp) == 1){
      return(temp$tad_id)
  }else{
    return(NA)
  }
}
gene.TSS.tb <- gene.TSS.tb %>% rowwise() %>%
  dplyr::mutate(closestBoundary = findClosestTADBoundaryID(chr, TSS, tad_boundary))

temp <- tad_boundary %>% dplyr::select(tad_id, rad21Score)

gene.TSS.tb <- gene.TSS.tb %>% left_join(temp, by = c(\closestBoundary\ = \tad_id\) )



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWNtVm1SR2x5SUR3dElHaGxjbVVvWEZ3dUxpOHVMbHhjTENCY1hISmxabVZ5Wlc1alpWeGNLVnh1WEc0aklFbHRjRzl5ZEdsdVp5QlVRVVFnWW05MWJtUmhjbmxjYm5SaFpGOWliM1Z1WkdGeWVTQThMU0JtY21WaFpDaG9aWEpsS0Z4Y0xpNHZMaTR2Y21WemRXeDBMMVJCUkZ4Y0xDQmNYRlJCUkY4eU5XdGlYekV5Tld0aVgyOTBjM1ZmWW05MWJtUmhjbWxsYzE5SE1VUk5VMDh1WW1Wa1hGd3BLVnh1WTI5c2JtRnRaWE1vZEdGa1gySnZkVzVrWVhKNUtTQThMU0JqS0Z4Y1kyaHlYRndzSUZ4Y2MzUmhjblJjWEN3Z1hGeGxibVJjWENsY2JuUmhaRjlpYjNWdVpHRnllU0E4TFNCMFlXUmZZbTkxYm1SaGNua2dKVDRsSUdSd2JIbHlPanB0ZFhSaGRHVW9kR0ZrWDJsa0lEMGdjR0Z6ZEdVb1kyaHlMQ0J6ZEdGeWRDd2daVzVrTENCelpYQWdQU0JjWEY5Y1hDa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUhOMFlYSjBJRDBnYzNSaGNuUWdMVEUzTlRBd01DOHlMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCbGJtUWdQU0JsYm1RZ0t5QXhOelV3TURBdk1peGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWTJWdWRHVnlJRDBnS0hOMFlYSjBJQ3NnWlc1a0tTOHlLVnh1WEc0aklFbHRjRzl5ZEdsdVp5QlNRVVF5TVNCaWFXZDNhV2NnZEhKaFkydGNibUozTGxKQlJESXhJRHd0SUdsdGNHOXlkQ2hvWlhKbEtISmxaa1JwY2l3Z1hGd3pNekkxTUY5U1FVUXlNVjloWWprNU1sOUNjblZqWlMwMFgzUnlhVzFmY1RJd1gyUmxaSFZ3WDJKc1lXTnJYMlJsY0hSb1RtOXliVjlpYVc0MU1HSndMbUozWEZ3cEtWeHVYRzRqSUVOeVpXRjBaU0JIVW1GdVoyVnpJRzlpYW1WamRDQm1iM0lnVkVGRUlHSnZkVzVrWVhKcFpYTmNiblJoWkY5eVlXNW5aWE1nUEMwZ2JXRnJaVWRTWVc1blpYTkdjbTl0UkdGMFlVWnlZVzFsS0hSaFpGOWliM1Z1WkdGeWVTd2dhMlZsY0M1bGVIUnlZUzVqYjJ4MWJXNXpJRDBnVkZKVlJTbGNibHh1SXlCR2FXNWtJRzkyWlhKc1lYQnpJR0psZEhkbFpXNGdZV3hzSUZSQlJDQmliM1Z1WkdGeWFXVnpJR0Z1WkNCU1FVUXlNU0JpYVdkM2FXY2daR0YwWVZ4dWIzWmxjbXhoY0hNZ1BDMGdabWx1WkU5MlpYSnNZWEJ6S0hSaFpGOXlZVzVuWlhNc0lHSjNMbEpCUkRJeEtWeHVYRzRqSUVWNGRISmhZM1FnYjNabGNteGhjSEJwYm1jZ2NtVm5hVzl1Y3lCaGJtUWdjMk52Y21WeklHWnliMjBnZEdobElFSnBaMWRwWjF4dWIzWmxjbXhoY0hCcGJtZGZZbmNnUEMwZ1luY3VVa0ZFTWpGYmMzVmlhbVZqZEVocGRITW9iM1psY214aGNITXBYVnh1YjNabGNteGhjSEJwYm1kZmRHRmtjeUE4TFNCMFlXUmZjbUZ1WjJWelczRjFaWEo1U0dsMGN5aHZkbVZ5YkdGd2N5bGRYRzVjYmlNZ1FXZG5jbVZuWVhSbElITmpiM0psY3lCaWVTQlVRVVFnWW05MWJtUmhjbmtnY21WbmFXOXVjMXh1WEc1Y2JuTmpiM0psY3lBOExTQmhjMTkwYVdKaWJHVW9iM1psY214aGNIQnBibWRmWW5jcElDVStKVnh1SUNCa2NHeDVjam82YlhWMFlYUmxLSFJoWkY5cFpDQTlJSFJoWkY5eVlXNW5aWE5iY1hWbGNubElhWFJ6S0c5MlpYSnNZWEJ6S1Ywa2RHRmtYMmxrS1NBbFBpVmNiaUFnWjNKdmRYQmZZbmtvZEdGa1gybGtLU0FsUGlWY2JpQWdjM1Z0YldGeWFYTmxLSEpoWkRJeFUyTnZjbVVnUFNCemRXMG9jMk52Y21VcEtWeHVYRzUwWVdSZlltOTFibVJoY25rZ1BDMGdkR0ZrWDJKdmRXNWtZWEo1SUNVK0pWeHVJQ0JzWldaMFgycHZhVzRvYzJOdmNtVnpMQ0JpZVNBOUlGeGNkR0ZrWDJsa1hGd3BYRzVjYmx4dVhHNWNibHh1SXlCSmJYQnZjblJwYm1jZ1oyVnVaVnh1WjJWdVpTNVVVMU11ZEdJZ1BDMGdabkpsWVdRb2FHVnlaU2h5WldaRWFYSXNJRnhjYlcweE1GOUhVa050TXpndWNEWmZaMlZ1WlY5emIzSjBaV1F1WW1Wa1hGd3BLU0FsUGlWY2JpQWdaSEJzZVhJNk9tMTFkR0YwWlNoVVUxTWdQU0JwWm1Wc2MyVW9WalFnUFQwZ1hGd3JYRndzSUZZeUxDQldNeWtwSUNVK0pWeHVJQ0JrY0d4NWNqbzZjMlZzWldOMEtGWTJMQ0JXTlN3Z1ZqRXNJRlJUVXlsY2JtTnZiRzVoYldWektHZGxibVV1VkZOVExuUmlLU0E4TFNCaktGeGNaVzV6WlcxaWJGeGNMQ0JjWEdkbGJtVmNYQ3dnWEZ4amFISmNYQ3dnWEZ4VVUxTmNYQ2xjYmx4dVhHNGpJRVpwYm1RZ2JtVmhjbVZ6ZENCVVFVUWdZbTkxYm1SaGNubGNibVpwYm1SRGJHOXpaWE4wVkVGRVFtOTFibVJoY25sSlJDQThMU0JtZFc1amRHbHZiaWhqYUhKdmJTd2dWRk5UTENCMFlXUmZZbTkxYm1SaGNua3BlMXh1SUNCMFpXMXdJRHd0SUhSaFpGOWliM1Z1WkdGeWVTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaGphSElnUFQwZ1kyaHliMjBwSUNVK0pWeHVJQ0FnSUdSd2JIbHlPanB0ZFhSaGRHVW9aR2x6ZEdGdVkyVWdQU0JoWW5Nb1kyVnVkR1Z5SUMwZ1ZGTlRLU2tnSlQ0bFhHNGdJQ0FnYzJ4cFkyVmZiV2x1S0dScGMzUmhibU5sS1Z4dUlDQnBaaWh1Y205M0tIUmxiWEFwSUQwOUlERXBlMXh1SUNBZ0lDQWdjbVYwZFhKdUtIUmxiWEFrZEdGa1gybGtLVnh1SUNCOVpXeHpaWHRjYmlBZ0lDQnlaWFIxY200b1RrRXBYRzRnSUgxY2JuMWNibWRsYm1VdVZGTlRMblJpSUR3dElHZGxibVV1VkZOVExuUmlJQ1UrSlNCeWIzZDNhWE5sS0NrZ0pUNGxYRzRnSUdSd2JIbHlPanB0ZFhSaGRHVW9ZMnh2YzJWemRFSnZkVzVrWVhKNUlEMGdabWx1WkVOc2IzTmxjM1JVUVVSQ2IzVnVaR0Z5ZVVsRUtHTm9jaXdnVkZOVExDQjBZV1JmWW05MWJtUmhjbmtwS1Z4dVhHNTBaVzF3SUR3dElIUmhaRjlpYjNWdVpHRnllU0FsUGlVZ1pIQnNlWEk2T25ObGJHVmpkQ2gwWVdSZmFXUXNJSEpoWkRJeFUyTnZjbVVwWEc1Y2JtZGxibVV1VkZOVExuUmlJRHd0SUdkbGJtVXVWRk5UTG5SaUlDVStKU0JzWldaMFgycHZhVzRvZEdWdGNDd2dZbmtnUFNCaktGeGNZMnh2YzJWemRFSnZkVzVrWVhKNVhGd2dQU0JjWEhSaFpGOXBaRnhjS1NBcFhHNWNibUJnWUZ4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG5gYGByXG5yZWZEaXIgPC0gaGVyZShcXC4uLy4uXFwsIFxccmVmZXJlbmNlXFwpXG5cbiMgSW1wb3J0aW5nIFRBRCBib3VuZGFyeVxudGFkX2JvdW5kYXJ5IDwtIGZyZWFkKGhlcmUoXFwuLi8uLi9yZXN1bHQvVEFEXFwsIFxcVEFEXzI1a2JfMTI1a2Jfb3RzdV9ib3VuZGFyaWVzX0cxRE1TTy5iZWRcXCkpXG5jb2xuYW1lcyh0YWRfYm91bmRhcnkpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6Om11dGF0ZSh0YWRfaWQgPSBwYXN0ZShjaHIsIHN0YXJ0LCBlbmQsIHNlcCA9IFxcX1xcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3RhcnQgPSBzdGFydCAtMTc1MDAwLzIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZCA9IGVuZCArIDE3NTAwMC8yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjZW50ZXIgPSAoc3RhcnQgKyBlbmQpLzIpXG5cbiMgSW1wb3J0aW5nIFJBRDIxIGJpZ3dpZyB0cmFja1xuYncuUkFEMjEgPC0gaW1wb3J0KGhlcmUocmVmRGlyLCBcXDMzMjUwX1JBRDIxX2FiOTkyX0JydWNlLTRfdHJpbV9xMjBfZGVkdXBfYmxhY2tfZGVwdGhOb3JtX2JpbjUwYnAuYndcXCkpXG5cbiMgQ3JlYXRlIEdSYW5nZXMgb2JqZWN0IGZvciBUQUQgYm91bmRhcmllc1xudGFkX3JhbmdlcyA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGFkX2JvdW5kYXJ5LCBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFKVxuXG4jIEZpbmQgb3ZlcmxhcHMgYmV0d2VlbiBhbGwgVEFEIGJvdW5kYXJpZXMgYW5kIFJBRDIxIGJpZ3dpZyBkYXRhXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHModGFkX3JhbmdlcywgYncuUkFEMjEpXG5cbiMgRXh0cmFjdCBvdmVybGFwcGluZyByZWdpb25zIGFuZCBzY29yZXMgZnJvbSB0aGUgQmlnV2lnXG5vdmVybGFwcGluZ19idyA8LSBidy5SQUQyMVtzdWJqZWN0SGl0cyhvdmVybGFwcyldXG5vdmVybGFwcGluZ190YWRzIDwtIHRhZF9yYW5nZXNbcXVlcnlIaXRzKG92ZXJsYXBzKV1cblxuIyBBZ2dyZWdhdGUgc2NvcmVzIGJ5IFRBRCBib3VuZGFyeSByZWdpb25zXG5cblxuc2NvcmVzIDwtIGFzX3RpYmJsZShvdmVybGFwcGluZ19idykgJT4lXG4gIGRwbHlyOjptdXRhdGUodGFkX2lkID0gdGFkX3Jhbmdlc1txdWVyeUhpdHMob3ZlcmxhcHMpXSR0YWRfaWQpICU+JVxuICBncm91cF9ieSh0YWRfaWQpICU+JVxuICBzdW1tYXJpc2UocmFkMjFTY29yZSA9IHN1bShzY29yZSkpXG5cbnRhZF9ib3VuZGFyeSA8LSB0YWRfYm91bmRhcnkgJT4lXG4gIGxlZnRfam9pbihzY29yZXMsIGJ5ID0gXFx0YWRfaWRcXClcblxuXG5cblxuXG4jIEltcG9ydGluZyBnZW5lXG5nZW5lLlRTUy50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjYsIFY1LCBWMSwgVFNTKVxuY29sbmFtZXMoZ2VuZS5UU1MudGIpIDwtIGMoXFxlbnNlbWJsXFwsIFxcZ2VuZVxcLCBcXGNoclxcLCBcXFRTU1xcKVxuXG5cbiMgRmluZCBuZWFyZXN0IFRBRCBib3VuZGFyeVxuZmluZENsb3Nlc3RUQURCb3VuZGFyeUlEIDwtIGZ1bmN0aW9uKGNocm9tLCBUU1MsIHRhZF9ib3VuZGFyeSl7XG4gIHRlbXAgPC0gdGFkX2JvdW5kYXJ5ICU+JSBkcGx5cjo6ZmlsdGVyKGNociA9PSBjaHJvbSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IGFicyhjZW50ZXIgLSBUU1MpKSAlPiVcbiAgICBzbGljZV9taW4oZGlzdGFuY2UpXG4gIGlmKG5yb3codGVtcCkgPT0gMSl7XG4gICAgICByZXR1cm4odGVtcCR0YWRfaWQpXG4gIH1lbHNle1xuICAgIHJldHVybihOQSlcbiAgfVxufVxuZ2VuZS5UU1MudGIgPC0gZ2VuZS5UU1MudGIgJT4lIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjbG9zZXN0Qm91bmRhcnkgPSBmaW5kQ2xvc2VzdFRBREJvdW5kYXJ5SUQoY2hyLCBUU1MsIHRhZF9ib3VuZGFyeSkpXG5cbnRlbXAgPC0gdGFkX2JvdW5kYXJ5ICU+JSBkcGx5cjo6c2VsZWN0KHRhZF9pZCwgcmFkMjFTY29yZSlcblxuZ2VuZS5UU1MudGIgPC0gZ2VuZS5UU1MudGIgJT4lIGxlZnRfam9pbih0ZW1wLCBieSA9IGMoXFxjbG9zZXN0Qm91bmRhcnlcXCA9IFxcdGFkX2lkXFwpIClcblxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxucmVmRGlyIDwtIGhlcmUoXFwuLi8uLlxcLCBcXHJlZmVyZW5jZVxcKVxuXG4jIEltcG9ydGluZyBUQUQgYm91bmRhcnlcbnRhZF9ib3VuZGFyeSA8LSBmcmVhZChoZXJlKFxcLi4vLi4vcmVzdWx0L1RBRFxcLCBcXFRBRF8yNWtiXzEyNWtiX290c3VfYm91bmRhcmllc19HMURNU08uYmVkXFwpKVxuY29sbmFtZXModGFkX2JvdW5kYXJ5KSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnRhZF9ib3VuZGFyeSA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjptdXRhdGUodGFkX2lkID0gcGFzdGUoY2hyLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHN0YXJ0ID0gc3RhcnQgLTE3NTAwMC8yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmQgPSBlbmQgKyAxNzUwMDAvMixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyID0gKHN0YXJ0ICsgZW5kKS8yKVxuXG4jIEltcG9ydGluZyBSQUQyMSBiaWd3aWcgdHJhY2tcbmJ3LlJBRDIxIDwtIGltcG9ydChoZXJlKHJlZkRpciwgXFwzMzI1MF9SQUQyMV9hYjk5Ml9CcnVjZS00X3RyaW1fcTIwX2RlZHVwX2JsYWNrX2RlcHRoTm9ybV9iaW41MGJwLmJ3XFwpKVxuXG4jIENyZWF0ZSBHUmFuZ2VzIG9iamVjdCBmb3IgVEFEIGJvdW5kYXJpZXNcbnRhZF9yYW5nZXMgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRhZF9ib3VuZGFyeSwga2VlcC5leHRyYS5jb2x1bW5zID0gVFJVRSlcblxuIyBGaW5kIG92ZXJsYXBzIGJldHdlZW4gYWxsIFRBRCBib3VuZGFyaWVzIGFuZCBSQUQyMSBiaWd3aWcgZGF0YVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKHRhZF9yYW5nZXMsIGJ3LlJBRDIxKVxuXG4jIEV4dHJhY3Qgb3ZlcmxhcHBpbmcgcmVnaW9ucyBhbmQgc2NvcmVzIGZyb20gdGhlIEJpZ1dpZ1xub3ZlcmxhcHBpbmdfYncgPC0gYncuUkFEMjFbc3ViamVjdEhpdHMob3ZlcmxhcHMpXVxub3ZlcmxhcHBpbmdfdGFkcyA8LSB0YWRfcmFuZ2VzW3F1ZXJ5SGl0cyhvdmVybGFwcyldXG5cbiMgQWdncmVnYXRlIHNjb3JlcyBieSBUQUQgYm91bmRhcnkgcmVnaW9uc1xuXG5cbnNjb3JlcyA8LSBhc190aWJibGUob3ZlcmxhcHBpbmdfYncpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhZF9pZCA9IHRhZF9yYW5nZXNbcXVlcnlIaXRzKG92ZXJsYXBzKV0kdGFkX2lkKSAlPiVcbiAgZ3JvdXBfYnkodGFkX2lkKSAlPiVcbiAgc3VtbWFyaXNlKHJhZDIxU2NvcmUgPSBzdW0oc2NvcmUpKVxuXG50YWRfYm91bmRhcnkgPC0gdGFkX2JvdW5kYXJ5ICU+JVxuICBsZWZ0X2pvaW4oc2NvcmVzLCBieSA9IFxcdGFkX2lkXFwpXG5cblxuXG5cblxuIyBJbXBvcnRpbmcgZ2VuZVxuZ2VuZS5UU1MudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXFwrXFwsIFYyLCBWMykpICU+JVxuICBkcGx5cjo6c2VsZWN0KFY2LCBWNSwgVjEsIFRTUylcbmNvbG5hbWVzKGdlbmUuVFNTLnRiKSA8LSBjKFxcZW5zZW1ibFxcLCBcXGdlbmVcXCwgXFxjaHJcXCwgXFxUU1NcXClcblxuXG4jIEZpbmQgbmVhcmVzdCBUQUQgYm91bmRhcnlcbmZpbmRDbG9zZXN0VEFEQm91bmRhcnlJRCA8LSBmdW5jdGlvbihjaHJvbSwgVFNTLCB0YWRfYm91bmRhcnkpe1xuICB0ZW1wIDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6OmZpbHRlcihjaHIgPT0gY2hyb20pICU+JVxuICAgIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBhYnMoY2VudGVyIC0gVFNTKSkgJT4lXG4gICAgc2xpY2VfbWluKGRpc3RhbmNlKVxuICBpZihucm93KHRlbXApID09IDEpe1xuICAgICAgcmV0dXJuKHRlbXAkdGFkX2lkKVxuICB9ZWxzZXtcbiAgICByZXR1cm4oTkEpXG4gIH1cbn1cbmdlbmUuVFNTLnRiIDwtIGdlbmUuVFNTLnRiICU+JSByb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2xvc2VzdEJvdW5kYXJ5ID0gZmluZENsb3Nlc3RUQURCb3VuZGFyeUlEKGNociwgVFNTLCB0YWRfYm91bmRhcnkpKVxuXG50ZW1wIDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6OnNlbGVjdCh0YWRfaWQsIHJhZDIxU2NvcmUpXG5cbmdlbmUuVFNTLnRiIDwtIGdlbmUuVFNTLnRiICU+JSBsZWZ0X2pvaW4odGVtcCwgYnkgPSBjKFxcY2xvc2VzdEJvdW5kYXJ5XFwgPSBcXHRhZF9pZFxcKSApXG5cbmBgYFxuYGBgIn0= -->

```r
```r
refDir <- here(\../..\, \reference\)

# Importing TAD boundary
tad_boundary <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\))
colnames(tad_boundary) <- c(\chr\, \start\, \end\)
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = \_\),
                                               start = start -175000/2,
                                               end = end + 175000/2,
                                               center = (start + end)/2)

# Importing RAD21 bigwig track
bw.RAD21 <- import(here(refDir, \33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm_bin50bp.bw\))

# Create GRanges object for TAD boundaries
tad_ranges <- makeGRangesFromDataFrame(tad_boundary, keep.extra.columns = TRUE)

# Find overlaps between all TAD boundaries and RAD21 bigwig data
overlaps <- findOverlaps(tad_ranges, bw.RAD21)

# Extract overlapping regions and scores from the BigWig
overlapping_bw <- bw.RAD21[subjectHits(overlaps)]
overlapping_tads <- tad_ranges[queryHits(overlaps)]

# Aggregate scores by TAD boundary regions


scores <- as_tibble(overlapping_bw) %>%
  dplyr::mutate(tad_id = tad_ranges[queryHits(overlaps)]$tad_id) %>%
  group_by(tad_id) %>%
  summarise(rad21Score = sum(score))

tad_boundary <- tad_boundary %>%
  left_join(scores, by = \tad_id\)





# Importing gene
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, V5, V1, TSS)
colnames(gene.TSS.tb) <- c(\ensembl\, \gene\, \chr\, \TSS\)


# Find nearest TAD boundary
findClosestTADBoundaryID <- function(chrom, TSS, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom) %>%
    dplyr::mutate(distance = abs(center - TSS)) %>%
    slice_min(distance)
  if(nrow(temp) == 1){
      return(temp$tad_id)
  }else{
    return(NA)
  }
}
gene.TSS.tb <- gene.TSS.tb %>% rowwise() %>%
  dplyr::mutate(closestBoundary = findClosestTADBoundaryID(chr, TSS, tad_boundary))

temp <- tad_boundary %>% dplyr::select(tad_id, rad21Score)

gene.TSS.tb <- gene.TSS.tb %>% left_join(temp, by = c(\closestBoundary\ = \tad_id\) )

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### A485 - Plotting for groups

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XCIpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcIikpJGdlbmVcbmdyb3VwNSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlwiKSkkZ2VuZVxuZ3JvdXA4IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XCIpKSRnZW5lXG5cblxuZ2VuZS5UU1MudGIucGxvdCA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAxLCBcImdyb3VwMVwiLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMiwgXCJncm91cDJcIixcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA1LCBcImdyb3VwNVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA4LCBcImdyb3VwOFwiLCBOQSkpKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbiMjIFBsb3QgZGlzdGFuY2VcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJHJhZDIxU2NvcmVcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRyYWQyMVNjb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfcmFkMjFTY29yZUF0Qm91bmRhcnkgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwiZ3JvdXAxXCIsIFwiZ3JvdXAyXCIpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMVwiLCBcImdyb3VwNVwiKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJncm91cDFcIiwgXCJncm91cDhcIiksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwiZ3JvdXAyXCIsIFwiZ3JvdXA1XCIpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMlwiLCBcImdyb3VwOFwiKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJncm91cDVcIiwgXCJncm91cDhcIiksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gcmFkMjFTY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFwicmVkXCIsIGNvbG9yID0gXCJibGFja1wiKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgXG4gICAgYW5ub3RhdGUoXCJ0ZXh0XCIsIHggPSAxLCB5ID0gMjAgKyAxLCBsYWJlbCA9IHBhc3RlMChcInAxMjogXCIsIGNvbnZQdmFsdWUocDEyKSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDE1OiBcIiwgY29udlB2YWx1ZShwMTUpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMTg6IFwiLCBjb252UHZhbHVlKHAxOCksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAyNTogXCIsIGNvbnZQdmFsdWUocDI1KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDI4OiBcIiwgY29udlB2YWx1ZShwMjgpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwNTg6IFwiLGNvbnZQdmFsdWUoIHA1OCksIFwiXFxuXCIpLFxuICAgICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcInJhZDIxU2NvcmVfXCIsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cblxucGxvdF9yYWQyMVNjb3JlQXRCb3VuZGFyeShnZW5lLlRTUy50Yi5wbG90LCBcImdyb3VwXCIpXG5cblxuYGBgIn0= -->\n\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\))$gene\n\n\ngene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\,\n                        ifelse(ensembl %in% group5, \\group5\\,\n                               ifelse(ensembl %in% group8, \\group8\\, NA))))) %>% \n  dplyr::filter(!is.na(group))\n\n\n## Plot distance\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$rad21Score\n  distance2 <- (data %>% dplyr::filter(group == group2) )$rad21Score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_rad21ScoreAtBoundary <- function(temp.tb, note){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = rad21Score)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + \n    annotate(\\text\\, x = 1, y = 20 + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p15: \\, convPvalue(p15), \\\\n\\,\n                                                         \\p18: \\, convPvalue(p18), \\\\n\\,\n                                                         \\p25: \\, convPvalue(p25), \\\\n\\,\n                                                         \\p28: \\, convPvalue(p28), \\\\n\\,\n                                                         \\p58: \\,convPvalue( p58), \\\\n\\),\n             color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\rad21Score_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\nplot_rad21ScoreAtBoundary(gene.TSS.tb.plot, \\group\\)\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\,
                        ifelse(ensembl %in% group5, \group5\,
                               ifelse(ensembl %in% group8, \group8\, NA))))) %>% 
  dplyr::filter(!is.na(group))


## Plot distance
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$rad21Score
  distance2 <- (data %>% dplyr::filter(group == group2) )$rad21Score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_rad21ScoreAtBoundary <- function(temp.tb, note){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = rad21Score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + 
    annotate(\text\, x = 1, y = 20 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\rad21Score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

plot_rad21ScoreAtBoundary(gene.TSS.tb.plot, \group\)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcXCkpJGdlbmVcbmdyb3VwNSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlxcKSkkZ2VuZVxuZ3JvdXA4IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XFwpKSRnZW5lXG5cblxuZ2VuZS5UU1MudGIucGxvdCA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAxLCBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMiwgXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA1LCBcXGdyb3VwNVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA4LCBcXGdyb3VwOFxcLCBOQSkpKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbiMjIFBsb3QgZGlzdGFuY2VcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJHJhZDIxU2NvcmVcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRyYWQyMVNjb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfcmFkMjFTY29yZUF0Qm91bmRhcnkgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gcmFkMjFTY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMjAgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE1OiBcXCwgY29udlB2YWx1ZShwMTUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTg6IFxcLCBjb252UHZhbHVlKHAxOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyNTogXFwsIGNvbnZQdmFsdWUocDI1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI4OiBcXCwgY29udlB2YWx1ZShwMjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwNTg6IFxcLGNvbnZQdmFsdWUoIHA1OCksIFxcXFxuXFwpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXHJhZDIxU2NvcmVfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cblxucGxvdF9yYWQyMVNjb3JlQXRCb3VuZGFyeShnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwXFwpXG5cblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\))$gene\n\n\ngene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\,\n                        ifelse(ensembl %in% group5, \\group5\\,\n                               ifelse(ensembl %in% group8, \\group8\\, NA))))) %>% \n  dplyr::filter(!is.na(group))\n\n\n## Plot distance\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$rad21Score\n  distance2 <- (data %>% dplyr::filter(group == group2) )$rad21Score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_rad21ScoreAtBoundary <- function(temp.tb, note){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = rad21Score)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() + \n    annotate(\\text\\, x = 1, y = 20 + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p15: \\, convPvalue(p15), \\\\n\\,\n                                                         \\p18: \\, convPvalue(p18), \\\\n\\,\n                                                         \\p25: \\, convPvalue(p25), \\\\n\\,\n                                                         \\p28: \\, convPvalue(p28), \\\\n\\,\n                                                         \\p58: \\,convPvalue( p58), \\\\n\\),\n             color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\rad21Score_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\nplot_rad21ScoreAtBoundary(gene.TSS.tb.plot, \\group\\)\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcXCkpJGdlbmVcbmdyb3VwNSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlxcKSkkZ2VuZVxuZ3JvdXA4IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XFwpKSRnZW5lXG5cblxuZ2VuZS5UU1MudGIucGxvdCA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAxLCBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMiwgXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA1LCBcXGdyb3VwNVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA4LCBcXGdyb3VwOFxcLCBOQSkpKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbiMjIFBsb3QgZGlzdGFuY2VcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJHJhZDIxU2NvcmVcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRyYWQyMVNjb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfcmFkMjFTY29yZUF0Qm91bmRhcnkgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gcmFkMjFTY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gMjAgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE1OiBcXCwgY29udlB2YWx1ZShwMTUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTg6IFxcLCBjb252UHZhbHVlKHAxOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyNTogXFwsIGNvbnZQdmFsdWUocDI1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI4OiBcXCwgY29udlB2YWx1ZShwMjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwNTg6IFxcLGNvbnZQdmFsdWUoIHA1OCksIFxcXFxuXFwpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXHJhZDIxU2NvcmVfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cblxucGxvdF9yYWQyMVNjb3JlQXRCb3VuZGFyeShnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwXFwpXG5cblxuYGBgXG5gYGAifQ== -->

```r
```r
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\,
                        ifelse(ensembl %in% group5, \group5\,
                               ifelse(ensembl %in% group8, \group8\, NA))))) %>% 
  dplyr::filter(!is.na(group))


## Plot distance
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$rad21Score
  distance2 <- (data %>% dplyr::filter(group == group2) )$rad21Score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_rad21ScoreAtBoundary <- function(temp.tb, note){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = rad21Score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + 
    annotate(\text\, x = 1, y = 20 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\rad21Score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

plot_rad21ScoreAtBoundary(gene.TSS.tb.plot, \group\)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


## [2.16] Checking the intensity of RAD21 at TAD boundary
#### Calculating RAD21 intensity of the nearest TAD boundary

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSUVsTlVFOVNWRWxPUnlCU1JWRlZTVkpGUkNCRVFWUkJYRzRqSUVsdGNHOXlkR2x1WnlCVVFVUmNiblJoWkNBOExTQm1jbVZoWkNob1pYSmxLRndpTGk0dkxpNHZjbVZ6ZFd4MEwxUkJSRndpTENCY0lsUkJSRjh5Tld0aVh6RXlOV3RpWDI5MGMzVmZSekZFVFZOUExtSmxaSEJsWENJcEtWeHVZMjlzYm1GdFpYTW9kR0ZrS1NBOExTQmpLRndpWTJoeU1Wd2lMQ0JjSW5OMFlYSjBNVndpTENCY0ltVnVaREZjSWl3Z1hDSmphSEl5WENJc0lGd2ljM1JoY25ReVhDSXNJRndpWlc1a01sd2lLVnh1ZEdGa0lEd3RJSFJoWkNBbFBpVWdaSEJzZVhJNk9tMTFkR0YwWlNoMFlXUkpSQ0E5SUhCaGMzUmxLR05vY2pFc0lITjBZWEowTVN3Z1pXNWtNU3dnYzJWd0lEMGdYQ0pmWENJcEtWeHVYRzVjYmlNZ1NXMXdiM0owYVc1bklHZGxibVZjYm1kbGJtVXVWRk5UTG5SaUlEd3RJR1p5WldGa0tHaGxjbVVvY21WbVJHbHlMQ0JjSW0xdE1UQmZSMUpEYlRNNExuQTJYMmRsYm1WZmMyOXlkR1ZrTG1KbFpGd2lLU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHRkWFJoZEdVb1ZGTlRJRDBnYVdabGJITmxLRlkwSUQwOUlGd2lLMXdpTENCV01pd2dWak1wS1NBbFBpVmNiaUFnWkhCc2VYSTZPbk5sYkdWamRDaFdOaXdnVmpVc0lGWXhMQ0JVVTFNcFhHNWpiMnh1WVcxbGN5aG5aVzVsTGxSVFV5NTBZaWtnUEMwZ1l5aGNJbVZ1YzJWdFlteGNJaXdnWENKblpXNWxYQ0lzSUZ3aVkyaHlYQ0lzSUZ3aVZGTlRYQ0lwWEc1Y2JpTWdTVzF3YjNKMGFXNW5JR1Z1YUdGdVkyVnlYRzV3WldGckxrZ3pTekkzWVdNZ1BDMGdZWE5mZEdsaVlteGxLR2x0Y0c5eWRGQmxZV3NvYUdWeVpTaHlaV1pFYVhJc0lGd2lSMU5OTWpRek9EUTNObDlGUXkxRVJ5MHpORFU0TFVnelN6STNRVU5mUVZOWlRsOHhMbTVoY25KdmQxQmxZV3N1WW1Wa1hDSXBLU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHRkWFJoZEdVb1kyVnVkR1Z5SUQwZ0tITjBZWEowSUNzZ1pXNWtLUzh5S1Z4dVhHNWNiaU1qSXlCR1ZVNURWRWxQVGlCR1QxSWdRMDlWVGxSSlRrZGNibVpwYm1SSmRITlVRVVFnUEMwZ1puVnVZM1JwYjI0b1kyaHliMjBzSUdOdmIzSmthVzVoZEdVc0lIUmhaQ2w3WEc0Z0lIUmxiWEFnUEMwZ2RHRmtJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLR05vY2pFZ1BUMGdZMmh5YjIwc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUhOMFlYSjBNU0E4SUdOdmIzSmthVzVoZEdVc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdWdVpERWdQaUJqYjI5eVpHbHVZWFJsS1Z4dUlDQnBaaWh1Y205M0tIUmxiWEFwSUQwOUlERXBlMXh1SUNBZ0lISmxkSFZ5YmloMFpXMXdKSFJoWkVsRUtWeHVJQ0I5Wld4elpYdGNiaUFnSUNCeVpYUjFjbTRvVGtFcFhHNGdJSDFjYm4xY2JseHVJeU1qSUVOdmRXNTBhVzVuSUdWaFkyZ2dabVZoZEhWeVpYTWdabTl5SUZSQlJGeHVJeU1qSUVOdmRXNTBhVzVuSUdkbGJtVmNibWRsYm1WRGIzVnVkRkJsY2xSQlJDQThMU0JuWlc1bExsUlRVeTUwWWlBbFBpVWdjbTkzZDJselpTZ3BJQ1UrSlZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0ZSQlJDQTlJR1pwYm1SSmRITlVRVVFvWTJoeUxDQlVVMU1zSUhSaFpDa3BJQ1UrSlZ4dUlDQmtjbTl3WDI1aEtDa2dKVDRsWEc0Z0lHZHliM1Z3WDJKNUtGUkJSQ2tnSlQ0bFhHNGdJSE4xYlcxaGNtbDZaU2hqYjNWdWRDQTlJRzRvS1NsY2JseHVJeU1qSUVOdmRXNTBhVzVuSUdWdWFHRnVZMlZ5WEc1Y2JtVnVhRU52ZFc1MFVHVnlWRUZFSUR3dElIQmxZV3N1U0ROTE1qZGhZeUFsUGlVZ2NtOTNkMmx6WlNncElDVStKVnh1SUNCa2NHeDVjam82YlhWMFlYUmxLRlJCUkNBOUlHWnBibVJKZEhOVVFVUW9jMlZ4Ym1GdFpYTXNJR05sYm5SbGNpd2dkR0ZrS1NrZ0pUNGxYRzRnSUdSeWIzQmZibUVvS1NBbFBpVmNiaUFnWjNKdmRYQmZZbmtvVkVGRUtTQWxQaVZjYmlBZ2MzVnRiV0Z5YVhwbEtHTnZkVzUwSUQwZ2JpZ3BLVnh1WEc0akl5TWdSMlYwSUZSQlJDQnphWHBsZWx4dWRHRmtMbVJpSUR3dElIUmhaQ0FsUGlVZ2JHVm1kRjlxYjJsdUtHZGxibVZEYjNWdWRGQmxjbFJCUkN3Z1lua2dQU0JqS0Z3aWRHRmtTVVJjSWlBOUlGd2lWRUZFWENJcExDQXBJQ1UrSlZ4dUlDQnNaV1owWDJwdmFXNG9aVzVvUTI5MWJuUlFaWEpVUVVRc0lHSjVJRDBnWXloY0luUmhaRWxFWENJZ1BTQmNJbFJCUkZ3aUtTa2dKVDRsWEc0Z0lHUndiSGx5T2pwelpXeGxZM1FvWXlneExDQXlMQ0F6TENBM0xDQTRMQ0E1S1NrZ0pUNGxYRzRnSUcxMWRHRjBaVjloYkd3b2ZuSmxjR3hoWTJVb0xpd2dhWE11Ym1Fb0xpa3NJREFwS1Z4dVhHNWpiMnh1WVcxbGN5aDBZV1F1WkdJcElEd3RJR01vWENKamFISmNJaXdnWENKemRHRnlkRndpTENCY0ltVnVaRndpTENCY0luUmhaRWxFWENJc0lGd2laMlZ1WlVOdmRXNTBYQ0lzSUZ3aVpXNW9RMjkxYm5SY0lpbGNibHh1ZEdGa0xtUmlJRHd0SUhSaFpDNWtZaUFsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hjYmlBZ2RHRmtVMmw2WlNBOUlHVnVaQ0F0SUhOMFlYSjBMRnh1SUNCblpXNWxSR1Z1YzJsMGVTQTlJR2RsYm1WRGIzVnVkQzkwWVdSVGFYcGxJQ29nTVRBd1pUTXNYRzRnSUdWdWFFUmxibk5wZEhrZ1BTQmxibWhEYjNWdWRDOTBZV1JUYVhwbEtpQXhNREJsTXl4Y2JpQWdjbVZuUkdWdWMybDBlU0E5SUNoblpXNWxRMjkxYm5RZ0t5QmxibWhEYjNWdWRDa3ZkR0ZrVTJsNlpTb2dNVEF3WlROY2JpbGNibHh1WEc1Y2JpTWpJeUJCYzNOcFoyNGdWRUZFSUdGdVpDQnBibVp2Y20xaGRHbHZiaUIwYnlCblpXNWxYRzVuWlc1bExsUlRVeTUwWWlBOExTQm5aVzVsTGxSVFV5NTBZaUFsUGlVZ2NtOTNkMmx6WlNncElDVStKVnh1SUNCa2NHeDVjam82YlhWMFlYUmxLRlJCUkNBOUlHWnBibVJKZEhOVVFVUW9ZMmh5TENCVVUxTXNJSFJoWkNrcFhHNGpaMlZ1WlM1VVUxTXVkR0lnUEMwZ1oyVnVaUzVVVTFNdWRHSWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9JV2x6TG01aEtGUkJSQ2twWEc1MFpXMXdJRHd0SUhSaFpDNWtZaUFsUGlVZ1pIQnNlWEk2T25ObGJHVmpkQ2d0WXlneExDQXlMQ0F6S1NsY2JseHVaMlZ1WlM1VVUxTXVkR0lnUEMwZ1oyVnVaUzVVVTFNdWRHSWdKVDRsSUdSd2JIbHlPanBzWldaMFgycHZhVzRvZEdWdGNDd2dZbmtnUFNCaktGd2lWRUZFWENJZ1BTQmNJblJoWkVsRVhDSXBLVnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbiMjIyBJTVBPUlRJTkcgUkVRVUlSRUQgREFUQVxuIyBJbXBvcnRpbmcgVEFEXG50YWQgPC0gZnJlYWQoaGVyZShcXC4uLy4uL3Jlc3VsdC9UQURcXCwgXFxUQURfMjVrYl8xMjVrYl9vdHN1X0cxRE1TTy5iZWRwZVxcKSlcbmNvbG5hbWVzKHRhZCkgPC0gYyhcXGNocjFcXCwgXFxzdGFydDFcXCwgXFxlbmQxXFwsIFxcY2hyMlxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXClcbnRhZCA8LSB0YWQgJT4lIGRwbHlyOjptdXRhdGUodGFkSUQgPSBwYXN0ZShjaHIxLCBzdGFydDEsIGVuZDEsIHNlcCA9IFxcX1xcKSlcblxuXG4jIEltcG9ydGluZyBnZW5lXG5nZW5lLlRTUy50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjYsIFY1LCBWMSwgVFNTKVxuY29sbmFtZXMoZ2VuZS5UU1MudGIpIDwtIGMoXFxlbnNlbWJsXFwsIFxcZ2VuZVxcLCBcXGNoclxcLCBcXFRTU1xcKVxuXG4jIEltcG9ydGluZyBlbmhhbmNlclxucGVhay5IM0syN2FjIDwtIGFzX3RpYmJsZShpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXEdTTTI0Mzg0NzZfRUMtREctMzQ1OC1IM0syN0FDX0FTWU5fMS5uYXJyb3dQZWFrLmJlZFxcKSkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGNlbnRlciA9IChzdGFydCArIGVuZCkvMilcblxuXG4jIyMgRlVOQ1RJT04gRk9SIENPVU5USU5HXG5maW5kSXRzVEFEIDwtIGZ1bmN0aW9uKGNocm9tLCBjb29yZGluYXRlLCB0YWQpe1xuICB0ZW1wIDwtIHRhZCAlPiUgZHBseXI6OmZpbHRlcihjaHIxID09IGNocm9tLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdGFydDEgPCBjb29yZGluYXRlLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmQxID4gY29vcmRpbmF0ZSlcbiAgaWYobnJvdyh0ZW1wKSA9PSAxKXtcbiAgICByZXR1cm4odGVtcCR0YWRJRClcbiAgfWVsc2V7XG4gICAgcmV0dXJuKE5BKVxuICB9XG59XG5cbiMjIyBDb3VudGluZyBlYWNoIGZlYXR1cmVzIGZvciBUQURcbiMjIyBDb3VudGluZyBnZW5lXG5nZW5lQ291bnRQZXJUQUQgPC0gZ2VuZS5UU1MudGIgJT4lIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUQUQgPSBmaW5kSXRzVEFEKGNociwgVFNTLCB0YWQpKSAlPiVcbiAgZHJvcF9uYSgpICU+JVxuICBncm91cF9ieShUQUQpICU+JVxuICBzdW1tYXJpemUoY291bnQgPSBuKCkpXG5cbiMjIyBDb3VudGluZyBlbmhhbmNlclxuXG5lbmhDb3VudFBlclRBRCA8LSBwZWFrLkgzSzI3YWMgJT4lIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUQUQgPSBmaW5kSXRzVEFEKHNlcW5hbWVzLCBjZW50ZXIsIHRhZCkpICU+JVxuICBkcm9wX25hKCkgJT4lXG4gIGdyb3VwX2J5KFRBRCkgJT4lXG4gIHN1bW1hcml6ZShjb3VudCA9IG4oKSlcblxuIyMjIEdldCBUQUQgc2l6ZXpcbnRhZC5kYiA8LSB0YWQgJT4lIGxlZnRfam9pbihnZW5lQ291bnRQZXJUQUQsIGJ5ID0gYyhcXHRhZElEXFwgPSBcXFRBRFxcKSwgKSAlPiVcbiAgbGVmdF9qb2luKGVuaENvdW50UGVyVEFELCBieSA9IGMoXFx0YWRJRFxcID0gXFxUQURcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGMoMSwgMiwgMywgNywgOCwgOSkpICU+JVxuICBtdXRhdGVfYWxsKH5yZXBsYWNlKC4sIGlzLm5hKC4pLCAwKSlcblxuY29sbmFtZXModGFkLmRiKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFx0YWRJRFxcLCBcXGdlbmVDb3VudFxcLCBcXGVuaENvdW50XFwpXG5cbnRhZC5kYiA8LSB0YWQuZGIgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHRhZFNpemUgPSBlbmQgLSBzdGFydCxcbiAgZ2VuZURlbnNpdHkgPSBnZW5lQ291bnQvdGFkU2l6ZSAqIDEwMGUzLFxuICBlbmhEZW5zaXR5ID0gZW5oQ291bnQvdGFkU2l6ZSogMTAwZTMsXG4gIHJlZ0RlbnNpdHkgPSAoZ2VuZUNvdW50ICsgZW5oQ291bnQpL3RhZFNpemUqIDEwMGUzXG4pXG5cblxuXG4jIyMgQXNzaWduIFRBRCBhbmQgaW5mb3JtYXRpb24gdG8gZ2VuZVxuZ2VuZS5UU1MudGIgPC0gZ2VuZS5UU1MudGIgJT4lIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUQUQgPSBmaW5kSXRzVEFEKGNociwgVFNTLCB0YWQpKVxuI2dlbmUuVFNTLnRiIDwtIGdlbmUuVFNTLnRiICU+JSBkcGx5cjo6ZmlsdGVyKCFpcy5uYShUQUQpKVxudGVtcCA8LSB0YWQuZGIgJT4lIGRwbHlyOjpzZWxlY3QoLWMoMSwgMiwgMykpXG5cbmdlbmUuVFNTLnRiIDwtIGdlbmUuVFNTLnRiICU+JSBkcGx5cjo6bGVmdF9qb2luKHRlbXAsIGJ5ID0gYyhcXFRBRFxcID0gXFx0YWRJRFxcKSlcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
### IMPORTING REQUIRED DATA
# Importing TAD
tad <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_G1DMSO.bedpe\))
colnames(tad) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\)
tad <- tad %>% dplyr::mutate(tadID = paste(chr1, start1, end1, sep = \_\))


# Importing gene
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, V5, V1, TSS)
colnames(gene.TSS.tb) <- c(\ensembl\, \gene\, \chr\, \TSS\)

# Importing enhancer
peak.H3K27ac <- as_tibble(importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))) %>%
  dplyr::mutate(center = (start + end)/2)


### FUNCTION FOR COUNTING
findItsTAD <- function(chrom, coordinate, tad){
  temp <- tad %>% dplyr::filter(chr1 == chrom,
                                         start1 < coordinate,
                                         end1 > coordinate)
  if(nrow(temp) == 1){
    return(temp$tadID)
  }else{
    return(NA)
  }
}

### Counting each features for TAD
### Counting gene
geneCountPerTAD <- gene.TSS.tb %>% rowwise() %>%
  dplyr::mutate(TAD = findItsTAD(chr, TSS, tad)) %>%
  drop_na() %>%
  group_by(TAD) %>%
  summarize(count = n())

### Counting enhancer

enhCountPerTAD <- peak.H3K27ac %>% rowwise() %>%
  dplyr::mutate(TAD = findItsTAD(seqnames, center, tad)) %>%
  drop_na() %>%
  group_by(TAD) %>%
  summarize(count = n())

### Get TAD sizez
tad.db <- tad %>% left_join(geneCountPerTAD, by = c(\tadID\ = \TAD\), ) %>%
  left_join(enhCountPerTAD, by = c(\tadID\ = \TAD\)) %>%
  dplyr::select(c(1, 2, 3, 7, 8, 9)) %>%
  mutate_all(~replace(., is.na(.), 0))

colnames(tad.db) <- c(\chr\, \start\, \end\, \tadID\, \geneCount\, \enhCount\)

tad.db <- tad.db %>% dplyr::mutate(
  tadSize = end - start,
  geneDensity = geneCount/tadSize * 100e3,
  enhDensity = enhCount/tadSize* 100e3,
  regDensity = (geneCount + enhCount)/tadSize* 100e3
)



### Assign TAD and information to gene
gene.TSS.tb <- gene.TSS.tb %>% rowwise() %>%
  dplyr::mutate(TAD = findItsTAD(chr, TSS, tad))
#gene.TSS.tb <- gene.TSS.tb %>% dplyr::filter(!is.na(TAD))
temp <- tad.db %>% dplyr::select(-c(1, 2, 3))

gene.TSS.tb <- gene.TSS.tb %>% dplyr::left_join(temp, by = c(\TAD\ = \tadID\))



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJRWxOVUU5U1ZFbE9SeUJTUlZGVlNWSkZSQ0JFUVZSQlhHNGpJRWx0Y0c5eWRHbHVaeUJVUVVSY2JuUmhaQ0E4TFNCbWNtVmhaQ2hvWlhKbEtGeGNMaTR2TGk0dmNtVnpkV3gwTDFSQlJGeGNMQ0JjWEZSQlJGOHlOV3RpWHpFeU5XdGlYMjkwYzNWZlJ6RkVUVk5QTG1KbFpIQmxYRndwS1Z4dVkyOXNibUZ0WlhNb2RHRmtLU0E4TFNCaktGeGNZMmh5TVZ4Y0xDQmNYSE4wWVhKME1WeGNMQ0JjWEdWdVpERmNYQ3dnWEZ4amFISXlYRndzSUZ4Y2MzUmhjblF5WEZ3c0lGeGNaVzVrTWx4Y0tWeHVkR0ZrSUR3dElIUmhaQ0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2gwWVdSSlJDQTlJSEJoYzNSbEtHTm9jakVzSUhOMFlYSjBNU3dnWlc1a01Td2djMlZ3SUQwZ1hGeGZYRndwS1Z4dVhHNWNiaU1nU1cxd2IzSjBhVzVuSUdkbGJtVmNibWRsYm1VdVZGTlRMblJpSUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNYRzF0TVRCZlIxSkRiVE00TG5BMlgyZGxibVZmYzI5eWRHVmtMbUpsWkZ4Y0tTa2dKVDRsWEc0Z0lHUndiSGx5T2pwdGRYUmhkR1VvVkZOVElEMGdhV1psYkhObEtGWTBJRDA5SUZ4Y0sxeGNMQ0JXTWl3Z1ZqTXBLU0FsUGlWY2JpQWdaSEJzZVhJNk9uTmxiR1ZqZENoV05pd2dWalVzSUZZeExDQlVVMU1wWEc1amIyeHVZVzFsY3loblpXNWxMbFJUVXk1MFlpa2dQQzBnWXloY1hHVnVjMlZ0WW14Y1hDd2dYRnhuWlc1bFhGd3NJRnhjWTJoeVhGd3NJRnhjVkZOVFhGd3BYRzVjYmlNZ1NXMXdiM0owYVc1bklHVnVhR0Z1WTJWeVhHNXdaV0ZyTGtnelN6STNZV01nUEMwZ1lYTmZkR2xpWW14bEtHbHRjRzl5ZEZCbFlXc29hR1Z5WlNoeVpXWkVhWElzSUZ4Y1IxTk5NalF6T0RRM05sOUZReTFFUnkwek5EVTRMVWd6U3pJM1FVTmZRVk5aVGw4eExtNWhjbkp2ZDFCbFlXc3VZbVZrWEZ3cEtTa2dKVDRsWEc0Z0lHUndiSGx5T2pwdGRYUmhkR1VvWTJWdWRHVnlJRDBnS0hOMFlYSjBJQ3NnWlc1a0tTOHlLVnh1WEc1Y2JpTWpJeUJHVlU1RFZFbFBUaUJHVDFJZ1EwOVZUbFJKVGtkY2JtWnBibVJKZEhOVVFVUWdQQzBnWm5WdVkzUnBiMjRvWTJoeWIyMHNJR052YjNKa2FXNWhkR1VzSUhSaFpDbDdYRzRnSUhSbGJYQWdQQzBnZEdGa0lDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHTm9jakVnUFQwZ1kyaHliMjBzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJSE4wWVhKME1TQThJR052YjNKa2FXNWhkR1VzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR1Z1WkRFZ1BpQmpiMjl5WkdsdVlYUmxLVnh1SUNCcFppaHVjbTkzS0hSbGJYQXBJRDA5SURFcGUxeHVJQ0FnSUhKbGRIVnliaWgwWlcxd0pIUmhaRWxFS1Z4dUlDQjlaV3h6Wlh0Y2JpQWdJQ0J5WlhSMWNtNG9Ua0VwWEc0Z0lIMWNibjFjYmx4dUl5TWpJRU52ZFc1MGFXNW5JR1ZoWTJnZ1ptVmhkSFZ5WlhNZ1ptOXlJRlJCUkZ4dUl5TWpJRU52ZFc1MGFXNW5JR2RsYm1WY2JtZGxibVZEYjNWdWRGQmxjbFJCUkNBOExTQm5aVzVsTGxSVFV5NTBZaUFsUGlVZ2NtOTNkMmx6WlNncElDVStKVnh1SUNCa2NHeDVjam82YlhWMFlYUmxLRlJCUkNBOUlHWnBibVJKZEhOVVFVUW9ZMmh5TENCVVUxTXNJSFJoWkNrcElDVStKVnh1SUNCa2NtOXdYMjVoS0NrZ0pUNGxYRzRnSUdkeWIzVndYMko1S0ZSQlJDa2dKVDRsWEc0Z0lITjFiVzFoY21sNlpTaGpiM1Z1ZENBOUlHNG9LU2xjYmx4dUl5TWpJRU52ZFc1MGFXNW5JR1Z1YUdGdVkyVnlYRzVjYm1WdWFFTnZkVzUwVUdWeVZFRkVJRHd0SUhCbFlXc3VTRE5MTWpkaFl5QWxQaVVnY205M2QybHpaU2dwSUNVK0pWeHVJQ0JrY0d4NWNqbzZiWFYwWVhSbEtGUkJSQ0E5SUdacGJtUkpkSE5VUVVRb2MyVnhibUZ0WlhNc0lHTmxiblJsY2l3Z2RHRmtLU2tnSlQ0bFhHNGdJR1J5YjNCZmJtRW9LU0FsUGlWY2JpQWdaM0p2ZFhCZllua29WRUZFS1NBbFBpVmNiaUFnYzNWdGJXRnlhWHBsS0dOdmRXNTBJRDBnYmlncEtWeHVYRzRqSXlNZ1IyVjBJRlJCUkNCemFYcGxlbHh1ZEdGa0xtUmlJRHd0SUhSaFpDQWxQaVVnYkdWbWRGOXFiMmx1S0dkbGJtVkRiM1Z1ZEZCbGNsUkJSQ3dnWW5rZ1BTQmpLRnhjZEdGa1NVUmNYQ0E5SUZ4Y1ZFRkVYRndwTENBcElDVStKVnh1SUNCc1pXWjBYMnB2YVc0b1pXNW9RMjkxYm5SUVpYSlVRVVFzSUdKNUlEMGdZeWhjWEhSaFpFbEVYRndnUFNCY1hGUkJSRnhjS1NrZ0pUNGxYRzRnSUdSd2JIbHlPanB6Wld4bFkzUW9ZeWd4TENBeUxDQXpMQ0EzTENBNExDQTVLU2tnSlQ0bFhHNGdJRzExZEdGMFpWOWhiR3dvZm5KbGNHeGhZMlVvTGl3Z2FYTXVibUVvTGlrc0lEQXBLVnh1WEc1amIyeHVZVzFsY3loMFlXUXVaR0lwSUR3dElHTW9YRnhqYUhKY1hDd2dYRnh6ZEdGeWRGeGNMQ0JjWEdWdVpGeGNMQ0JjWEhSaFpFbEVYRndzSUZ4Y1oyVnVaVU52ZFc1MFhGd3NJRnhjWlc1b1EyOTFiblJjWENsY2JseHVkR0ZrTG1SaUlEd3RJSFJoWkM1a1lpQWxQaVVnWkhCc2VYSTZPbTExZEdGMFpTaGNiaUFnZEdGa1UybDZaU0E5SUdWdVpDQXRJSE4wWVhKMExGeHVJQ0JuWlc1bFJHVnVjMmwwZVNBOUlHZGxibVZEYjNWdWRDOTBZV1JUYVhwbElDb2dNVEF3WlRNc1hHNGdJR1Z1YUVSbGJuTnBkSGtnUFNCbGJtaERiM1Z1ZEM5MFlXUlRhWHBsS2lBeE1EQmxNeXhjYmlBZ2NtVm5SR1Z1YzJsMGVTQTlJQ2huWlc1bFEyOTFiblFnS3lCbGJtaERiM1Z1ZENrdmRHRmtVMmw2WlNvZ01UQXdaVE5jYmlsY2JseHVYRzVjYmlNakl5QkJjM05wWjI0Z1ZFRkVJR0Z1WkNCcGJtWnZjbTFoZEdsdmJpQjBieUJuWlc1bFhHNW5aVzVsTGxSVFV5NTBZaUE4TFNCblpXNWxMbFJUVXk1MFlpQWxQaVVnY205M2QybHpaU2dwSUNVK0pWeHVJQ0JrY0d4NWNqbzZiWFYwWVhSbEtGUkJSQ0E5SUdacGJtUkpkSE5VUVVRb1kyaHlMQ0JVVTFNc0lIUmhaQ2twWEc0aloyVnVaUzVVVTFNdWRHSWdQQzBnWjJWdVpTNVVVMU11ZEdJZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb0lXbHpMbTVoS0ZSQlJDa3BYRzUwWlcxd0lEd3RJSFJoWkM1a1lpQWxQaVVnWkhCc2VYSTZPbk5sYkdWamRDZ3RZeWd4TENBeUxDQXpLU2xjYmx4dVoyVnVaUzVVVTFNdWRHSWdQQzBnWjJWdVpTNVVVMU11ZEdJZ0pUNGxJR1J3YkhseU9qcHNaV1owWDJwdmFXNG9kR1Z0Y0N3Z1lua2dQU0JqS0Z4Y1ZFRkVYRndnUFNCY1hIUmhaRWxFWEZ3cEtWeHVZR0JnWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5gYGByXG4jIyMgSU1QT1JUSU5HIFJFUVVJUkVEIERBVEFcbiMgSW1wb3J0aW5nIFRBRFxudGFkIDwtIGZyZWFkKGhlcmUoXFwuLi8uLi9yZXN1bHQvVEFEXFwsIFxcVEFEXzI1a2JfMTI1a2Jfb3RzdV9HMURNU08uYmVkcGVcXCkpXG5jb2xuYW1lcyh0YWQpIDwtIGMoXFxjaHIxXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocjJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwpXG50YWQgPC0gdGFkICU+JSBkcGx5cjo6bXV0YXRlKHRhZElEID0gcGFzdGUoY2hyMSwgc3RhcnQxLCBlbmQxLCBzZXAgPSBcXF9cXCkpXG5cblxuIyBJbXBvcnRpbmcgZ2VuZVxuZ2VuZS5UU1MudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXFwrXFwsIFYyLCBWMykpICU+JVxuICBkcGx5cjo6c2VsZWN0KFY2LCBWNSwgVjEsIFRTUylcbmNvbG5hbWVzKGdlbmUuVFNTLnRiKSA8LSBjKFxcZW5zZW1ibFxcLCBcXGdlbmVcXCwgXFxjaHJcXCwgXFxUU1NcXClcblxuIyBJbXBvcnRpbmcgZW5oYW5jZXJcbnBlYWsuSDNLMjdhYyA8LSBhc190aWJibGUoaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFxHU00yNDM4NDc2X0VDLURHLTM0NTgtSDNLMjdBQ19BU1lOXzEubmFycm93UGVhay5iZWRcXCkpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjZW50ZXIgPSAoc3RhcnQgKyBlbmQpLzIpXG5cblxuIyMjIEZVTkNUSU9OIEZPUiBDT1VOVElOR1xuZmluZEl0c1RBRCA8LSBmdW5jdGlvbihjaHJvbSwgY29vcmRpbmF0ZSwgdGFkKXtcbiAgdGVtcCA8LSB0YWQgJT4lIGRwbHlyOjpmaWx0ZXIoY2hyMSA9PSBjaHJvbSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3RhcnQxIDwgY29vcmRpbmF0ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZW5kMSA+IGNvb3JkaW5hdGUpXG4gIGlmKG5yb3codGVtcCkgPT0gMSl7XG4gICAgcmV0dXJuKHRlbXAkdGFkSUQpXG4gIH1lbHNle1xuICAgIHJldHVybihOQSlcbiAgfVxufVxuXG4jIyMgQ291bnRpbmcgZWFjaCBmZWF0dXJlcyBmb3IgVEFEXG4jIyMgQ291bnRpbmcgZ2VuZVxuZ2VuZUNvdW50UGVyVEFEIDwtIGdlbmUuVFNTLnRiICU+JSByb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVEFEID0gZmluZEl0c1RBRChjaHIsIFRTUywgdGFkKSkgJT4lXG4gIGRyb3BfbmEoKSAlPiVcbiAgZ3JvdXBfYnkoVEFEKSAlPiVcbiAgc3VtbWFyaXplKGNvdW50ID0gbigpKVxuXG4jIyMgQ291bnRpbmcgZW5oYW5jZXJcblxuZW5oQ291bnRQZXJUQUQgPC0gcGVhay5IM0syN2FjICU+JSByb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVEFEID0gZmluZEl0c1RBRChzZXFuYW1lcywgY2VudGVyLCB0YWQpKSAlPiVcbiAgZHJvcF9uYSgpICU+JVxuICBncm91cF9ieShUQUQpICU+JVxuICBzdW1tYXJpemUoY291bnQgPSBuKCkpXG5cbiMjIyBHZXQgVEFEIHNpemV6XG50YWQuZGIgPC0gdGFkICU+JSBsZWZ0X2pvaW4oZ2VuZUNvdW50UGVyVEFELCBieSA9IGMoXFx0YWRJRFxcID0gXFxUQURcXCksICkgJT4lXG4gIGxlZnRfam9pbihlbmhDb3VudFBlclRBRCwgYnkgPSBjKFxcdGFkSURcXCA9IFxcVEFEXFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMsIDcsIDgsIDkpKSAlPiVcbiAgbXV0YXRlX2FsbCh+cmVwbGFjZSguLCBpcy5uYSguKSwgMCkpXG5cbmNvbG5hbWVzKHRhZC5kYikgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcdGFkSURcXCwgXFxnZW5lQ291bnRcXCwgXFxlbmhDb3VudFxcKVxuXG50YWQuZGIgPC0gdGFkLmRiICU+JSBkcGx5cjo6bXV0YXRlKFxuICB0YWRTaXplID0gZW5kIC0gc3RhcnQsXG4gIGdlbmVEZW5zaXR5ID0gZ2VuZUNvdW50L3RhZFNpemUgKiAxMDBlMyxcbiAgZW5oRGVuc2l0eSA9IGVuaENvdW50L3RhZFNpemUqIDEwMGUzLFxuICByZWdEZW5zaXR5ID0gKGdlbmVDb3VudCArIGVuaENvdW50KS90YWRTaXplKiAxMDBlM1xuKVxuXG5cblxuIyMjIEFzc2lnbiBUQUQgYW5kIGluZm9ybWF0aW9uIHRvIGdlbmVcbmdlbmUuVFNTLnRiIDwtIGdlbmUuVFNTLnRiICU+JSByb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVEFEID0gZmluZEl0c1RBRChjaHIsIFRTUywgdGFkKSlcbiNnZW5lLlRTUy50YiA8LSBnZW5lLlRTUy50YiAlPiUgZHBseXI6OmZpbHRlcighaXMubmEoVEFEKSlcbnRlbXAgPC0gdGFkLmRiICU+JSBkcGx5cjo6c2VsZWN0KC1jKDEsIDIsIDMpKVxuXG5nZW5lLlRTUy50YiA8LSBnZW5lLlRTUy50YiAlPiUgZHBseXI6OmxlZnRfam9pbih0ZW1wLCBieSA9IGMoXFxUQURcXCA9IFxcdGFkSURcXCkpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIElNUE9SVElORyBSRVFVSVJFRCBEQVRBXG4jIEltcG9ydGluZyBUQURcbnRhZCA8LSBmcmVhZChoZXJlKFxcLi4vLi4vcmVzdWx0L1RBRFxcLCBcXFRBRF8yNWtiXzEyNWtiX290c3VfRzFETVNPLmJlZHBlXFwpKVxuY29sbmFtZXModGFkKSA8LSBjKFxcY2hyMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHIyXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcKVxudGFkIDwtIHRhZCAlPiUgZHBseXI6Om11dGF0ZSh0YWRJRCA9IHBhc3RlKGNocjEsIHN0YXJ0MSwgZW5kMSwgc2VwID0gXFxfXFwpKVxuXG5cbiMgSW1wb3J0aW5nIGdlbmVcbmdlbmUuVFNTLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWNiwgVjUsIFYxLCBUU1MpXG5jb2xuYW1lcyhnZW5lLlRTUy50YikgPC0gYyhcXGVuc2VtYmxcXCwgXFxnZW5lXFwsIFxcY2hyXFwsIFxcVFNTXFwpXG5cbiMgSW1wb3J0aW5nIGVuaGFuY2VyXG5wZWFrLkgzSzI3YWMgPC0gYXNfdGliYmxlKGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcR1NNMjQzODQ3Nl9FQy1ERy0zNDU4LUgzSzI3QUNfQVNZTl8xLm5hcnJvd1BlYWsuYmVkXFwpKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2VudGVyID0gKHN0YXJ0ICsgZW5kKS8yKVxuXG5cbiMjIyBGVU5DVElPTiBGT1IgQ09VTlRJTkdcbmZpbmRJdHNUQUQgPC0gZnVuY3Rpb24oY2hyb20sIGNvb3JkaW5hdGUsIHRhZCl7XG4gIHRlbXAgPC0gdGFkICU+JSBkcGx5cjo6ZmlsdGVyKGNocjEgPT0gY2hyb20sXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHN0YXJ0MSA8IGNvb3JkaW5hdGUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZDEgPiBjb29yZGluYXRlKVxuICBpZihucm93KHRlbXApID09IDEpe1xuICAgIHJldHVybih0ZW1wJHRhZElEKVxuICB9ZWxzZXtcbiAgICByZXR1cm4oTkEpXG4gIH1cbn1cblxuIyMjIENvdW50aW5nIGVhY2ggZmVhdHVyZXMgZm9yIFRBRFxuIyMjIENvdW50aW5nIGdlbmVcbmdlbmVDb3VudFBlclRBRCA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRBRCA9IGZpbmRJdHNUQUQoY2hyLCBUU1MsIHRhZCkpICU+JVxuICBkcm9wX25hKCkgJT4lXG4gIGdyb3VwX2J5KFRBRCkgJT4lXG4gIHN1bW1hcml6ZShjb3VudCA9IG4oKSlcblxuIyMjIENvdW50aW5nIGVuaGFuY2VyXG5cbmVuaENvdW50UGVyVEFEIDwtIHBlYWsuSDNLMjdhYyAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRBRCA9IGZpbmRJdHNUQUQoc2VxbmFtZXMsIGNlbnRlciwgdGFkKSkgJT4lXG4gIGRyb3BfbmEoKSAlPiVcbiAgZ3JvdXBfYnkoVEFEKSAlPiVcbiAgc3VtbWFyaXplKGNvdW50ID0gbigpKVxuXG4jIyMgR2V0IFRBRCBzaXplelxudGFkLmRiIDwtIHRhZCAlPiUgbGVmdF9qb2luKGdlbmVDb3VudFBlclRBRCwgYnkgPSBjKFxcdGFkSURcXCA9IFxcVEFEXFwpLCApICU+JVxuICBsZWZ0X2pvaW4oZW5oQ291bnRQZXJUQUQsIGJ5ID0gYyhcXHRhZElEXFwgPSBcXFRBRFxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzLCA3LCA4LCA5KSkgJT4lXG4gIG11dGF0ZV9hbGwofnJlcGxhY2UoLiwgaXMubmEoLiksIDApKVxuXG5jb2xuYW1lcyh0YWQuZGIpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXHRhZElEXFwsIFxcZ2VuZUNvdW50XFwsIFxcZW5oQ291bnRcXClcblxudGFkLmRiIDwtIHRhZC5kYiAlPiUgZHBseXI6Om11dGF0ZShcbiAgdGFkU2l6ZSA9IGVuZCAtIHN0YXJ0LFxuICBnZW5lRGVuc2l0eSA9IGdlbmVDb3VudC90YWRTaXplICogMTAwZTMsXG4gIGVuaERlbnNpdHkgPSBlbmhDb3VudC90YWRTaXplKiAxMDBlMyxcbiAgcmVnRGVuc2l0eSA9IChnZW5lQ291bnQgKyBlbmhDb3VudCkvdGFkU2l6ZSogMTAwZTNcbilcblxuXG5cbiMjIyBBc3NpZ24gVEFEIGFuZCBpbmZvcm1hdGlvbiB0byBnZW5lXG5nZW5lLlRTUy50YiA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRBRCA9IGZpbmRJdHNUQUQoY2hyLCBUU1MsIHRhZCkpXG4jZ2VuZS5UU1MudGIgPC0gZ2VuZS5UU1MudGIgJT4lIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKFRBRCkpXG50ZW1wIDwtIHRhZC5kYiAlPiUgZHBseXI6OnNlbGVjdCgtYygxLCAyLCAzKSlcblxuZ2VuZS5UU1MudGIgPC0gZ2VuZS5UU1MudGIgJT4lIGRwbHlyOjpsZWZ0X2pvaW4odGVtcCwgYnkgPSBjKFxcVEFEXFwgPSBcXHRhZElEXFwpKVxuYGBgXG5gYGAifQ== -->

```r
```r
### IMPORTING REQUIRED DATA
# Importing TAD
tad <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_G1DMSO.bedpe\))
colnames(tad) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\)
tad <- tad %>% dplyr::mutate(tadID = paste(chr1, start1, end1, sep = \_\))


# Importing gene
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, V5, V1, TSS)
colnames(gene.TSS.tb) <- c(\ensembl\, \gene\, \chr\, \TSS\)

# Importing enhancer
peak.H3K27ac <- as_tibble(importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))) %>%
  dplyr::mutate(center = (start + end)/2)


### FUNCTION FOR COUNTING
findItsTAD <- function(chrom, coordinate, tad){
  temp <- tad %>% dplyr::filter(chr1 == chrom,
                                         start1 < coordinate,
                                         end1 > coordinate)
  if(nrow(temp) == 1){
    return(temp$tadID)
  }else{
    return(NA)
  }
}

### Counting each features for TAD
### Counting gene
geneCountPerTAD <- gene.TSS.tb %>% rowwise() %>%
  dplyr::mutate(TAD = findItsTAD(chr, TSS, tad)) %>%
  drop_na() %>%
  group_by(TAD) %>%
  summarize(count = n())

### Counting enhancer

enhCountPerTAD <- peak.H3K27ac %>% rowwise() %>%
  dplyr::mutate(TAD = findItsTAD(seqnames, center, tad)) %>%
  drop_na() %>%
  group_by(TAD) %>%
  summarize(count = n())

### Get TAD sizez
tad.db <- tad %>% left_join(geneCountPerTAD, by = c(\tadID\ = \TAD\), ) %>%
  left_join(enhCountPerTAD, by = c(\tadID\ = \TAD\)) %>%
  dplyr::select(c(1, 2, 3, 7, 8, 9)) %>%
  mutate_all(~replace(., is.na(.), 0))

colnames(tad.db) <- c(\chr\, \start\, \end\, \tadID\, \geneCount\, \enhCount\)

tad.db <- tad.db %>% dplyr::mutate(
  tadSize = end - start,
  geneDensity = geneCount/tadSize * 100e3,
  enhDensity = enhCount/tadSize* 100e3,
  regDensity = (geneCount + enhCount)/tadSize* 100e3
)



### Assign TAD and information to gene
gene.TSS.tb <- gene.TSS.tb %>% rowwise() %>%
  dplyr::mutate(TAD = findItsTAD(chr, TSS, tad))
#gene.TSS.tb <- gene.TSS.tb %>% dplyr::filter(!is.na(TAD))
temp <- tad.db %>% dplyr::select(-c(1, 2, 3))

gene.TSS.tb <- gene.TSS.tb %>% dplyr::left_join(temp, by = c(\TAD\ = \tadID\))
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



##### Plotting for groups

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVaM0p2ZFhBeElEd3RJR1p5WldGa0tHaGxjbVVvY21WbVJHbHlMQ0JjSW1kbGJtVk1hWE4wWDJSVVFVZGZkbk5mUkUxVFQxOVNUa0ZmYkc5dmNGOWlhVzVoY25sSGNtOTFjREV1ZEhOMlhDSXBLU1JuWlc1bFhHNW5jbTkxY0RJZ1BDMGdabkpsWVdRb2FHVnlaU2h5WldaRWFYSXNJRndpWjJWdVpVeHBjM1JmWkZSQlIxOTJjMTlFVFZOUFgxSk9RVjlzYjI5d1gySnBibUZ5ZVVkeWIzVndNaTUwYzNaY0lpa3BKR2RsYm1WY2JseHVYRzVuWlc1bExsUlRVeTUwWWk1d2JHOTBJRHd0SUdkbGJtVXVWRk5UTG5SaUlDVStKU0J5YjNkM2FYTmxLQ2tnSlQ0bElHUndiSGx5T2pwdGRYUmhkR1VvWEc0Z0lHZHliM1Z3SUQwZ2FXWmxiSE5sS0dWdWMyVnRZbXdnSldsdUpTQm5jbTkxY0RFc0lGd2laM0p2ZFhBeFhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaGxibk5sYldKc0lDVnBiaVVnWjNKdmRYQXlMQ0JjSW1keWIzVndNbHdpTENCT1FTa3BLU0FsUGlVZ1hHNGdJR1J3YkhseU9qcG1hV3gwWlhJb0lXbHpMbTVoS0dkeWIzVndLU2xjYmx4dVhHNGpJeUJuWlc1bFEyOTFiblJjYm1kbGRGQjJZV3hYYVd4amIzZ2dQQzBnWm5WdVkzUnBiMjRvWkdGMFlTd2daM0p2ZFhBeExDQm5jbTkxY0RJcGUxeHVJQ0JrYVhOMFlXNWpaVEVnUEMwZ0tHUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWjNKdmRYQWdQVDBnWjNKdmRYQXhLU0FwSkdkbGJtVkRiM1Z1ZEZ4dUlDQmthWE4wWVc1alpUSWdQQzBnS0dSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9aM0p2ZFhBZ1BUMGdaM0p2ZFhBeUtTQXBKR2RsYm1WRGIzVnVkRnh1SUNCM2FXd2dQQzBnZDJsc1kyOTRMblJsYzNRb1pHbHpkR0Z1WTJVeExDQmthWE4wWVc1alpUSXBYRzRnSUhKbGRIVnliaWgzYVd3a2NDNTJZV3gxWlNsY2JuMWNibHh1WEc1d2JHOTBYMmRsYm1WRGIzVnVkQ0E4TFNCbWRXNWpkR2x2YmloMFpXMXdMblJpTENCdWIzUmxMQ0I1YldsdUlEMGdNQ3dnZVcxaGVDQTlJREl3TURBd01EQXBlMXh1SUNCd01USWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMblJpTENCY0ltZHliM1Z3TVZ3aUxDQmNJbWR5YjNWd01sd2lLU3dnTlNsY2JpQWdYRzRnSUhBZ1BDMGdaMmR3Ykc5MEtIUmxiWEF1ZEdJc0lHRmxjeWg0SUQwZ1ozSnZkWEFzSUhrZ1BTQm5aVzVsUTI5MWJuUXBLU0FySUdkbGIyMWZkbWx2YkdsdUtHRmxjeWhtYVd4c0lEMGdaM0p2ZFhBcExDQnphRzkzTG14bFoyVnVaQ0E5SUVaQlRGTkZLU0FySUZ4dUlDQWdJR2RsYjIxZlltOTRjR3h2ZENoM2FXUjBhQ0E5SURBdU1Td2diM1YwYkdsbGNpNXphR0Z3WlNBOUlFNUJLU0FyWEc0Z0lDQWdjM1JoZEY5emRXMXRZWEo1S0dGbGN5aG5jbTkxY0NBOUlHZHliM1Z3S1N3Z1puVnVJRDBnYldWaGJpd2daMlZ2YlNBOUlGd2ljRzlwYm5SY0lpd2djMmhoY0dVZ1BTQXlNU3dnYzJsNlpTQTlJRElzSUdacGJHd2dQU0JjSW5KbFpGd2lMQ0JqYjJ4dmNpQTlJRndpWW14aFkydGNJaWtnSzF4dUlDQWdJSFJvWlcxbFgyTnNZWE56YVdNb0tTQXJYRzRnSUNBZ1lXNXViM1JoZEdVb1hDSjBaWGgwWENJc0lIZ2dQU0F4TENCNUlEMGdLSGx0YVc0Z0t5QjViV0Y0S1M4eUlDc2dNU3dnYkdGaVpXd2dQU0J3WVhOMFpUQW9YQ0p3TVRJNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hBeE1pa3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lHTnZiRzl5SUQwZ1hDSmliR0ZqYTF3aUxDQm9hblZ6ZENBOUlEQXNJSE5wZW1VZ1BTQXpLVnh1SUNCY2JpQWdYRzRnSUdacGJHVk9ZVzFsSUR3dElIQmhjM1JsTUNoY0ltZGxibVZEYjNWdWRGOWNJaXdnYm05MFpTbGNiaUFnYUdWcFoyaDBJRHd0SUROY2JpQWdkMmxrZEdnZ1BDMGdNUzQxWEc0Z0lIQnVaeWhvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY0lpNXdibWRjSWlrcExDQnlaWE1nUFNBMk1EQXNJSFZ1YVhRZ1BTQmNJbWx1WENJc0lHaGxhV2RvZENBOUlHaGxhV2RvZEN3Z2QybGtkR2dnUFNCM2FXUjBhQ2xjYmlBZ2NISnBiblFvY0NsY2JpQWdaR1YyTG05bVppZ3BYRzRnSUhOMloyeHBkR1VvYUdWeVpTaG1hV2RFYVhJc0lIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hDSXVjM1puWENJcEtTd2dJR2hsYVdkb2RDQTlJR2hsYVdkb2RDd2dkMmxrZEdnZ1BTQjNhV1IwYUNsY2JpQWdjSEpwYm5Rb2NDbGNiaUFnWkdWMkxtOW1aaWdwWEc1OVhHNXdiRzkwWDJkbGJtVkRiM1Z1ZENoblpXNWxMbFJUVXk1MFlpNXdiRzkwTENCY0ltZHliM1Z3WDJKcGJtRnllVWR5YjNWd1hDSXNJSGx0WVhnZ1BTQXlNREFwWEc1Y2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG5cbmdlbmUuVFNTLnRiLnBsb3QgPC0gZ2VuZS5UU1MudGIgJT4lIHJvd3dpc2UoKSAlPiUgZHBseXI6Om11dGF0ZShcbiAgZ3JvdXAgPSBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMSwgXFxncm91cDFcXCxcbiAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBncm91cDIsIFxcZ3JvdXAyXFwsIE5BKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbiMjIGdlbmVDb3VudFxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZ2VuZUNvdW50XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZ2VuZUNvdW50XG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfZ2VuZUNvdW50IDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAwLCB5bWF4ID0gMjAwMDAwMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IGdlbmVDb3VudCkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcZ2VuZUNvdW50X1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAxLjVcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cbnBsb3RfZ2VuZUNvdW50KGdlbmUuVFNTLnRiLnBsb3QsIFxcZ3JvdXBfYmluYXJ5R3JvdXBcXCwgeW1heCA9IDIwMClcblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\, NA))) %>% 
  dplyr::filter(!is.na(group))


## geneCount
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$geneCount
  distance2 <- (data %>% dplyr::filter(group == group2) )$geneCount
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_geneCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = geneCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12)),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\geneCount_\, note)
  height <- 3
  width <- 1.5
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_geneCount(gene.TSS.tb.plot, \group_binaryGroup\, ymax = 200)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVozSnZkWEF4SUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNYR2RsYm1WTWFYTjBYMlJVUVVkZmRuTmZSRTFUVDE5U1RrRmZiRzl2Y0Y5aWFXNWhjbmxIY205MWNERXVkSE4yWEZ3cEtTUm5aVzVsWEc1bmNtOTFjRElnUEMwZ1puSmxZV1FvYUdWeVpTaHlaV1pFYVhJc0lGeGNaMlZ1WlV4cGMzUmZaRlJCUjE5MmMxOUVUVk5QWDFKT1FWOXNiMjl3WDJKcGJtRnllVWR5YjNWd01pNTBjM1pjWENrcEpHZGxibVZjYmx4dVhHNW5aVzVsTGxSVFV5NTBZaTV3Ykc5MElEd3RJR2RsYm1VdVZGTlRMblJpSUNVK0pTQnliM2QzYVhObEtDa2dKVDRsSUdSd2JIbHlPanB0ZFhSaGRHVW9YRzRnSUdkeWIzVndJRDBnYVdabGJITmxLR1Z1YzJWdFltd2dKV2x1SlNCbmNtOTFjREVzSUZ4Y1ozSnZkWEF4WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNobGJuTmxiV0pzSUNWcGJpVWdaM0p2ZFhBeUxDQmNYR2R5YjNWd01seGNMQ0JPUVNrcEtTQWxQaVVnWEc0Z0lHUndiSGx5T2pwbWFXeDBaWElvSVdsekxtNWhLR2R5YjNWd0tTbGNibHh1WEc0akl5Qm5aVzVsUTI5MWJuUmNibWRsZEZCMllXeFhhV3hqYjNnZ1BDMGdablZ1WTNScGIyNG9aR0YwWVN3Z1ozSnZkWEF4TENCbmNtOTFjRElwZTF4dUlDQmthWE4wWVc1alpURWdQQzBnS0dSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9aM0p2ZFhBZ1BUMGdaM0p2ZFhBeEtTQXBKR2RsYm1WRGIzVnVkRnh1SUNCa2FYTjBZVzVqWlRJZ1BDMGdLR1JoZEdFZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1ozSnZkWEFnUFQwZ1ozSnZkWEF5S1NBcEpHZGxibVZEYjNWdWRGeHVJQ0IzYVd3Z1BDMGdkMmxzWTI5NExuUmxjM1FvWkdsemRHRnVZMlV4TENCa2FYTjBZVzVqWlRJcFhHNGdJSEpsZEhWeWJpaDNhV3drY0M1MllXeDFaU2xjYm4xY2JseHVYRzV3Ykc5MFgyZGxibVZEYjNWdWRDQThMU0JtZFc1amRHbHZiaWgwWlcxd0xuUmlMQ0J1YjNSbExDQjViV2x1SUQwZ01Dd2dlVzFoZUNBOUlESXdNREF3TURBcGUxeHVJQ0J3TVRJZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xuUmlMQ0JjWEdkeWIzVndNVnhjTENCY1hHZHliM1Z3TWx4Y0tTd2dOU2xjYmlBZ1hHNGdJSEFnUEMwZ1oyZHdiRzkwS0hSbGJYQXVkR0lzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCblpXNWxRMjkxYm5RcEtTQXJJR2RsYjIxZmRtbHZiR2x1S0dGbGN5aG1hV3hzSUQwZ1ozSnZkWEFwTENCemFHOTNMbXhsWjJWdVpDQTlJRVpCVEZORktTQXJJRnh1SUNBZ0lHZGxiMjFmWW05NGNHeHZkQ2gzYVdSMGFDQTlJREF1TVN3Z2IzVjBiR2xsY2k1emFHRndaU0E5SUU1QktTQXJYRzRnSUNBZ2MzUmhkRjl6ZFcxdFlYSjVLR0ZsY3lobmNtOTFjQ0E5SUdkeWIzVndLU3dnWm5WdUlEMGdiV1ZoYml3Z1oyVnZiU0E5SUZ4Y2NHOXBiblJjWEN3Z2MyaGhjR1VnUFNBeU1Td2djMmw2WlNBOUlESXNJR1pwYkd3Z1BTQmNYSEpsWkZ4Y0xDQmpiMnh2Y2lBOUlGeGNZbXhoWTJ0Y1hDa2dLMXh1SUNBZ0lIUm9aVzFsWDJOc1lYTnphV01vS1NBclhHNGdJQ0FnWVc1dWIzUmhkR1VvWEZ4MFpYaDBYRndzSUhnZ1BTQXhMQ0I1SUQwZ0tIbHRhVzRnS3lCNWJXRjRLUzh5SUNzZ01Td2diR0ZpWld3Z1BTQndZWE4wWlRBb1hGeHdNVEk2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEF4TWlrcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUdOdmJHOXlJRDBnWEZ4aWJHRmphMXhjTENCb2FuVnpkQ0E5SURBc0lITnBlbVVnUFNBektWeHVJQ0JjYmlBZ1hHNGdJR1pwYkdWT1lXMWxJRHd0SUhCaGMzUmxNQ2hjWEdkbGJtVkRiM1Z1ZEY5Y1hDd2dibTkwWlNsY2JpQWdhR1ZwWjJoMElEd3RJRE5jYmlBZ2QybGtkR2dnUEMwZ01TNDFYRzRnSUhCdVp5aG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjWEM1d2JtZGNYQ2twTENCeVpYTWdQU0EyTURBc0lIVnVhWFFnUFNCY1hHbHVYRndzSUdobGFXZG9kQ0E5SUdobGFXZG9kQ3dnZDJsa2RHZ2dQU0IzYVdSMGFDbGNiaUFnY0hKcGJuUW9jQ2xjYmlBZ1pHVjJMbTltWmlncFhHNGdJSE4yWjJ4cGRHVW9hR1Z5WlNobWFXZEVhWElzSUhCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWEZ3dWMzWm5YRndwS1N3Z0lHaGxhV2RvZENBOUlHaGxhV2RvZEN3Z2QybGtkR2dnUFNCM2FXUjBhQ2xjYmlBZ2NISnBiblFvY0NsY2JpQWdaR1YyTG05bVppZ3BYRzU5WEc1d2JHOTBYMmRsYm1WRGIzVnVkQ2huWlc1bExsUlRVeTUwWWk1d2JHOTBMQ0JjWEdkeWIzVndYMkpwYm1GeWVVZHliM1Z3WEZ3c0lIbHRZWGdnUFNBeU1EQXBYRzVjYm1CZ1lGeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuXG5nZW5lLlRTUy50Yi5wbG90IDwtIGdlbmUuVFNTLnRiICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBncm91cDEsIFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAyLCBcXGdyb3VwMlxcLCBOQSkpKSAlPiUgXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSlcblxuXG4jIyBnZW5lQ291bnRcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGdlbmVDb3VudFxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJGdlbmVDb3VudFxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuXG5wbG90X2dlbmVDb3VudCA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBnZW5lQ291bnQpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gKHltaW4gKyB5bWF4KS8yICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMikpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGdlbmVDb3VudF9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gMS41XG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X2dlbmVDb3VudChnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwX2JpbmFyeUdyb3VwXFwsIHltYXggPSAyMDApXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuXG5nZW5lLlRTUy50Yi5wbG90IDwtIGdlbmUuVFNTLnRiICU+JSByb3d3aXNlKCkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBncm91cDEsIFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAyLCBcXGdyb3VwMlxcLCBOQSkpKSAlPiUgXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSlcblxuXG4jIyBnZW5lQ291bnRcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGdlbmVDb3VudFxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJGdlbmVDb3VudFxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuXG5wbG90X2dlbmVDb3VudCA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBnZW5lQ291bnQpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gKHltaW4gKyB5bWF4KS8yICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMikpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGdlbmVDb3VudF9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gMS41XG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X2dlbmVDb3VudChnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwX2JpbmFyeUdyb3VwXFwsIHltYXggPSAyMDApXG5cbmBgYFxuYGBgIn0= -->

```r
```r
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\, NA))) %>% 
  dplyr::filter(!is.na(group))


## geneCount
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$geneCount
  distance2 <- (data %>% dplyr::filter(group == group2) )$geneCount
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_geneCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = geneCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12)),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\geneCount_\, note)
  height <- 3
  width <- 1.5
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_geneCount(gene.TSS.tb.plot, \group_binaryGroup\, ymax = 200)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



## [2.17] Checking the density of gene / enhancer within designated TAD
#### Making TAD gene count

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XCIpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcIikpJGdlbmVcbmdyb3VwNSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlwiKSkkZ2VuZVxuZ3JvdXA4IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XCIpKSRnZW5lXG5cblxuZ2VuZS5UU1MudGIucGxvdCA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAxLCBcImdyb3VwMVwiLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMiwgXCJncm91cDJcIixcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA1LCBcImdyb3VwNVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA4LCBcImdyb3VwOFwiLCBOQSkpKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbiMjIGdlbmVDb3VudFxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZ2VuZUNvdW50XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZ2VuZUNvdW50XG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfZ2VuZUNvdW50IDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAwLCB5bWF4ID0gMjAwMDAwMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwiZ3JvdXAxXCIsIFwiZ3JvdXAyXCIpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMVwiLCBcImdyb3VwNVwiKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJncm91cDFcIiwgXCJncm91cDhcIiksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFwiZ3JvdXAyXCIsIFwiZ3JvdXA1XCIpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcImdyb3VwMlwiLCBcImdyb3VwOFwiKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJncm91cDVcIiwgXCJncm91cDhcIiksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gZ2VuZUNvdW50KSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcInBvaW50XCIsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCIpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgK1xuICAgIGFubm90YXRlKFwidGV4dFwiLCB4ID0gMSwgeSA9ICh5bWluICsgeW1heCkvMiArIDEsIGxhYmVsID0gcGFzdGUwKFwicDEyOiBcIiwgY29udlB2YWx1ZShwMTIpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMTU6IFwiLCBjb252UHZhbHVlKHAxNSksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInAxODogXCIsIGNvbnZQdmFsdWUocDE4KSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicDI1OiBcIiwgY29udlB2YWx1ZShwMjUpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwMjg6IFwiLCBjb252UHZhbHVlKHAyOCksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInA1ODogXCIsY29udlB2YWx1ZSggcDU4KSwgXCJcXG5cIiksXG4gICAgICAgICAgICAgY29sb3IgPSBcImJsYWNrXCIsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFwiZ2VuZUNvdW50X1wiLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X2dlbmVDb3VudChnZW5lLlRTUy50Yi5wbG90LCBcImdyb3VwXCIsIHltYXggPSAyMDApXG5cbmBgYCJ9 -->\n\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\))$gene\n\n\ngene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\,\n                        ifelse(ensembl %in% group5, \\group5\\,\n                               ifelse(ensembl %in% group8, \\group8\\, NA))))) %>% \n  dplyr::filter(!is.na(group))\n\n\n## geneCount\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$geneCount\n  distance2 <- (data %>% dplyr::filter(group == group2) )$geneCount\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_geneCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = geneCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() +\n    annotate(\\text\\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p15: \\, convPvalue(p15), \\\\n\\,\n                                                         \\p18: \\, convPvalue(p18), \\\\n\\,\n                                                         \\p25: \\, convPvalue(p25), \\\\n\\,\n                                                         \\p28: \\, convPvalue(p28), \\\\n\\,\n                                                         \\p58: \\,convPvalue( p58), \\\\n\\),\n             color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\geneCount_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\nplot_geneCount(gene.TSS.tb.plot, \\group\\, ymax = 200)\n\n```\n\n<!-- rnb-source-end -->\n"} -->
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\,
                        ifelse(ensembl %in% group5, \group5\,
                               ifelse(ensembl %in% group8, \group8\, NA))))) %>% 
  dplyr::filter(!is.na(group))


## geneCount
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$geneCount
  distance2 <- (data %>% dplyr::filter(group == group2) )$geneCount
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_geneCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = geneCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\geneCount_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_geneCount(gene.TSS.tb.plot, \group\, ymax = 200)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcXCkpJGdlbmVcbmdyb3VwNSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlxcKSkkZ2VuZVxuZ3JvdXA4IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XFwpKSRnZW5lXG5cblxuZ2VuZS5UU1MudGIucGxvdCA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAxLCBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMiwgXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA1LCBcXGdyb3VwNVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA4LCBcXGdyb3VwOFxcLCBOQSkpKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbiMjIGdlbmVDb3VudFxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZ2VuZUNvdW50XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZ2VuZUNvdW50XG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfZ2VuZUNvdW50IDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAwLCB5bWF4ID0gMjAwMDAwMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gZ2VuZUNvdW50KSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgK1xuICAgIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9ICh5bWluICsgeW1heCkvMiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDEyOiBcXCwgY29udlB2YWx1ZShwMTIpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTU6IFxcLCBjb252UHZhbHVlKHAxNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxODogXFwsIGNvbnZQdmFsdWUocDE4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI1OiBcXCwgY29udlB2YWx1ZShwMjUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjg6IFxcLCBjb252UHZhbHVlKHAyOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHA1ODogXFwsY29udlB2YWx1ZSggcDU4KSwgXFxcXG5cXCksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcZ2VuZUNvdW50X1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X2dlbmVDb3VudChnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwXFwsIHltYXggPSAyMDApXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\))$gene\n\n\ngene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(\n  group = ifelse(ensembl %in% group1, \\group1\\,\n                 ifelse(ensembl %in% group2, \\group2\\,\n                        ifelse(ensembl %in% group5, \\group5\\,\n                               ifelse(ensembl %in% group8, \\group8\\, NA))))) %>% \n  dplyr::filter(!is.na(group))\n\n\n## geneCount\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$geneCount\n  distance2 <- (data %>% dplyr::filter(group == group2) )$geneCount\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_geneCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  p15 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group5\\), 5)\n  p18 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group8\\), 5)\n  p25 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group5\\), 5)\n  p28 <- round(getPvalWilcox(temp.tb, \\group2\\, \\group8\\), 5)\n  p58 <- round(getPvalWilcox(temp.tb, \\group5\\, \\group8\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = group, y = geneCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n    theme_classic() +\n    annotate(\\text\\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                                                         \\p15: \\, convPvalue(p15), \\\\n\\,\n                                                         \\p18: \\, convPvalue(p18), \\\\n\\,\n                                                         \\p25: \\, convPvalue(p25), \\\\n\\,\n                                                         \\p28: \\, convPvalue(p28), \\\\n\\,\n                                                         \\p58: \\,convPvalue( p58), \\\\n\\),\n             color = \\black\\, hjust = 0, size = 3)\n  \n  \n  fileName <- paste0(\\geneCount_\\, note)\n  height <- 3\n  width <- 3\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\nplot_geneCount(gene.TSS.tb.plot, \\group\\, ymax = 200)\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcXCkpJGdlbmVcbmdyb3VwNSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlxcKSkkZ2VuZVxuZ3JvdXA4IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XFwpKSRnZW5lXG5cblxuZ2VuZS5UU1MudGIucGxvdCA8LSBnZW5lLlRTUy50YiAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAxLCBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMiwgXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA1LCBcXGdyb3VwNVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA4LCBcXGdyb3VwOFxcLCBOQSkpKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbiMjIGdlbmVDb3VudFxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZ2VuZUNvdW50XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZ2VuZUNvdW50XG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfZ2VuZUNvdW50IDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAwLCB5bWF4ID0gMjAwMDAwMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gZ2VuZUNvdW50KSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgK1xuICAgIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9ICh5bWluICsgeW1heCkvMiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDEyOiBcXCwgY29udlB2YWx1ZShwMTIpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTU6IFxcLCBjb252UHZhbHVlKHAxNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxODogXFwsIGNvbnZQdmFsdWUocDE4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI1OiBcXCwgY29udlB2YWx1ZShwMjUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjg6IFxcLCBjb252UHZhbHVlKHAyOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHA1ODogXFwsY29udlB2YWx1ZSggcDU4KSwgXFxcXG5cXCksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcZ2VuZUNvdW50X1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X2dlbmVDb3VudChnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwXFwsIHltYXggPSAyMDApXG5cbmBgYFxuYGBgIn0= -->

```r
```r
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\,
                        ifelse(ensembl %in% group5, \group5\,
                               ifelse(ensembl %in% group8, \group8\, NA))))) %>% 
  dplyr::filter(!is.na(group))


## geneCount
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$geneCount
  distance2 <- (data %>% dplyr::filter(group == group2) )$geneCount
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_geneCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = geneCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\geneCount_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_geneCount(gene.TSS.tb.plot, \group\, ymax = 200)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Plotting for groups
##### geneCount
###### Binary group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1nWlc1b1EyOTFiblJjYm1kbGRGQjJZV3hYYVd4amIzZ2dQQzBnWm5WdVkzUnBiMjRvWkdGMFlTd2daM0p2ZFhBeExDQm5jbTkxY0RJcGUxeHVJQ0JrYVhOMFlXNWpaVEVnUEMwZ0tHUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWjNKdmRYQWdQVDBnWjNKdmRYQXhLU0FwSkdWdWFFTnZkVzUwWEc0Z0lHUnBjM1JoYm1ObE1pQThMU0FvWkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaG5jbTkxY0NBOVBTQm5jbTkxY0RJcElDa2taVzVvUTI5MWJuUmNiaUFnZDJsc0lEd3RJSGRwYkdOdmVDNTBaWE4wS0dScGMzUmhibU5sTVN3Z1pHbHpkR0Z1WTJVeUtWeHVJQ0J5WlhSMWNtNG9kMmxzSkhBdWRtRnNkV1VwWEc1OVhHNWNibHh1Y0d4dmRGOWxibWhEYjNWdWRDQThMU0JtZFc1amRHbHZiaWgwWlcxd0xuUmlMQ0J1YjNSbExDQjViV2x1SUQwZ01Dd2dlVzFoZUNBOUlESXdNREF3TURBcGUxeHVJQ0J3TVRJZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xuUmlMQ0JjSW1keWIzVndNVndpTENCY0ltZHliM1Z3TWx3aUtTd2dOU2xjYmlBZ1hHNGdJSEFnUEMwZ1oyZHdiRzkwS0hSbGJYQXVkR0lzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCbGJtaERiM1Z1ZENrcElDc2daMlZ2YlY5MmFXOXNhVzRvWVdWektHWnBiR3dnUFNCbmNtOTFjQ2tzSUhOb2IzY3ViR1ZuWlc1a0lEMGdSa0ZNVTBVcElDc2dYRzRnSUNBZ1oyVnZiVjlpYjNod2JHOTBLSGRwWkhSb0lEMGdNQzR4TENCdmRYUnNhV1Z5TG5Ob1lYQmxJRDBnVGtFcElDdGNiaUFnSUNCemRHRjBYM04xYlcxaGNua29ZV1Z6S0dkeWIzVndJRDBnWjNKdmRYQXBMQ0JtZFc0Z1BTQnRaV0Z1TENCblpXOXRJRDBnWENKd2IybHVkRndpTENCemFHRndaU0E5SURJeExDQnphWHBsSUQwZ01pd2dabWxzYkNBOUlGd2ljbVZrWENJc0lHTnZiRzl5SUQwZ1hDSmliR0ZqYTF3aUtTQXJYRzRnSUNBZ2RHaGxiV1ZmWTJ4aGMzTnBZeWdwSUN0Y2JpQWdJQ0JoYm01dmRHRjBaU2hjSW5SbGVIUmNJaXdnZUNBOUlERXNJSGtnUFNBb2VXMXBiaUFySUhsdFlYZ3BMeklnS3lBeExDQnNZV0psYkNBOUlIQmhjM1JsTUNoY0luQXhNam9nWENJc0lHTnZiblpRZG1Gc2RXVW9jREV5S1Nrc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnWTI5c2IzSWdQU0JjSW1Kc1lXTnJYQ0lzSUdocWRYTjBJRDBnTUN3Z2MybDZaU0E5SURNcFhHNGdJRnh1SUNCY2JpQWdabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRndpWlc1b1EyOTFiblJmWENJc0lHNXZkR1VwWEc0Z0lHaGxhV2RvZENBOExTQXpYRzRnSUhkcFpIUm9JRHd0SURFdU5WeHVJQ0J3Ym1jb2FHVnlaU2htYVdkRWFYSXNJSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYQ0l1Y0c1blhDSXBLU3dnY21WeklEMGdOakF3TENCMWJtbDBJRDBnWENKcGJsd2lMQ0JvWldsbmFIUWdQU0JvWldsbmFIUXNJSGRwWkhSb0lEMGdkMmxrZEdncFhHNGdJSEJ5YVc1MEtIQXBYRzRnSUdSbGRpNXZabVlvS1Z4dUlDQnpkbWRzYVhSbEtHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRndpTG5OMloxd2lLU2tzSUNCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzRnSUhCeWFXNTBLSEFwWEc0Z0lHUmxkaTV2Wm1Zb0tWeHVmVnh1Y0d4dmRGOWxibWhEYjNWdWRDaG5aVzVsTGxSVFV5NTBZaTV3Ykc5MExDQmNJbWR5YjNWd1gySnBibUZ5ZVVkeWIzVndYQ0lzSUhsdFlYZ2dQU0F5TURBcFhHNWNibUJnWUNKOSAtLT5cblxuYGBgclxuIyMgZW5oQ291bnRcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGVuaENvdW50XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZW5oQ291bnRcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9lbmhDb3VudCA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBlbmhDb3VudCkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcZW5oQ291bnRfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDEuNVxuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxucGxvdF9lbmhDb3VudChnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwX2JpbmFyeUdyb3VwXFwsIHltYXggPSAyMDApXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
## enhCount
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$enhCount
  distance2 <- (data %>% dplyr::filter(group == group2) )$enhCount
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_enhCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = enhCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12)),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\enhCount_\, note)
  height <- 3
  width <- 1.5
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_enhCount(gene.TSS.tb.plot, \group_binaryGroup\, ymax = 200)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWdaVzVvUTI5MWJuUmNibWRsZEZCMllXeFhhV3hqYjNnZ1BDMGdablZ1WTNScGIyNG9aR0YwWVN3Z1ozSnZkWEF4TENCbmNtOTFjRElwZTF4dUlDQmthWE4wWVc1alpURWdQQzBnS0dSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9aM0p2ZFhBZ1BUMGdaM0p2ZFhBeEtTQXBKR1Z1YUVOdmRXNTBYRzRnSUdScGMzUmhibU5sTWlBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFNCbmNtOTFjRElwSUNra1pXNW9RMjkxYm5SY2JpQWdkMmxzSUR3dElIZHBiR052ZUM1MFpYTjBLR1JwYzNSaGJtTmxNU3dnWkdsemRHRnVZMlV5S1Z4dUlDQnlaWFIxY200b2QybHNKSEF1ZG1Gc2RXVXBYRzU5WEc1Y2JseHVjR3h2ZEY5bGJtaERiM1Z1ZENBOExTQm1kVzVqZEdsdmJpaDBaVzF3TG5SaUxDQnViM1JsTENCNWJXbHVJRDBnTUN3Z2VXMWhlQ0E5SURJd01EQXdNREFwZTF4dUlDQndNVElnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaDBaVzF3TG5SaUxDQmNYR2R5YjNWd01WeGNMQ0JjWEdkeWIzVndNbHhjS1N3Z05TbGNiaUFnWEc0Z0lIQWdQQzBnWjJkd2JHOTBLSFJsYlhBdWRHSXNJR0ZsY3loNElEMGdaM0p2ZFhBc0lIa2dQU0JsYm1oRGIzVnVkQ2twSUNzZ1oyVnZiVjkyYVc5c2FXNG9ZV1Z6S0dacGJHd2dQU0JuY205MWNDa3NJSE5vYjNjdWJHVm5aVzVrSUQwZ1JrRk1VMFVwSUNzZ1hHNGdJQ0FnWjJWdmJWOWliM2h3Ykc5MEtIZHBaSFJvSUQwZ01DNHhMQ0J2ZFhSc2FXVnlMbk5vWVhCbElEMGdUa0VwSUN0Y2JpQWdJQ0J6ZEdGMFgzTjFiVzFoY25rb1lXVnpLR2R5YjNWd0lEMGdaM0p2ZFhBcExDQm1kVzRnUFNCdFpXRnVMQ0JuWlc5dElEMGdYRnh3YjJsdWRGeGNMQ0J6YUdGd1pTQTlJREl4TENCemFYcGxJRDBnTWl3Z1ptbHNiQ0E5SUZ4Y2NtVmtYRndzSUdOdmJHOXlJRDBnWEZ4aWJHRmphMXhjS1NBclhHNGdJQ0FnZEdobGJXVmZZMnhoYzNOcFl5Z3BJQ3RjYmlBZ0lDQmhibTV2ZEdGMFpTaGNYSFJsZUhSY1hDd2dlQ0E5SURFc0lIa2dQU0FvZVcxcGJpQXJJSGx0WVhncEx6SWdLeUF4TENCc1lXSmxiQ0E5SUhCaGMzUmxNQ2hjWEhBeE1qb2dYRndzSUdOdmJuWlFkbUZzZFdVb2NERXlLU2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNYR0pzWVdOclhGd3NJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJRE1wWEc0Z0lGeHVJQ0JjYmlBZ1ptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGeGNaVzVvUTI5MWJuUmZYRndzSUc1dmRHVXBYRzRnSUdobGFXZG9kQ0E4TFNBelhHNGdJSGRwWkhSb0lEd3RJREV1TlZ4dUlDQndibWNvYUdWeVpTaG1hV2RFYVhJc0lIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hGd3VjRzVuWEZ3cEtTd2djbVZ6SUQwZ05qQXdMQ0IxYm1sMElEMGdYRnhwYmx4Y0xDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc0Z0lIQnlhVzUwS0hBcFhHNGdJR1JsZGk1dlptWW9LVnh1SUNCemRtZHNhWFJsS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGeGNMbk4yWjF4Y0tTa3NJQ0JvWldsbmFIUWdQU0JvWldsbmFIUXNJSGRwWkhSb0lEMGdkMmxrZEdncFhHNGdJSEJ5YVc1MEtIQXBYRzRnSUdSbGRpNXZabVlvS1Z4dWZWeHVjR3h2ZEY5bGJtaERiM1Z1ZENoblpXNWxMbFJUVXk1MFlpNXdiRzkwTENCY1hHZHliM1Z3WDJKcGJtRnllVWR5YjNWd1hGd3NJSGx0WVhnZ1BTQXlNREFwWEc1Y2JtQmdZRnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbmBgYHJcbiMjIGVuaENvdW50XG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMSkgKSRlbmhDb3VudFxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJGVuaENvdW50XG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfZW5oQ291bnQgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAyMDAwMDAwKXtcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDJcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gZW5oQ291bnQpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gKHltaW4gKyB5bWF4KS8yICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMikpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGVuaENvdW50X1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAxLjVcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cbnBsb3RfZW5oQ291bnQoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cF9iaW5hcnlHcm91cFxcLCB5bWF4ID0gMjAwKVxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMgZW5oQ291bnRcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGVuaENvdW50XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZW5oQ291bnRcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9lbmhDb3VudCA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBlbmhDb3VudCkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcZW5oQ291bnRfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDEuNVxuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxucGxvdF9lbmhDb3VudChnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwX2JpbmFyeUdyb3VwXFwsIHltYXggPSAyMDApXG5cbmBgYFxuYGBgIn0= -->

```r
```r
## enhCount
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$enhCount
  distance2 <- (data %>% dplyr::filter(group == group2) )$enhCount
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_enhCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = enhCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12)),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\enhCount_\, note)
  height <- 3
  width <- 1.5
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_enhCount(gene.TSS.tb.plot, \group_binaryGroup\, ymax = 200)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

###### Group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1nWlc1b1EyOTFiblJjYm1kbGRGQjJZV3hYYVd4amIzZ2dQQzBnWm5WdVkzUnBiMjRvWkdGMFlTd2daM0p2ZFhBeExDQm5jbTkxY0RJcGUxeHVJQ0JrYVhOMFlXNWpaVEVnUEMwZ0tHUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWjNKdmRYQWdQVDBnWjNKdmRYQXhLU0FwSkdWdWFFTnZkVzUwWEc0Z0lHUnBjM1JoYm1ObE1pQThMU0FvWkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaG5jbTkxY0NBOVBTQm5jbTkxY0RJcElDa2taVzVvUTI5MWJuUmNiaUFnZDJsc0lEd3RJSGRwYkdOdmVDNTBaWE4wS0dScGMzUmhibU5sTVN3Z1pHbHpkR0Z1WTJVeUtWeHVJQ0J5WlhSMWNtNG9kMmxzSkhBdWRtRnNkV1VwWEc1OVhHNWNibHh1Y0d4dmRGOWxibWhEYjNWdWRDQThMU0JtZFc1amRHbHZiaWgwWlcxd0xuUmlMQ0J1YjNSbExDQjViV2x1SUQwZ01Dd2dlVzFoZUNBOUlESXdNREF3TURBcGUxeHVJQ0J3TVRJZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xuUmlMQ0JjSW1keWIzVndNVndpTENCY0ltZHliM1Z3TWx3aUtTd2dOU2xjYmlBZ2NERTFJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQzUwWWl3Z1hDSm5jbTkxY0RGY0lpd2dYQ0puY205MWNEVmNJaWtzSURVcFhHNGdJSEF4T0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBdWRHSXNJRndpWjNKdmRYQXhYQ0lzSUZ3aVozSnZkWEE0WENJcExDQTFLVnh1SUNCd01qVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMblJpTENCY0ltZHliM1Z3TWx3aUxDQmNJbWR5YjNWd05Wd2lLU3dnTlNsY2JpQWdjREk0SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0M1MFlpd2dYQ0puY205MWNESmNJaXdnWENKbmNtOTFjRGhjSWlrc0lEVXBYRzRnSUhBMU9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXVkR0lzSUZ3aVozSnZkWEExWENJc0lGd2laM0p2ZFhBNFhDSXBMQ0ExS1Z4dUlDQmNiaUFnY0NBOExTQm5aM0JzYjNRb2RHVnRjQzUwWWl3Z1lXVnpLSGdnUFNCbmNtOTFjQ3dnZVNBOUlHVnVhRU52ZFc1MEtTa2dLeUJuWlc5dFgzWnBiMnhwYmloaFpYTW9abWxzYkNBOUlHZHliM1Z3S1N3Z2MyaHZkeTVzWldkbGJtUWdQU0JHUVV4VFJTa2dLeUJjYmlBZ0lDQm5aVzl0WDJKdmVIQnNiM1FvZDJsa2RHZ2dQU0F3TGpFc0lHOTFkR3hwWlhJdWMyaGhjR1VnUFNCT1FTa2dLMXh1SUNBZ0lITjBZWFJmYzNWdGJXRnllU2hoWlhNb1ozSnZkWEFnUFNCbmNtOTFjQ2tzSUdaMWJpQTlJRzFsWVc0c0lHZGxiMjBnUFNCY0luQnZhVzUwWENJc0lITm9ZWEJsSUQwZ01qRXNJSE5wZW1VZ1BTQXlMQ0JtYVd4c0lEMGdYQ0p5WldSY0lpd2dZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXBJQ3RjYmlBZ0lDQjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0sxeHVJQ0FnSUdGdWJtOTBZWFJsS0Z3aWRHVjRkRndpTENCNElEMGdNU3dnZVNBOUlDaDViV2x1SUNzZ2VXMWhlQ2t2TWlBcklERXNJR3hoWW1Wc0lEMGdjR0Z6ZEdVd0tGd2ljREV5T2lCY0lpd2dZMjl1ZGxCMllXeDFaU2h3TVRJcExDQmNJbHhjYmx3aUxGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWENKd01UVTZJRndpTENCamIyNTJVSFpoYkhWbEtIQXhOU2tzSUZ3aVhGeHVYQ0lzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNJbkF4T0RvZ1hDSXNJR052Ym5aUWRtRnNkV1VvY0RFNEtTd2dYQ0pjWEc1Y0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ3aWNESTFPaUJjSWl3Z1kyOXVkbEIyWVd4MVpTaHdNalVwTENCY0lseGNibHdpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p3TWpnNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hBeU9Da3NJRndpWEZ4dVhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQTFPRG9nWENJc1kyOXVkbEIyWVd4MVpTZ2djRFU0S1N3Z1hDSmNYRzVjSWlrc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnWTI5c2IzSWdQU0JjSW1Kc1lXTnJYQ0lzSUdocWRYTjBJRDBnTUN3Z2MybDZaU0E5SURNcFhHNGdJRnh1SUNCY2JpQWdabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRndpWlc1b1EyOTFiblJmWENJc0lHNXZkR1VwWEc0Z0lHaGxhV2RvZENBOExTQXpYRzRnSUhkcFpIUm9JRHd0SUROY2JpQWdjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGd2lMbkJ1WjF3aUtTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRndpYVc1Y0lpd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dUlDQndjbWx1ZENod0tWeHVJQ0JrWlhZdWIyWm1LQ2xjYmlBZ2MzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNJaTV6ZG1kY0lpa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVJQ0J3Y21sdWRDaHdLVnh1SUNCa1pYWXViMlptS0NsY2JuMWNibkJzYjNSZlpXNW9RMjkxYm5Rb1oyVnVaUzVVVTFNdWRHSXVjR3h2ZEN3Z1hDSm5jbTkxY0Z3aUxDQjViV0Y0SUQwZ01qQXdLVnh1WEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG4jIyBlbmhDb3VudFxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZW5oQ291bnRcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRlbmhDb3VudFxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuXG5wbG90X2VuaENvdW50IDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAwLCB5bWF4ID0gMjAwMDAwMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gZW5oQ291bnQpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gKHltaW4gKyB5bWF4KS8yICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNTogXFwsIGNvbnZQdmFsdWUocDE1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE4OiBcXCwgY29udlB2YWx1ZShwMTgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjU6IFxcLCBjb252UHZhbHVlKHAyNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyODogXFwsIGNvbnZQdmFsdWUocDI4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDU4OiBcXCxjb252UHZhbHVlKCBwNTgpLCBcXFxcblxcKSxcbiAgICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxlbmhDb3VudF9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxucGxvdF9lbmhDb3VudChnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwXFwsIHltYXggPSAyMDApXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
## enhCount
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$enhCount
  distance2 <- (data %>% dplyr::filter(group == group2) )$enhCount
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_enhCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = enhCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\enhCount_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_enhCount(gene.TSS.tb.plot, \group\, ymax = 200)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWdaVzVvUTI5MWJuUmNibWRsZEZCMllXeFhhV3hqYjNnZ1BDMGdablZ1WTNScGIyNG9aR0YwWVN3Z1ozSnZkWEF4TENCbmNtOTFjRElwZTF4dUlDQmthWE4wWVc1alpURWdQQzBnS0dSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9aM0p2ZFhBZ1BUMGdaM0p2ZFhBeEtTQXBKR1Z1YUVOdmRXNTBYRzRnSUdScGMzUmhibU5sTWlBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFNCbmNtOTFjRElwSUNra1pXNW9RMjkxYm5SY2JpQWdkMmxzSUR3dElIZHBiR052ZUM1MFpYTjBLR1JwYzNSaGJtTmxNU3dnWkdsemRHRnVZMlV5S1Z4dUlDQnlaWFIxY200b2QybHNKSEF1ZG1Gc2RXVXBYRzU5WEc1Y2JseHVjR3h2ZEY5bGJtaERiM1Z1ZENBOExTQm1kVzVqZEdsdmJpaDBaVzF3TG5SaUxDQnViM1JsTENCNWJXbHVJRDBnTUN3Z2VXMWhlQ0E5SURJd01EQXdNREFwZTF4dUlDQndNVElnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaDBaVzF3TG5SaUxDQmNYR2R5YjNWd01WeGNMQ0JjWEdkeWIzVndNbHhjS1N3Z05TbGNiaUFnY0RFMUlEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDNTBZaXdnWEZ4bmNtOTFjREZjWEN3Z1hGeG5jbTkxY0RWY1hDa3NJRFVwWEc0Z0lIQXhPQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEF1ZEdJc0lGeGNaM0p2ZFhBeFhGd3NJRnhjWjNKdmRYQTRYRndwTENBMUtWeHVJQ0J3TWpVZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xuUmlMQ0JjWEdkeWIzVndNbHhjTENCY1hHZHliM1Z3TlZ4Y0tTd2dOU2xjYmlBZ2NESTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQzUwWWl3Z1hGeG5jbTkxY0RKY1hDd2dYRnhuY205MWNEaGNYQ2tzSURVcFhHNGdJSEExT0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBdWRHSXNJRnhjWjNKdmRYQTFYRndzSUZ4Y1ozSnZkWEE0WEZ3cExDQTFLVnh1SUNCY2JpQWdjQ0E4TFNCblozQnNiM1FvZEdWdGNDNTBZaXdnWVdWektIZ2dQU0JuY205MWNDd2dlU0E5SUdWdWFFTnZkVzUwS1NrZ0t5Qm5aVzl0WDNacGIyeHBiaWhoWlhNb1ptbHNiQ0E5SUdkeWIzVndLU3dnYzJodmR5NXNaV2RsYm1RZ1BTQkdRVXhUUlNrZ0t5QmNiaUFnSUNCblpXOXRYMkp2ZUhCc2IzUW9kMmxrZEdnZ1BTQXdMakVzSUc5MWRHeHBaWEl1YzJoaGNHVWdQU0JPUVNrZ0sxeHVJQ0FnSUhOMFlYUmZjM1Z0YldGeWVTaGhaWE1vWjNKdmRYQWdQU0JuY205MWNDa3NJR1oxYmlBOUlHMWxZVzRzSUdkbGIyMGdQU0JjWEhCdmFXNTBYRndzSUhOb1lYQmxJRDBnTWpFc0lITnBlbVVnUFNBeUxDQm1hV3hzSUQwZ1hGeHlaV1JjWEN3Z1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3cElDdGNiaUFnSUNCMGFHVnRaVjlqYkdGemMybGpLQ2tnSzF4dUlDQWdJR0Z1Ym05MFlYUmxLRnhjZEdWNGRGeGNMQ0I0SUQwZ01Td2dlU0E5SUNoNWJXbHVJQ3NnZVcxaGVDa3ZNaUFySURFc0lHeGhZbVZzSUQwZ2NHRnpkR1V3S0Z4Y2NERXlPaUJjWEN3Z1kyOXVkbEIyWVd4MVpTaHdNVElwTENCY1hGeGNibHhjTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYRnh3TVRVNklGeGNMQ0JqYjI1MlVIWmhiSFZsS0hBeE5Ta3NJRnhjWEZ4dVhGd3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY1hIQXhPRG9nWEZ3c0lHTnZiblpRZG1Gc2RXVW9jREU0S1N3Z1hGeGNYRzVjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRnhjY0RJMU9pQmNYQ3dnWTI5dWRsQjJZV3gxWlNod01qVXBMQ0JjWEZ4Y2JseGNMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hGeHdNamc2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEF5T0Nrc0lGeGNYRnh1WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhBMU9Eb2dYRndzWTI5dWRsQjJZV3gxWlNnZ2NEVTRLU3dnWEZ4Y1hHNWNYQ2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNYR0pzWVdOclhGd3NJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJRE1wWEc0Z0lGeHVJQ0JjYmlBZ1ptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGeGNaVzVvUTI5MWJuUmZYRndzSUc1dmRHVXBYRzRnSUdobGFXZG9kQ0E4TFNBelhHNGdJSGRwWkhSb0lEd3RJRE5jYmlBZ2NHNW5LR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ4Y0xuQnVaMXhjS1Nrc0lISmxjeUE5SURZd01Dd2dkVzVwZENBOUlGeGNhVzVjWEN3Z2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1SUNCd2NtbHVkQ2h3S1Z4dUlDQmtaWFl1YjJabUtDbGNiaUFnYzNabmJHbDBaU2hvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY1hDNXpkbWRjWENrcExDQWdhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dUlDQndjbWx1ZENod0tWeHVJQ0JrWlhZdWIyWm1LQ2xjYm4xY2JuQnNiM1JmWlc1b1EyOTFiblFvWjJWdVpTNVVVMU11ZEdJdWNHeHZkQ3dnWEZ4bmNtOTFjRnhjTENCNWJXRjRJRDBnTWpBd0tWeHVYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG4jIyBlbmhDb3VudFxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZW5oQ291bnRcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRlbmhDb3VudFxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuXG5wbG90X2VuaENvdW50IDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAwLCB5bWF4ID0gMjAwMDAwMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gZW5oQ291bnQpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gKHltaW4gKyB5bWF4KS8yICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNTogXFwsIGNvbnZQdmFsdWUocDE1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE4OiBcXCwgY29udlB2YWx1ZShwMTgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjU6IFxcLCBjb252UHZhbHVlKHAyNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyODogXFwsIGNvbnZQdmFsdWUocDI4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDU4OiBcXCxjb252UHZhbHVlKCBwNTgpLCBcXFxcblxcKSxcbiAgICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxlbmhDb3VudF9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxucGxvdF9lbmhDb3VudChnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwXFwsIHltYXggPSAyMDApXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMgZW5oQ291bnRcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGVuaENvdW50XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZW5oQ291bnRcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9lbmhDb3VudCA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IGVuaENvdW50KSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgK1xuICAgIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9ICh5bWluICsgeW1heCkvMiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDEyOiBcXCwgY29udlB2YWx1ZShwMTIpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTU6IFxcLCBjb252UHZhbHVlKHAxNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxODogXFwsIGNvbnZQdmFsdWUocDE4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI1OiBcXCwgY29udlB2YWx1ZShwMjUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjg6IFxcLCBjb252UHZhbHVlKHAyOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHA1ODogXFwsY29udlB2YWx1ZSggcDU4KSwgXFxcXG5cXCksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcZW5oQ291bnRfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cbnBsb3RfZW5oQ291bnQoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cFxcLCB5bWF4ID0gMjAwKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
## enhCount
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$enhCount
  distance2 <- (data %>% dplyr::filter(group == group2) )$enhCount
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_enhCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = enhCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\enhCount_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_enhCount(gene.TSS.tb.plot, \group\, ymax = 200)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### enhCount
###### Binary Group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyMgZ2VuZURlbnNpdHlcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGdlbmVEZW5zaXR5XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZ2VuZURlbnNpdHlcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9nZW5lRGVuc2l0eSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEwKXtcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXCJncm91cDFcIiwgXCJncm91cDJcIiksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IFwiLlwiLCBmaWxsID0gZ3JvdXAsIHkgPSBnZW5lRGVuc2l0eSkpICtcbiAgICAjIFNldCBheGlzIGxhYmVscyAobm8geC1heGlzIHRpdGxlKVxuICAgIGxhYnMoeCA9IE5VTEwsIHkgPSBcIkdlbmUgZGVuc2l0eSB3aXRoaW4gVEFEXCIpICtcbiAgICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSAocmV2KGMoXCIjNzc3Nzc3XCIsXCIjRjI4RTJDXCIpKSkpICtcbiAgICAjIFZpb2xpbiBwbG90IHdpdGggYmxhY2sgb3V0bGluZSwgY3VzdG9taXplZCBsaW5lIHdpZHRoIGFuZCBlbmRcbiAgICBpbnRyb2RhdGF2aXo6Omdlb21fc3BsaXRfdmlvbGluKGxpbmV3aWR0aCA9IGxpbmVNZWRpdW0gKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcInNxdWFyZVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWxwaGEgPSAuNFxuICAgICkgK1xuICAgIFxuICAgICMgQm94IHBsb3Qgd2l0aCBjdXN0b21pemVkIGxpbmUgd2lkdGgsIHNxdWFyZSBlbmQsIGFuZCBvdXRsaWVyIHNpemVcbiAgICBnZW9tX2JveHBsb3QoXG4gICAgICB3aWR0aCA9IDAuMywgY29sb3IgPSBcImJsYWNrXCIsXG4gICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIixcbiAgICAgIG91dGxpZXIuc2hhcGUgPSBOQSwgIGFscGhhID0gMC42LCBzaG93LmxlZ2VuZCA9IEZBTFNFXG4gICAgKSArXG4gICAgXG4gICAgIyBNZWFuIHBvaW50IGluIGVhY2ggZ3JvdXBcbiAgICBzdGF0X3N1bW1hcnkoXG4gICAgICBhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sXG4gICAgICBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgICAgZmlsbCA9IFwiYmxhY2tcIiwgY29sb3IgPSBcImJsYWNrXCIsIHBvc2l0aW9uID0gcG9zaXRpb25fZG9kZ2UoLjMpXG4gICAgKSArXG4gICAgXG4gICAgIyBIb3Jpem9udGFsIGxpbmUgYXQgeSA9IDBcbiAgICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgICBcbiAgICAjIENvb3JkaW5hdGUgbGltaXRzIGFuZCBjdXN0b20geS1heGlzIGxhYmVsc1xuICAgIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYyh5bWluLCB5bWF4KSkgK1xuICAgIFxuICAgICMgQW5ub3RhdGUgcC12YWx1ZSB0ZXh0XG4gICAgYW5ub3RhdGUoXG4gICAgICBcInRleHRcIiwgeCA9IDEsIHkgPSB5bWluICsgMSxcbiAgICAgIGxhYmVsID0gcGFzdGUwKFwicDEyOiBcIiwgY29udlB2YWx1ZShwMTIpKSxcbiAgICAgIGNvbG9yID0gXCJibGFja1wiLCBoanVzdCA9IDAsIHNpemUgPSAzXG4gICAgKSArXG4gICAgXG4gICAgIyBUaGVtZSBjdXN0b21pemF0aW9uXG4gICAgdGhlbWVfY2xhc3NpYygpICtcbiAgICB0aGVtZShcbiAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFwiIzAwMDAwMFwiXG4gICAgICApLFxuICAgICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICAgKSxcbiAgICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICAgKSxcbiAgICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIiwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICAgICksXG4gICAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICAgKSxcbiAgICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFwidHJhbnNwYXJlbnRcIiksXG4gICAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gICAgKSsgICBcbiAgICBndWlkZXMoXG4gICAgICBmaWxsID0gZ3VpZGVfbGVnZW5kKFxuICAgICAgICBrZXl3aWR0aCA9IDAuMiwgICMgQWRqdXN0IHRoZSB3aWR0aCBvZiB0aGUgbGVnZW5kIGtleXNcbiAgICAgICAga2V5aGVpZ2h0ID0gMC4yICAjIEFkanVzdCB0aGUgaGVpZ2h0IG9mIHRoZSBsZWdlbmQga2V5c1xuICAgICAgKSlcbiAgXG4gIFxuICBcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXCJnZW5lRGVuc2l0eV9cIiwgbm90ZSlcbiAgd2lkdGggPC0gcGFuZWxTaXplKDEuNSkqbW1Ub0luY2hcbiAgaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjIpKm1tVG9JbmNoXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X2dlbmVEZW5zaXR5KGdlbmUuVFNTLnRiLnBsb3QsIFwiZ3JvdXBfYmluYXJ5R3JvdXBcIiwgeW1heCA9IDgpXG5cbmBgYCJ9 -->\n\n```r\n## geneDensity\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$geneDensity\n  distance2 <- (data %>% dplyr::filter(group == group2) )$geneDensity\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_geneDensity <- function(temp.tb, note, ymin = 0, ymax = 10){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \\.\\, fill = group, y = geneDensity)) +\n    # Set axis labels (no x-axis title)\n    labs(x = NULL, y = \\Gene density within TAD\\) +\n    scale_fill_manual(values = (rev(c(\\#777777\\,\\#F28E2C\\)))) +\n    # Violin plot with black outline, customized line width and end\n    introdataviz::geom_split_violin(linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n                                    alpha = .4\n    ) +\n    \n    # Box plot with customized line width, square end, and outlier size\n    geom_boxplot(\n      width = 0.3, color = \\black\\,\n      linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE\n    ) +\n    \n    # Mean point in each group\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    \n    # Horizontal line at y = 0\n    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n    \n    # Coordinate limits and custom y-axis labels\n    coord_cartesian(ylim = c(ymin, ymax)) +\n    \n    # Annotate p-value text\n    annotate(\n      \\text\\, x = 1, y = ymin + 1,\n      label = paste0(\\p12: \\, convPvalue(p12)),\n      color = \\black\\, hjust = 0, size = 3\n    ) +\n    \n    # Theme customization\n    theme_classic() +\n    theme(\n      axis.title = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    )+   \n    guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      ))\n  \n  \n  \n  \n  \n  fileName <- paste0(\\geneDensity_\\, note)\n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\nplot_geneDensity(gene.TSS.tb.plot, \\group_binaryGroup\\, ymax = 8)\n\n```\n\n<!-- rnb-source-end -->\n"} -->
## geneDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$geneDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$geneDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_geneDensity <- function(temp.tb, note, ymin = 0, ymax = 10){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = \.\, fill = group, y = geneDensity)) +
    # Set axis labels (no x-axis title)
    labs(x = NULL, y = \Gene density within TAD\) +
    scale_fill_manual(values = (rev(c(\#777777\,\#F28E2C\)))) +
    # Violin plot with black outline, customized line width and end
    introdataviz::geom_split_violin(linewidth = lineMedium * mmToLineUnit, lineend = \square\,
                                    alpha = .4
    ) +
    
    # Box plot with customized line width, square end, and outlier size
    geom_boxplot(
      width = 0.3, color = \black\,
      linewidth = lineMedium * mmToLineUnit, lineend = \square\,
      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE
    ) +
    
    # Mean point in each group
    stat_summary(
      aes(group = group), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) +
    
    # Horizontal line at y = 0
    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
    
    # Coordinate limits and custom y-axis labels
    coord_cartesian(ylim = c(ymin, ymax)) +
    
    # Annotate p-value text
    annotate(
      \text\, x = 1, y = ymin + 1,
      label = paste0(\p12: \, convPvalue(p12)),
      color = \black\, hjust = 0, size = 3
    ) +
    
    # Theme customization
    theme_classic() +
    theme(
      axis.title = element_text(
        size = fontSizeM, family = fontType, color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS, family = fontType, color = \#000000\
      ),
      axis.text.x = element_text(
        angle = 45, hjust = 1, vjust = 1
      ),
      axis.line = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    )+   
    guides(
      fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
      ))
  
  
  
  
  
  fileName <- paste0(\geneDensity_\, note)
  width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_geneDensity(gene.TSS.tb.plot, \group_binaryGroup\, ymax = 8)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMgZ2VuZURlbnNpdHlcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGdlbmVEZW5zaXR5XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZ2VuZURlbnNpdHlcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9nZW5lRGVuc2l0eSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEwKXtcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDJcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IFxcLlxcLCBmaWxsID0gZ3JvdXAsIHkgPSBnZW5lRGVuc2l0eSkpICtcbiAgICAjIFNldCBheGlzIGxhYmVscyAobm8geC1heGlzIHRpdGxlKVxuICAgIGxhYnMoeCA9IE5VTEwsIHkgPSBcXEdlbmUgZGVuc2l0eSB3aXRoaW4gVEFEXFwpICtcbiAgICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSAocmV2KGMoXFwjNzc3Nzc3XFwsXFwjRjI4RTJDXFwpKSkpICtcbiAgICAjIFZpb2xpbiBwbG90IHdpdGggYmxhY2sgb3V0bGluZSwgY3VzdG9taXplZCBsaW5lIHdpZHRoIGFuZCBlbmRcbiAgICBpbnRyb2RhdGF2aXo6Omdlb21fc3BsaXRfdmlvbGluKGxpbmV3aWR0aCA9IGxpbmVNZWRpdW0gKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcXHNxdWFyZVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWxwaGEgPSAuNFxuICAgICkgK1xuICAgIFxuICAgICMgQm94IHBsb3Qgd2l0aCBjdXN0b21pemVkIGxpbmUgd2lkdGgsIHNxdWFyZSBlbmQsIGFuZCBvdXRsaWVyIHNpemVcbiAgICBnZW9tX2JveHBsb3QoXG4gICAgICB3aWR0aCA9IDAuMywgY29sb3IgPSBcXGJsYWNrXFwsXG4gICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgIG91dGxpZXIuc2hhcGUgPSBOQSwgIGFscGhhID0gMC42LCBzaG93LmxlZ2VuZCA9IEZBTFNFXG4gICAgKSArXG4gICAgXG4gICAgIyBNZWFuIHBvaW50IGluIGVhY2ggZ3JvdXBcbiAgICBzdGF0X3N1bW1hcnkoXG4gICAgICBhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sXG4gICAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgICAgZmlsbCA9IFxcYmxhY2tcXCwgY29sb3IgPSBcXGJsYWNrXFwsIHBvc2l0aW9uID0gcG9zaXRpb25fZG9kZ2UoLjMpXG4gICAgKSArXG4gICAgXG4gICAgIyBIb3Jpem9udGFsIGxpbmUgYXQgeSA9IDBcbiAgICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgICBcbiAgICAjIENvb3JkaW5hdGUgbGltaXRzIGFuZCBjdXN0b20geS1heGlzIGxhYmVsc1xuICAgIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYyh5bWluLCB5bWF4KSkgK1xuICAgIFxuICAgICMgQW5ub3RhdGUgcC12YWx1ZSB0ZXh0XG4gICAgYW5ub3RhdGUoXG4gICAgICBcXHRleHRcXCwgeCA9IDEsIHkgPSB5bWluICsgMSxcbiAgICAgIGxhYmVsID0gcGFzdGUwKFxccDEyOiBcXCwgY29udlB2YWx1ZShwMTIpKSxcbiAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzXG4gICAgKSArXG4gICAgXG4gICAgIyBUaGVtZSBjdXN0b21pemF0aW9uXG4gICAgdGhlbWVfY2xhc3NpYygpICtcbiAgICB0aGVtZShcbiAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgICApLFxuICAgICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICAgKSxcbiAgICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICAgKSxcbiAgICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICAgICksXG4gICAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICAgKSxcbiAgICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gICAgKSsgICBcbiAgICBndWlkZXMoXG4gICAgICBmaWxsID0gZ3VpZGVfbGVnZW5kKFxuICAgICAgICBrZXl3aWR0aCA9IDAuMiwgICMgQWRqdXN0IHRoZSB3aWR0aCBvZiB0aGUgbGVnZW5kIGtleXNcbiAgICAgICAga2V5aGVpZ2h0ID0gMC4yICAjIEFkanVzdCB0aGUgaGVpZ2h0IG9mIHRoZSBsZWdlbmQga2V5c1xuICAgICAgKSlcbiAgXG4gIFxuICBcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxnZW5lRGVuc2l0eV9cXCwgbm90ZSlcbiAgd2lkdGggPC0gcGFuZWxTaXplKDEuNSkqbW1Ub0luY2hcbiAgaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjIpKm1tVG9JbmNoXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X2dlbmVEZW5zaXR5KGdlbmUuVFNTLnRiLnBsb3QsIFxcZ3JvdXBfYmluYXJ5R3JvdXBcXCwgeW1heCA9IDgpXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\n## geneDensity\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$geneDensity\n  distance2 <- (data %>% dplyr::filter(group == group2) )$geneDensity\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nplot_geneDensity <- function(temp.tb, note, ymin = 0, ymax = 10){\n  p12 <- round(getPvalWilcox(temp.tb, \\group1\\, \\group2\\), 5)\n  \n  p <- ggplot(temp.tb, aes(x = \\.\\, fill = group, y = geneDensity)) +\n    # Set axis labels (no x-axis title)\n    labs(x = NULL, y = \\Gene density within TAD\\) +\n    scale_fill_manual(values = (rev(c(\\#777777\\,\\#F28E2C\\)))) +\n    # Violin plot with black outline, customized line width and end\n    introdataviz::geom_split_violin(linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n                                    alpha = .4\n    ) +\n    \n    # Box plot with customized line width, square end, and outlier size\n    geom_boxplot(\n      width = 0.3, color = \\black\\,\n      linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE\n    ) +\n    \n    # Mean point in each group\n    stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n    \n    # Horizontal line at y = 0\n    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n    \n    # Coordinate limits and custom y-axis labels\n    coord_cartesian(ylim = c(ymin, ymax)) +\n    \n    # Annotate p-value text\n    annotate(\n      \\text\\, x = 1, y = ymin + 1,\n      label = paste0(\\p12: \\, convPvalue(p12)),\n      color = \\black\\, hjust = 0, size = 3\n    ) +\n    \n    # Theme customization\n    theme_classic() +\n    theme(\n      axis.title = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    )+   \n    guides(\n      fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n      ))\n  \n  \n  \n  \n  \n  fileName <- paste0(\\geneDensity_\\, note)\n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\nplot_geneDensity(gene.TSS.tb.plot, \\group_binaryGroup\\, ymax = 8)\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMgZ2VuZURlbnNpdHlcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGdlbmVEZW5zaXR5XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZ2VuZURlbnNpdHlcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9nZW5lRGVuc2l0eSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDEwKXtcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDJcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IFxcLlxcLCBmaWxsID0gZ3JvdXAsIHkgPSBnZW5lRGVuc2l0eSkpICtcbiAgICAjIFNldCBheGlzIGxhYmVscyAobm8geC1heGlzIHRpdGxlKVxuICAgIGxhYnMoeCA9IE5VTEwsIHkgPSBcXEdlbmUgZGVuc2l0eSB3aXRoaW4gVEFEXFwpICtcbiAgICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSAocmV2KGMoXFwjNzc3Nzc3XFwsXFwjRjI4RTJDXFwpKSkpICtcbiAgICAjIFZpb2xpbiBwbG90IHdpdGggYmxhY2sgb3V0bGluZSwgY3VzdG9taXplZCBsaW5lIHdpZHRoIGFuZCBlbmRcbiAgICBpbnRyb2RhdGF2aXo6Omdlb21fc3BsaXRfdmlvbGluKGxpbmV3aWR0aCA9IGxpbmVNZWRpdW0gKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcXHNxdWFyZVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWxwaGEgPSAuNFxuICAgICkgK1xuICAgIFxuICAgICMgQm94IHBsb3Qgd2l0aCBjdXN0b21pemVkIGxpbmUgd2lkdGgsIHNxdWFyZSBlbmQsIGFuZCBvdXRsaWVyIHNpemVcbiAgICBnZW9tX2JveHBsb3QoXG4gICAgICB3aWR0aCA9IDAuMywgY29sb3IgPSBcXGJsYWNrXFwsXG4gICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgIG91dGxpZXIuc2hhcGUgPSBOQSwgIGFscGhhID0gMC42LCBzaG93LmxlZ2VuZCA9IEZBTFNFXG4gICAgKSArXG4gICAgXG4gICAgIyBNZWFuIHBvaW50IGluIGVhY2ggZ3JvdXBcbiAgICBzdGF0X3N1bW1hcnkoXG4gICAgICBhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sXG4gICAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgICAgZmlsbCA9IFxcYmxhY2tcXCwgY29sb3IgPSBcXGJsYWNrXFwsIHBvc2l0aW9uID0gcG9zaXRpb25fZG9kZ2UoLjMpXG4gICAgKSArXG4gICAgXG4gICAgIyBIb3Jpem9udGFsIGxpbmUgYXQgeSA9IDBcbiAgICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgICBcbiAgICAjIENvb3JkaW5hdGUgbGltaXRzIGFuZCBjdXN0b20geS1heGlzIGxhYmVsc1xuICAgIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYyh5bWluLCB5bWF4KSkgK1xuICAgIFxuICAgICMgQW5ub3RhdGUgcC12YWx1ZSB0ZXh0XG4gICAgYW5ub3RhdGUoXG4gICAgICBcXHRleHRcXCwgeCA9IDEsIHkgPSB5bWluICsgMSxcbiAgICAgIGxhYmVsID0gcGFzdGUwKFxccDEyOiBcXCwgY29udlB2YWx1ZShwMTIpKSxcbiAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzXG4gICAgKSArXG4gICAgXG4gICAgIyBUaGVtZSBjdXN0b21pemF0aW9uXG4gICAgdGhlbWVfY2xhc3NpYygpICtcbiAgICB0aGVtZShcbiAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgICApLFxuICAgICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICAgKSxcbiAgICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICAgKSxcbiAgICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICAgICksXG4gICAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICAgKSxcbiAgICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gICAgKSsgICBcbiAgICBndWlkZXMoXG4gICAgICBmaWxsID0gZ3VpZGVfbGVnZW5kKFxuICAgICAgICBrZXl3aWR0aCA9IDAuMiwgICMgQWRqdXN0IHRoZSB3aWR0aCBvZiB0aGUgbGVnZW5kIGtleXNcbiAgICAgICAga2V5aGVpZ2h0ID0gMC4yICAjIEFkanVzdCB0aGUgaGVpZ2h0IG9mIHRoZSBsZWdlbmQga2V5c1xuICAgICAgKSlcbiAgXG4gIFxuICBcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxnZW5lRGVuc2l0eV9cXCwgbm90ZSlcbiAgd2lkdGggPC0gcGFuZWxTaXplKDEuNSkqbW1Ub0luY2hcbiAgaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjIpKm1tVG9JbmNoXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X2dlbmVEZW5zaXR5KGdlbmUuVFNTLnRiLnBsb3QsIFxcZ3JvdXBfYmluYXJ5R3JvdXBcXCwgeW1heCA9IDgpXG5cbmBgYFxuYGBgIn0= -->

```r
```r
## geneDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$geneDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$geneDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_geneDensity <- function(temp.tb, note, ymin = 0, ymax = 10){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = \.\, fill = group, y = geneDensity)) +
    # Set axis labels (no x-axis title)
    labs(x = NULL, y = \Gene density within TAD\) +
    scale_fill_manual(values = (rev(c(\#777777\,\#F28E2C\)))) +
    # Violin plot with black outline, customized line width and end
    introdataviz::geom_split_violin(linewidth = lineMedium * mmToLineUnit, lineend = \square\,
                                    alpha = .4
    ) +
    
    # Box plot with customized line width, square end, and outlier size
    geom_boxplot(
      width = 0.3, color = \black\,
      linewidth = lineMedium * mmToLineUnit, lineend = \square\,
      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE
    ) +
    
    # Mean point in each group
    stat_summary(
      aes(group = group), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) +
    
    # Horizontal line at y = 0
    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
    
    # Coordinate limits and custom y-axis labels
    coord_cartesian(ylim = c(ymin, ymax)) +
    
    # Annotate p-value text
    annotate(
      \text\, x = 1, y = ymin + 1,
      label = paste0(\p12: \, convPvalue(p12)),
      color = \black\, hjust = 0, size = 3
    ) +
    
    # Theme customization
    theme_classic() +
    theme(
      axis.title = element_text(
        size = fontSizeM, family = fontType, color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS, family = fontType, color = \#000000\
      ),
      axis.text.x = element_text(
        angle = 45, hjust = 1, vjust = 1
      ),
      axis.line = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    )+   
    guides(
      fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
      ))
  
  
  
  
  
  fileName <- paste0(\geneDensity_\, note)
  width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_geneDensity(gene.TSS.tb.plot, \group_binaryGroup\, ymax = 8)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

###### Group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1nWjJWdVpVUmxibk5wZEhsY2JtZGxkRkIyWVd4WGFXeGpiM2dnUEMwZ1puVnVZM1JwYjI0b1pHRjBZU3dnWjNKdmRYQXhMQ0JuY205MWNESXBlMXh1SUNCa2FYTjBZVzVqWlRFZ1BDMGdLR1JoZEdFZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1ozSnZkWEFnUFQwZ1ozSnZkWEF4S1NBcEpHZGxibVZFWlc1emFYUjVYRzRnSUdScGMzUmhibU5sTWlBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFNCbmNtOTFjRElwSUNra1oyVnVaVVJsYm5OcGRIbGNiaUFnZDJsc0lEd3RJSGRwYkdOdmVDNTBaWE4wS0dScGMzUmhibU5sTVN3Z1pHbHpkR0Z1WTJVeUtWeHVJQ0J5WlhSMWNtNG9kMmxzSkhBdWRtRnNkV1VwWEc1OVhHNWNibHh1Y0d4dmRGOW5aVzVsUkdWdWMybDBlU0E4TFNCbWRXNWpkR2x2YmloMFpXMXdMblJpTENCdWIzUmxMQ0I1YldsdUlEMGdNQ3dnZVcxaGVDQTlJREl3TURBd01EQXBlMXh1SUNCd01USWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMblJpTENCY0ltZHliM1Z3TVZ3aUxDQmNJbWR5YjNWd01sd2lLU3dnTlNsY2JpQWdjREUxSUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0M1MFlpd2dYQ0puY205MWNERmNJaXdnWENKbmNtOTFjRFZjSWlrc0lEVXBYRzRnSUhBeE9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXVkR0lzSUZ3aVozSnZkWEF4WENJc0lGd2laM0p2ZFhBNFhDSXBMQ0ExS1Z4dUlDQndNalVnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaDBaVzF3TG5SaUxDQmNJbWR5YjNWd01sd2lMQ0JjSW1keWIzVndOVndpS1N3Z05TbGNiaUFnY0RJNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDNTBZaXdnWENKbmNtOTFjREpjSWl3Z1hDSm5jbTkxY0RoY0lpa3NJRFVwWEc0Z0lIQTFPQ0E4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEF1ZEdJc0lGd2laM0p2ZFhBMVhDSXNJRndpWjNKdmRYQTRYQ0lwTENBMUtWeHVJQ0JjYmlBZ2NDQThMU0JuWjNCc2IzUW9kR1Z0Y0M1MFlpd2dZV1Z6S0hnZ1BTQm5jbTkxY0N3Z2VTQTlJR2RsYm1WRVpXNXphWFI1S1NrZ0t5Qm5aVzl0WDNacGIyeHBiaWhoWlhNb1ptbHNiQ0E5SUdkeWIzVndLU3dnYzJodmR5NXNaV2RsYm1RZ1BTQkdRVXhUUlNrZ0t5QmNiaUFnSUNCblpXOXRYMkp2ZUhCc2IzUW9kMmxrZEdnZ1BTQXdMakVzSUc5MWRHeHBaWEl1YzJoaGNHVWdQU0JPUVNrZ0sxeHVJQ0FnSUhOMFlYUmZjM1Z0YldGeWVTaGhaWE1vWjNKdmRYQWdQU0JuY205MWNDa3NJR1oxYmlBOUlHMWxZVzRzSUdkbGIyMGdQU0JjSW5CdmFXNTBYQ0lzSUhOb1lYQmxJRDBnTWpFc0lITnBlbVVnUFNBeUxDQm1hV3hzSUQwZ1hDSnlaV1JjSWl3Z1kyOXNiM0lnUFNCY0ltSnNZV05yWENJcElDdGNiaUFnSUNCMGFHVnRaVjlqYkdGemMybGpLQ2tnSzF4dUlDQWdJR0Z1Ym05MFlYUmxLRndpZEdWNGRGd2lMQ0I0SUQwZ01Td2dlU0E5SUNoNWJXbHVJQ3NnZVcxaGVDa3ZNaUFySURFc0lHeGhZbVZzSUQwZ2NHRnpkR1V3S0Z3aWNERXlPaUJjSWl3Z1kyOXVkbEIyWVd4MVpTaHdNVElwTENCY0lseGNibHdpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p3TVRVNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hBeE5Ta3NJRndpWEZ4dVhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQXhPRG9nWENJc0lHTnZiblpRZG1Gc2RXVW9jREU0S1N3Z1hDSmNYRzVjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0RJMU9pQmNJaXdnWTI5dWRsQjJZV3gxWlNod01qVXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hDSndNamc2SUZ3aUxDQmpiMjUyVUhaaGJIVmxLSEF5T0Nrc0lGd2lYRnh1WENJc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5BMU9Eb2dYQ0lzWTI5dWRsQjJZV3gxWlNnZ2NEVTRLU3dnWENKY1hHNWNJaWtzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJRE1wWEc0Z0lGeHVJQ0JjYmlBZ1ptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGd2laMlZ1WlVSbGJuTnBkSGxmWENJc0lHNXZkR1VwWEc0Z0lHaGxhV2RvZENBOExTQXpYRzRnSUhkcFpIUm9JRHd0SUROY2JpQWdjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGd2lMbkJ1WjF3aUtTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRndpYVc1Y0lpd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dUlDQndjbWx1ZENod0tWeHVJQ0JrWlhZdWIyWm1LQ2xjYmlBZ2MzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNJaTV6ZG1kY0lpa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVJQ0J3Y21sdWRDaHdLVnh1SUNCa1pYWXViMlptS0NsY2JuMWNibkJzYjNSZloyVnVaVVJsYm5OcGRIa29aMlZ1WlM1VVUxTXVkR0l1Y0d4dmRDd2dYQ0puY205MWNGd2lMQ0I1YldGNElEMGdNVEFwWEc1Y2JtQmdZQ0o5IC0tPlxuXG5gYGByXG4jIyBnZW5lRGVuc2l0eVxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZ2VuZURlbnNpdHlcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRnZW5lRGVuc2l0eVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuXG5wbG90X2dlbmVEZW5zaXR5IDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAwLCB5bWF4ID0gMjAwMDAwMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gZ2VuZURlbnNpdHkpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gKHltaW4gKyB5bWF4KS8yICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNTogXFwsIGNvbnZQdmFsdWUocDE1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE4OiBcXCwgY29udlB2YWx1ZShwMTgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjU6IFxcLCBjb252UHZhbHVlKHAyNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyODogXFwsIGNvbnZQdmFsdWUocDI4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDU4OiBcXCxjb252UHZhbHVlKCBwNTgpLCBcXFxcblxcKSxcbiAgICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxnZW5lRGVuc2l0eV9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxucGxvdF9nZW5lRGVuc2l0eShnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwXFwsIHltYXggPSAxMClcblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
## geneDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$geneDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$geneDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_geneDensity <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = geneDensity)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\geneDensity_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_geneDensity(gene.TSS.tb.plot, \group\, ymax = 10)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWdaMlZ1WlVSbGJuTnBkSGxjYm1kbGRGQjJZV3hYYVd4amIzZ2dQQzBnWm5WdVkzUnBiMjRvWkdGMFlTd2daM0p2ZFhBeExDQm5jbTkxY0RJcGUxeHVJQ0JrYVhOMFlXNWpaVEVnUEMwZ0tHUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWjNKdmRYQWdQVDBnWjNKdmRYQXhLU0FwSkdkbGJtVkVaVzV6YVhSNVhHNGdJR1JwYzNSaGJtTmxNaUE4TFNBb1pHRjBZU0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhuY205MWNDQTlQU0JuY205MWNESXBJQ2trWjJWdVpVUmxibk5wZEhsY2JpQWdkMmxzSUR3dElIZHBiR052ZUM1MFpYTjBLR1JwYzNSaGJtTmxNU3dnWkdsemRHRnVZMlV5S1Z4dUlDQnlaWFIxY200b2QybHNKSEF1ZG1Gc2RXVXBYRzU5WEc1Y2JseHVjR3h2ZEY5blpXNWxSR1Z1YzJsMGVTQThMU0JtZFc1amRHbHZiaWgwWlcxd0xuUmlMQ0J1YjNSbExDQjViV2x1SUQwZ01Dd2dlVzFoZUNBOUlESXdNREF3TURBcGUxeHVJQ0J3TVRJZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xuUmlMQ0JjWEdkeWIzVndNVnhjTENCY1hHZHliM1Z3TWx4Y0tTd2dOU2xjYmlBZ2NERTFJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQzUwWWl3Z1hGeG5jbTkxY0RGY1hDd2dYRnhuY205MWNEVmNYQ2tzSURVcFhHNGdJSEF4T0NBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBdWRHSXNJRnhjWjNKdmRYQXhYRndzSUZ4Y1ozSnZkWEE0WEZ3cExDQTFLVnh1SUNCd01qVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMblJpTENCY1hHZHliM1Z3TWx4Y0xDQmNYR2R5YjNWd05WeGNLU3dnTlNsY2JpQWdjREk0SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0M1MFlpd2dYRnhuY205MWNESmNYQ3dnWEZ4bmNtOTFjRGhjWENrc0lEVXBYRzRnSUhBMU9DQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXVkR0lzSUZ4Y1ozSnZkWEExWEZ3c0lGeGNaM0p2ZFhBNFhGd3BMQ0ExS1Z4dUlDQmNiaUFnY0NBOExTQm5aM0JzYjNRb2RHVnRjQzUwWWl3Z1lXVnpLSGdnUFNCbmNtOTFjQ3dnZVNBOUlHZGxibVZFWlc1emFYUjVLU2tnS3lCblpXOXRYM1pwYjJ4cGJpaGhaWE1vWm1sc2JDQTlJR2R5YjNWd0tTd2djMmh2ZHk1c1pXZGxibVFnUFNCR1FVeFRSU2tnS3lCY2JpQWdJQ0JuWlc5dFgySnZlSEJzYjNRb2QybGtkR2dnUFNBd0xqRXNJRzkxZEd4cFpYSXVjMmhoY0dVZ1BTQk9RU2tnSzF4dUlDQWdJSE4wWVhSZmMzVnRiV0Z5ZVNoaFpYTW9aM0p2ZFhBZ1BTQm5jbTkxY0Nrc0lHWjFiaUE5SUcxbFlXNHNJR2RsYjIwZ1BTQmNYSEJ2YVc1MFhGd3NJSE5vWVhCbElEMGdNakVzSUhOcGVtVWdQU0F5TENCbWFXeHNJRDBnWEZ4eVpXUmNYQ3dnWTI5c2IzSWdQU0JjWEdKc1lXTnJYRndwSUN0Y2JpQWdJQ0IwYUdWdFpWOWpiR0Z6YzJsaktDa2dLMXh1SUNBZ0lHRnVibTkwWVhSbEtGeGNkR1Y0ZEZ4Y0xDQjRJRDBnTVN3Z2VTQTlJQ2g1YldsdUlDc2dlVzFoZUNrdk1pQXJJREVzSUd4aFltVnNJRDBnY0dGemRHVXdLRnhjY0RFeU9pQmNYQ3dnWTI5dWRsQjJZV3gxWlNod01USXBMQ0JjWEZ4Y2JseGNMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hGeHdNVFU2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEF4TlNrc0lGeGNYRnh1WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhBeE9Eb2dYRndzSUdOdmJuWlFkbUZzZFdVb2NERTRLU3dnWEZ4Y1hHNWNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjREkxT2lCY1hDd2dZMjl1ZGxCMllXeDFaU2h3TWpVcExDQmNYRnhjYmx4Y0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWEZ4d01qZzZJRnhjTENCamIyNTJVSFpoYkhWbEtIQXlPQ2tzSUZ4Y1hGeHVYRndzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEExT0RvZ1hGd3NZMjl1ZGxCMllXeDFaU2dnY0RVNEtTd2dYRnhjWEc1Y1hDa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlETXBYRzRnSUZ4dUlDQmNiaUFnWm1sc1pVNWhiV1VnUEMwZ2NHRnpkR1V3S0Z4Y1oyVnVaVVJsYm5OcGRIbGZYRndzSUc1dmRHVXBYRzRnSUdobGFXZG9kQ0E4TFNBelhHNGdJSGRwWkhSb0lEd3RJRE5jYmlBZ2NHNW5LR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ4Y0xuQnVaMXhjS1Nrc0lISmxjeUE5SURZd01Dd2dkVzVwZENBOUlGeGNhVzVjWEN3Z2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1SUNCd2NtbHVkQ2h3S1Z4dUlDQmtaWFl1YjJabUtDbGNiaUFnYzNabmJHbDBaU2hvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY1hDNXpkbWRjWENrcExDQWdhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dUlDQndjbWx1ZENod0tWeHVJQ0JrWlhZdWIyWm1LQ2xjYm4xY2JuQnNiM1JmWjJWdVpVUmxibk5wZEhrb1oyVnVaUzVVVTFNdWRHSXVjR3h2ZEN3Z1hGeG5jbTkxY0Z4Y0xDQjViV0Y0SUQwZ01UQXBYRzVjYm1CZ1lGeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYGBgclxuIyMgZ2VuZURlbnNpdHlcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGdlbmVEZW5zaXR5XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZ2VuZURlbnNpdHlcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9nZW5lRGVuc2l0eSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IGdlbmVEZW5zaXR5KSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgK1xuICAgIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9ICh5bWluICsgeW1heCkvMiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDEyOiBcXCwgY29udlB2YWx1ZShwMTIpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTU6IFxcLCBjb252UHZhbHVlKHAxNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxODogXFwsIGNvbnZQdmFsdWUocDE4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI1OiBcXCwgY29udlB2YWx1ZShwMjUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjg6IFxcLCBjb252UHZhbHVlKHAyOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHA1ODogXFwsY29udlB2YWx1ZSggcDU4KSwgXFxcXG5cXCksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcZ2VuZURlbnNpdHlfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cbnBsb3RfZ2VuZURlbnNpdHkoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cFxcLCB5bWF4ID0gMTApXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMgZ2VuZURlbnNpdHlcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGdlbmVEZW5zaXR5XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZ2VuZURlbnNpdHlcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9nZW5lRGVuc2l0eSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IGdlbmVEZW5zaXR5KSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgK1xuICAgIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9ICh5bWluICsgeW1heCkvMiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDEyOiBcXCwgY29udlB2YWx1ZShwMTIpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTU6IFxcLCBjb252UHZhbHVlKHAxNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxODogXFwsIGNvbnZQdmFsdWUocDE4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI1OiBcXCwgY29udlB2YWx1ZShwMjUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjg6IFxcLCBjb252UHZhbHVlKHAyOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHA1ODogXFwsY29udlB2YWx1ZSggcDU4KSwgXFxcXG5cXCksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcZ2VuZURlbnNpdHlfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cbnBsb3RfZ2VuZURlbnNpdHkoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cFxcLCB5bWF4ID0gMTApXG5cbmBgYFxuYGBgIn0= -->

```r
```r
## geneDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$geneDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$geneDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_geneDensity <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = geneDensity)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\geneDensity_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_geneDensity(gene.TSS.tb.plot, \group\, ymax = 10)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### geneDensity
###### binaryGroup

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1nWlc1b1JHVnVjMmwwZVZ4dVoyVjBVSFpoYkZkcGJHTnZlQ0E4TFNCbWRXNWpkR2x2Ymloa1lYUmhMQ0JuY205MWNERXNJR2R5YjNWd01pbDdYRzRnSUdScGMzUmhibU5sTVNBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFNCbmNtOTFjREVwSUNra1pXNW9SR1Z1YzJsMGVWeHVJQ0JrYVhOMFlXNWpaVElnUEMwZ0tHUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWjNKdmRYQWdQVDBnWjNKdmRYQXlLU0FwSkdWdWFFUmxibk5wZEhsY2JpQWdkMmxzSUR3dElIZHBiR052ZUM1MFpYTjBLR1JwYzNSaGJtTmxNU3dnWkdsemRHRnVZMlV5S1Z4dUlDQnlaWFIxY200b2QybHNKSEF1ZG1Gc2RXVXBYRzU5WEc1Y2JseHVjR3h2ZEY5bGJtaEVaVzV6YVhSNUlEd3RJR1oxYm1OMGFXOXVLSFJsYlhBdWRHSXNJRzV2ZEdVc0lIbHRhVzRnUFNBd0xDQjViV0Y0SUQwZ01qQXdNREF3TUNsN1hHNGdJSEF4TWlBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBdWRHSXNJRndpWjNKdmRYQXhYQ0lzSUZ3aVozSnZkWEF5WENJcExDQTFLVnh1SUNCY2JpQWdjQ0E4TFNCblozQnNiM1FvZEdWdGNDNTBZaXdnWVdWektIZ2dQU0JuY205MWNDd2dlU0E5SUdWdWFFUmxibk5wZEhrcEtTQXJJR2RsYjIxZmRtbHZiR2x1S0dGbGN5aG1hV3hzSUQwZ1ozSnZkWEFwTENCemFHOTNMbXhsWjJWdVpDQTlJRVpCVEZORktTQXJJRnh1SUNBZ0lHZGxiMjFmWW05NGNHeHZkQ2gzYVdSMGFDQTlJREF1TVN3Z2IzVjBiR2xsY2k1emFHRndaU0E5SUU1QktTQXJYRzRnSUNBZ2MzUmhkRjl6ZFcxdFlYSjVLR0ZsY3lobmNtOTFjQ0E5SUdkeWIzVndLU3dnWm5WdUlEMGdiV1ZoYml3Z1oyVnZiU0E5SUZ3aWNHOXBiblJjSWl3Z2MyaGhjR1VnUFNBeU1Td2djMmw2WlNBOUlESXNJR1pwYkd3Z1BTQmNJbkpsWkZ3aUxDQmpiMnh2Y2lBOUlGd2lZbXhoWTJ0Y0lpa2dLMXh1SUNBZ0lIUm9aVzFsWDJOc1lYTnphV01vS1NBclhHNGdJQ0FnWVc1dWIzUmhkR1VvWENKMFpYaDBYQ0lzSUhnZ1BTQXhMQ0I1SUQwZ0tIbHRhVzRnS3lCNWJXRjRLUzh5SUNzZ01Td2diR0ZpWld3Z1BTQndZWE4wWlRBb1hDSndNVEk2SUZ3aUxDQmpiMjUyVUhaaGJIVmxLSEF4TWlrcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUdOdmJHOXlJRDBnWENKaWJHRmphMXdpTENCb2FuVnpkQ0E5SURBc0lITnBlbVVnUFNBektWeHVJQ0JjYmlBZ1hHNGdJR1pwYkdWT1lXMWxJRHd0SUhCaGMzUmxNQ2hjSW1WdWFFUmxibk5wZEhsZlhDSXNJRzV2ZEdVcFhHNGdJR2hsYVdkb2RDQThMU0F6WEc0Z0lIZHBaSFJvSUR3dElERXVOVnh1SUNCd2JtY29hR1Z5WlNobWFXZEVhWElzSUhCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWENJdWNHNW5YQ0lwS1N3Z2NtVnpJRDBnTmpBd0xDQjFibWwwSUQwZ1hDSnBibHdpTENCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzRnSUhCeWFXNTBLSEFwWEc0Z0lHUmxkaTV2Wm1Zb0tWeHVJQ0J6ZG1kc2FYUmxLR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ3aUxuTjJaMXdpS1Nrc0lDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc0Z0lIQnlhVzUwS0hBcFhHNGdJR1JsZGk1dlptWW9LVnh1ZlZ4dWNHeHZkRjlsYm1oRVpXNXphWFI1S0dkbGJtVXVWRk5UTG5SaUxuQnNiM1FzSUZ3aVozSnZkWEJmWW1sdVlYSjVSM0p2ZFhCY0lpd2dlVzFoZUNBOUlERXdLVnh1WEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG4jIyBlbmhEZW5zaXR5XG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMSkgKSRlbmhEZW5zaXR5XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZW5oRGVuc2l0eVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuXG5wbG90X2VuaERlbnNpdHkgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAyMDAwMDAwKXtcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDJcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gZW5oRGVuc2l0eSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcZW5oRGVuc2l0eV9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gMS41XG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X2VuaERlbnNpdHkoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cF9iaW5hcnlHcm91cFxcLCB5bWF4ID0gMTApXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
## enhDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$enhDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$enhDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_enhDensity <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = enhDensity)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12)),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\enhDensity_\, note)
  height <- 3
  width <- 1.5
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_enhDensity(gene.TSS.tb.plot, \group_binaryGroup\, ymax = 10)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWdaVzVvUkdWdWMybDBlVnh1WjJWMFVIWmhiRmRwYkdOdmVDQThMU0JtZFc1amRHbHZiaWhrWVhSaExDQm5jbTkxY0RFc0lHZHliM1Z3TWlsN1hHNGdJR1JwYzNSaGJtTmxNU0E4TFNBb1pHRjBZU0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhuY205MWNDQTlQU0JuY205MWNERXBJQ2trWlc1b1JHVnVjMmwwZVZ4dUlDQmthWE4wWVc1alpUSWdQQzBnS0dSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9aM0p2ZFhBZ1BUMGdaM0p2ZFhBeUtTQXBKR1Z1YUVSbGJuTnBkSGxjYmlBZ2QybHNJRHd0SUhkcGJHTnZlQzUwWlhOMEtHUnBjM1JoYm1ObE1Td2daR2x6ZEdGdVkyVXlLVnh1SUNCeVpYUjFjbTRvZDJsc0pIQXVkbUZzZFdVcFhHNTlYRzVjYmx4dWNHeHZkRjlsYm1oRVpXNXphWFI1SUR3dElHWjFibU4wYVc5dUtIUmxiWEF1ZEdJc0lHNXZkR1VzSUhsdGFXNGdQU0F3TENCNWJXRjRJRDBnTWpBd01EQXdNQ2w3WEc0Z0lIQXhNaUE4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEF1ZEdJc0lGeGNaM0p2ZFhBeFhGd3NJRnhjWjNKdmRYQXlYRndwTENBMUtWeHVJQ0JjYmlBZ2NDQThMU0JuWjNCc2IzUW9kR1Z0Y0M1MFlpd2dZV1Z6S0hnZ1BTQm5jbTkxY0N3Z2VTQTlJR1Z1YUVSbGJuTnBkSGtwS1NBcklHZGxiMjFmZG1sdmJHbHVLR0ZsY3lobWFXeHNJRDBnWjNKdmRYQXBMQ0J6YUc5M0xteGxaMlZ1WkNBOUlFWkJURk5GS1NBcklGeHVJQ0FnSUdkbGIyMWZZbTk0Y0d4dmRDaDNhV1IwYUNBOUlEQXVNU3dnYjNWMGJHbGxjaTV6YUdGd1pTQTlJRTVCS1NBclhHNGdJQ0FnYzNSaGRGOXpkVzF0WVhKNUtHRmxjeWhuY205MWNDQTlJR2R5YjNWd0tTd2dablZ1SUQwZ2JXVmhiaXdnWjJWdmJTQTlJRnhjY0c5cGJuUmNYQ3dnYzJoaGNHVWdQU0F5TVN3Z2MybDZaU0E5SURJc0lHWnBiR3dnUFNCY1hISmxaRnhjTENCamIyeHZjaUE5SUZ4Y1lteGhZMnRjWENrZ0sxeHVJQ0FnSUhSb1pXMWxYMk5zWVhOemFXTW9LU0FyWEc0Z0lDQWdZVzV1YjNSaGRHVW9YRngwWlhoMFhGd3NJSGdnUFNBeExDQjVJRDBnS0hsdGFXNGdLeUI1YldGNEtTOHlJQ3NnTVN3Z2JHRmlaV3dnUFNCd1lYTjBaVEFvWEZ4d01USTZJRnhjTENCamIyNTJVSFpoYkhWbEtIQXhNaWtwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJR052Ykc5eUlEMGdYRnhpYkdGamExeGNMQ0JvYW5WemRDQTlJREFzSUhOcGVtVWdQU0F6S1Z4dUlDQmNiaUFnWEc0Z0lHWnBiR1ZPWVcxbElEd3RJSEJoYzNSbE1DaGNYR1Z1YUVSbGJuTnBkSGxmWEZ3c0lHNXZkR1VwWEc0Z0lHaGxhV2RvZENBOExTQXpYRzRnSUhkcFpIUm9JRHd0SURFdU5WeHVJQ0J3Ym1jb2FHVnlaU2htYVdkRWFYSXNJSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYRnd1Y0c1blhGd3BLU3dnY21WeklEMGdOakF3TENCMWJtbDBJRDBnWEZ4cGJseGNMQ0JvWldsbmFIUWdQU0JvWldsbmFIUXNJSGRwWkhSb0lEMGdkMmxrZEdncFhHNGdJSEJ5YVc1MEtIQXBYRzRnSUdSbGRpNXZabVlvS1Z4dUlDQnpkbWRzYVhSbEtHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRnhjTG5OMloxeGNLU2tzSUNCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzRnSUhCeWFXNTBLSEFwWEc0Z0lHUmxkaTV2Wm1Zb0tWeHVmVnh1Y0d4dmRGOWxibWhFWlc1emFYUjVLR2RsYm1VdVZGTlRMblJpTG5Cc2IzUXNJRnhjWjNKdmRYQmZZbWx1WVhKNVIzSnZkWEJjWEN3Z2VXMWhlQ0E5SURFd0tWeHVYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG4jIyBlbmhEZW5zaXR5XG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMSkgKSRlbmhEZW5zaXR5XG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDIpICkkZW5oRGVuc2l0eVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuXG5wbG90X2VuaERlbnNpdHkgPC0gZnVuY3Rpb24odGVtcC50Yiwgbm90ZSwgeW1pbiA9IDAsIHltYXggPSAyMDAwMDAwKXtcbiAgcDEyIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDJcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gZW5oRGVuc2l0eSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcZW5oRGVuc2l0eV9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gMS41XG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X2VuaERlbnNpdHkoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cF9iaW5hcnlHcm91cFxcLCB5bWF4ID0gMTApXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMgZW5oRGVuc2l0eVxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZW5oRGVuc2l0eVxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJGVuaERlbnNpdHlcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9lbmhEZW5zaXR5IDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAwLCB5bWF4ID0gMjAwMDAwMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IGVuaERlbnNpdHkpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gKHltaW4gKyB5bWF4KS8yICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMikpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGVuaERlbnNpdHlfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDEuNVxuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxufVxucGxvdF9lbmhEZW5zaXR5KGdlbmUuVFNTLnRiLnBsb3QsIFxcZ3JvdXBfYmluYXJ5R3JvdXBcXCwgeW1heCA9IDEwKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
## enhDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$enhDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$enhDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_enhDensity <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = enhDensity)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12)),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\enhDensity_\, note)
  height <- 3
  width <- 1.5
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_enhDensity(gene.TSS.tb.plot, \group_binaryGroup\, ymax = 10)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

###### Group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1nWlc1b1JHVnVjMmwwZVZ4dVoyVjBVSFpoYkZkcGJHTnZlQ0E4TFNCbWRXNWpkR2x2Ymloa1lYUmhMQ0JuY205MWNERXNJR2R5YjNWd01pbDdYRzRnSUdScGMzUmhibU5sTVNBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFNCbmNtOTFjREVwSUNra1pXNW9SR1Z1YzJsMGVWeHVJQ0JrYVhOMFlXNWpaVElnUEMwZ0tHUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWjNKdmRYQWdQVDBnWjNKdmRYQXlLU0FwSkdWdWFFUmxibk5wZEhsY2JpQWdkMmxzSUR3dElIZHBiR052ZUM1MFpYTjBLR1JwYzNSaGJtTmxNU3dnWkdsemRHRnVZMlV5S1Z4dUlDQnlaWFIxY200b2QybHNKSEF1ZG1Gc2RXVXBYRzU5WEc1Y2JseHVjR3h2ZEY5bGJtaEVaVzV6YVhSNUlEd3RJR1oxYm1OMGFXOXVLSFJsYlhBdWRHSXNJRzV2ZEdVc0lIbHRhVzRnUFNBd0xDQjViV0Y0SUQwZ01qQXdNREF3TUNsN1hHNGdJSEF4TWlBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBdWRHSXNJRndpWjNKdmRYQXhYQ0lzSUZ3aVozSnZkWEF5WENJcExDQTFLVnh1SUNCd01UVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMblJpTENCY0ltZHliM1Z3TVZ3aUxDQmNJbWR5YjNWd05Wd2lLU3dnTlNsY2JpQWdjREU0SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0M1MFlpd2dYQ0puY205MWNERmNJaXdnWENKbmNtOTFjRGhjSWlrc0lEVXBYRzRnSUhBeU5TQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXVkR0lzSUZ3aVozSnZkWEF5WENJc0lGd2laM0p2ZFhBMVhDSXBMQ0ExS1Z4dUlDQndNamdnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaDBaVzF3TG5SaUxDQmNJbWR5YjNWd01sd2lMQ0JjSW1keWIzVndPRndpS1N3Z05TbGNiaUFnY0RVNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDNTBZaXdnWENKbmNtOTFjRFZjSWl3Z1hDSm5jbTkxY0RoY0lpa3NJRFVwWEc0Z0lGeHVJQ0J3SUR3dElHZG5jR3h2ZENoMFpXMXdMblJpTENCaFpYTW9lQ0E5SUdkeWIzVndMQ0I1SUQwZ1pXNW9SR1Z1YzJsMGVTa3BJQ3NnWjJWdmJWOTJhVzlzYVc0b1lXVnpLR1pwYkd3Z1BTQm5jbTkxY0Nrc0lITm9iM2N1YkdWblpXNWtJRDBnUmtGTVUwVXBJQ3NnWEc0Z0lDQWdaMlZ2YlY5aWIzaHdiRzkwS0hkcFpIUm9JRDBnTUM0eExDQnZkWFJzYVdWeUxuTm9ZWEJsSUQwZ1RrRXBJQ3RjYmlBZ0lDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ1ozSnZkWEFwTENCbWRXNGdQU0J0WldGdUxDQm5aVzl0SUQwZ1hDSndiMmx1ZEZ3aUxDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNaXdnWm1sc2JDQTlJRndpY21Wa1hDSXNJR052Ykc5eUlEMGdYQ0ppYkdGamExd2lLU0FyWEc0Z0lDQWdkR2hsYldWZlkyeGhjM05wWXlncElDdGNiaUFnSUNCaGJtNXZkR0YwWlNoY0luUmxlSFJjSWl3Z2VDQTlJREVzSUhrZ1BTQW9lVzFwYmlBcklIbHRZWGdwTHpJZ0t5QXhMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNJbkF4TWpvZ1hDSXNJR052Ym5aUWRtRnNkV1VvY0RFeUtTd2dYQ0pjWEc1Y0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ3aWNERTFPaUJjSWl3Z1kyOXVkbEIyWVd4MVpTaHdNVFVwTENCY0lseGNibHdpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p3TVRnNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hBeE9Da3NJRndpWEZ4dVhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQXlOVG9nWENJc0lHTnZiblpRZG1Gc2RXVW9jREkxS1N3Z1hDSmNYRzVjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0RJNE9pQmNJaXdnWTI5dWRsQjJZV3gxWlNod01qZ3BMQ0JjSWx4Y2Jsd2lMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hDSndOVGc2SUZ3aUxHTnZiblpRZG1Gc2RXVW9JSEExT0Nrc0lGd2lYRnh1WENJcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUdOdmJHOXlJRDBnWENKaWJHRmphMXdpTENCb2FuVnpkQ0E5SURBc0lITnBlbVVnUFNBektWeHVJQ0JjYmlBZ1hHNGdJR1pwYkdWT1lXMWxJRHd0SUhCaGMzUmxNQ2hjSW1WdWFFUmxibk5wZEhsZlhDSXNJRzV2ZEdVcFhHNGdJR2hsYVdkb2RDQThMU0F6WEc0Z0lIZHBaSFJvSUR3dElETmNiaUFnY0c1bktHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRndpTG5CdVoxd2lLU2tzSUhKbGN5QTlJRFl3TUN3Z2RXNXBkQ0E5SUZ3aWFXNWNJaXdnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVJQ0J3Y21sdWRDaHdLVnh1SUNCa1pYWXViMlptS0NsY2JpQWdjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjSWk1emRtZGNJaWtwTENBZ2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1SUNCd2NtbHVkQ2h3S1Z4dUlDQmtaWFl1YjJabUtDbGNibjFjYm5Cc2IzUmZaVzVvUkdWdWMybDBlU2huWlc1bExsUlRVeTUwWWk1d2JHOTBMQ0JjSW1keWIzVndYQ0lzSUhsdFlYZ2dQU0F4TUNsY2JseHVZR0JnSW4wPSAtLT5cblxuYGBgclxuIyMgZW5oRGVuc2l0eVxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZW5oRGVuc2l0eVxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJGVuaERlbnNpdHlcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9lbmhEZW5zaXR5IDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAwLCB5bWF4ID0gMjAwMDAwMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gZW5oRGVuc2l0eSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE1OiBcXCwgY29udlB2YWx1ZShwMTUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTg6IFxcLCBjb252UHZhbHVlKHAxOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyNTogXFwsIGNvbnZQdmFsdWUocDI1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI4OiBcXCwgY29udlB2YWx1ZShwMjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwNTg6IFxcLGNvbnZQdmFsdWUoIHA1OCksIFxcXFxuXFwpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGVuaERlbnNpdHlfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cbnBsb3RfZW5oRGVuc2l0eShnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwXFwsIHltYXggPSAxMClcblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
## enhDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$enhDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$enhDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_enhDensity <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = enhDensity)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\enhDensity_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_enhDensity(gene.TSS.tb.plot, \group\, ymax = 10)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWdaVzVvUkdWdWMybDBlVnh1WjJWMFVIWmhiRmRwYkdOdmVDQThMU0JtZFc1amRHbHZiaWhrWVhSaExDQm5jbTkxY0RFc0lHZHliM1Z3TWlsN1hHNGdJR1JwYzNSaGJtTmxNU0E4TFNBb1pHRjBZU0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhuY205MWNDQTlQU0JuY205MWNERXBJQ2trWlc1b1JHVnVjMmwwZVZ4dUlDQmthWE4wWVc1alpUSWdQQzBnS0dSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9aM0p2ZFhBZ1BUMGdaM0p2ZFhBeUtTQXBKR1Z1YUVSbGJuTnBkSGxjYmlBZ2QybHNJRHd0SUhkcGJHTnZlQzUwWlhOMEtHUnBjM1JoYm1ObE1Td2daR2x6ZEdGdVkyVXlLVnh1SUNCeVpYUjFjbTRvZDJsc0pIQXVkbUZzZFdVcFhHNTlYRzVjYmx4dWNHeHZkRjlsYm1oRVpXNXphWFI1SUR3dElHWjFibU4wYVc5dUtIUmxiWEF1ZEdJc0lHNXZkR1VzSUhsdGFXNGdQU0F3TENCNWJXRjRJRDBnTWpBd01EQXdNQ2w3WEc0Z0lIQXhNaUE4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEF1ZEdJc0lGeGNaM0p2ZFhBeFhGd3NJRnhjWjNKdmRYQXlYRndwTENBMUtWeHVJQ0J3TVRVZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xuUmlMQ0JjWEdkeWIzVndNVnhjTENCY1hHZHliM1Z3TlZ4Y0tTd2dOU2xjYmlBZ2NERTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQzUwWWl3Z1hGeG5jbTkxY0RGY1hDd2dYRnhuY205MWNEaGNYQ2tzSURVcFhHNGdJSEF5TlNBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBdWRHSXNJRnhjWjNKdmRYQXlYRndzSUZ4Y1ozSnZkWEExWEZ3cExDQTFLVnh1SUNCd01qZ2dQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMblJpTENCY1hHZHliM1Z3TWx4Y0xDQmNYR2R5YjNWd09GeGNLU3dnTlNsY2JpQWdjRFU0SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0M1MFlpd2dYRnhuY205MWNEVmNYQ3dnWEZ4bmNtOTFjRGhjWENrc0lEVXBYRzRnSUZ4dUlDQndJRHd0SUdkbmNHeHZkQ2gwWlcxd0xuUmlMQ0JoWlhNb2VDQTlJR2R5YjNWd0xDQjVJRDBnWlc1b1JHVnVjMmwwZVNrcElDc2daMlZ2YlY5MmFXOXNhVzRvWVdWektHWnBiR3dnUFNCbmNtOTFjQ2tzSUhOb2IzY3ViR1ZuWlc1a0lEMGdSa0ZNVTBVcElDc2dYRzRnSUNBZ1oyVnZiVjlpYjNod2JHOTBLSGRwWkhSb0lEMGdNQzR4TENCdmRYUnNhV1Z5TG5Ob1lYQmxJRDBnVGtFcElDdGNiaUFnSUNCemRHRjBYM04xYlcxaGNua29ZV1Z6S0dkeWIzVndJRDBnWjNKdmRYQXBMQ0JtZFc0Z1BTQnRaV0Z1TENCblpXOXRJRDBnWEZ4d2IybHVkRnhjTENCemFHRndaU0E5SURJeExDQnphWHBsSUQwZ01pd2dabWxzYkNBOUlGeGNjbVZrWEZ3c0lHTnZiRzl5SUQwZ1hGeGliR0ZqYTF4Y0tTQXJYRzRnSUNBZ2RHaGxiV1ZmWTJ4aGMzTnBZeWdwSUN0Y2JpQWdJQ0JoYm01dmRHRjBaU2hjWEhSbGVIUmNYQ3dnZUNBOUlERXNJSGtnUFNBb2VXMXBiaUFySUhsdFlYZ3BMeklnS3lBeExDQnNZV0psYkNBOUlIQmhjM1JsTUNoY1hIQXhNam9nWEZ3c0lHTnZiblpRZG1Gc2RXVW9jREV5S1N3Z1hGeGNYRzVjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRnhjY0RFMU9pQmNYQ3dnWTI5dWRsQjJZV3gxWlNod01UVXBMQ0JjWEZ4Y2JseGNMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hGeHdNVGc2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEF4T0Nrc0lGeGNYRnh1WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhBeU5Ub2dYRndzSUdOdmJuWlFkbUZzZFdVb2NESTFLU3dnWEZ4Y1hHNWNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjREk0T2lCY1hDd2dZMjl1ZGxCMllXeDFaU2h3TWpncExDQmNYRnhjYmx4Y0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWEZ4d05UZzZJRnhjTEdOdmJuWlFkbUZzZFdVb0lIQTFPQ2tzSUZ4Y1hGeHVYRndwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJR052Ykc5eUlEMGdYRnhpYkdGamExeGNMQ0JvYW5WemRDQTlJREFzSUhOcGVtVWdQU0F6S1Z4dUlDQmNiaUFnWEc0Z0lHWnBiR1ZPWVcxbElEd3RJSEJoYzNSbE1DaGNYR1Z1YUVSbGJuTnBkSGxmWEZ3c0lHNXZkR1VwWEc0Z0lHaGxhV2RvZENBOExTQXpYRzRnSUhkcFpIUm9JRHd0SUROY2JpQWdjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGeGNMbkJ1WjF4Y0tTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRnhjYVc1Y1hDd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dUlDQndjbWx1ZENod0tWeHVJQ0JrWlhZdWIyWm1LQ2xjYmlBZ2MzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNYQzV6ZG1kY1hDa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVJQ0J3Y21sdWRDaHdLVnh1SUNCa1pYWXViMlptS0NsY2JuMWNibkJzYjNSZlpXNW9SR1Z1YzJsMGVTaG5aVzVsTGxSVFV5NTBZaTV3Ykc5MExDQmNYR2R5YjNWd1hGd3NJSGx0WVhnZ1BTQXhNQ2xjYmx4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbiMjIGVuaERlbnNpdHlcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJGVuaERlbnNpdHlcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRlbmhEZW5zaXR5XG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfZW5oRGVuc2l0eSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IGVuaERlbnNpdHkpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gKHltaW4gKyB5bWF4KS8yICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNTogXFwsIGNvbnZQdmFsdWUocDE1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE4OiBcXCwgY29udlB2YWx1ZShwMTgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjU6IFxcLCBjb252UHZhbHVlKHAyNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyODogXFwsIGNvbnZQdmFsdWUocDI4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDU4OiBcXCxjb252UHZhbHVlKCBwNTgpLCBcXFxcblxcKSxcbiAgICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxlbmhEZW5zaXR5X1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X2VuaERlbnNpdHkoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cFxcLCB5bWF4ID0gMTApXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMgZW5oRGVuc2l0eVxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZW5oRGVuc2l0eVxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJGVuaERlbnNpdHlcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9lbmhEZW5zaXR5IDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAwLCB5bWF4ID0gMjAwMDAwMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gZW5oRGVuc2l0eSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE1OiBcXCwgY29udlB2YWx1ZShwMTUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTg6IFxcLCBjb252UHZhbHVlKHAxOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyNTogXFwsIGNvbnZQdmFsdWUocDI1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI4OiBcXCwgY29udlB2YWx1ZShwMjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwNTg6IFxcLGNvbnZQdmFsdWUoIHA1OCksIFxcXFxuXFwpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGVuaERlbnNpdHlfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cbnBsb3RfZW5oRGVuc2l0eShnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwXFwsIHltYXggPSAxMClcblxuYGBgXG5gYGAifQ== -->

```r
```r
## enhDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$enhDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$enhDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_enhDensity <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = enhDensity)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\enhDensity_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_enhDensity(gene.TSS.tb.plot, \group\, ymax = 10)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### enhDensity
###### Binary group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1nY21WblJHVnVjMmwwZVZ4dVoyVjBVSFpoYkZkcGJHTnZlQ0E4TFNCbWRXNWpkR2x2Ymloa1lYUmhMQ0JuY205MWNERXNJR2R5YjNWd01pbDdYRzRnSUdScGMzUmhibU5sTVNBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFNCbmNtOTFjREVwSUNra2NtVm5SR1Z1YzJsMGVWeHVJQ0JrYVhOMFlXNWpaVElnUEMwZ0tHUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWjNKdmRYQWdQVDBnWjNKdmRYQXlLU0FwSkhKbFowUmxibk5wZEhsY2JpQWdkMmxzSUR3dElIZHBiR052ZUM1MFpYTjBLR1JwYzNSaGJtTmxNU3dnWkdsemRHRnVZMlV5S1Z4dUlDQnlaWFIxY200b2QybHNKSEF1ZG1Gc2RXVXBYRzU5WEc1Y2JseHVjR3h2ZEY5eVpXZEVaVzV6YVhSNUlEd3RJR1oxYm1OMGFXOXVLSFJsYlhBdWRHSXNJRzV2ZEdVc0lIbHRhVzRnUFNBd0xDQjViV0Y0SUQwZ01qQXdNREF3TUNsN1hHNGdJSEF4TWlBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBdWRHSXNJRndpWjNKdmRYQXhYQ0lzSUZ3aVozSnZkWEF5WENJcExDQTFLVnh1SUNCd01UVWdQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMblJpTENCY0ltZHliM1Z3TVZ3aUxDQmNJbWR5YjNWd05Wd2lLU3dnTlNsY2JpQWdjREU0SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0M1MFlpd2dYQ0puY205MWNERmNJaXdnWENKbmNtOTFjRGhjSWlrc0lEVXBYRzRnSUhBeU5TQThMU0J5YjNWdVpDaG5aWFJRZG1Gc1YybHNZMjk0S0hSbGJYQXVkR0lzSUZ3aVozSnZkWEF5WENJc0lGd2laM0p2ZFhBMVhDSXBMQ0ExS1Z4dUlDQndNamdnUEMwZ2NtOTFibVFvWjJWMFVIWmhiRmRwYkdOdmVDaDBaVzF3TG5SaUxDQmNJbWR5YjNWd01sd2lMQ0JjSW1keWIzVndPRndpS1N3Z05TbGNiaUFnY0RVNElEd3RJSEp2ZFc1a0tHZGxkRkIyWVd4WGFXeGpiM2dvZEdWdGNDNTBZaXdnWENKbmNtOTFjRFZjSWl3Z1hDSm5jbTkxY0RoY0lpa3NJRFVwWEc0Z0lGeHVJQ0J3SUR3dElHZG5jR3h2ZENoMFpXMXdMblJpTENCaFpYTW9lQ0E5SUdkeWIzVndMQ0I1SUQwZ2NtVm5SR1Z1YzJsMGVTa3BJQ3NnWjJWdmJWOTJhVzlzYVc0b1lXVnpLR1pwYkd3Z1BTQm5jbTkxY0Nrc0lITm9iM2N1YkdWblpXNWtJRDBnUmtGTVUwVXBJQ3NnWEc0Z0lDQWdaMlZ2YlY5aWIzaHdiRzkwS0hkcFpIUm9JRDBnTUM0eExDQnZkWFJzYVdWeUxuTm9ZWEJsSUQwZ1RrRXBJQ3RjYmlBZ0lDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ1ozSnZkWEFwTENCbWRXNGdQU0J0WldGdUxDQm5aVzl0SUQwZ1hDSndiMmx1ZEZ3aUxDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNaXdnWm1sc2JDQTlJRndpY21Wa1hDSXNJR052Ykc5eUlEMGdYQ0ppYkdGamExd2lLU0FyWEc0Z0lDQWdkR2hsYldWZlkyeGhjM05wWXlncElDdGNiaUFnSUNCaGJtNXZkR0YwWlNoY0luUmxlSFJjSWl3Z2VDQTlJREVzSUhrZ1BTQW9lVzFwYmlBcklIbHRZWGdwTHpJZ0t5QXhMQ0JzWVdKbGJDQTlJSEJoYzNSbE1DaGNJbkF4TWpvZ1hDSXNJR052Ym5aUWRtRnNkV1VvY0RFeUtTd2dYQ0pjWEc1Y0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZ3aWNERTFPaUJjSWl3Z1kyOXVkbEIyWVd4MVpTaHdNVFVwTENCY0lseGNibHdpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p3TVRnNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hBeE9Da3NJRndpWEZ4dVhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQXlOVG9nWENJc0lHTnZiblpRZG1Gc2RXVW9jREkxS1N3Z1hDSmNYRzVjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0RJNE9pQmNJaXdnWTI5dWRsQjJZV3gxWlNod01qZ3BMQ0JjSWx4Y2Jsd2lMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hDSndOVGc2SUZ3aUxHTnZiblpRZG1Gc2RXVW9JSEExT0Nrc0lGd2lYRnh1WENJcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUdOdmJHOXlJRDBnWENKaWJHRmphMXdpTENCb2FuVnpkQ0E5SURBc0lITnBlbVVnUFNBektWeHVJQ0JjYmlBZ1hHNGdJR1pwYkdWT1lXMWxJRHd0SUhCaGMzUmxNQ2hjSW5KbFowUmxibk5wZEhsZlhDSXNJRzV2ZEdVcFhHNGdJR2hsYVdkb2RDQThMU0F6WEc0Z0lIZHBaSFJvSUR3dElETmNiaUFnY0c1bktHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRndpTG5CdVoxd2lLU2tzSUhKbGN5QTlJRFl3TUN3Z2RXNXBkQ0E5SUZ3aWFXNWNJaXdnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVJQ0J3Y21sdWRDaHdLVnh1SUNCa1pYWXViMlptS0NsY2JpQWdjM1puYkdsMFpTaG9aWEpsS0dacFowUnBjaXdnY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjSWk1emRtZGNJaWtwTENBZ2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1SUNCd2NtbHVkQ2h3S1Z4dUlDQmtaWFl1YjJabUtDbGNibjFjYm5Cc2IzUmZjbVZuUkdWdWMybDBlU2huWlc1bExsUlRVeTUwWWk1d2JHOTBMQ0JjSW1keWIzVndYQ0lzSUhsdFlYZ2dQU0F4TUNsY2JseHVZR0JnSW4wPSAtLT5cblxuYGBgclxuIyMgcmVnRGVuc2l0eVxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkcmVnRGVuc2l0eVxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJHJlZ0RlbnNpdHlcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9yZWdEZW5zaXR5IDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAwLCB5bWF4ID0gMjAwMDAwMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gcmVnRGVuc2l0eSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE1OiBcXCwgY29udlB2YWx1ZShwMTUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTg6IFxcLCBjb252UHZhbHVlKHAxOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyNTogXFwsIGNvbnZQdmFsdWUocDI1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI4OiBcXCwgY29udlB2YWx1ZShwMjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwNTg6IFxcLGNvbnZQdmFsdWUoIHA1OCksIFxcXFxuXFwpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXHJlZ0RlbnNpdHlfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cbnBsb3RfcmVnRGVuc2l0eShnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwXFwsIHltYXggPSAxMClcblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
## regDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$regDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$regDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_regDensity <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = regDensity)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\regDensity_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_regDensity(gene.TSS.tb.plot, \group\, ymax = 10)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWdjbVZuUkdWdWMybDBlVnh1WjJWMFVIWmhiRmRwYkdOdmVDQThMU0JtZFc1amRHbHZiaWhrWVhSaExDQm5jbTkxY0RFc0lHZHliM1Z3TWlsN1hHNGdJR1JwYzNSaGJtTmxNU0E4TFNBb1pHRjBZU0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhuY205MWNDQTlQU0JuY205MWNERXBJQ2trY21WblJHVnVjMmwwZVZ4dUlDQmthWE4wWVc1alpUSWdQQzBnS0dSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9aM0p2ZFhBZ1BUMGdaM0p2ZFhBeUtTQXBKSEpsWjBSbGJuTnBkSGxjYmlBZ2QybHNJRHd0SUhkcGJHTnZlQzUwWlhOMEtHUnBjM1JoYm1ObE1Td2daR2x6ZEdGdVkyVXlLVnh1SUNCeVpYUjFjbTRvZDJsc0pIQXVkbUZzZFdVcFhHNTlYRzVjYmx4dWNHeHZkRjl5WldkRVpXNXphWFI1SUR3dElHWjFibU4wYVc5dUtIUmxiWEF1ZEdJc0lHNXZkR1VzSUhsdGFXNGdQU0F3TENCNWJXRjRJRDBnTWpBd01EQXdNQ2w3WEc0Z0lIQXhNaUE4TFNCeWIzVnVaQ2huWlhSUWRtRnNWMmxzWTI5NEtIUmxiWEF1ZEdJc0lGeGNaM0p2ZFhBeFhGd3NJRnhjWjNKdmRYQXlYRndwTENBMUtWeHVJQ0J3TVRVZ1BDMGdjbTkxYm1Rb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xuUmlMQ0JjWEdkeWIzVndNVnhjTENCY1hHZHliM1Z3TlZ4Y0tTd2dOU2xjYmlBZ2NERTRJRHd0SUhKdmRXNWtLR2RsZEZCMllXeFhhV3hqYjNnb2RHVnRjQzUwWWl3Z1hGeG5jbTkxY0RGY1hDd2dYRnhuY205MWNEaGNYQ2tzSURVcFhHNGdJSEF5TlNBOExTQnliM1Z1WkNoblpYUlFkbUZzVjJsc1kyOTRLSFJsYlhBdWRHSXNJRnhjWjNKdmRYQXlYRndzSUZ4Y1ozSnZkWEExWEZ3cExDQTFLVnh1SUNCd01qZ2dQQzBnY205MWJtUW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMblJpTENCY1hHZHliM1Z3TWx4Y0xDQmNYR2R5YjNWd09GeGNLU3dnTlNsY2JpQWdjRFU0SUR3dElISnZkVzVrS0dkbGRGQjJZV3hYYVd4amIzZ29kR1Z0Y0M1MFlpd2dYRnhuY205MWNEVmNYQ3dnWEZ4bmNtOTFjRGhjWENrc0lEVXBYRzRnSUZ4dUlDQndJRHd0SUdkbmNHeHZkQ2gwWlcxd0xuUmlMQ0JoWlhNb2VDQTlJR2R5YjNWd0xDQjVJRDBnY21WblJHVnVjMmwwZVNrcElDc2daMlZ2YlY5MmFXOXNhVzRvWVdWektHWnBiR3dnUFNCbmNtOTFjQ2tzSUhOb2IzY3ViR1ZuWlc1a0lEMGdSa0ZNVTBVcElDc2dYRzRnSUNBZ1oyVnZiVjlpYjNod2JHOTBLSGRwWkhSb0lEMGdNQzR4TENCdmRYUnNhV1Z5TG5Ob1lYQmxJRDBnVGtFcElDdGNiaUFnSUNCemRHRjBYM04xYlcxaGNua29ZV1Z6S0dkeWIzVndJRDBnWjNKdmRYQXBMQ0JtZFc0Z1BTQnRaV0Z1TENCblpXOXRJRDBnWEZ4d2IybHVkRnhjTENCemFHRndaU0E5SURJeExDQnphWHBsSUQwZ01pd2dabWxzYkNBOUlGeGNjbVZrWEZ3c0lHTnZiRzl5SUQwZ1hGeGliR0ZqYTF4Y0tTQXJYRzRnSUNBZ2RHaGxiV1ZmWTJ4aGMzTnBZeWdwSUN0Y2JpQWdJQ0JoYm01dmRHRjBaU2hjWEhSbGVIUmNYQ3dnZUNBOUlERXNJSGtnUFNBb2VXMXBiaUFySUhsdFlYZ3BMeklnS3lBeExDQnNZV0psYkNBOUlIQmhjM1JsTUNoY1hIQXhNam9nWEZ3c0lHTnZiblpRZG1Gc2RXVW9jREV5S1N3Z1hGeGNYRzVjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRnhjY0RFMU9pQmNYQ3dnWTI5dWRsQjJZV3gxWlNod01UVXBMQ0JjWEZ4Y2JseGNMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hGeHdNVGc2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEF4T0Nrc0lGeGNYRnh1WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhBeU5Ub2dYRndzSUdOdmJuWlFkbUZzZFdVb2NESTFLU3dnWEZ4Y1hHNWNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjREk0T2lCY1hDd2dZMjl1ZGxCMllXeDFaU2h3TWpncExDQmNYRnhjYmx4Y0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWEZ4d05UZzZJRnhjTEdOdmJuWlFkbUZzZFdVb0lIQTFPQ2tzSUZ4Y1hGeHVYRndwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJR052Ykc5eUlEMGdYRnhpYkdGamExeGNMQ0JvYW5WemRDQTlJREFzSUhOcGVtVWdQU0F6S1Z4dUlDQmNiaUFnWEc0Z0lHWnBiR1ZPWVcxbElEd3RJSEJoYzNSbE1DaGNYSEpsWjBSbGJuTnBkSGxmWEZ3c0lHNXZkR1VwWEc0Z0lHaGxhV2RvZENBOExTQXpYRzRnSUhkcFpIUm9JRHd0SUROY2JpQWdjRzVuS0dobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1ptbHNaVTVoYldVc0lGeGNMbkJ1WjF4Y0tTa3NJSEpsY3lBOUlEWXdNQ3dnZFc1cGRDQTlJRnhjYVc1Y1hDd2dhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dUlDQndjbWx1ZENod0tWeHVJQ0JrWlhZdWIyWm1LQ2xjYmlBZ2MzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNYQzV6ZG1kY1hDa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVJQ0J3Y21sdWRDaHdLVnh1SUNCa1pYWXViMlptS0NsY2JuMWNibkJzYjNSZmNtVm5SR1Z1YzJsMGVTaG5aVzVsTGxSVFV5NTBZaTV3Ykc5MExDQmNYR2R5YjNWd1hGd3NJSGx0WVhnZ1BTQXhNQ2xjYmx4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbiMjIHJlZ0RlbnNpdHlcbmdldFB2YWxXaWxjb3ggPC0gZnVuY3Rpb24oZGF0YSwgZ3JvdXAxLCBncm91cDIpe1xuICBkaXN0YW5jZTEgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAxKSApJHJlZ0RlbnNpdHlcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRyZWdEZW5zaXR5XG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5cbnBsb3RfcmVnRGVuc2l0eSA8LSBmdW5jdGlvbih0ZW1wLnRiLCBub3RlLCB5bWluID0gMCwgeW1heCA9IDIwMDAwMDApe1xuICBwMTIgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSwgNSlcbiAgcDE1IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDVcXCksIDUpXG4gIHAxOCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBwMjUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDI4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDJcXCwgXFxncm91cDhcXCksIDUpXG4gIHA1OCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXA1XFwsIFxcZ3JvdXA4XFwpLCA1KVxuICBcbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IHJlZ0RlbnNpdHkpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0gKHltaW4gKyB5bWF4KS8yICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNTogXFwsIGNvbnZQdmFsdWUocDE1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE4OiBcXCwgY29udlB2YWx1ZShwMTgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjU6IFxcLCBjb252UHZhbHVlKHAyNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyODogXFwsIGNvbnZQdmFsdWUocDI4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDU4OiBcXCxjb252UHZhbHVlKCBwNTgpLCBcXFxcblxcKSxcbiAgICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxyZWdEZW5zaXR5X1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5wbG90X3JlZ0RlbnNpdHkoZ2VuZS5UU1MudGIucGxvdCwgXFxncm91cFxcLCB5bWF4ID0gMTApXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMgcmVnRGVuc2l0eVxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkcmVnRGVuc2l0eVxuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gZ3JvdXAyKSApJHJlZ0RlbnNpdHlcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cblxucGxvdF9yZWdEZW5zaXR5IDwtIGZ1bmN0aW9uKHRlbXAudGIsIG5vdGUsIHltaW4gPSAwLCB5bWF4ID0gMjAwMDAwMCl7XG4gIHAxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpLCA1KVxuICBwMTUgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMVxcLCBcXGdyb3VwNVxcKSwgNSlcbiAgcDE4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDFcXCwgXFxncm91cDhcXCksIDUpXG4gIHAyNSA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAudGIsIFxcZ3JvdXAyXFwsIFxcZ3JvdXA1XFwpLCA1KVxuICBwMjggPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLnRiLCBcXGdyb3VwMlxcLCBcXGdyb3VwOFxcKSwgNSlcbiAgcDU4IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcC50YiwgXFxncm91cDVcXCwgXFxncm91cDhcXCksIDUpXG4gIFxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gcmVnRGVuc2l0eSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAoeW1pbiArIHltYXgpLzIgKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE1OiBcXCwgY29udlB2YWx1ZShwMTUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTg6IFxcLCBjb252UHZhbHVlKHAxOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyNTogXFwsIGNvbnZQdmFsdWUocDI1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI4OiBcXCwgY29udlB2YWx1ZShwMjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwNTg6IFxcLGNvbnZQdmFsdWUoIHA1OCksIFxcXFxuXFwpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXHJlZ0RlbnNpdHlfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbn1cbnBsb3RfcmVnRGVuc2l0eShnZW5lLlRTUy50Yi5wbG90LCBcXGdyb3VwXFwsIHltYXggPSAxMClcblxuYGBgXG5gYGAifQ== -->

```r
```r
## regDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$regDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$regDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_regDensity <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, \group1\, \group2\), 5)
  p15 <- round(getPvalWilcox(temp.tb, \group1\, \group5\), 5)
  p18 <- round(getPvalWilcox(temp.tb, \group1\, \group8\), 5)
  p25 <- round(getPvalWilcox(temp.tb, \group2\, \group5\), 5)
  p28 <- round(getPvalWilcox(temp.tb, \group2\, \group8\), 5)
  p58 <- round(getPvalWilcox(temp.tb, \group5\, \group8\), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = regDensity)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() +
    annotate(\text\, x = 1, y = (ymin + ymax)/2 + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\regDensity_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}
plot_regDensity(gene.TSS.tb.plot, \group\, ymax = 10)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

###### Group

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ndiff.RNA <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj)\n\ntemp <- left_join(gene.TSS.tb, diff.RNA, by = c(\"ensembl\" = \"ensembl_gene_id\")) %>% dplyr::filter(!is.na(log2FoldChange),\n                                                                                                  !is.na(TAD))\n\n\ndata <- temp %>% group_by(TAD) %>%\n  dplyr::summarise(absAvgLog2FC = abs(mean(log2FoldChange)),\n                   avgLog2FC = mean(log2FoldChange),\n                   geneDensity = mean(geneDensity),\n                   enhDensity = mean(enhDensity),\n                   regDensity = mean(regDensity))\n\ndata$geneDensityGroup <- cut(\n  data$geneDensity,\n  breaks = quantile(data$geneDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),\n  include.lowest = TRUE,\n  labels = paste0(seq(0, 80, 20), \"-\", seq(20, 100, 20), \"%\")\n)\n\ndata$enhDensityGroup <- cut(\n  data$enhDensity,\n  breaks = quantile(data$enhDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),\n  include.lowest = TRUE,\n  labels = paste0(seq(0, 80, 20), \"-\", seq(20, 100, 20), \"%\")\n)\n\n\n### Ploting  grouping\n\np <- ggplot(data, aes(x = enhDensityGroup, y = enhDensity, fill = enhDensityGroup)) + \n  geom_boxplot(color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA) + theme_classic() +\n  coord_cartesian(ylim = c(0, quantile(data$enhDensity, 0.99))) +\n  labs(x = \"Enhancer Density Group\" , y = \"TAD enhancer density\") +\n  scale_fill_manual(values = c(\"#D9D9D9\", \"#BFBFBF\", \"#A6A6A6\", \"#8C8C8C\", \"#737373\")) +\n  theme(\n    legend.position = \"none\",\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- paste0(\"tadGroup_enhDensity\")\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\np <- ggplot(data, aes(x = geneDensityGroup, y = geneDensity, fill = geneDensityGroup)) + \n  geom_boxplot(color = \"black\",\n               linewidth = lineMedium * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA) + theme_classic() +\n  coord_cartesian(ylim = c(0, quantile(data$geneDensity, 0.99))) +\n  labs(x = \"Gene Density Group\" , y = \"Gene density\") +\n  scale_fill_manual(values = c(\"#777777\", \"#8B7E65\", \"#A28452\", \"#C2884D\", \"#F28E2C\")) +\n  theme(\n    legend.position = \"none\",\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\nfileName <- paste0(\"tadGroup_geneDensity\")\nwidth <- 31*mmToInch\nheight <- 38*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n### Plotting distribution - enh\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(enhDensityGroup ==group1) )$avgLog2FC\n  distance2 <- (data %>% dplyr::filter(enhDensityGroup ==group2) )$avgLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\n#### ALL\n# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))\n# p <- ggplot(data, aes(x = enhDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = enhDensityGroup))+ \n#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +\n#   coord_cartesian(ylim = c(-ylim, ylim)) +\n#   geom_hline(yintercept = 0) +   theme(legend.position = \"none\") +\n#   scale_fill_manual(values = c(\"#d9d9d9\", \"#bdbdbd\", \"#969696\", \"#737373\", \"#525252\"))\n# \n# fileName <- paste0(\"tadGroup_enhDensity_avgLog2FC\")\n# height <- 3\n# width <- 3\n# png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\n# print(p)\n# dev.off()\n#### UP\ndata.plus <- data %>% dplyr::filter(avgLog2FC > 0)\nps01 <- round(getPvalWilcox(data.plus, \"0-20%\", \"20-40%\"), 5)\nps12 <- round(getPvalWilcox(data.plus, \"20-40%\", \"40-60%\"), 5)\nps23 <- round(getPvalWilcox(data.plus, \"40-60%\", \"60-80%\"), 5)\nps34 <- round(getPvalWilcox(data.plus, \"60-80%\", \"80-100%\"), 5)\n\n\n\np <- ggplot(data.plus, aes(x = enhDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = enhDensityGroup),\n              color = \"black\",\n              linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \"Enhancer density group\" , y = \"avg log2(fold change)\") +\n  stat_summary(\n    aes(group = enhDensityGroup), fun = mean,\n    geom = \"point\", shape = 21, size = 1,\n    fill = \"red\", color = \"black\"\n  ) +\n  scale_fill_manual(values = c(\"#D9D9D9\", \"#BFBFBF\", \"#A6A6A6\", \"#8C8C8C\", \"#737373\")) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(0, 1.5)) +\n  annotate(\"text\", x = 1, y = 1, label = paste0(\"ps01: \", convPvalue(ps01), \"\\n\",\n                                                \"ps12: \", convPvalue(ps12), \"\\n\",\n                                                \"ps23: \", convPvalue(ps23), \"\\n\",\n                                                \"ps34: \", convPvalue(ps34), \"\\n\"), \n           color = \"black\", hjust = 0, size = 2)\n\n\nfileName <- paste0(\"tadGroup_enhDensity_avgLog2FC_up\")\nwidth <- panelSize(1.15)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#### DOWN\ndata.minus <- data %>% dplyr::filter(avgLog2FC < 0)\nps01 <- round(getPvalWilcox(data.minus, \"0-20%\", \"20-40%\"), 5)\nps12 <- round(getPvalWilcox(data.minus, \"20-40%\", \"40-60%\"), 5)\nps23 <- round(getPvalWilcox(data.minus, \"40-60%\", \"60-80%\"), 5)\nps34 <- round(getPvalWilcox(data.minus, \"60-80%\", \"80-100%\"), 5)\n\n\np <- ggplot(data.minus, aes(x = enhDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = enhDensityGroup),\n              color = \"black\",\n              linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \"Enhancer density group\" , y = \"avg log2(fold change)\") +\n  stat_summary(\n    aes(group = enhDensityGroup), fun = mean,\n    geom = \"point\", shape = 21, size = 1,\n    fill = \"red\", color = \"black\"\n  ) +\n  scale_fill_manual(values = c(\"#D9D9D9\", \"#BFBFBF\", \"#A6A6A6\", \"#8C8C8C\", \"#737373\")) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(-1.5, 0))+\n  annotate(\"text\", x = 1, y = -1, label = paste0(\"ps01: \", convPvalue(ps01), \"\\n\",\n                                                \"ps12: \", convPvalue(ps12), \"\\n\",\n                                                \"ps23: \", convPvalue(ps23), \"\\n\",\n                                                \"ps34: \", convPvalue(ps34), \"\\n\"), \n           color = \"black\", hjust = 0, size = 2)\n\nfileName <- paste0(\"tadGroup_enhDensity_avgLog2FC_down\")\nwidth <- panelSize(1.175)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Plotting distribution - gene\n#### ALL\n# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))\n# p <- ggplot(data, aes(x = geneDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = geneDensityGroup))+ \n#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +\n#   coord_cartesian(ylim = c(-ylim, ylim)) +\n#   geom_hline(yintercept = 0) +   theme(legend.position = \"none\") +\n#   scale_fill_manual(values = c(\"#d9d9d9\", \"#bdbdbd\", \"#969696\", \"#737373\", \"#525252\"))\n# \n# fileName <- paste0(\"tadGroup_geneDensity_avgLog2FC\")\n# height <- 3\n# width <- 3\n# png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\n# print(p)\n# dev.off()\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(geneDensityGroup ==group1) )$avgLog2FC\n  distance2 <- (data %>% dplyr::filter(geneDensityGroup ==group2) )$avgLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\ndata.plus <- data %>% dplyr::filter(avgLog2FC > 0)\nps01 <- round(getPvalWilcox(data.plus, \"0-20%\", \"20-40%\"), 5)\nps12 <- round(getPvalWilcox(data.plus, \"20-40%\", \"40-60%\"), 5)\nps23 <- round(getPvalWilcox(data.plus, \"40-60%\", \"60-80%\"), 5)\nps34 <- round(getPvalWilcox(data.plus, \"60-80%\", \"80-100%\"), 5)\n\n\n\np <- ggplot(data.plus, aes(x = geneDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = geneDensityGroup),\n              color = \"black\",\n              linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \"Gene density group\" , y = \"avg log2(fold change)\") +\n  stat_summary(\n    aes(group = geneDensityGroup), fun = mean,\n    geom = \"point\", shape = 21, size = 1,\n    fill = \"red\", color = \"black\"\n  ) +\n  scale_fill_manual(values = c(\"#D9D9D9\", \"#BFBFBF\", \"#A6A6A6\", \"#8C8C8C\", \"#737373\")) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(0, 1.5)) +\n  annotate(\"text\", x = 1, y = 1, label = paste0(\"ps01: \", convPvalue(ps01), \"\\n\",\n                                                \"ps12: \", convPvalue(ps12), \"\\n\",\n                                                \"ps23: \", convPvalue(ps23), \"\\n\",\n                                                \"ps34: \", convPvalue(ps34), \"\\n\"), \n           color = \"black\", hjust = 0, size = 2)\n\n\nfileName <- paste0(\"tadGroup_geneDensity_avgLog2FC_up\")\nwidth <- panelSize(1.15)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#### DOWN\ndata.minus <- data %>% dplyr::filter(avgLog2FC < 0)\nps01 <- round(getPvalWilcox(data.minus, \"0-20%\", \"20-40%\"), 5)\nps12 <- round(getPvalWilcox(data.minus, \"20-40%\", \"40-60%\"), 5)\nps23 <- round(getPvalWilcox(data.minus, \"40-60%\", \"60-80%\"), 5)\nps34 <- round(getPvalWilcox(data.minus, \"60-80%\", \"80-100%\"), 5)\n\n\np <- ggplot(data.minus, aes(x = geneDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = geneDensityGroup),\n              color = \"black\",\n              linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \"Gene density group\" , y = \"avg log2(fold change)\") +\n  stat_summary(\n    aes(group = geneDensityGroup), fun = mean,\n    geom = \"point\", shape = 21, size = 1,\n    fill = \"red\", color = \"black\"\n  ) +\n  scale_fill_manual(values = c(\"#D9D9D9\", \"#BFBFBF\", \"#A6A6A6\", \"#8C8C8C\", \"#737373\")) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(-1.5, 0))+\n  annotate(\"text\", x = 1, y = -1, label = paste0(\"ps01: \", convPvalue(ps01), \"\\n\",\n                                                \"ps12: \", convPvalue(ps12), \"\\n\",\n                                                \"ps23: \", convPvalue(ps23), \"\\n\",\n                                                \"ps34: \", convPvalue(ps34), \"\\n\"), \n           color = \"black\", hjust = 0, size = 2)\n\nfileName <- paste0(\"tadGroup_geneDensity_avgLog2FC_down\")\nwidth <- panelSize(1.175)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n### CDF plot\n\nks_result <- ks.test(\n  data %>% dplyr::filter(geneDensityGroup == \"0-20%\") %>% pull(absAvgLog2FC),\n  data %>% dplyr::filter(geneDensityGroup == \"20-40%\") %>% pull(absAvgLog2FC)\n)\n\n\np <- ggplot(data, aes(x = absAvgLog2FC, color = geneDensityGroup)) +\n  scale_color_manual(values = rev(c(\"#777777\", \"#8B7E65\", \"#A28452\", \"#C2884D\", \"#F28E2C\"))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \"square\" ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \"Abs. log2(fold change)\",\n    y = \"Cumulative Probability\"\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.position = \"none\",\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS),\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\n\n\nfileName <- paste0(\"tadGroup_geneDensity_avgLog2FC_cdf\")\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\ndata <- data.minus\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \"0-20%\"]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \"20-40%\"]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \"20-40%\"]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \"40-60%\"]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \"40-60%\"]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \"60-80%\"]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \"60-80%\"]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \"80-100%\"]\nks.test(group1_data, group2_data)\n\n\n```"} -->\n\n```r\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj)\n\ntemp <- left_join(gene.TSS.tb, diff.RNA, by = c(\\ensembl\\ = \\ensembl_gene_id\\)) %>% dplyr::filter(!is.na(log2FoldChange),\n                                                                                                  !is.na(TAD))\n\n\ndata <- temp %>% group_by(TAD) %>%\n  dplyr::summarise(absAvgLog2FC = abs(mean(log2FoldChange)),\n                   avgLog2FC = mean(log2FoldChange),\n                   geneDensity = mean(geneDensity),\n                   enhDensity = mean(enhDensity),\n                   regDensity = mean(regDensity))\n\ndata$geneDensityGroup <- cut(\n  data$geneDensity,\n  breaks = quantile(data$geneDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),\n  include.lowest = TRUE,\n  labels = paste0(seq(0, 80, 20), \\-\\, seq(20, 100, 20), \\%\\)\n)\n\ndata$enhDensityGroup <- cut(\n  data$enhDensity,\n  breaks = quantile(data$enhDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),\n  include.lowest = TRUE,\n  labels = paste0(seq(0, 80, 20), \\-\\, seq(20, 100, 20), \\%\\)\n)\n\n\n### Ploting  grouping\n\np <- ggplot(data, aes(x = enhDensityGroup, y = enhDensity, fill = enhDensityGroup)) + \n  geom_boxplot(color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  coord_cartesian(ylim = c(0, quantile(data$enhDensity, 0.99))) +\n  labs(x = \\Enhancer Density Group\\ , y = \\TAD enhancer density\\) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    legend.position = \\none\\,\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- paste0(\\tadGroup_enhDensity\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\np <- ggplot(data, aes(x = geneDensityGroup, y = geneDensity, fill = geneDensityGroup)) + \n  geom_boxplot(color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  coord_cartesian(ylim = c(0, quantile(data$geneDensity, 0.99))) +\n  labs(x = \\Gene Density Group\\ , y = \\Gene density\\) +\n  scale_fill_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)) +\n  theme(\n    legend.position = \\none\\,\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\nfileName <- paste0(\\tadGroup_geneDensity\\)\nwidth <- 31*mmToInch\nheight <- 38*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n### Plotting distribution - enh\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(enhDensityGroup ==group1) )$avgLog2FC\n  distance2 <- (data %>% dplyr::filter(enhDensityGroup ==group2) )$avgLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\n#### ALL\n# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))\n# p <- ggplot(data, aes(x = enhDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = enhDensityGroup))+ \n#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +\n#   coord_cartesian(ylim = c(-ylim, ylim)) +\n#   geom_hline(yintercept = 0) +   theme(legend.position = \\none\\) +\n#   scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n# \n# fileName <- paste0(\\tadGroup_enhDensity_avgLog2FC\\)\n# height <- 3\n# width <- 3\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n#### UP\ndata.plus <- data %>% dplyr::filter(avgLog2FC > 0)\nps01 <- round(getPvalWilcox(data.plus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.plus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.plus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.plus, \\60-80%\\, \\80-100%\\), 5)\n\n\n\np <- ggplot(data.plus, aes(x = enhDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = enhDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Enhancer density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = enhDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(0, 1.5)) +\n  annotate(\\text\\, x = 1, y = 1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\n\nfileName <- paste0(\\tadGroup_enhDensity_avgLog2FC_up\\)\nwidth <- panelSize(1.15)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#### DOWN\ndata.minus <- data %>% dplyr::filter(avgLog2FC < 0)\nps01 <- round(getPvalWilcox(data.minus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.minus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.minus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.minus, \\60-80%\\, \\80-100%\\), 5)\n\n\np <- ggplot(data.minus, aes(x = enhDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = enhDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Enhancer density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = enhDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(-1.5, 0))+\n  annotate(\\text\\, x = 1, y = -1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\nfileName <- paste0(\\tadGroup_enhDensity_avgLog2FC_down\\)\nwidth <- panelSize(1.175)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Plotting distribution - gene\n#### ALL\n# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))\n# p <- ggplot(data, aes(x = geneDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = geneDensityGroup))+ \n#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +\n#   coord_cartesian(ylim = c(-ylim, ylim)) +\n#   geom_hline(yintercept = 0) +   theme(legend.position = \\none\\) +\n#   scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n# \n# fileName <- paste0(\\tadGroup_geneDensity_avgLog2FC\\)\n# height <- 3\n# width <- 3\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(geneDensityGroup ==group1) )$avgLog2FC\n  distance2 <- (data %>% dplyr::filter(geneDensityGroup ==group2) )$avgLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\ndata.plus <- data %>% dplyr::filter(avgLog2FC > 0)\nps01 <- round(getPvalWilcox(data.plus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.plus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.plus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.plus, \\60-80%\\, \\80-100%\\), 5)\n\n\n\np <- ggplot(data.plus, aes(x = geneDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = geneDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Gene density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = geneDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(0, 1.5)) +\n  annotate(\\text\\, x = 1, y = 1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\n\nfileName <- paste0(\\tadGroup_geneDensity_avgLog2FC_up\\)\nwidth <- panelSize(1.15)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#### DOWN\ndata.minus <- data %>% dplyr::filter(avgLog2FC < 0)\nps01 <- round(getPvalWilcox(data.minus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.minus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.minus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.minus, \\60-80%\\, \\80-100%\\), 5)\n\n\np <- ggplot(data.minus, aes(x = geneDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = geneDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Gene density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = geneDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(-1.5, 0))+\n  annotate(\\text\\, x = 1, y = -1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\nfileName <- paste0(\\tadGroup_geneDensity_avgLog2FC_down\\)\nwidth <- panelSize(1.175)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n### CDF plot\n\nks_result <- ks.test(\n  data %>% dplyr::filter(geneDensityGroup == \\0-20%\\) %>% pull(absAvgLog2FC),\n  data %>% dplyr::filter(geneDensityGroup == \\20-40%\\) %>% pull(absAvgLog2FC)\n)\n\n\np <- ggplot(data, aes(x = absAvgLog2FC, color = geneDensityGroup)) +\n  scale_color_manual(values = rev(c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS),\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\n\n\nfileName <- paste0(\\tadGroup_geneDensity_avgLog2FC_cdf\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\ndata <- data.minus\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\0-20%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\20-40%\\]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\20-40%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\40-60%\\]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\40-60%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\60-80%\\]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\60-80%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\80-100%\\]\nks.test(group1_data, group2_data)\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj)

temp <- left_join(gene.TSS.tb, diff.RNA, by = c(\ensembl\ = \ensembl_gene_id\)) %>% dplyr::filter(!is.na(log2FoldChange),
                                                                                                  !is.na(TAD))


data <- temp %>% group_by(TAD) %>%
  dplyr::summarise(absAvgLog2FC = abs(mean(log2FoldChange)),
                   avgLog2FC = mean(log2FoldChange),
                   geneDensity = mean(geneDensity),
                   enhDensity = mean(enhDensity),
                   regDensity = mean(regDensity))

data$geneDensityGroup <- cut(
  data$geneDensity,
  breaks = quantile(data$geneDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),
  include.lowest = TRUE,
  labels = paste0(seq(0, 80, 20), \-\, seq(20, 100, 20), \%\)
)

data$enhDensityGroup <- cut(
  data$enhDensity,
  breaks = quantile(data$enhDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),
  include.lowest = TRUE,
  labels = paste0(seq(0, 80, 20), \-\, seq(20, 100, 20), \%\)
)


### Ploting  grouping

p <- ggplot(data, aes(x = enhDensityGroup, y = enhDensity, fill = enhDensityGroup)) + 
  geom_boxplot(color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA) + theme_classic() +
  coord_cartesian(ylim = c(0, quantile(data$enhDensity, 0.99))) +
  labs(x = \Enhancer Density Group\ , y = \TAD enhancer density\) +
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) +
  theme(
    legend.position = \none\,
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- paste0(\tadGroup_enhDensity\)
width <- panelSize(1.2)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()




p <- ggplot(data, aes(x = geneDensityGroup, y = geneDensity, fill = geneDensityGroup)) + 
  geom_boxplot(color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA) + theme_classic() +
  coord_cartesian(ylim = c(0, quantile(data$geneDensity, 0.99))) +
  labs(x = \Gene Density Group\ , y = \Gene density\) +
  scale_fill_manual(values = c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\)) +
  theme(
    legend.position = \none\,
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )
fileName <- paste0(\tadGroup_geneDensity\)
width <- 31*mmToInch
height <- 38*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


### Plotting distribution - enh
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(enhDensityGroup ==group1) )$avgLog2FC
  distance2 <- (data %>% dplyr::filter(enhDensityGroup ==group2) )$avgLog2FC
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


#### ALL
# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))
# p <- ggplot(data, aes(x = enhDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = enhDensityGroup))+ 
#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +
#   coord_cartesian(ylim = c(-ylim, ylim)) +
#   geom_hline(yintercept = 0) +   theme(legend.position = \none\) +
#   scale_fill_manual(values = c(\#d9d9d9\, \#bdbdbd\, \#969696\, \#737373\, \#525252\))
# 
# fileName <- paste0(\tadGroup_enhDensity_avgLog2FC\)
# height <- 3
# width <- 3
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()
#### UP
data.plus <- data %>% dplyr::filter(avgLog2FC > 0)
ps01 <- round(getPvalWilcox(data.plus, \0-20%\, \20-40%\), 5)
ps12 <- round(getPvalWilcox(data.plus, \20-40%\, \40-60%\), 5)
ps23 <- round(getPvalWilcox(data.plus, \40-60%\, \60-80%\), 5)
ps34 <- round(getPvalWilcox(data.plus, \60-80%\, \80-100%\), 5)



p <- ggplot(data.plus, aes(x = enhDensityGroup, y = avgLog2FC)) + 
  geom_violin(aes(fill = enhDensityGroup),
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE)+ 
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  labs(x = \Enhancer density group\ , y = \avg log2(fold change)\) +
  stat_summary(
    aes(group = enhDensityGroup), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+ coord_cartesian(ylim = c(0, 1.5)) +
  annotate(\text\, x = 1, y = 1, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\), 
           color = \black\, hjust = 0, size = 2)


fileName <- paste0(\tadGroup_enhDensity_avgLog2FC_up\)
width <- panelSize(1.15)*mmToInch
height <- panelSize(1.07)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


#### DOWN
data.minus <- data %>% dplyr::filter(avgLog2FC < 0)
ps01 <- round(getPvalWilcox(data.minus, \0-20%\, \20-40%\), 5)
ps12 <- round(getPvalWilcox(data.minus, \20-40%\, \40-60%\), 5)
ps23 <- round(getPvalWilcox(data.minus, \40-60%\, \60-80%\), 5)
ps34 <- round(getPvalWilcox(data.minus, \60-80%\, \80-100%\), 5)


p <- ggplot(data.minus, aes(x = enhDensityGroup, y = avgLog2FC)) + 
  geom_violin(aes(fill = enhDensityGroup),
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE)+ 
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  labs(x = \Enhancer density group\ , y = \avg log2(fold change)\) +
  stat_summary(
    aes(group = enhDensityGroup), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+ coord_cartesian(ylim = c(-1.5, 0))+
  annotate(\text\, x = 1, y = -1, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\), 
           color = \black\, hjust = 0, size = 2)

fileName <- paste0(\tadGroup_enhDensity_avgLog2FC_down\)
width <- panelSize(1.175)*mmToInch
height <- panelSize(1.07)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



### Plotting distribution - gene
#### ALL
# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))
# p <- ggplot(data, aes(x = geneDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = geneDensityGroup))+ 
#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +
#   coord_cartesian(ylim = c(-ylim, ylim)) +
#   geom_hline(yintercept = 0) +   theme(legend.position = \none\) +
#   scale_fill_manual(values = c(\#d9d9d9\, \#bdbdbd\, \#969696\, \#737373\, \#525252\))
# 
# fileName <- paste0(\tadGroup_geneDensity_avgLog2FC\)
# height <- 3
# width <- 3
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(geneDensityGroup ==group1) )$avgLog2FC
  distance2 <- (data %>% dplyr::filter(geneDensityGroup ==group2) )$avgLog2FC
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


data.plus <- data %>% dplyr::filter(avgLog2FC > 0)
ps01 <- round(getPvalWilcox(data.plus, \0-20%\, \20-40%\), 5)
ps12 <- round(getPvalWilcox(data.plus, \20-40%\, \40-60%\), 5)
ps23 <- round(getPvalWilcox(data.plus, \40-60%\, \60-80%\), 5)
ps34 <- round(getPvalWilcox(data.plus, \60-80%\, \80-100%\), 5)



p <- ggplot(data.plus, aes(x = geneDensityGroup, y = avgLog2FC)) + 
  geom_violin(aes(fill = geneDensityGroup),
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE)+ 
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  labs(x = \Gene density group\ , y = \avg log2(fold change)\) +
  stat_summary(
    aes(group = geneDensityGroup), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+ coord_cartesian(ylim = c(0, 1.5)) +
  annotate(\text\, x = 1, y = 1, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\), 
           color = \black\, hjust = 0, size = 2)


fileName <- paste0(\tadGroup_geneDensity_avgLog2FC_up\)
width <- panelSize(1.15)*mmToInch
height <- panelSize(1.07)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


#### DOWN
data.minus <- data %>% dplyr::filter(avgLog2FC < 0)
ps01 <- round(getPvalWilcox(data.minus, \0-20%\, \20-40%\), 5)
ps12 <- round(getPvalWilcox(data.minus, \20-40%\, \40-60%\), 5)
ps23 <- round(getPvalWilcox(data.minus, \40-60%\, \60-80%\), 5)
ps34 <- round(getPvalWilcox(data.minus, \60-80%\, \80-100%\), 5)


p <- ggplot(data.minus, aes(x = geneDensityGroup, y = avgLog2FC)) + 
  geom_violin(aes(fill = geneDensityGroup),
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE)+ 
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  labs(x = \Gene density group\ , y = \avg log2(fold change)\) +
  stat_summary(
    aes(group = geneDensityGroup), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+ coord_cartesian(ylim = c(-1.5, 0))+
  annotate(\text\, x = 1, y = -1, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\), 
           color = \black\, hjust = 0, size = 2)

fileName <- paste0(\tadGroup_geneDensity_avgLog2FC_down\)
width <- panelSize(1.175)*mmToInch
height <- panelSize(1.07)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


### CDF plot

ks_result <- ks.test(
  data %>% dplyr::filter(geneDensityGroup == \0-20%\) %>% pull(absAvgLog2FC),
  data %>% dplyr::filter(geneDensityGroup == \20-40%\) %>% pull(absAvgLog2FC)
)


p <- ggplot(data, aes(x = absAvgLog2FC, color = geneDensityGroup)) +
  scale_color_manual(values = rev(c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \square\ ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Abs. log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.position = \none\,
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS),
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))


fileName <- paste0(\tadGroup_geneDensity_avgLog2FC_cdf\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

data <- data.minus

group1_data <- data$absAvgLog2FC[data$geneDensityGroup == \0-20%\]
group2_data <- data$absAvgLog2FC[data$geneDensityGroup == \20-40%\]
ks.test(group1_data, group2_data)

group1_data <- data$absAvgLog2FC[data$geneDensityGroup == \20-40%\]
group2_data <- data$absAvgLog2FC[data$geneDensityGroup == \40-60%\]
ks.test(group1_data, group2_data)

group1_data <- data$absAvgLog2FC[data$geneDensityGroup == \40-60%\]
group2_data <- data$absAvgLog2FC[data$geneDensityGroup == \60-80%\]
ks.test(group1_data, group2_data)

group1_data <- data$absAvgLog2FC[data$geneDensityGroup == \60-80%\]
group2_data <- data$absAvgLog2FC[data$geneDensityGroup == \80-100%\]
ks.test(group1_data, group2_data)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj)\n\ntemp <- left_join(gene.TSS.tb, diff.RNA, by = c(\\ensembl\\ = \\ensembl_gene_id\\)) %>% dplyr::filter(!is.na(log2FoldChange),\n                                                                                                  !is.na(TAD))\n\n\ndata <- temp %>% group_by(TAD) %>%\n  dplyr::summarise(absAvgLog2FC = abs(mean(log2FoldChange)),\n                   avgLog2FC = mean(log2FoldChange),\n                   geneDensity = mean(geneDensity),\n                   enhDensity = mean(enhDensity),\n                   regDensity = mean(regDensity))\n\ndata$geneDensityGroup <- cut(\n  data$geneDensity,\n  breaks = quantile(data$geneDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),\n  include.lowest = TRUE,\n  labels = paste0(seq(0, 80, 20), \\-\\, seq(20, 100, 20), \\%\\)\n)\n\ndata$enhDensityGroup <- cut(\n  data$enhDensity,\n  breaks = quantile(data$enhDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),\n  include.lowest = TRUE,\n  labels = paste0(seq(0, 80, 20), \\-\\, seq(20, 100, 20), \\%\\)\n)\n\n\n### Ploting  grouping\n\np <- ggplot(data, aes(x = enhDensityGroup, y = enhDensity, fill = enhDensityGroup)) + \n  geom_boxplot(color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  coord_cartesian(ylim = c(0, quantile(data$enhDensity, 0.99))) +\n  labs(x = \\Enhancer Density Group\\ , y = \\TAD enhancer density\\) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    legend.position = \\none\\,\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- paste0(\\tadGroup_enhDensity\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\np <- ggplot(data, aes(x = geneDensityGroup, y = geneDensity, fill = geneDensityGroup)) + \n  geom_boxplot(color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  coord_cartesian(ylim = c(0, quantile(data$geneDensity, 0.99))) +\n  labs(x = \\Gene Density Group\\ , y = \\Gene density\\) +\n  scale_fill_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)) +\n  theme(\n    legend.position = \\none\\,\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\nfileName <- paste0(\\tadGroup_geneDensity\\)\nwidth <- 31*mmToInch\nheight <- 38*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n### Plotting distribution - enh\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(enhDensityGroup ==group1) )$avgLog2FC\n  distance2 <- (data %>% dplyr::filter(enhDensityGroup ==group2) )$avgLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\n#### ALL\n# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))\n# p <- ggplot(data, aes(x = enhDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = enhDensityGroup))+ \n#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +\n#   coord_cartesian(ylim = c(-ylim, ylim)) +\n#   geom_hline(yintercept = 0) +   theme(legend.position = \\none\\) +\n#   scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n# \n# fileName <- paste0(\\tadGroup_enhDensity_avgLog2FC\\)\n# height <- 3\n# width <- 3\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n#### UP\ndata.plus <- data %>% dplyr::filter(avgLog2FC > 0)\nps01 <- round(getPvalWilcox(data.plus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.plus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.plus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.plus, \\60-80%\\, \\80-100%\\), 5)\n\n\n\np <- ggplot(data.plus, aes(x = enhDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = enhDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Enhancer density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = enhDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(0, 1.5)) +\n  annotate(\\text\\, x = 1, y = 1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\n\nfileName <- paste0(\\tadGroup_enhDensity_avgLog2FC_up\\)\nwidth <- panelSize(1.15)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#### DOWN\ndata.minus <- data %>% dplyr::filter(avgLog2FC < 0)\nps01 <- round(getPvalWilcox(data.minus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.minus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.minus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.minus, \\60-80%\\, \\80-100%\\), 5)\n\n\np <- ggplot(data.minus, aes(x = enhDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = enhDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Enhancer density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = enhDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(-1.5, 0))+\n  annotate(\\text\\, x = 1, y = -1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\nfileName <- paste0(\\tadGroup_enhDensity_avgLog2FC_down\\)\nwidth <- panelSize(1.175)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Plotting distribution - gene\n#### ALL\n# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))\n# p <- ggplot(data, aes(x = geneDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = geneDensityGroup))+ \n#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +\n#   coord_cartesian(ylim = c(-ylim, ylim)) +\n#   geom_hline(yintercept = 0) +   theme(legend.position = \\none\\) +\n#   scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n# \n# fileName <- paste0(\\tadGroup_geneDensity_avgLog2FC\\)\n# height <- 3\n# width <- 3\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(geneDensityGroup ==group1) )$avgLog2FC\n  distance2 <- (data %>% dplyr::filter(geneDensityGroup ==group2) )$avgLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\ndata.plus <- data %>% dplyr::filter(avgLog2FC > 0)\nps01 <- round(getPvalWilcox(data.plus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.plus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.plus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.plus, \\60-80%\\, \\80-100%\\), 5)\n\n\n\np <- ggplot(data.plus, aes(x = geneDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = geneDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Gene density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = geneDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(0, 1.5)) +\n  annotate(\\text\\, x = 1, y = 1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\n\nfileName <- paste0(\\tadGroup_geneDensity_avgLog2FC_up\\)\nwidth <- panelSize(1.15)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#### DOWN\ndata.minus <- data %>% dplyr::filter(avgLog2FC < 0)\nps01 <- round(getPvalWilcox(data.minus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.minus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.minus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.minus, \\60-80%\\, \\80-100%\\), 5)\n\n\np <- ggplot(data.minus, aes(x = geneDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = geneDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Gene density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = geneDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(-1.5, 0))+\n  annotate(\\text\\, x = 1, y = -1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\nfileName <- paste0(\\tadGroup_geneDensity_avgLog2FC_down\\)\nwidth <- panelSize(1.175)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n### CDF plot\n\nks_result <- ks.test(\n  data %>% dplyr::filter(geneDensityGroup == \\0-20%\\) %>% pull(absAvgLog2FC),\n  data %>% dplyr::filter(geneDensityGroup == \\20-40%\\) %>% pull(absAvgLog2FC)\n)\n\n\np <- ggplot(data, aes(x = absAvgLog2FC, color = geneDensityGroup)) +\n  scale_color_manual(values = rev(c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS),\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\n\n\nfileName <- paste0(\\tadGroup_geneDensity_avgLog2FC_cdf\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\ndata <- data.minus\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\0-20%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\20-40%\\]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\20-40%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\40-60%\\]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\40-60%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\60-80%\\]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\60-80%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\80-100%\\]\nks.test(group1_data, group2_data)\n\n\n```\n```"} -->\n\n```r\n```r\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj)\n\ntemp <- left_join(gene.TSS.tb, diff.RNA, by = c(\\ensembl\\ = \\ensembl_gene_id\\)) %>% dplyr::filter(!is.na(log2FoldChange),\n                                                                                                  !is.na(TAD))\n\n\ndata <- temp %>% group_by(TAD) %>%\n  dplyr::summarise(absAvgLog2FC = abs(mean(log2FoldChange)),\n                   avgLog2FC = mean(log2FoldChange),\n                   geneDensity = mean(geneDensity),\n                   enhDensity = mean(enhDensity),\n                   regDensity = mean(regDensity))\n\ndata$geneDensityGroup <- cut(\n  data$geneDensity,\n  breaks = quantile(data$geneDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),\n  include.lowest = TRUE,\n  labels = paste0(seq(0, 80, 20), \\-\\, seq(20, 100, 20), \\%\\)\n)\n\ndata$enhDensityGroup <- cut(\n  data$enhDensity,\n  breaks = quantile(data$enhDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),\n  include.lowest = TRUE,\n  labels = paste0(seq(0, 80, 20), \\-\\, seq(20, 100, 20), \\%\\)\n)\n\n\n### Ploting  grouping\n\np <- ggplot(data, aes(x = enhDensityGroup, y = enhDensity, fill = enhDensityGroup)) + \n  geom_boxplot(color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  coord_cartesian(ylim = c(0, quantile(data$enhDensity, 0.99))) +\n  labs(x = \\Enhancer Density Group\\ , y = \\TAD enhancer density\\) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    legend.position = \\none\\,\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- paste0(\\tadGroup_enhDensity\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\np <- ggplot(data, aes(x = geneDensityGroup, y = geneDensity, fill = geneDensityGroup)) + \n  geom_boxplot(color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  coord_cartesian(ylim = c(0, quantile(data$geneDensity, 0.99))) +\n  labs(x = \\Gene Density Group\\ , y = \\Gene density\\) +\n  scale_fill_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)) +\n  theme(\n    legend.position = \\none\\,\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\nfileName <- paste0(\\tadGroup_geneDensity\\)\nwidth <- 31*mmToInch\nheight <- 38*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n### Plotting distribution - enh\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(enhDensityGroup ==group1) )$avgLog2FC\n  distance2 <- (data %>% dplyr::filter(enhDensityGroup ==group2) )$avgLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\n#### ALL\n# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))\n# p <- ggplot(data, aes(x = enhDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = enhDensityGroup))+ \n#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +\n#   coord_cartesian(ylim = c(-ylim, ylim)) +\n#   geom_hline(yintercept = 0) +   theme(legend.position = \\none\\) +\n#   scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n# \n# fileName <- paste0(\\tadGroup_enhDensity_avgLog2FC\\)\n# height <- 3\n# width <- 3\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n#### UP\ndata.plus <- data %>% dplyr::filter(avgLog2FC > 0)\nps01 <- round(getPvalWilcox(data.plus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.plus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.plus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.plus, \\60-80%\\, \\80-100%\\), 5)\n\n\n\np <- ggplot(data.plus, aes(x = enhDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = enhDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Enhancer density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = enhDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(0, 1.5)) +\n  annotate(\\text\\, x = 1, y = 1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\n\nfileName <- paste0(\\tadGroup_enhDensity_avgLog2FC_up\\)\nwidth <- panelSize(1.15)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#### DOWN\ndata.minus <- data %>% dplyr::filter(avgLog2FC < 0)\nps01 <- round(getPvalWilcox(data.minus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.minus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.minus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.minus, \\60-80%\\, \\80-100%\\), 5)\n\n\np <- ggplot(data.minus, aes(x = enhDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = enhDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Enhancer density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = enhDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(-1.5, 0))+\n  annotate(\\text\\, x = 1, y = -1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\nfileName <- paste0(\\tadGroup_enhDensity_avgLog2FC_down\\)\nwidth <- panelSize(1.175)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Plotting distribution - gene\n#### ALL\n# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))\n# p <- ggplot(data, aes(x = geneDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = geneDensityGroup))+ \n#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +\n#   coord_cartesian(ylim = c(-ylim, ylim)) +\n#   geom_hline(yintercept = 0) +   theme(legend.position = \\none\\) +\n#   scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n# \n# fileName <- paste0(\\tadGroup_geneDensity_avgLog2FC\\)\n# height <- 3\n# width <- 3\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(geneDensityGroup ==group1) )$avgLog2FC\n  distance2 <- (data %>% dplyr::filter(geneDensityGroup ==group2) )$avgLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\ndata.plus <- data %>% dplyr::filter(avgLog2FC > 0)\nps01 <- round(getPvalWilcox(data.plus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.plus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.plus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.plus, \\60-80%\\, \\80-100%\\), 5)\n\n\n\np <- ggplot(data.plus, aes(x = geneDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = geneDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Gene density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = geneDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(0, 1.5)) +\n  annotate(\\text\\, x = 1, y = 1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\n\nfileName <- paste0(\\tadGroup_geneDensity_avgLog2FC_up\\)\nwidth <- panelSize(1.15)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#### DOWN\ndata.minus <- data %>% dplyr::filter(avgLog2FC < 0)\nps01 <- round(getPvalWilcox(data.minus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.minus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.minus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.minus, \\60-80%\\, \\80-100%\\), 5)\n\n\np <- ggplot(data.minus, aes(x = geneDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = geneDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Gene density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = geneDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(-1.5, 0))+\n  annotate(\\text\\, x = 1, y = -1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\nfileName <- paste0(\\tadGroup_geneDensity_avgLog2FC_down\\)\nwidth <- panelSize(1.175)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n### CDF plot\n\nks_result <- ks.test(\n  data %>% dplyr::filter(geneDensityGroup == \\0-20%\\) %>% pull(absAvgLog2FC),\n  data %>% dplyr::filter(geneDensityGroup == \\20-40%\\) %>% pull(absAvgLog2FC)\n)\n\n\np <- ggplot(data, aes(x = absAvgLog2FC, color = geneDensityGroup)) +\n  scale_color_manual(values = rev(c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS),\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\n\n\nfileName <- paste0(\\tadGroup_geneDensity_avgLog2FC_cdf\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\ndata <- data.minus\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\0-20%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\20-40%\\]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\20-40%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\40-60%\\]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\40-60%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\60-80%\\]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\60-80%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\80-100%\\]\nks.test(group1_data, group2_data)\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj)\n\ntemp <- left_join(gene.TSS.tb, diff.RNA, by = c(\\ensembl\\ = \\ensembl_gene_id\\)) %>% dplyr::filter(!is.na(log2FoldChange),\n                                                                                                  !is.na(TAD))\n\n\ndata <- temp %>% group_by(TAD) %>%\n  dplyr::summarise(absAvgLog2FC = abs(mean(log2FoldChange)),\n                   avgLog2FC = mean(log2FoldChange),\n                   geneDensity = mean(geneDensity),\n                   enhDensity = mean(enhDensity),\n                   regDensity = mean(regDensity))\n\ndata$geneDensityGroup <- cut(\n  data$geneDensity,\n  breaks = quantile(data$geneDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),\n  include.lowest = TRUE,\n  labels = paste0(seq(0, 80, 20), \\-\\, seq(20, 100, 20), \\%\\)\n)\n\ndata$enhDensityGroup <- cut(\n  data$enhDensity,\n  breaks = quantile(data$enhDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),\n  include.lowest = TRUE,\n  labels = paste0(seq(0, 80, 20), \\-\\, seq(20, 100, 20), \\%\\)\n)\n\n\n### Ploting  grouping\n\np <- ggplot(data, aes(x = enhDensityGroup, y = enhDensity, fill = enhDensityGroup)) + \n  geom_boxplot(color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  coord_cartesian(ylim = c(0, quantile(data$enhDensity, 0.99))) +\n  labs(x = \\Enhancer Density Group\\ , y = \\TAD enhancer density\\) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    legend.position = \\none\\,\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- paste0(\\tadGroup_enhDensity\\)\nwidth <- panelSize(1.2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\np <- ggplot(data, aes(x = geneDensityGroup, y = geneDensity, fill = geneDensityGroup)) + \n  geom_boxplot(color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  coord_cartesian(ylim = c(0, quantile(data$geneDensity, 0.99))) +\n  labs(x = \\Gene Density Group\\ , y = \\Gene density\\) +\n  scale_fill_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)) +\n  theme(\n    legend.position = \\none\\,\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\nfileName <- paste0(\\tadGroup_geneDensity\\)\nwidth <- 31*mmToInch\nheight <- 38*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n### Plotting distribution - enh\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(enhDensityGroup ==group1) )$avgLog2FC\n  distance2 <- (data %>% dplyr::filter(enhDensityGroup ==group2) )$avgLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\n#### ALL\n# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))\n# p <- ggplot(data, aes(x = enhDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = enhDensityGroup))+ \n#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +\n#   coord_cartesian(ylim = c(-ylim, ylim)) +\n#   geom_hline(yintercept = 0) +   theme(legend.position = \\none\\) +\n#   scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n# \n# fileName <- paste0(\\tadGroup_enhDensity_avgLog2FC\\)\n# height <- 3\n# width <- 3\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n#### UP\ndata.plus <- data %>% dplyr::filter(avgLog2FC > 0)\nps01 <- round(getPvalWilcox(data.plus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.plus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.plus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.plus, \\60-80%\\, \\80-100%\\), 5)\n\n\n\np <- ggplot(data.plus, aes(x = enhDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = enhDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Enhancer density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = enhDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(0, 1.5)) +\n  annotate(\\text\\, x = 1, y = 1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\n\nfileName <- paste0(\\tadGroup_enhDensity_avgLog2FC_up\\)\nwidth <- panelSize(1.15)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#### DOWN\ndata.minus <- data %>% dplyr::filter(avgLog2FC < 0)\nps01 <- round(getPvalWilcox(data.minus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.minus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.minus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.minus, \\60-80%\\, \\80-100%\\), 5)\n\n\np <- ggplot(data.minus, aes(x = enhDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = enhDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Enhancer density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = enhDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(-1.5, 0))+\n  annotate(\\text\\, x = 1, y = -1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\nfileName <- paste0(\\tadGroup_enhDensity_avgLog2FC_down\\)\nwidth <- panelSize(1.175)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Plotting distribution - gene\n#### ALL\n# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))\n# p <- ggplot(data, aes(x = geneDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = geneDensityGroup))+ \n#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +\n#   coord_cartesian(ylim = c(-ylim, ylim)) +\n#   geom_hline(yintercept = 0) +   theme(legend.position = \\none\\) +\n#   scale_fill_manual(values = c(\\#d9d9d9\\, \\#bdbdbd\\, \\#969696\\, \\#737373\\, \\#525252\\))\n# \n# fileName <- paste0(\\tadGroup_geneDensity_avgLog2FC\\)\n# height <- 3\n# width <- 3\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n getPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(geneDensityGroup ==group1) )$avgLog2FC\n  distance2 <- (data %>% dplyr::filter(geneDensityGroup ==group2) )$avgLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\ndata.plus <- data %>% dplyr::filter(avgLog2FC > 0)\nps01 <- round(getPvalWilcox(data.plus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.plus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.plus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.plus, \\60-80%\\, \\80-100%\\), 5)\n\n\n\np <- ggplot(data.plus, aes(x = geneDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = geneDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Gene density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = geneDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(0, 1.5)) +\n  annotate(\\text\\, x = 1, y = 1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\n\nfileName <- paste0(\\tadGroup_geneDensity_avgLog2FC_up\\)\nwidth <- panelSize(1.15)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n#### DOWN\ndata.minus <- data %>% dplyr::filter(avgLog2FC < 0)\nps01 <- round(getPvalWilcox(data.minus, \\0-20%\\, \\20-40%\\), 5)\nps12 <- round(getPvalWilcox(data.minus, \\20-40%\\, \\40-60%\\), 5)\nps23 <- round(getPvalWilcox(data.minus, \\40-60%\\, \\60-80%\\), 5)\nps34 <- round(getPvalWilcox(data.minus, \\60-80%\\, \\80-100%\\), 5)\n\n\np <- ggplot(data.minus, aes(x = geneDensityGroup, y = avgLog2FC)) + \n  geom_violin(aes(fill = geneDensityGroup),\n              color = \\black\\,\n              linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE)+ \n  geom_boxplot(width = 0.1, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  labs(x = \\Gene density group\\ , y = \\avg log2(fold change)\\) +\n  stat_summary(\n    aes(group = geneDensityGroup), fun = mean,\n    geom = \\point\\, shape = 21, size = 1,\n    fill = \\red\\, color = \\black\\\n  ) +\n  scale_fill_manual(values = c(\\#D9D9D9\\, \\#BFBFBF\\, \\#A6A6A6\\, \\#8C8C8C\\, \\#737373\\)) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+ coord_cartesian(ylim = c(-1.5, 0))+\n  annotate(\\text\\, x = 1, y = -1, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2)\n\nfileName <- paste0(\\tadGroup_geneDensity_avgLog2FC_down\\)\nwidth <- panelSize(1.175)*mmToInch\nheight <- panelSize(1.07)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n### CDF plot\n\nks_result <- ks.test(\n  data %>% dplyr::filter(geneDensityGroup == \\0-20%\\) %>% pull(absAvgLog2FC),\n  data %>% dplyr::filter(geneDensityGroup == \\20-40%\\) %>% pull(absAvgLog2FC)\n)\n\n\np <- ggplot(data, aes(x = absAvgLog2FC, color = geneDensityGroup)) +\n  scale_color_manual(values = rev(c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))) +\n  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\ ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS),\n    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))\n\n\nfileName <- paste0(\\tadGroup_geneDensity_avgLog2FC_cdf\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\ndata <- data.minus\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\0-20%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\20-40%\\]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\20-40%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\40-60%\\]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\40-60%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\60-80%\\]\nks.test(group1_data, group2_data)\n\ngroup1_data <- data$absAvgLog2FC[data$geneDensityGroup == \\60-80%\\]\ngroup2_data <- data$absAvgLog2FC[data$geneDensityGroup == \\80-100%\\]\nks.test(group1_data, group2_data)\n\n\n```\n```"} -->

```r
```r
diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj)

temp <- left_join(gene.TSS.tb, diff.RNA, by = c(\ensembl\ = \ensembl_gene_id\)) %>% dplyr::filter(!is.na(log2FoldChange),
                                                                                                  !is.na(TAD))


data <- temp %>% group_by(TAD) %>%
  dplyr::summarise(absAvgLog2FC = abs(mean(log2FoldChange)),
                   avgLog2FC = mean(log2FoldChange),
                   geneDensity = mean(geneDensity),
                   enhDensity = mean(enhDensity),
                   regDensity = mean(regDensity))

data$geneDensityGroup <- cut(
  data$geneDensity,
  breaks = quantile(data$geneDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),
  include.lowest = TRUE,
  labels = paste0(seq(0, 80, 20), \-\, seq(20, 100, 20), \%\)
)

data$enhDensityGroup <- cut(
  data$enhDensity,
  breaks = quantile(data$enhDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),
  include.lowest = TRUE,
  labels = paste0(seq(0, 80, 20), \-\, seq(20, 100, 20), \%\)
)


### Ploting  grouping

p <- ggplot(data, aes(x = enhDensityGroup, y = enhDensity, fill = enhDensityGroup)) + 
  geom_boxplot(color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA) + theme_classic() +
  coord_cartesian(ylim = c(0, quantile(data$enhDensity, 0.99))) +
  labs(x = \Enhancer Density Group\ , y = \TAD enhancer density\) +
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) +
  theme(
    legend.position = \none\,
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- paste0(\tadGroup_enhDensity\)
width <- panelSize(1.2)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()




p <- ggplot(data, aes(x = geneDensityGroup, y = geneDensity, fill = geneDensityGroup)) + 
  geom_boxplot(color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA) + theme_classic() +
  coord_cartesian(ylim = c(0, quantile(data$geneDensity, 0.99))) +
  labs(x = \Gene Density Group\ , y = \Gene density\) +
  scale_fill_manual(values = c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\)) +
  theme(
    legend.position = \none\,
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )
fileName <- paste0(\tadGroup_geneDensity\)
width <- 31*mmToInch
height <- 38*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


### Plotting distribution - enh
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(enhDensityGroup ==group1) )$avgLog2FC
  distance2 <- (data %>% dplyr::filter(enhDensityGroup ==group2) )$avgLog2FC
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


#### ALL
# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))
# p <- ggplot(data, aes(x = enhDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = enhDensityGroup))+ 
#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +
#   coord_cartesian(ylim = c(-ylim, ylim)) +
#   geom_hline(yintercept = 0) +   theme(legend.position = \none\) +
#   scale_fill_manual(values = c(\#d9d9d9\, \#bdbdbd\, \#969696\, \#737373\, \#525252\))
# 
# fileName <- paste0(\tadGroup_enhDensity_avgLog2FC\)
# height <- 3
# width <- 3
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()
#### UP
data.plus <- data %>% dplyr::filter(avgLog2FC > 0)
ps01 <- round(getPvalWilcox(data.plus, \0-20%\, \20-40%\), 5)
ps12 <- round(getPvalWilcox(data.plus, \20-40%\, \40-60%\), 5)
ps23 <- round(getPvalWilcox(data.plus, \40-60%\, \60-80%\), 5)
ps34 <- round(getPvalWilcox(data.plus, \60-80%\, \80-100%\), 5)



p <- ggplot(data.plus, aes(x = enhDensityGroup, y = avgLog2FC)) + 
  geom_violin(aes(fill = enhDensityGroup),
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE)+ 
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  labs(x = \Enhancer density group\ , y = \avg log2(fold change)\) +
  stat_summary(
    aes(group = enhDensityGroup), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+ coord_cartesian(ylim = c(0, 1.5)) +
  annotate(\text\, x = 1, y = 1, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\), 
           color = \black\, hjust = 0, size = 2)


fileName <- paste0(\tadGroup_enhDensity_avgLog2FC_up\)
width <- panelSize(1.15)*mmToInch
height <- panelSize(1.07)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


#### DOWN
data.minus <- data %>% dplyr::filter(avgLog2FC < 0)
ps01 <- round(getPvalWilcox(data.minus, \0-20%\, \20-40%\), 5)
ps12 <- round(getPvalWilcox(data.minus, \20-40%\, \40-60%\), 5)
ps23 <- round(getPvalWilcox(data.minus, \40-60%\, \60-80%\), 5)
ps34 <- round(getPvalWilcox(data.minus, \60-80%\, \80-100%\), 5)


p <- ggplot(data.minus, aes(x = enhDensityGroup, y = avgLog2FC)) + 
  geom_violin(aes(fill = enhDensityGroup),
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE)+ 
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  labs(x = \Enhancer density group\ , y = \avg log2(fold change)\) +
  stat_summary(
    aes(group = enhDensityGroup), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+ coord_cartesian(ylim = c(-1.5, 0))+
  annotate(\text\, x = 1, y = -1, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\), 
           color = \black\, hjust = 0, size = 2)

fileName <- paste0(\tadGroup_enhDensity_avgLog2FC_down\)
width <- panelSize(1.175)*mmToInch
height <- panelSize(1.07)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



### Plotting distribution - gene
#### ALL
# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))
# p <- ggplot(data, aes(x = geneDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = geneDensityGroup))+ 
#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +
#   coord_cartesian(ylim = c(-ylim, ylim)) +
#   geom_hline(yintercept = 0) +   theme(legend.position = \none\) +
#   scale_fill_manual(values = c(\#d9d9d9\, \#bdbdbd\, \#969696\, \#737373\, \#525252\))
# 
# fileName <- paste0(\tadGroup_geneDensity_avgLog2FC\)
# height <- 3
# width <- 3
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(geneDensityGroup ==group1) )$avgLog2FC
  distance2 <- (data %>% dplyr::filter(geneDensityGroup ==group2) )$avgLog2FC
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


data.plus <- data %>% dplyr::filter(avgLog2FC > 0)
ps01 <- round(getPvalWilcox(data.plus, \0-20%\, \20-40%\), 5)
ps12 <- round(getPvalWilcox(data.plus, \20-40%\, \40-60%\), 5)
ps23 <- round(getPvalWilcox(data.plus, \40-60%\, \60-80%\), 5)
ps34 <- round(getPvalWilcox(data.plus, \60-80%\, \80-100%\), 5)



p <- ggplot(data.plus, aes(x = geneDensityGroup, y = avgLog2FC)) + 
  geom_violin(aes(fill = geneDensityGroup),
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE)+ 
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  labs(x = \Gene density group\ , y = \avg log2(fold change)\) +
  stat_summary(
    aes(group = geneDensityGroup), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+ coord_cartesian(ylim = c(0, 1.5)) +
  annotate(\text\, x = 1, y = 1, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\), 
           color = \black\, hjust = 0, size = 2)


fileName <- paste0(\tadGroup_geneDensity_avgLog2FC_up\)
width <- panelSize(1.15)*mmToInch
height <- panelSize(1.07)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


#### DOWN
data.minus <- data %>% dplyr::filter(avgLog2FC < 0)
ps01 <- round(getPvalWilcox(data.minus, \0-20%\, \20-40%\), 5)
ps12 <- round(getPvalWilcox(data.minus, \20-40%\, \40-60%\), 5)
ps23 <- round(getPvalWilcox(data.minus, \40-60%\, \60-80%\), 5)
ps34 <- round(getPvalWilcox(data.minus, \60-80%\, \80-100%\), 5)


p <- ggplot(data.minus, aes(x = geneDensityGroup, y = avgLog2FC)) + 
  geom_violin(aes(fill = geneDensityGroup),
              color = \black\,
              linewidth = lineThick * mmToLineUnit, lineend = \square\,
              show.legend = FALSE)+ 
  geom_boxplot(width = 0.1, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  labs(x = \Gene density group\ , y = \avg log2(fold change)\) +
  stat_summary(
    aes(group = geneDensityGroup), fun = mean,
    geom = \point\, shape = 21, size = 1,
    fill = \red\, color = \black\
  ) +
  scale_fill_manual(values = c(\#D9D9D9\, \#BFBFBF\, \#A6A6A6\, \#8C8C8C\, \#737373\)) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+ coord_cartesian(ylim = c(-1.5, 0))+
  annotate(\text\, x = 1, y = -1, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\), 
           color = \black\, hjust = 0, size = 2)

fileName <- paste0(\tadGroup_geneDensity_avgLog2FC_down\)
width <- panelSize(1.175)*mmToInch
height <- panelSize(1.07)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


### CDF plot

ks_result <- ks.test(
  data %>% dplyr::filter(geneDensityGroup == \0-20%\) %>% pull(absAvgLog2FC),
  data %>% dplyr::filter(geneDensityGroup == \20-40%\) %>% pull(absAvgLog2FC)
)


p <- ggplot(data, aes(x = absAvgLog2FC, color = geneDensityGroup)) +
  scale_color_manual(values = rev(c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \square\ ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Abs. log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.position = \none\,
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS),
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))


fileName <- paste0(\tadGroup_geneDensity_avgLog2FC_cdf\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

data <- data.minus

group1_data <- data$absAvgLog2FC[data$geneDensityGroup == \0-20%\]
group2_data <- data$absAvgLog2FC[data$geneDensityGroup == \20-40%\]
ks.test(group1_data, group2_data)

group1_data <- data$absAvgLog2FC[data$geneDensityGroup == \20-40%\]
group2_data <- data$absAvgLog2FC[data$geneDensityGroup == \40-60%\]
ks.test(group1_data, group2_data)

group1_data <- data$absAvgLog2FC[data$geneDensityGroup == \40-60%\]
group2_data <- data$absAvgLog2FC[data$geneDensityGroup == \60-80%\]
ks.test(group1_data, group2_data)

group1_data <- data$absAvgLog2FC[data$geneDensityGroup == \60-80%\]
group2_data <- data$absAvgLog2FC[data$geneDensityGroup == \80-100%\]
ks.test(group1_data, group2_data)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### regdensity

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuY29uc2Vuc3VzLmxvb3AuYW5uby50YiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiLnRzdlwiKSkpXG5cbiMgSW1wb3J0IGluc3VsYXRpb24gc2NvcmUgY2FsY3VsYXRlZCB3aXRoIHB5dGhvblxucmVzdWx0RGlyIDwtIGhlcmUoXCIuLi8uLi9yZXN1bHRcIilcbmluc1Njb3JlLkRNU08gPC0gZnJlYWQoaGVyZShyZXN1bHREaXIsIFwiVEFEXCIsIFwiaW5zdWxhdGlvblNjb3JlXzI1a2JfRzFETVNPLnRzdlwiKSkgJT4lIFxuICBkcGx5cjo6c2VsZWN0KGMoXCJjaHJvbVwiLCBcInN0YXJ0XCIsIFwiZW5kXCIsIFwibG9nMl9pbnN1bGF0aW9uX3Njb3JlXzEyNTAwMFwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoYmluSUQgPSBwYXN0ZShjaHJvbSwgc3RhcnQsIGVuZCwgc2VwID0gXCJfXCIpKVxuY29sbmFtZXMoaW5zU2NvcmUuRE1TTykgPC0gYyhcImNocm9tXCIsIFwic3RhcnRcIiwgXCJlbmRcIiwgXCJpbnN1bGF0aW9uU2NvcmVcIiwgXCJiaW5JRFwiKVxuaW5zU2NvcmUuZFRBRyA8LSBmcmVhZChoZXJlKHJlc3VsdERpciwgXCJUQURcIiwgXCJpbnN1bGF0aW9uU2NvcmVfMjVrYl9HMWRUQUcudHN2XCIpKSAlPiUgXG4gIGRwbHlyOjpzZWxlY3QoYyhcImNocm9tXCIsIFwic3RhcnRcIiwgXCJlbmRcIiwgXCJsb2cyX2luc3VsYXRpb25fc2NvcmVfMTI1MDAwXCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShiaW5JRCA9IHBhc3RlKGNocm9tLCBzdGFydCwgZW5kLCBzZXAgPSBcIl9cIikpXG5jb2xuYW1lcyhpbnNTY29yZS5kVEFHKSA8LSBjKFwiY2hyb21cIiwgXCJzdGFydFwiLCBcImVuZFwiLCBcImluc3VsYXRpb25TY29yZVwiLCBcImJpbklEXCIpXG5pbnNTY29yZS5BNDg1IDwtIGZyZWFkKGhlcmUocmVzdWx0RGlyLCBcIlRBRFwiLCBcImluc3VsYXRpb25TY29yZV8yNWtiX0cxQTQ4NS50c3ZcIikpICU+JSBcbiAgZHBseXI6OnNlbGVjdChjKFwiY2hyb21cIiwgXCJzdGFydFwiLCBcImVuZFwiLCBcImxvZzJfaW5zdWxhdGlvbl9zY29yZV8xMjUwMDBcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKGJpbklEID0gcGFzdGUoY2hyb20sIHN0YXJ0LCBlbmQsIHNlcCA9IFwiX1wiKSlcbmNvbG5hbWVzKGluc1Njb3JlLkE0ODUpIDwtIGMoXCJjaHJvbVwiLCBcInN0YXJ0XCIsIFwiZW5kXCIsIFwiaW5zdWxhdGlvblNjb3JlXCIsIFwiYmluSURcIilcblxuZ2V0SW5zdWxhdGlvblNjb3JlIDwtIGZ1bmN0aW9uKGNociwgY29vcmRpbmF0ZSwgaW5zU2NvcmUudGIpe1xuICB0ZW1wLnRiIDwtIGluc1Njb3JlLnRiICU+JSBkcGx5cjo6ZmlsdGVyKGNocm9tID09IGNociwgc3RhcnQgPCBjb29yZGluYXRlLCBlbmQgPiBjb29yZGluYXRlKVxuICBvdXQgPC0gdGVtcC50YiRpbnN1bGF0aW9uU2NvcmVcbiAgaWYobGVuZ3RoKG91dCkgPCAxKXtcbiAgICByZXR1cm4oTkEpXG4gIH1lbHNle1xuICAgIHJldHVybih0ZW1wLnRiJGluc3VsYXRpb25TY29yZSlcbiAgfVxufVxuXG4jIEltcG9ydGluZyBUQUQgYm91bmRhcmllc1xudGFkX2JvdW5kYXJ5IDwtIGZyZWFkKGhlcmUoXCIuLi8uLi9yZXN1bHQvVEFEXCIsIFwiVEFEXzI1a2JfMTI1a2Jfb3RzdV9ib3VuZGFyaWVzX0cxRE1TTy5iZWRcIikpXG5jb2xuYW1lcyh0YWRfYm91bmRhcnkpIDwtIGMoXCJjaHJcIiwgXCJzdGFydFwiLCBcImVuZFwiKVxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhZF9pZCA9IHBhc3RlKGNociwgc3RhcnQsIGVuZCwgc2VwID0gXCJfXCIpLFxuICAgICAgICAgICAgICAgIGNlbnRlciA9IChzdGFydCArIGVuZCkvMixcbiAgICAgICAgICAgICAgICBpbnNTY29yZV9ETVNPID0gZ2V0SW5zdWxhdGlvblNjb3JlKGNociwgY2VudGVyLCBpbnNTY29yZS5ETVNPKSxcbiAgICAgICAgICAgICAgICBpbnNTY29yZV9kVEFHID0gZ2V0SW5zdWxhdGlvblNjb3JlKGNociwgY2VudGVyLCBpbnNTY29yZS5kVEFHKSxcbiAgICAgICAgICAgICAgICBpbnNTY29yZV9BNDg1ID0gZ2V0SW5zdWxhdGlvblNjb3JlKGNociwgY2VudGVyLCBpbnNTY29yZS5BNDg1KSlcblxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgZmlsdGVyKCFpZl9hbnkoZXZlcnl0aGluZygpLCBpcy5uYSkpXG5cbnRhZF9ib3VuZGFyeSRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRhZF9ib3VuZGFyeSRpbnNTY29yZV9ETVNPLCB0YWRfYm91bmRhcnkkaW5zU2NvcmVfZFRBRywgbiA9IDEwMClcbnRhZF9ib3VuZGFyeSA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nZ3Bsb3QodGFkX2JvdW5kYXJ5LCBhZXMoeCA9IGluc1Njb3JlX0RNU08sIHkgPSBpbnNTY29yZV9kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArIGNvb3JkX2ZpeGVkKCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICsgdGhlbWVfYncoKVxuXG5cblxudGFkX2JvdW5kYXJ5JGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGFkX2JvdW5kYXJ5JGluc1Njb3JlX0RNU08sIHRhZF9ib3VuZGFyeSRpbnNTY29yZV9BNDg1LCBuID0gMTAwKVxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmdncGxvdCh0YWRfYm91bmRhcnksIGFlcyh4ID0gaW5zU2NvcmVfRE1TTywgeSA9IGluc1Njb3JlX0E0ODUsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgc2NhbGVfY29sb3JfdmlyaWRpcygpICsgY29vcmRfZml4ZWQoKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgKyB0aGVtZV9idygpXG5cblxuXG5cbmBgYCJ9 -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\nconsensus.loop.anno.tb <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\n\n# Import insulation score calculated with python\nresultDir <- here(\\../../result\\)\ninsScore.DMSO <- fread(here(resultDir, \\TAD\\, \\insulationScore_25kb_G1DMSO.tsv\\)) %>% \n  dplyr::select(c(\\chrom\\, \\start\\, \\end\\, \\log2_insulation_score_125000\\)) %>%\n  dplyr::mutate(binID = paste(chrom, start, end, sep = \\_\\))\ncolnames(insScore.DMSO) <- c(\\chrom\\, \\start\\, \\end\\, \\insulationScore\\, \\binID\\)\ninsScore.dTAG <- fread(here(resultDir, \\TAD\\, \\insulationScore_25kb_G1dTAG.tsv\\)) %>% \n  dplyr::select(c(\\chrom\\, \\start\\, \\end\\, \\log2_insulation_score_125000\\)) %>%\n  dplyr::mutate(binID = paste(chrom, start, end, sep = \\_\\))\ncolnames(insScore.dTAG) <- c(\\chrom\\, \\start\\, \\end\\, \\insulationScore\\, \\binID\\)\ninsScore.A485 <- fread(here(resultDir, \\TAD\\, \\insulationScore_25kb_G1A485.tsv\\)) %>% \n  dplyr::select(c(\\chrom\\, \\start\\, \\end\\, \\log2_insulation_score_125000\\)) %>%\n  dplyr::mutate(binID = paste(chrom, start, end, sep = \\_\\))\ncolnames(insScore.A485) <- c(\\chrom\\, \\start\\, \\end\\, \\insulationScore\\, \\binID\\)\n\ngetInsulationScore <- function(chr, coordinate, insScore.tb){\n  temp.tb <- insScore.tb %>% dplyr::filter(chrom == chr, start < coordinate, end > coordinate)\n  out <- temp.tb$insulationScore\n  if(length(out) < 1){\n    return(NA)\n  }else{\n    return(temp.tb$insulationScore)\n  }\n}\n\n# Importing TAD boundaries\ntad_boundary <- fread(here(\\../../result/TAD\\, \\TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\\))\ncolnames(tad_boundary) <- c(\\chr\\, \\start\\, \\end\\)\ntad_boundary <- tad_boundary %>% rowwise() %>%\n  dplyr::mutate(tad_id = paste(chr, start, end, sep = \\_\\),\n                center = (start + end)/2,\n                insScore_DMSO = getInsulationScore(chr, center, insScore.DMSO),\n                insScore_dTAG = getInsulationScore(chr, center, insScore.dTAG),\n                insScore_A485 = getInsulationScore(chr, center, insScore.A485))\n\ntad_boundary <- tad_boundary %>% filter(!if_any(everything(), is.na))\n\ntad_boundary$density <- get_density(tad_boundary$insScore_DMSO, tad_boundary$insScore_dTAG, n = 100)\ntad_boundary <- tad_boundary %>% dplyr::arrange(density)\nggplot(tad_boundary, aes(x = insScore_DMSO, y = insScore_dTAG, color = density)) + \n  geom_point(show.legend = FALSE) + \n  scale_color_viridis() + coord_fixed() +\n  geom_abline(slope = 1, intercept = 0) + theme_bw()\n\n\n\ntad_boundary$density <- get_density(tad_boundary$insScore_DMSO, tad_boundary$insScore_A485, n = 100)\ntad_boundary <- tad_boundary %>% dplyr::arrange(density)\nggplot(tad_boundary, aes(x = insScore_DMSO, y = insScore_A485, color = density)) + \n  geom_point(show.legend = FALSE) + \n  scale_color_viridis() + coord_fixed() +\n  geom_abline(slope = 1, intercept = 0) + theme_bw()\n\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\
consensus.loop.anno.tb <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import insulation score calculated with python
resultDir <- here(\../../result\)
insScore.DMSO <- fread(here(resultDir, \TAD\, \insulationScore_25kb_G1DMSO.tsv\)) %>% 
  dplyr::select(c(\chrom\, \start\, \end\, \log2_insulation_score_125000\)) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = \_\))
colnames(insScore.DMSO) <- c(\chrom\, \start\, \end\, \insulationScore\, \binID\)
insScore.dTAG <- fread(here(resultDir, \TAD\, \insulationScore_25kb_G1dTAG.tsv\)) %>% 
  dplyr::select(c(\chrom\, \start\, \end\, \log2_insulation_score_125000\)) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = \_\))
colnames(insScore.dTAG) <- c(\chrom\, \start\, \end\, \insulationScore\, \binID\)
insScore.A485 <- fread(here(resultDir, \TAD\, \insulationScore_25kb_G1A485.tsv\)) %>% 
  dplyr::select(c(\chrom\, \start\, \end\, \log2_insulation_score_125000\)) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = \_\))
colnames(insScore.A485) <- c(\chrom\, \start\, \end\, \insulationScore\, \binID\)

getInsulationScore <- function(chr, coordinate, insScore.tb){
  temp.tb <- insScore.tb %>% dplyr::filter(chrom == chr, start < coordinate, end > coordinate)
  out <- temp.tb$insulationScore
  if(length(out) < 1){
    return(NA)
  }else{
    return(temp.tb$insulationScore)
  }
}

# Importing TAD boundaries
tad_boundary <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\))
colnames(tad_boundary) <- c(\chr\, \start\, \end\)
tad_boundary <- tad_boundary %>% rowwise() %>%
  dplyr::mutate(tad_id = paste(chr, start, end, sep = \_\),
                center = (start + end)/2,
                insScore_DMSO = getInsulationScore(chr, center, insScore.DMSO),
                insScore_dTAG = getInsulationScore(chr, center, insScore.dTAG),
                insScore_A485 = getInsulationScore(chr, center, insScore.A485))

tad_boundary <- tad_boundary %>% filter(!if_any(everything(), is.na))

tad_boundary$density <- get_density(tad_boundary$insScore_DMSO, tad_boundary$insScore_dTAG, n = 100)
tad_boundary <- tad_boundary %>% dplyr::arrange(density)
ggplot(tad_boundary, aes(x = insScore_DMSO, y = insScore_dTAG, color = density)) + 
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() + coord_fixed() +
  geom_abline(slope = 1, intercept = 0) + theme_bw()



tad_boundary$density <- get_density(tad_boundary$insScore_DMSO, tad_boundary$insScore_A485, n = 100)
tad_boundary <- tad_boundary %>% dplyr::arrange(density)
ggplot(tad_boundary, aes(x = insScore_DMSO, y = insScore_A485, color = density)) + 
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() + coord_fixed() +
  geom_abline(slope = 1, intercept = 0) + theme_bw()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuY29uc2Vuc3VzLmxvb3AuYW5uby50YiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5cbiMgSW1wb3J0IGluc3VsYXRpb24gc2NvcmUgY2FsY3VsYXRlZCB3aXRoIHB5dGhvblxucmVzdWx0RGlyIDwtIGhlcmUoXFwuLi8uLi9yZXN1bHRcXClcbmluc1Njb3JlLkRNU08gPC0gZnJlYWQoaGVyZShyZXN1bHREaXIsIFxcVEFEXFwsIFxcaW5zdWxhdGlvblNjb3JlXzI1a2JfRzFETVNPLnRzdlxcKSkgJT4lIFxuICBkcGx5cjo6c2VsZWN0KGMoXFxjaHJvbVxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcbG9nMl9pbnN1bGF0aW9uX3Njb3JlXzEyNTAwMFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoYmluSUQgPSBwYXN0ZShjaHJvbSwgc3RhcnQsIGVuZCwgc2VwID0gXFxfXFwpKVxuY29sbmFtZXMoaW5zU2NvcmUuRE1TTykgPC0gYyhcXGNocm9tXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxpbnN1bGF0aW9uU2NvcmVcXCwgXFxiaW5JRFxcKVxuaW5zU2NvcmUuZFRBRyA8LSBmcmVhZChoZXJlKHJlc3VsdERpciwgXFxUQURcXCwgXFxpbnN1bGF0aW9uU2NvcmVfMjVrYl9HMWRUQUcudHN2XFwpKSAlPiUgXG4gIGRwbHlyOjpzZWxlY3QoYyhcXGNocm9tXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxsb2cyX2luc3VsYXRpb25fc2NvcmVfMTI1MDAwXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShiaW5JRCA9IHBhc3RlKGNocm9tLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCkpXG5jb2xuYW1lcyhpbnNTY29yZS5kVEFHKSA8LSBjKFxcY2hyb21cXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGluc3VsYXRpb25TY29yZVxcLCBcXGJpbklEXFwpXG5pbnNTY29yZS5BNDg1IDwtIGZyZWFkKGhlcmUocmVzdWx0RGlyLCBcXFRBRFxcLCBcXGluc3VsYXRpb25TY29yZV8yNWtiX0cxQTQ4NS50c3ZcXCkpICU+JSBcbiAgZHBseXI6OnNlbGVjdChjKFxcY2hyb21cXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGxvZzJfaW5zdWxhdGlvbl9zY29yZV8xMjUwMDBcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGJpbklEID0gcGFzdGUoY2hyb20sIHN0YXJ0LCBlbmQsIHNlcCA9IFxcX1xcKSlcbmNvbG5hbWVzKGluc1Njb3JlLkE0ODUpIDwtIGMoXFxjaHJvbVxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcaW5zdWxhdGlvblNjb3JlXFwsIFxcYmluSURcXClcblxuZ2V0SW5zdWxhdGlvblNjb3JlIDwtIGZ1bmN0aW9uKGNociwgY29vcmRpbmF0ZSwgaW5zU2NvcmUudGIpe1xuICB0ZW1wLnRiIDwtIGluc1Njb3JlLnRiICU+JSBkcGx5cjo6ZmlsdGVyKGNocm9tID09IGNociwgc3RhcnQgPCBjb29yZGluYXRlLCBlbmQgPiBjb29yZGluYXRlKVxuICBvdXQgPC0gdGVtcC50YiRpbnN1bGF0aW9uU2NvcmVcbiAgaWYobGVuZ3RoKG91dCkgPCAxKXtcbiAgICByZXR1cm4oTkEpXG4gIH1lbHNle1xuICAgIHJldHVybih0ZW1wLnRiJGluc3VsYXRpb25TY29yZSlcbiAgfVxufVxuXG4jIEltcG9ydGluZyBUQUQgYm91bmRhcmllc1xudGFkX2JvdW5kYXJ5IDwtIGZyZWFkKGhlcmUoXFwuLi8uLi9yZXN1bHQvVEFEXFwsIFxcVEFEXzI1a2JfMTI1a2Jfb3RzdV9ib3VuZGFyaWVzX0cxRE1TTy5iZWRcXCkpXG5jb2xuYW1lcyh0YWRfYm91bmRhcnkpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhZF9pZCA9IHBhc3RlKGNociwgc3RhcnQsIGVuZCwgc2VwID0gXFxfXFwpLFxuICAgICAgICAgICAgICAgIGNlbnRlciA9IChzdGFydCArIGVuZCkvMixcbiAgICAgICAgICAgICAgICBpbnNTY29yZV9ETVNPID0gZ2V0SW5zdWxhdGlvblNjb3JlKGNociwgY2VudGVyLCBpbnNTY29yZS5ETVNPKSxcbiAgICAgICAgICAgICAgICBpbnNTY29yZV9kVEFHID0gZ2V0SW5zdWxhdGlvblNjb3JlKGNociwgY2VudGVyLCBpbnNTY29yZS5kVEFHKSxcbiAgICAgICAgICAgICAgICBpbnNTY29yZV9BNDg1ID0gZ2V0SW5zdWxhdGlvblNjb3JlKGNociwgY2VudGVyLCBpbnNTY29yZS5BNDg1KSlcblxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgZmlsdGVyKCFpZl9hbnkoZXZlcnl0aGluZygpLCBpcy5uYSkpXG5cbnRhZF9ib3VuZGFyeSRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRhZF9ib3VuZGFyeSRpbnNTY29yZV9ETVNPLCB0YWRfYm91bmRhcnkkaW5zU2NvcmVfZFRBRywgbiA9IDEwMClcbnRhZF9ib3VuZGFyeSA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nZ3Bsb3QodGFkX2JvdW5kYXJ5LCBhZXMoeCA9IGluc1Njb3JlX0RNU08sIHkgPSBpbnNTY29yZV9kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArIGNvb3JkX2ZpeGVkKCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICsgdGhlbWVfYncoKVxuXG5cblxudGFkX2JvdW5kYXJ5JGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGFkX2JvdW5kYXJ5JGluc1Njb3JlX0RNU08sIHRhZF9ib3VuZGFyeSRpbnNTY29yZV9BNDg1LCBuID0gMTAwKVxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmdncGxvdCh0YWRfYm91bmRhcnksIGFlcyh4ID0gaW5zU2NvcmVfRE1TTywgeSA9IGluc1Njb3JlX0E0ODUsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgc2NhbGVfY29sb3JfdmlyaWRpcygpICsgY29vcmRfZml4ZWQoKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgKyB0aGVtZV9idygpXG5cblxuXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\nconsensus.loop.anno.tb <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\n\n# Import insulation score calculated with python\nresultDir <- here(\\../../result\\)\ninsScore.DMSO <- fread(here(resultDir, \\TAD\\, \\insulationScore_25kb_G1DMSO.tsv\\)) %>% \n  dplyr::select(c(\\chrom\\, \\start\\, \\end\\, \\log2_insulation_score_125000\\)) %>%\n  dplyr::mutate(binID = paste(chrom, start, end, sep = \\_\\))\ncolnames(insScore.DMSO) <- c(\\chrom\\, \\start\\, \\end\\, \\insulationScore\\, \\binID\\)\ninsScore.dTAG <- fread(here(resultDir, \\TAD\\, \\insulationScore_25kb_G1dTAG.tsv\\)) %>% \n  dplyr::select(c(\\chrom\\, \\start\\, \\end\\, \\log2_insulation_score_125000\\)) %>%\n  dplyr::mutate(binID = paste(chrom, start, end, sep = \\_\\))\ncolnames(insScore.dTAG) <- c(\\chrom\\, \\start\\, \\end\\, \\insulationScore\\, \\binID\\)\ninsScore.A485 <- fread(here(resultDir, \\TAD\\, \\insulationScore_25kb_G1A485.tsv\\)) %>% \n  dplyr::select(c(\\chrom\\, \\start\\, \\end\\, \\log2_insulation_score_125000\\)) %>%\n  dplyr::mutate(binID = paste(chrom, start, end, sep = \\_\\))\ncolnames(insScore.A485) <- c(\\chrom\\, \\start\\, \\end\\, \\insulationScore\\, \\binID\\)\n\ngetInsulationScore <- function(chr, coordinate, insScore.tb){\n  temp.tb <- insScore.tb %>% dplyr::filter(chrom == chr, start < coordinate, end > coordinate)\n  out <- temp.tb$insulationScore\n  if(length(out) < 1){\n    return(NA)\n  }else{\n    return(temp.tb$insulationScore)\n  }\n}\n\n# Importing TAD boundaries\ntad_boundary <- fread(here(\\../../result/TAD\\, \\TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\\))\ncolnames(tad_boundary) <- c(\\chr\\, \\start\\, \\end\\)\ntad_boundary <- tad_boundary %>% rowwise() %>%\n  dplyr::mutate(tad_id = paste(chr, start, end, sep = \\_\\),\n                center = (start + end)/2,\n                insScore_DMSO = getInsulationScore(chr, center, insScore.DMSO),\n                insScore_dTAG = getInsulationScore(chr, center, insScore.dTAG),\n                insScore_A485 = getInsulationScore(chr, center, insScore.A485))\n\ntad_boundary <- tad_boundary %>% filter(!if_any(everything(), is.na))\n\ntad_boundary$density <- get_density(tad_boundary$insScore_DMSO, tad_boundary$insScore_dTAG, n = 100)\ntad_boundary <- tad_boundary %>% dplyr::arrange(density)\nggplot(tad_boundary, aes(x = insScore_DMSO, y = insScore_dTAG, color = density)) + \n  geom_point(show.legend = FALSE) + \n  scale_color_viridis() + coord_fixed() +\n  geom_abline(slope = 1, intercept = 0) + theme_bw()\n\n\n\ntad_boundary$density <- get_density(tad_boundary$insScore_DMSO, tad_boundary$insScore_A485, n = 100)\ntad_boundary <- tad_boundary %>% dplyr::arrange(density)\nggplot(tad_boundary, aes(x = insScore_DMSO, y = insScore_A485, color = density)) + \n  geom_point(show.legend = FALSE) + \n  scale_color_viridis() + coord_fixed() +\n  geom_abline(slope = 1, intercept = 0) + theme_bw()\n\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuY29uc2Vuc3VzLmxvb3AuYW5uby50YiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5cbiMgSW1wb3J0IGluc3VsYXRpb24gc2NvcmUgY2FsY3VsYXRlZCB3aXRoIHB5dGhvblxucmVzdWx0RGlyIDwtIGhlcmUoXFwuLi8uLi9yZXN1bHRcXClcbmluc1Njb3JlLkRNU08gPC0gZnJlYWQoaGVyZShyZXN1bHREaXIsIFxcVEFEXFwsIFxcaW5zdWxhdGlvblNjb3JlXzI1a2JfRzFETVNPLnRzdlxcKSkgJT4lIFxuICBkcGx5cjo6c2VsZWN0KGMoXFxjaHJvbVxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcbG9nMl9pbnN1bGF0aW9uX3Njb3JlXzEyNTAwMFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoYmluSUQgPSBwYXN0ZShjaHJvbSwgc3RhcnQsIGVuZCwgc2VwID0gXFxfXFwpKVxuY29sbmFtZXMoaW5zU2NvcmUuRE1TTykgPC0gYyhcXGNocm9tXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxpbnN1bGF0aW9uU2NvcmVcXCwgXFxiaW5JRFxcKVxuaW5zU2NvcmUuZFRBRyA8LSBmcmVhZChoZXJlKHJlc3VsdERpciwgXFxUQURcXCwgXFxpbnN1bGF0aW9uU2NvcmVfMjVrYl9HMWRUQUcudHN2XFwpKSAlPiUgXG4gIGRwbHlyOjpzZWxlY3QoYyhcXGNocm9tXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxsb2cyX2luc3VsYXRpb25fc2NvcmVfMTI1MDAwXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShiaW5JRCA9IHBhc3RlKGNocm9tLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCkpXG5jb2xuYW1lcyhpbnNTY29yZS5kVEFHKSA8LSBjKFxcY2hyb21cXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGluc3VsYXRpb25TY29yZVxcLCBcXGJpbklEXFwpXG5pbnNTY29yZS5BNDg1IDwtIGZyZWFkKGhlcmUocmVzdWx0RGlyLCBcXFRBRFxcLCBcXGluc3VsYXRpb25TY29yZV8yNWtiX0cxQTQ4NS50c3ZcXCkpICU+JSBcbiAgZHBseXI6OnNlbGVjdChjKFxcY2hyb21cXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGxvZzJfaW5zdWxhdGlvbl9zY29yZV8xMjUwMDBcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGJpbklEID0gcGFzdGUoY2hyb20sIHN0YXJ0LCBlbmQsIHNlcCA9IFxcX1xcKSlcbmNvbG5hbWVzKGluc1Njb3JlLkE0ODUpIDwtIGMoXFxjaHJvbVxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcaW5zdWxhdGlvblNjb3JlXFwsIFxcYmluSURcXClcblxuZ2V0SW5zdWxhdGlvblNjb3JlIDwtIGZ1bmN0aW9uKGNociwgY29vcmRpbmF0ZSwgaW5zU2NvcmUudGIpe1xuICB0ZW1wLnRiIDwtIGluc1Njb3JlLnRiICU+JSBkcGx5cjo6ZmlsdGVyKGNocm9tID09IGNociwgc3RhcnQgPCBjb29yZGluYXRlLCBlbmQgPiBjb29yZGluYXRlKVxuICBvdXQgPC0gdGVtcC50YiRpbnN1bGF0aW9uU2NvcmVcbiAgaWYobGVuZ3RoKG91dCkgPCAxKXtcbiAgICByZXR1cm4oTkEpXG4gIH1lbHNle1xuICAgIHJldHVybih0ZW1wLnRiJGluc3VsYXRpb25TY29yZSlcbiAgfVxufVxuXG4jIEltcG9ydGluZyBUQUQgYm91bmRhcmllc1xudGFkX2JvdW5kYXJ5IDwtIGZyZWFkKGhlcmUoXFwuLi8uLi9yZXN1bHQvVEFEXFwsIFxcVEFEXzI1a2JfMTI1a2Jfb3RzdV9ib3VuZGFyaWVzX0cxRE1TTy5iZWRcXCkpXG5jb2xuYW1lcyh0YWRfYm91bmRhcnkpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhZF9pZCA9IHBhc3RlKGNociwgc3RhcnQsIGVuZCwgc2VwID0gXFxfXFwpLFxuICAgICAgICAgICAgICAgIGNlbnRlciA9IChzdGFydCArIGVuZCkvMixcbiAgICAgICAgICAgICAgICBpbnNTY29yZV9ETVNPID0gZ2V0SW5zdWxhdGlvblNjb3JlKGNociwgY2VudGVyLCBpbnNTY29yZS5ETVNPKSxcbiAgICAgICAgICAgICAgICBpbnNTY29yZV9kVEFHID0gZ2V0SW5zdWxhdGlvblNjb3JlKGNociwgY2VudGVyLCBpbnNTY29yZS5kVEFHKSxcbiAgICAgICAgICAgICAgICBpbnNTY29yZV9BNDg1ID0gZ2V0SW5zdWxhdGlvblNjb3JlKGNociwgY2VudGVyLCBpbnNTY29yZS5BNDg1KSlcblxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgZmlsdGVyKCFpZl9hbnkoZXZlcnl0aGluZygpLCBpcy5uYSkpXG5cbnRhZF9ib3VuZGFyeSRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRhZF9ib3VuZGFyeSRpbnNTY29yZV9ETVNPLCB0YWRfYm91bmRhcnkkaW5zU2NvcmVfZFRBRywgbiA9IDEwMClcbnRhZF9ib3VuZGFyeSA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nZ3Bsb3QodGFkX2JvdW5kYXJ5LCBhZXMoeCA9IGluc1Njb3JlX0RNU08sIHkgPSBpbnNTY29yZV9kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gIHNjYWxlX2NvbG9yX3ZpcmlkaXMoKSArIGNvb3JkX2ZpeGVkKCkgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICsgdGhlbWVfYncoKVxuXG5cblxudGFkX2JvdW5kYXJ5JGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGFkX2JvdW5kYXJ5JGluc1Njb3JlX0RNU08sIHRhZF9ib3VuZGFyeSRpbnNTY29yZV9BNDg1LCBuID0gMTAwKVxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmdncGxvdCh0YWRfYm91bmRhcnksIGFlcyh4ID0gaW5zU2NvcmVfRE1TTywgeSA9IGluc1Njb3JlX0E0ODUsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgc2NhbGVfY29sb3JfdmlyaWRpcygpICsgY29vcmRfZml4ZWQoKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgKyB0aGVtZV9idygpXG5cblxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
name <- \chromo_cons_annoHierarchy\
consensus.loop.anno.tb <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import insulation score calculated with python
resultDir <- here(\../../result\)
insScore.DMSO <- fread(here(resultDir, \TAD\, \insulationScore_25kb_G1DMSO.tsv\)) %>% 
  dplyr::select(c(\chrom\, \start\, \end\, \log2_insulation_score_125000\)) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = \_\))
colnames(insScore.DMSO) <- c(\chrom\, \start\, \end\, \insulationScore\, \binID\)
insScore.dTAG <- fread(here(resultDir, \TAD\, \insulationScore_25kb_G1dTAG.tsv\)) %>% 
  dplyr::select(c(\chrom\, \start\, \end\, \log2_insulation_score_125000\)) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = \_\))
colnames(insScore.dTAG) <- c(\chrom\, \start\, \end\, \insulationScore\, \binID\)
insScore.A485 <- fread(here(resultDir, \TAD\, \insulationScore_25kb_G1A485.tsv\)) %>% 
  dplyr::select(c(\chrom\, \start\, \end\, \log2_insulation_score_125000\)) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = \_\))
colnames(insScore.A485) <- c(\chrom\, \start\, \end\, \insulationScore\, \binID\)

getInsulationScore <- function(chr, coordinate, insScore.tb){
  temp.tb <- insScore.tb %>% dplyr::filter(chrom == chr, start < coordinate, end > coordinate)
  out <- temp.tb$insulationScore
  if(length(out) < 1){
    return(NA)
  }else{
    return(temp.tb$insulationScore)
  }
}

# Importing TAD boundaries
tad_boundary <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\))
colnames(tad_boundary) <- c(\chr\, \start\, \end\)
tad_boundary <- tad_boundary %>% rowwise() %>%
  dplyr::mutate(tad_id = paste(chr, start, end, sep = \_\),
                center = (start + end)/2,
                insScore_DMSO = getInsulationScore(chr, center, insScore.DMSO),
                insScore_dTAG = getInsulationScore(chr, center, insScore.dTAG),
                insScore_A485 = getInsulationScore(chr, center, insScore.A485))

tad_boundary <- tad_boundary %>% filter(!if_any(everything(), is.na))

tad_boundary$density <- get_density(tad_boundary$insScore_DMSO, tad_boundary$insScore_dTAG, n = 100)
tad_boundary <- tad_boundary %>% dplyr::arrange(density)
ggplot(tad_boundary, aes(x = insScore_DMSO, y = insScore_dTAG, color = density)) + 
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() + coord_fixed() +
  geom_abline(slope = 1, intercept = 0) + theme_bw()



tad_boundary$density <- get_density(tad_boundary$insScore_DMSO, tad_boundary$insScore_A485, n = 100)
tad_boundary <- tad_boundary %>% dplyr::arrange(density)
ggplot(tad_boundary, aes(x = insScore_DMSO, y = insScore_A485, color = density)) + 
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() + coord_fixed() +
  geom_abline(slope = 1, intercept = 0) + theme_bw()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Checking TAD average log2FC

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyMjIEltcG9ydGluZyBkaWZmZXJlbnRpYWwgcmVndWxhdG9yeSBsb29wc1xuXG5sb29wLnVwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IFwiVVAvTk9cIilcbmNvbG5hbWVzKGxvb3AudXApIDwtIGMoXCJjaHIxXCIsIFwic3RhcnQxXCIsIFwiZW5kMVwiLCBcImNocjJcIiwgXCJzdGFydDJcIiwgXCJlbmQyXCIsIFwiZ3JvdXBcIilcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXCJVUC9OT1wiKVxuY29sbmFtZXMobG9vcC5ubykgPC0gYyhcImNocjFcIiwgXCJzdGFydDFcIiwgXCJlbmQxXCIsIFwiY2hyMlwiLCBcInN0YXJ0MlwiLCBcImVuZDJcIiwgXCJncm91cFwiKVxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXCJET1dOXCIpXG5jb2xuYW1lcyhsb29wLmRvd24pIDwtIGMoXCJjaHIxXCIsIFwic3RhcnQxXCIsIFwiZW5kMVwiLCBcImNocjJcIiwgXCJzdGFydDJcIiwgXCJlbmQyXCIsIFwiZ3JvdXBcIilcblxubG9vcHMgPC0gYmluZF9yb3dzKGJpbmRfcm93cyhsb29wLnVwLCBsb29wLm5vKSwgbG9vcC5kb3duKVxuXG4jIyMgSW1wb3J0aW5nIFRBRCBib3VuZGFyeVxudGFkX2JvdW5kYXJ5IDwtIGZyZWFkKGhlcmUoXCIuLi8uLi9yZXN1bHQvVEFEXCIsIFwiVEFEXzI1a2JfMTI1a2Jfb3RzdV9ib3VuZGFyaWVzX0cxRE1TTy5iZWRcIikpXG5jb2xuYW1lcyh0YWRfYm91bmRhcnkpIDwtIGMoXCJjaHJcIiwgXCJzdGFydFwiLCBcImVuZFwiKVxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6Om11dGF0ZSh0YWRfaWQgPSBwYXN0ZShjaHIsIHN0YXJ0LCBlbmQsIHNlcCA9IFwiX1wiKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3RhcnQgPSBzdGFydCAtMTc1MDAwLzIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZCA9IGVuZCArIDE3NTAwMC8yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjZW50ZXIgPSAoc3RhcnQgKyBlbmQpLzIpXG4jIyMgRnVuY3Rpb25zXG5jaGVja0JvdW5kYXJ5Q3Jvc3MgPC0gZnVuY3Rpb24oY2hyb20xLCBzdGFydDEsIGVuZDIsIHRhZF9ib3VuZGFyeSl7XG4gIHRlbXAgPC0gdGFkX2JvdW5kYXJ5ICU+JSBkcGx5cjo6ZmlsdGVyKGNociA9PSBjaHJvbTEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjZW50ZXIgPiBzdGFydDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjZW50ZXIgPCBlbmQyKVxuICByZXR1cm4obGVuZ3RoKHRlbXAkY2VudGVyKSlcbn1cblxuIyMjIENoZWNrIG92ZXJsYXBcbmxvb3BzIDwtIGxvb3BzICU+JSByb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoYm91bmRhcnlDcm9zcyA9IGNoZWNrQm91bmRhcnlDcm9zcyhjaHIxLCBzdGFydDEsIGVuZDIsIHRhZF9ib3VuZGFyeSkpXG5cbiMjIyBQbG90dGluZ1xuc3VtbWFyeV9kYXRhIDwtIGxvb3BzICU+JVxuICBncm91cF9ieShncm91cCkgJT4lXG4gIHN1bW1hcmlzZShwZXJjZW50YWdlID0gbWVhbihib3VuZGFyeUNyb3NzID4gMCkgKiAxMDApXG5cbnN1bW1hcnlfZGF0YSRncm91cCA8LSBmYWN0b3Ioc3VtbWFyeV9kYXRhJGdyb3VwLCBsZXZlbHMgPSBjKFwiVVAvTk9cIiwgXCJET1dOXCIpKVxuXG5wIDwtIGdncGxvdChzdW1tYXJ5X2RhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBwZXJjZW50YWdlKSkgK1xuICBnZW9tX2JhcihzdGF0ID0gXCJpZGVudGl0eVwiLCBmaWxsID0gZGFya2VuKHN0cm9uZ19ncmVlbiwgYW1vdW50ID0gMC4yKSkgK1xuICBsYWJzKHkgPSBcIiUgb2YgbG9vcHMgY3Jvc3NpbmcgVEFEIGJvdW5kYXJ5XCIsIHggPSBOVUxMKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIHlsaW0oMCwgMTAwKSArXG4gIHRoZW1lKFxuICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiXG4gICAgKSxcbiAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIGFuZ2xlID0gNDUsICAgICAgIyBSb3RhdGUgeC1heGlzIGxhYmVscyA0NSBkZWdyZWVzXG4gICAgICBoanVzdCA9IDEsICAgICAgICMgQWRqdXN0IGhvcml6b250YWwganVzdGlmaWNhdGlvblxuICAgICAgdmp1c3QgPSAxICAgICAgICAjIEFkanVzdCB2ZXJ0aWNhbCBqdXN0aWZpY2F0aW9uXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCIsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcInNxdWFyZVwiXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcInRyYW5zcGFyZW50XCIpLFxuICApXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcImJvdW5kYXJ5Q3Jvc3NSYXRpb1wiKVxud2lkdGggPC0gcGFuZWxTaXplKDEpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuNSkqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYCJ9 -->\n\n```r\n### Importing differential regulatory loops\n\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(group = \\UP/NO\\)\ncolnames(loop.up) <- c(\\chr1\\, \\start1\\, \\end1\\, \\chr2\\, \\start2\\, \\end2\\, \\group\\)\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(group = \\UP/NO\\)\ncolnames(loop.no) <- c(\\chr1\\, \\start1\\, \\end1\\, \\chr2\\, \\start2\\, \\end2\\, \\group\\)\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(group = \\DOWN\\)\ncolnames(loop.down) <- c(\\chr1\\, \\start1\\, \\end1\\, \\chr2\\, \\start2\\, \\end2\\, \\group\\)\n\nloops <- bind_rows(bind_rows(loop.up, loop.no), loop.down)\n\n### Importing TAD boundary\ntad_boundary <- fread(here(\\../../result/TAD\\, \\TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\\))\ncolnames(tad_boundary) <- c(\\chr\\, \\start\\, \\end\\)\ntad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = \\_\\),\n                                               start = start -175000/2,\n                                               end = end + 175000/2,\n                                               center = (start + end)/2)\n### Functions\ncheckBoundaryCross <- function(chrom1, start1, end2, tad_boundary){\n  temp <- tad_boundary %>% dplyr::filter(chr == chrom1,\n                                 center > start1,\n                                 center < end2)\n  return(length(temp$center))\n}\n\n### Check overlap\nloops <- loops %>% rowwise() %>%\n  dplyr::mutate(boundaryCross = checkBoundaryCross(chr1, start1, end2, tad_boundary))\n\n### Plotting\nsummary_data <- loops %>%\n  group_by(group) %>%\n  summarise(percentage = mean(boundaryCross > 0) * 100)\n\nsummary_data$group <- factor(summary_data$group, levels = c(\\UP/NO\\, \\DOWN\\))\n\np <- ggplot(summary_data, aes(x = group, y = percentage)) +\n  geom_bar(stat = \\identity\\, fill = darken(strong_green, amount = 0.2)) +\n  labs(y = \\% of loops crossing TAD boundary\\, x = NULL) +\n  theme_classic() + ylim(0, 100) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n  )\n\nfileName <- paste0(\\boundaryCrossRatio\\)\nwidth <- panelSize(1)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
### Importing differential regulatory loops

loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>%
  dplyr::mutate(group = \UP/NO\)
colnames(loop.up) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\, \group\)
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>%
  dplyr::mutate(group = \UP/NO\)
colnames(loop.no) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\, \group\)
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>%
  dplyr::mutate(group = \DOWN\)
colnames(loop.down) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\, \group\)

loops <- bind_rows(bind_rows(loop.up, loop.no), loop.down)

### Importing TAD boundary
tad_boundary <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\))
colnames(tad_boundary) <- c(\chr\, \start\, \end\)
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = \_\),
                                               start = start -175000/2,
                                               end = end + 175000/2,
                                               center = (start + end)/2)
### Functions
checkBoundaryCross <- function(chrom1, start1, end2, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom1,
                                 center > start1,
                                 center < end2)
  return(length(temp$center))
}

### Check overlap
loops <- loops %>% rowwise() %>%
  dplyr::mutate(boundaryCross = checkBoundaryCross(chr1, start1, end2, tad_boundary))

### Plotting
summary_data <- loops %>%
  group_by(group) %>%
  summarise(percentage = mean(boundaryCross > 0) * 100)

summary_data$group <- factor(summary_data$group, levels = c(\UP/NO\, \DOWN\))

p <- ggplot(summary_data, aes(x = group, y = percentage)) +
  geom_bar(stat = \identity\, fill = darken(strong_green, amount = 0.2)) +
  labs(y = \% of loops crossing TAD boundary\, x = NULL) +
  theme_classic() + ylim(0, 100) +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
  )

fileName <- paste0(\boundaryCrossRatio\)
width <- panelSize(1)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIEltcG9ydGluZyBkaWZmZXJlbnRpYWwgcmVndWxhdG9yeSBsb29wc1xuXG5sb29wLnVwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IFxcVVAvTk9cXClcbmNvbG5hbWVzKGxvb3AudXApIDwtIGMoXFxjaHIxXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocjJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcZ3JvdXBcXClcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxVUC9OT1xcKVxuY29sbmFtZXMobG9vcC5ubykgPC0gYyhcXGNocjFcXCwgXFxzdGFydDFcXCwgXFxlbmQxXFwsIFxcY2hyMlxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXCwgXFxncm91cFxcKVxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxET1dOXFwpXG5jb2xuYW1lcyhsb29wLmRvd24pIDwtIGMoXFxjaHIxXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocjJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcZ3JvdXBcXClcblxubG9vcHMgPC0gYmluZF9yb3dzKGJpbmRfcm93cyhsb29wLnVwLCBsb29wLm5vKSwgbG9vcC5kb3duKVxuXG4jIyMgSW1wb3J0aW5nIFRBRCBib3VuZGFyeVxudGFkX2JvdW5kYXJ5IDwtIGZyZWFkKGhlcmUoXFwuLi8uLi9yZXN1bHQvVEFEXFwsIFxcVEFEXzI1a2JfMTI1a2Jfb3RzdV9ib3VuZGFyaWVzX0cxRE1TTy5iZWRcXCkpXG5jb2xuYW1lcyh0YWRfYm91bmRhcnkpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6Om11dGF0ZSh0YWRfaWQgPSBwYXN0ZShjaHIsIHN0YXJ0LCBlbmQsIHNlcCA9IFxcX1xcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3RhcnQgPSBzdGFydCAtMTc1MDAwLzIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZCA9IGVuZCArIDE3NTAwMC8yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjZW50ZXIgPSAoc3RhcnQgKyBlbmQpLzIpXG4jIyMgRnVuY3Rpb25zXG5jaGVja0JvdW5kYXJ5Q3Jvc3MgPC0gZnVuY3Rpb24oY2hyb20xLCBzdGFydDEsIGVuZDIsIHRhZF9ib3VuZGFyeSl7XG4gIHRlbXAgPC0gdGFkX2JvdW5kYXJ5ICU+JSBkcGx5cjo6ZmlsdGVyKGNociA9PSBjaHJvbTEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjZW50ZXIgPiBzdGFydDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjZW50ZXIgPCBlbmQyKVxuICByZXR1cm4obGVuZ3RoKHRlbXAkY2VudGVyKSlcbn1cblxuIyMjIENoZWNrIG92ZXJsYXBcbmxvb3BzIDwtIGxvb3BzICU+JSByb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoYm91bmRhcnlDcm9zcyA9IGNoZWNrQm91bmRhcnlDcm9zcyhjaHIxLCBzdGFydDEsIGVuZDIsIHRhZF9ib3VuZGFyeSkpXG5cbiMjIyBQbG90dGluZ1xuc3VtbWFyeV9kYXRhIDwtIGxvb3BzICU+JVxuICBncm91cF9ieShncm91cCkgJT4lXG4gIHN1bW1hcmlzZShwZXJjZW50YWdlID0gbWVhbihib3VuZGFyeUNyb3NzID4gMCkgKiAxMDApXG5cbnN1bW1hcnlfZGF0YSRncm91cCA8LSBmYWN0b3Ioc3VtbWFyeV9kYXRhJGdyb3VwLCBsZXZlbHMgPSBjKFxcVVAvTk9cXCwgXFxET1dOXFwpKVxuXG5wIDwtIGdncGxvdChzdW1tYXJ5X2RhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBwZXJjZW50YWdlKSkgK1xuICBnZW9tX2JhcihzdGF0ID0gXFxpZGVudGl0eVxcLCBmaWxsID0gZGFya2VuKHN0cm9uZ19ncmVlbiwgYW1vdW50ID0gMC4yKSkgK1xuICBsYWJzKHkgPSBcXCUgb2YgbG9vcHMgY3Jvc3NpbmcgVEFEIGJvdW5kYXJ5XFwsIHggPSBOVUxMKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIHlsaW0oMCwgMTAwKSArXG4gIHRoZW1lKFxuICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIGFuZ2xlID0gNDUsICAgICAgIyBSb3RhdGUgeC1heGlzIGxhYmVscyA0NSBkZWdyZWVzXG4gICAgICBoanVzdCA9IDEsICAgICAgICMgQWRqdXN0IGhvcml6b250YWwganVzdGlmaWNhdGlvblxuICAgICAgdmp1c3QgPSAxICAgICAgICAjIEFkanVzdCB2ZXJ0aWNhbCBqdXN0aWZpY2F0aW9uXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcXHRyYW5zcGFyZW50XFwpLFxuICApXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGJvdW5kYXJ5Q3Jvc3NSYXRpb1xcKVxud2lkdGggPC0gcGFuZWxTaXplKDEpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuNSkqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\n### Importing differential regulatory loops\n\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(group = \\UP/NO\\)\ncolnames(loop.up) <- c(\\chr1\\, \\start1\\, \\end1\\, \\chr2\\, \\start2\\, \\end2\\, \\group\\)\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(group = \\UP/NO\\)\ncolnames(loop.no) <- c(\\chr1\\, \\start1\\, \\end1\\, \\chr2\\, \\start2\\, \\end2\\, \\group\\)\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(group = \\DOWN\\)\ncolnames(loop.down) <- c(\\chr1\\, \\start1\\, \\end1\\, \\chr2\\, \\start2\\, \\end2\\, \\group\\)\n\nloops <- bind_rows(bind_rows(loop.up, loop.no), loop.down)\n\n### Importing TAD boundary\ntad_boundary <- fread(here(\\../../result/TAD\\, \\TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\\))\ncolnames(tad_boundary) <- c(\\chr\\, \\start\\, \\end\\)\ntad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = \\_\\),\n                                               start = start -175000/2,\n                                               end = end + 175000/2,\n                                               center = (start + end)/2)\n### Functions\ncheckBoundaryCross <- function(chrom1, start1, end2, tad_boundary){\n  temp <- tad_boundary %>% dplyr::filter(chr == chrom1,\n                                 center > start1,\n                                 center < end2)\n  return(length(temp$center))\n}\n\n### Check overlap\nloops <- loops %>% rowwise() %>%\n  dplyr::mutate(boundaryCross = checkBoundaryCross(chr1, start1, end2, tad_boundary))\n\n### Plotting\nsummary_data <- loops %>%\n  group_by(group) %>%\n  summarise(percentage = mean(boundaryCross > 0) * 100)\n\nsummary_data$group <- factor(summary_data$group, levels = c(\\UP/NO\\, \\DOWN\\))\n\np <- ggplot(summary_data, aes(x = group, y = percentage)) +\n  geom_bar(stat = \\identity\\, fill = darken(strong_green, amount = 0.2)) +\n  labs(y = \\% of loops crossing TAD boundary\\, x = NULL) +\n  theme_classic() + ylim(0, 100) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n  )\n\nfileName <- paste0(\\boundaryCrossRatio\\)\nwidth <- panelSize(1)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIEltcG9ydGluZyBkaWZmZXJlbnRpYWwgcmVndWxhdG9yeSBsb29wc1xuXG5sb29wLnVwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IFxcVVAvTk9cXClcbmNvbG5hbWVzKGxvb3AudXApIDwtIGMoXFxjaHIxXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocjJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcZ3JvdXBcXClcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxVUC9OT1xcKVxuY29sbmFtZXMobG9vcC5ubykgPC0gYyhcXGNocjFcXCwgXFxzdGFydDFcXCwgXFxlbmQxXFwsIFxcY2hyMlxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXCwgXFxncm91cFxcKVxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxET1dOXFwpXG5jb2xuYW1lcyhsb29wLmRvd24pIDwtIGMoXFxjaHIxXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocjJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcZ3JvdXBcXClcblxubG9vcHMgPC0gYmluZF9yb3dzKGJpbmRfcm93cyhsb29wLnVwLCBsb29wLm5vKSwgbG9vcC5kb3duKVxuXG4jIyMgSW1wb3J0aW5nIFRBRCBib3VuZGFyeVxudGFkX2JvdW5kYXJ5IDwtIGZyZWFkKGhlcmUoXFwuLi8uLi9yZXN1bHQvVEFEXFwsIFxcVEFEXzI1a2JfMTI1a2Jfb3RzdV9ib3VuZGFyaWVzX0cxRE1TTy5iZWRcXCkpXG5jb2xuYW1lcyh0YWRfYm91bmRhcnkpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxudGFkX2JvdW5kYXJ5IDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6Om11dGF0ZSh0YWRfaWQgPSBwYXN0ZShjaHIsIHN0YXJ0LCBlbmQsIHNlcCA9IFxcX1xcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3RhcnQgPSBzdGFydCAtMTc1MDAwLzIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZCA9IGVuZCArIDE3NTAwMC8yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjZW50ZXIgPSAoc3RhcnQgKyBlbmQpLzIpXG4jIyMgRnVuY3Rpb25zXG5jaGVja0JvdW5kYXJ5Q3Jvc3MgPC0gZnVuY3Rpb24oY2hyb20xLCBzdGFydDEsIGVuZDIsIHRhZF9ib3VuZGFyeSl7XG4gIHRlbXAgPC0gdGFkX2JvdW5kYXJ5ICU+JSBkcGx5cjo6ZmlsdGVyKGNociA9PSBjaHJvbTEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjZW50ZXIgPiBzdGFydDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjZW50ZXIgPCBlbmQyKVxuICByZXR1cm4obGVuZ3RoKHRlbXAkY2VudGVyKSlcbn1cblxuIyMjIENoZWNrIG92ZXJsYXBcbmxvb3BzIDwtIGxvb3BzICU+JSByb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoYm91bmRhcnlDcm9zcyA9IGNoZWNrQm91bmRhcnlDcm9zcyhjaHIxLCBzdGFydDEsIGVuZDIsIHRhZF9ib3VuZGFyeSkpXG5cbiMjIyBQbG90dGluZ1xuc3VtbWFyeV9kYXRhIDwtIGxvb3BzICU+JVxuICBncm91cF9ieShncm91cCkgJT4lXG4gIHN1bW1hcmlzZShwZXJjZW50YWdlID0gbWVhbihib3VuZGFyeUNyb3NzID4gMCkgKiAxMDApXG5cbnN1bW1hcnlfZGF0YSRncm91cCA8LSBmYWN0b3Ioc3VtbWFyeV9kYXRhJGdyb3VwLCBsZXZlbHMgPSBjKFxcVVAvTk9cXCwgXFxET1dOXFwpKVxuXG5wIDwtIGdncGxvdChzdW1tYXJ5X2RhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBwZXJjZW50YWdlKSkgK1xuICBnZW9tX2JhcihzdGF0ID0gXFxpZGVudGl0eVxcLCBmaWxsID0gZGFya2VuKHN0cm9uZ19ncmVlbiwgYW1vdW50ID0gMC4yKSkgK1xuICBsYWJzKHkgPSBcXCUgb2YgbG9vcHMgY3Jvc3NpbmcgVEFEIGJvdW5kYXJ5XFwsIHggPSBOVUxMKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIHlsaW0oMCwgMTAwKSArXG4gIHRoZW1lKFxuICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIGFuZ2xlID0gNDUsICAgICAgIyBSb3RhdGUgeC1heGlzIGxhYmVscyA0NSBkZWdyZWVzXG4gICAgICBoanVzdCA9IDEsICAgICAgICMgQWRqdXN0IGhvcml6b250YWwganVzdGlmaWNhdGlvblxuICAgICAgdmp1c3QgPSAxICAgICAgICAjIEFkanVzdCB2ZXJ0aWNhbCBqdXN0aWZpY2F0aW9uXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcXHRyYW5zcGFyZW50XFwpLFxuICApXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGJvdW5kYXJ5Q3Jvc3NSYXRpb1xcKVxud2lkdGggPC0gcGFuZWxTaXplKDEpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuNSkqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
### Importing differential regulatory loops

loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>%
  dplyr::mutate(group = \UP/NO\)
colnames(loop.up) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\, \group\)
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>%
  dplyr::mutate(group = \UP/NO\)
colnames(loop.no) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\, \group\)
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>%
  dplyr::mutate(group = \DOWN\)
colnames(loop.down) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\, \group\)

loops <- bind_rows(bind_rows(loop.up, loop.no), loop.down)

### Importing TAD boundary
tad_boundary <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\))
colnames(tad_boundary) <- c(\chr\, \start\, \end\)
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = \_\),
                                               start = start -175000/2,
                                               end = end + 175000/2,
                                               center = (start + end)/2)
### Functions
checkBoundaryCross <- function(chrom1, start1, end2, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom1,
                                 center > start1,
                                 center < end2)
  return(length(temp$center))
}

### Check overlap
loops <- loops %>% rowwise() %>%
  dplyr::mutate(boundaryCross = checkBoundaryCross(chr1, start1, end2, tad_boundary))

### Plotting
summary_data <- loops %>%
  group_by(group) %>%
  summarise(percentage = mean(boundaryCross > 0) * 100)

summary_data$group <- factor(summary_data$group, levels = c(\UP/NO\, \DOWN\))

p <- ggplot(summary_data, aes(x = group, y = percentage)) +
  geom_bar(stat = \identity\, fill = darken(strong_green, amount = 0.2)) +
  labs(y = \% of loops crossing TAD boundary\, x = NULL) +
  theme_classic() + ylim(0, 100) +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
  )

fileName <- paste0(\boundaryCrossRatio\)
width <- panelSize(1)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



## [2.18] Comparing TAD insulation score across samples
Checking how insulation score changes by treatment at DMSO TAD boundaries

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSUVsdGNHOXlkR2x1WnlCa2FXWm1aWEpsYm5ScFlXd2djbVZuZFd4aGRHOXllU0JzYjI5d2MxeHViRzl2Y0M1MWNDQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2dYQ0pqYUhKdmJXOWZZMjl1YzE5aGJtNXZTR2xsY21GeVkyaDVYM0JsTFhCbFgwRTBPRFYyYzBSTlUwOWZWVkJmWkdsbVpqQXVNaTVpWldSd1pWd2lLU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHRkWFJoZEdVb1ozSnZkWEFnUFNCY0luVndYQ0lwWEc1amIyeHVZVzFsY3loc2IyOXdMblZ3S1NBOExTQmpLRndpWTJoeU1Wd2lMQ0JjSW5OMFlYSjBNVndpTENCY0ltVnVaREZjSWl3Z1hDSmphSEl5WENJc0lGd2ljM1JoY25ReVhDSXNJRndpWlc1a01sd2lMQ0JjSW1keWIzVndYQ0lwWEc1c2IyOXdMbTV2SUR3dElHWnlaV0ZrS0dobGNtVW9ZMjl1YzJWdWMzVnpSR2x5TENCY0ltTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsZmNHVXRjR1ZmUVRRNE5YWnpSRTFUVDE5T1QxOWthV1ptTUM0eUxtSmxaSEJsWENJcEtTQWxQaVZjYmlBZ1pIQnNlWEk2T20xMWRHRjBaU2huY205MWNDQTlJRndpYm05Y0lpbGNibU52Ykc1aGJXVnpLR3h2YjNBdWJtOHBJRHd0SUdNb1hDSmphSEl4WENJc0lGd2ljM1JoY25ReFhDSXNJRndpWlc1a01Wd2lMQ0JjSW1Ob2NqSmNJaXdnWENKemRHRnlkREpjSWl3Z1hDSmxibVF5WENJc0lGd2laM0p2ZFhCY0lpbGNibXh2YjNBdVpHOTNiaUE4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnWENKamFISnZiVzlmWTI5dWMxOWhibTV2U0dsbGNtRnlZMmg1WDNCbExYQmxYMEUwT0RWMmMwUk5VMDlmUkU5WFRsOWthV1ptTUM0eUxtSmxaSEJsWENJcEtTQWxQaVZjYmlBZ1pIQnNlWEk2T20xMWRHRjBaU2huY205MWNDQTlJRndpWkc5M2Jsd2lLVnh1WTI5c2JtRnRaWE1vYkc5dmNDNWtiM2R1S1NBOExTQmpLRndpWTJoeU1Wd2lMQ0JjSW5OMFlYSjBNVndpTENCY0ltVnVaREZjSWl3Z1hDSmphSEl5WENJc0lGd2ljM1JoY25ReVhDSXNJRndpWlc1a01sd2lMQ0JjSW1keWIzVndYQ0lwWEc1Y2JteHZiM0J6SUR3dElHSnBibVJmY205M2N5aGlhVzVrWDNKdmQzTW9iRzl2Y0M1MWNDd2diRzl2Y0M1dWJ5a3NJR3h2YjNBdVpHOTNiaWxjYmx4dUl5TWpJRWx0Y0c5eWRHbHVaeUJVUVVRZ1ltOTFibVJoY25sY2JuUmhaRjlpYjNWdVpHRnllU0E4TFNCbWNtVmhaQ2hvWlhKbEtGd2lMaTR2TGk0dmNtVnpkV3gwTDFSQlJGd2lMQ0JjSWxSQlJGOHlOV3RpWHpFeU5XdGlYMjkwYzNWZlltOTFibVJoY21sbGMxOUhNVVJOVTA4dVltVmtYQ0lwS1Z4dVkyOXNibUZ0WlhNb2RHRmtYMkp2ZFc1a1lYSjVLU0E4TFNCaktGd2lZMmh5WENJc0lGd2ljM1JoY25SY0lpd2dYQ0psYm1SY0lpbGNiblJoWkY5aWIzVnVaR0Z5ZVNBOExTQjBZV1JmWW05MWJtUmhjbmtnSlQ0bElHUndiSGx5T2pwdGRYUmhkR1VvZEdGa1gybGtJRDBnY0dGemRHVW9ZMmh5TENCemRHRnlkQ3dnWlc1a0xDQnpaWEFnUFNCY0lsOWNJaWtzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lITjBZWEowSUQwZ2MzUmhjblFnTFRFM05UQXdNQzh5TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmxibVFnUFNCbGJtUWdLeUF4TnpVd01EQXZNaXhjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1kyVnVkR1Z5SUQwZ0tITjBZWEowSUNzZ1pXNWtLUzh5S1Z4dUl5TWpJRVoxYm1OMGFXOXVjMXh1WTJobFkydENiM1Z1WkdGeWVVTnliM056SUR3dElHWjFibU4wYVc5dUtHTm9jbTl0TVN3Z2MzUmhjblF4TENCbGJtUXlMQ0IwWVdSZlltOTFibVJoY25rcGUxeHVJQ0IwWlcxd0lEd3RJSFJoWkY5aWIzVnVaR0Z5ZVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2loamFISWdQVDBnWTJoeWIyMHhMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdZMlZ1ZEdWeUlENGdjM1JoY25ReExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1kyVnVkR1Z5SUR3Z1pXNWtNaWxjYmlBZ2NtVjBkWEp1S0d4bGJtZDBhQ2gwWlcxd0pHTmxiblJsY2lrcFhHNTlYRzVjYmlNakl5QkRhR1ZqYXlCdmRtVnliR0Z3WEc1c2IyOXdjeUE4TFNCc2IyOXdjeUFsUGlVZ2NtOTNkMmx6WlNncElDVStKVnh1SUNCa2NHeDVjam82YlhWMFlYUmxLR0p2ZFc1a1lYSjVRM0p2YzNNZ1BTQmphR1ZqYTBKdmRXNWtZWEo1UTNKdmMzTW9ZMmh5TVN3Z2MzUmhjblF4TENCbGJtUXlMQ0IwWVdSZlltOTFibVJoY25rcEtWeHVYRzRqSXlNZ1VHeHZkSFJwYm1kY2JuTjFiVzFoY25sZlpHRjBZU0E4TFNCc2IyOXdjeUFsUGlWY2JpQWdaM0p2ZFhCZllua29aM0p2ZFhBcElDVStKVnh1SUNCemRXMXRZWEpwYzJVb2NHVnlZMlZ1ZEdGblpTQTlJRzFsWVc0b1ltOTFibVJoY25sRGNtOXpjeUErSURBcElDb2dNVEF3S1Z4dVhHNWNibkFnUEMwZ1oyZHdiRzkwS0hOMWJXMWhjbmxmWkdGMFlTd2dZV1Z6S0hnZ1BTQm5jbTkxY0N3Z2VTQTlJSEJsY21ObGJuUmhaMlVwS1NBclhHNGdJR2RsYjIxZlltRnlLSE4wWVhRZ1BTQmNJbWxrWlc1MGFYUjVYQ0lzSUdacGJHd2dQU0JjSW5OcmVXSnNkV1ZjSWlrZ0sxeHVJQ0JzWVdKektIUnBkR3hsSUQwZ1hDSlFaWEpqWlc1MFlXZGxJRzltSUZKdmQzTWdkMmwwYUNCaWIzVnVaR0Z5ZVVOeWIzTnpJRDRnTUNCd1pYSWdSM0p2ZFhCY0lpeGNiaUFnSUNBZ0lDQjRJRDBnWENKSGNtOTFjRndpTEZ4dUlDQWdJQ0FnSUhrZ1BTQmNJbEJsY21ObGJuUmhaMlZjSWlrZ0sxeHVJQ0IwYUdWdFpWOWpiR0Z6YzJsaktDa2dLeUI1YkdsdEtEQXNJREV3TUNsY2JseHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRndpWW05MWJtUmhjbmxEY205emMxSmhkR2x2WDBFME9EVmNJaWxjYm1obGFXZG9kQ0E4TFNBelhHNTNhV1IwYUNBOExTQXpYRzV3Ym1jb2FHVnlaU2htYVdkRWFYSXNJSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYQ0l1Y0c1blhDSXBLU3dnY21WeklEMGdOakF3TENCMWJtbDBJRDBnWENKcGJsd2lMQ0JvWldsbmFIUWdQU0JvWldsbmFIUXNJSGRwWkhSb0lEMGdkMmxrZEdncFhHNXdjbWx1ZENod0tWeHVaR1YyTG05bVppZ3BYRzV6ZG1kc2FYUmxLR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ3aUxuTjJaMXdpS1Nrc0lDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc1d2NtbHVkQ2h3S1Z4dVpHVjJMbTltWmlncFhHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuIyMjIEltcG9ydGluZyBkaWZmZXJlbnRpYWwgcmVndWxhdG9yeSBsb29wc1xubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXHVwXFwpXG5jb2xuYW1lcyhsb29wLnVwKSA8LSBjKFxcY2hyMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHIyXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcLCBcXGdyb3VwXFwpXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IFxcbm9cXClcbmNvbG5hbWVzKGxvb3Aubm8pIDwtIGMoXFxjaHIxXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocjJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcZ3JvdXBcXClcbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IFxcZG93blxcKVxuY29sbmFtZXMobG9vcC5kb3duKSA8LSBjKFxcY2hyMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHIyXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcLCBcXGdyb3VwXFwpXG5cbmxvb3BzIDwtIGJpbmRfcm93cyhiaW5kX3Jvd3MobG9vcC51cCwgbG9vcC5ubyksIGxvb3AuZG93bilcblxuIyMjIEltcG9ydGluZyBUQUQgYm91bmRhcnlcbnRhZF9ib3VuZGFyeSA8LSBmcmVhZChoZXJlKFxcLi4vLi4vcmVzdWx0L1RBRFxcLCBcXFRBRF8yNWtiXzEyNWtiX290c3VfYm91bmRhcmllc19HMURNU08uYmVkXFwpKVxuY29sbmFtZXModGFkX2JvdW5kYXJ5KSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnRhZF9ib3VuZGFyeSA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjptdXRhdGUodGFkX2lkID0gcGFzdGUoY2hyLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHN0YXJ0ID0gc3RhcnQgLTE3NTAwMC8yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmQgPSBlbmQgKyAxNzUwMDAvMixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyID0gKHN0YXJ0ICsgZW5kKS8yKVxuIyMjIEZ1bmN0aW9uc1xuY2hlY2tCb3VuZGFyeUNyb3NzIDwtIGZ1bmN0aW9uKGNocm9tMSwgc3RhcnQxLCBlbmQyLCB0YWRfYm91bmRhcnkpe1xuICB0ZW1wIDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6OmZpbHRlcihjaHIgPT0gY2hyb20xLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyID4gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyIDwgZW5kMilcbiAgcmV0dXJuKGxlbmd0aCh0ZW1wJGNlbnRlcikpXG59XG5cbiMjIyBDaGVjayBvdmVybGFwXG5sb29wcyA8LSBsb29wcyAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKGJvdW5kYXJ5Q3Jvc3MgPSBjaGVja0JvdW5kYXJ5Q3Jvc3MoY2hyMSwgc3RhcnQxLCBlbmQyLCB0YWRfYm91bmRhcnkpKVxuXG4jIyMgUGxvdHRpbmdcbnN1bW1hcnlfZGF0YSA8LSBsb29wcyAlPiVcbiAgZ3JvdXBfYnkoZ3JvdXApICU+JVxuICBzdW1tYXJpc2UocGVyY2VudGFnZSA9IG1lYW4oYm91bmRhcnlDcm9zcyA+IDApICogMTAwKVxuXG5cbnAgPC0gZ2dwbG90KHN1bW1hcnlfZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IHBlcmNlbnRhZ2UpKSArXG4gIGdlb21fYmFyKHN0YXQgPSBcXGlkZW50aXR5XFwsIGZpbGwgPSBcXHNreWJsdWVcXCkgK1xuICBsYWJzKHRpdGxlID0gXFxQZXJjZW50YWdlIG9mIFJvd3Mgd2l0aCBib3VuZGFyeUNyb3NzID4gMCBwZXIgR3JvdXBcXCxcbiAgICAgICB4ID0gXFxHcm91cFxcLFxuICAgICAgIHkgPSBcXFBlcmNlbnRhZ2VcXCkgK1xuICB0aGVtZV9jbGFzc2ljKCkgKyB5bGltKDAsIDEwMClcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcYm91bmRhcnlDcm9zc1JhdGlvX0E0ODVcXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
### Importing differential regulatory loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\)) %>%
  dplyr::mutate(group = \up\)
colnames(loop.up) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\, \group\)
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\)) %>%
  dplyr::mutate(group = \no\)
colnames(loop.no) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\, \group\)
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\)) %>%
  dplyr::mutate(group = \down\)
colnames(loop.down) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\, \group\)

loops <- bind_rows(bind_rows(loop.up, loop.no), loop.down)

### Importing TAD boundary
tad_boundary <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\))
colnames(tad_boundary) <- c(\chr\, \start\, \end\)
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = \_\),
                                               start = start -175000/2,
                                               end = end + 175000/2,
                                               center = (start + end)/2)
### Functions
checkBoundaryCross <- function(chrom1, start1, end2, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom1,
                                 center > start1,
                                 center < end2)
  return(length(temp$center))
}

### Check overlap
loops <- loops %>% rowwise() %>%
  dplyr::mutate(boundaryCross = checkBoundaryCross(chr1, start1, end2, tad_boundary))

### Plotting
summary_data <- loops %>%
  group_by(group) %>%
  summarise(percentage = mean(boundaryCross > 0) * 100)


p <- ggplot(summary_data, aes(x = group, y = percentage)) +
  geom_bar(stat = \identity\, fill = \skyblue\) +
  labs(title = \Percentage of Rows with boundaryCross > 0 per Group\,
       x = \Group\,
       y = \Percentage\) +
  theme_classic() + ylim(0, 100)

fileName <- paste0(\boundaryCrossRatio_A485\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJRWx0Y0c5eWRHbHVaeUJrYVdabVpYSmxiblJwWVd3Z2NtVm5kV3hoZEc5eWVTQnNiMjl3YzF4dWJHOXZjQzUxY0NBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z1hGeGphSEp2Ylc5ZlkyOXVjMTloYm01dlNHbGxjbUZ5WTJoNVgzQmxMWEJsWDBFME9EVjJjMFJOVTA5ZlZWQmZaR2xtWmpBdU1pNWlaV1J3WlZ4Y0tTa2dKVDRsWEc0Z0lHUndiSGx5T2pwdGRYUmhkR1VvWjNKdmRYQWdQU0JjWEhWd1hGd3BYRzVqYjJ4dVlXMWxjeWhzYjI5d0xuVndLU0E4TFNCaktGeGNZMmh5TVZ4Y0xDQmNYSE4wWVhKME1WeGNMQ0JjWEdWdVpERmNYQ3dnWEZ4amFISXlYRndzSUZ4Y2MzUmhjblF5WEZ3c0lGeGNaVzVrTWx4Y0xDQmNYR2R5YjNWd1hGd3BYRzVzYjI5d0xtNXZJRHd0SUdaeVpXRmtLR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0JjWEdOb2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxmY0dVdGNHVmZRVFE0TlhaelJFMVRUMTlPVDE5a2FXWm1NQzR5TG1KbFpIQmxYRndwS1NBbFBpVmNiaUFnWkhCc2VYSTZPbTExZEdGMFpTaG5jbTkxY0NBOUlGeGNibTljWENsY2JtTnZiRzVoYldWektHeHZiM0F1Ym04cElEd3RJR01vWEZ4amFISXhYRndzSUZ4Y2MzUmhjblF4WEZ3c0lGeGNaVzVrTVZ4Y0xDQmNYR05vY2pKY1hDd2dYRnh6ZEdGeWRESmNYQ3dnWEZ4bGJtUXlYRndzSUZ4Y1ozSnZkWEJjWENsY2JteHZiM0F1Wkc5M2JpQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2dYRnhqYUhKdmJXOWZZMjl1YzE5aGJtNXZTR2xsY21GeVkyaDVYM0JsTFhCbFgwRTBPRFYyYzBSTlUwOWZSRTlYVGw5a2FXWm1NQzR5TG1KbFpIQmxYRndwS1NBbFBpVmNiaUFnWkhCc2VYSTZPbTExZEdGMFpTaG5jbTkxY0NBOUlGeGNaRzkzYmx4Y0tWeHVZMjlzYm1GdFpYTW9iRzl2Y0M1a2IzZHVLU0E4TFNCaktGeGNZMmh5TVZ4Y0xDQmNYSE4wWVhKME1WeGNMQ0JjWEdWdVpERmNYQ3dnWEZ4amFISXlYRndzSUZ4Y2MzUmhjblF5WEZ3c0lGeGNaVzVrTWx4Y0xDQmNYR2R5YjNWd1hGd3BYRzVjYm14dmIzQnpJRHd0SUdKcGJtUmZjbTkzY3loaWFXNWtYM0p2ZDNNb2JHOXZjQzUxY0N3Z2JHOXZjQzV1Ynlrc0lHeHZiM0F1Wkc5M2JpbGNibHh1SXlNaklFbHRjRzl5ZEdsdVp5QlVRVVFnWW05MWJtUmhjbmxjYm5SaFpGOWliM1Z1WkdGeWVTQThMU0JtY21WaFpDaG9aWEpsS0Z4Y0xpNHZMaTR2Y21WemRXeDBMMVJCUkZ4Y0xDQmNYRlJCUkY4eU5XdGlYekV5Tld0aVgyOTBjM1ZmWW05MWJtUmhjbWxsYzE5SE1VUk5VMDh1WW1Wa1hGd3BLVnh1WTI5c2JtRnRaWE1vZEdGa1gySnZkVzVrWVhKNUtTQThMU0JqS0Z4Y1kyaHlYRndzSUZ4Y2MzUmhjblJjWEN3Z1hGeGxibVJjWENsY2JuUmhaRjlpYjNWdVpHRnllU0E4TFNCMFlXUmZZbTkxYm1SaGNua2dKVDRsSUdSd2JIbHlPanB0ZFhSaGRHVW9kR0ZrWDJsa0lEMGdjR0Z6ZEdVb1kyaHlMQ0J6ZEdGeWRDd2daVzVrTENCelpYQWdQU0JjWEY5Y1hDa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUhOMFlYSjBJRDBnYzNSaGNuUWdMVEUzTlRBd01DOHlMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCbGJtUWdQU0JsYm1RZ0t5QXhOelV3TURBdk1peGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWTJWdWRHVnlJRDBnS0hOMFlYSjBJQ3NnWlc1a0tTOHlLVnh1SXlNaklFWjFibU4wYVc5dWMxeHVZMmhsWTJ0Q2IzVnVaR0Z5ZVVOeWIzTnpJRHd0SUdaMWJtTjBhVzl1S0dOb2NtOXRNU3dnYzNSaGNuUXhMQ0JsYm1ReUxDQjBZV1JmWW05MWJtUmhjbmtwZTF4dUlDQjBaVzF3SUR3dElIUmhaRjlpYjNWdVpHRnllU0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhqYUhJZ1BUMGdZMmh5YjIweExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1kyVnVkR1Z5SUQ0Z2MzUmhjblF4TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWTJWdWRHVnlJRHdnWlc1a01pbGNiaUFnY21WMGRYSnVLR3hsYm1kMGFDaDBaVzF3SkdObGJuUmxjaWtwWEc1OVhHNWNiaU1qSXlCRGFHVmpheUJ2ZG1WeWJHRndYRzVzYjI5d2N5QThMU0JzYjI5d2N5QWxQaVVnY205M2QybHpaU2dwSUNVK0pWeHVJQ0JrY0d4NWNqbzZiWFYwWVhSbEtHSnZkVzVrWVhKNVEzSnZjM01nUFNCamFHVmphMEp2ZFc1a1lYSjVRM0p2YzNNb1kyaHlNU3dnYzNSaGNuUXhMQ0JsYm1ReUxDQjBZV1JmWW05MWJtUmhjbmtwS1Z4dVhHNGpJeU1nVUd4dmRIUnBibWRjYm5OMWJXMWhjbmxmWkdGMFlTQThMU0JzYjI5d2N5QWxQaVZjYmlBZ1ozSnZkWEJmWW5rb1ozSnZkWEFwSUNVK0pWeHVJQ0J6ZFcxdFlYSnBjMlVvY0dWeVkyVnVkR0ZuWlNBOUlHMWxZVzRvWW05MWJtUmhjbmxEY205emN5QStJREFwSUNvZ01UQXdLVnh1WEc1Y2JuQWdQQzBnWjJkd2JHOTBLSE4xYlcxaGNubGZaR0YwWVN3Z1lXVnpLSGdnUFNCbmNtOTFjQ3dnZVNBOUlIQmxjbU5sYm5SaFoyVXBLU0FyWEc0Z0lHZGxiMjFmWW1GeUtITjBZWFFnUFNCY1hHbGtaVzUwYVhSNVhGd3NJR1pwYkd3Z1BTQmNYSE5yZVdKc2RXVmNYQ2tnSzF4dUlDQnNZV0p6S0hScGRHeGxJRDBnWEZ4UVpYSmpaVzUwWVdkbElHOW1JRkp2ZDNNZ2QybDBhQ0JpYjNWdVpHRnllVU55YjNOeklENGdNQ0J3WlhJZ1IzSnZkWEJjWEN4Y2JpQWdJQ0FnSUNCNElEMGdYRnhIY205MWNGeGNMRnh1SUNBZ0lDQWdJSGtnUFNCY1hGQmxjbU5sYm5SaFoyVmNYQ2tnSzF4dUlDQjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0t5QjViR2x0S0RBc0lERXdNQ2xjYmx4dVptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGeGNZbTkxYm1SaGNubERjbTl6YzFKaGRHbHZYMEUwT0RWY1hDbGNibWhsYVdkb2RDQThMU0F6WEc1M2FXUjBhQ0E4TFNBelhHNXdibWNvYUdWeVpTaG1hV2RFYVhJc0lIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hGd3VjRzVuWEZ3cEtTd2djbVZ6SUQwZ05qQXdMQ0IxYm1sMElEMGdYRnhwYmx4Y0xDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc1d2NtbHVkQ2h3S1Z4dVpHVjJMbTltWmlncFhHNXpkbWRzYVhSbEtHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRnhjTG5OMloxeGNLU2tzSUNCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzV3Y21sdWRDaHdLVnh1WkdWMkxtOW1aaWdwWEc1Z1lHQmNibUJnWUNKOSAtLT5cblxuYGBgclxuYGBgclxuIyMjIEltcG9ydGluZyBkaWZmZXJlbnRpYWwgcmVndWxhdG9yeSBsb29wc1xubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXHVwXFwpXG5jb2xuYW1lcyhsb29wLnVwKSA8LSBjKFxcY2hyMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHIyXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcLCBcXGdyb3VwXFwpXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IFxcbm9cXClcbmNvbG5hbWVzKGxvb3Aubm8pIDwtIGMoXFxjaHIxXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocjJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcZ3JvdXBcXClcbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IFxcZG93blxcKVxuY29sbmFtZXMobG9vcC5kb3duKSA8LSBjKFxcY2hyMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHIyXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcLCBcXGdyb3VwXFwpXG5cbmxvb3BzIDwtIGJpbmRfcm93cyhiaW5kX3Jvd3MobG9vcC51cCwgbG9vcC5ubyksIGxvb3AuZG93bilcblxuIyMjIEltcG9ydGluZyBUQUQgYm91bmRhcnlcbnRhZF9ib3VuZGFyeSA8LSBmcmVhZChoZXJlKFxcLi4vLi4vcmVzdWx0L1RBRFxcLCBcXFRBRF8yNWtiXzEyNWtiX290c3VfYm91bmRhcmllc19HMURNU08uYmVkXFwpKVxuY29sbmFtZXModGFkX2JvdW5kYXJ5KSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnRhZF9ib3VuZGFyeSA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjptdXRhdGUodGFkX2lkID0gcGFzdGUoY2hyLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHN0YXJ0ID0gc3RhcnQgLTE3NTAwMC8yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmQgPSBlbmQgKyAxNzUwMDAvMixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyID0gKHN0YXJ0ICsgZW5kKS8yKVxuIyMjIEZ1bmN0aW9uc1xuY2hlY2tCb3VuZGFyeUNyb3NzIDwtIGZ1bmN0aW9uKGNocm9tMSwgc3RhcnQxLCBlbmQyLCB0YWRfYm91bmRhcnkpe1xuICB0ZW1wIDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6OmZpbHRlcihjaHIgPT0gY2hyb20xLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyID4gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyIDwgZW5kMilcbiAgcmV0dXJuKGxlbmd0aCh0ZW1wJGNlbnRlcikpXG59XG5cbiMjIyBDaGVjayBvdmVybGFwXG5sb29wcyA8LSBsb29wcyAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKGJvdW5kYXJ5Q3Jvc3MgPSBjaGVja0JvdW5kYXJ5Q3Jvc3MoY2hyMSwgc3RhcnQxLCBlbmQyLCB0YWRfYm91bmRhcnkpKVxuXG4jIyMgUGxvdHRpbmdcbnN1bW1hcnlfZGF0YSA8LSBsb29wcyAlPiVcbiAgZ3JvdXBfYnkoZ3JvdXApICU+JVxuICBzdW1tYXJpc2UocGVyY2VudGFnZSA9IG1lYW4oYm91bmRhcnlDcm9zcyA+IDApICogMTAwKVxuXG5cbnAgPC0gZ2dwbG90KHN1bW1hcnlfZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IHBlcmNlbnRhZ2UpKSArXG4gIGdlb21fYmFyKHN0YXQgPSBcXGlkZW50aXR5XFwsIGZpbGwgPSBcXHNreWJsdWVcXCkgK1xuICBsYWJzKHRpdGxlID0gXFxQZXJjZW50YWdlIG9mIFJvd3Mgd2l0aCBib3VuZGFyeUNyb3NzID4gMCBwZXIgR3JvdXBcXCxcbiAgICAgICB4ID0gXFxHcm91cFxcLFxuICAgICAgIHkgPSBcXFBlcmNlbnRhZ2VcXCkgK1xuICB0aGVtZV9jbGFzc2ljKCkgKyB5bGltKDAsIDEwMClcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcYm91bmRhcnlDcm9zc1JhdGlvX0E0ODVcXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIEltcG9ydGluZyBkaWZmZXJlbnRpYWwgcmVndWxhdG9yeSBsb29wc1xubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBcXHVwXFwpXG5jb2xuYW1lcyhsb29wLnVwKSA8LSBjKFxcY2hyMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHIyXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcLCBcXGdyb3VwXFwpXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IFxcbm9cXClcbmNvbG5hbWVzKGxvb3Aubm8pIDwtIGMoXFxjaHIxXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocjJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcZ3JvdXBcXClcbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IFxcZG93blxcKVxuY29sbmFtZXMobG9vcC5kb3duKSA8LSBjKFxcY2hyMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHIyXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcLCBcXGdyb3VwXFwpXG5cbmxvb3BzIDwtIGJpbmRfcm93cyhiaW5kX3Jvd3MobG9vcC51cCwgbG9vcC5ubyksIGxvb3AuZG93bilcblxuIyMjIEltcG9ydGluZyBUQUQgYm91bmRhcnlcbnRhZF9ib3VuZGFyeSA8LSBmcmVhZChoZXJlKFxcLi4vLi4vcmVzdWx0L1RBRFxcLCBcXFRBRF8yNWtiXzEyNWtiX290c3VfYm91bmRhcmllc19HMURNU08uYmVkXFwpKVxuY29sbmFtZXModGFkX2JvdW5kYXJ5KSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnRhZF9ib3VuZGFyeSA8LSB0YWRfYm91bmRhcnkgJT4lIGRwbHlyOjptdXRhdGUodGFkX2lkID0gcGFzdGUoY2hyLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHN0YXJ0ID0gc3RhcnQgLTE3NTAwMC8yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmQgPSBlbmQgKyAxNzUwMDAvMixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyID0gKHN0YXJ0ICsgZW5kKS8yKVxuIyMjIEZ1bmN0aW9uc1xuY2hlY2tCb3VuZGFyeUNyb3NzIDwtIGZ1bmN0aW9uKGNocm9tMSwgc3RhcnQxLCBlbmQyLCB0YWRfYm91bmRhcnkpe1xuICB0ZW1wIDwtIHRhZF9ib3VuZGFyeSAlPiUgZHBseXI6OmZpbHRlcihjaHIgPT0gY2hyb20xLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyID4gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyIDwgZW5kMilcbiAgcmV0dXJuKGxlbmd0aCh0ZW1wJGNlbnRlcikpXG59XG5cbiMjIyBDaGVjayBvdmVybGFwXG5sb29wcyA8LSBsb29wcyAlPiUgcm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKGJvdW5kYXJ5Q3Jvc3MgPSBjaGVja0JvdW5kYXJ5Q3Jvc3MoY2hyMSwgc3RhcnQxLCBlbmQyLCB0YWRfYm91bmRhcnkpKVxuXG4jIyMgUGxvdHRpbmdcbnN1bW1hcnlfZGF0YSA8LSBsb29wcyAlPiVcbiAgZ3JvdXBfYnkoZ3JvdXApICU+JVxuICBzdW1tYXJpc2UocGVyY2VudGFnZSA9IG1lYW4oYm91bmRhcnlDcm9zcyA+IDApICogMTAwKVxuXG5cbnAgPC0gZ2dwbG90KHN1bW1hcnlfZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IHBlcmNlbnRhZ2UpKSArXG4gIGdlb21fYmFyKHN0YXQgPSBcXGlkZW50aXR5XFwsIGZpbGwgPSBcXHNreWJsdWVcXCkgK1xuICBsYWJzKHRpdGxlID0gXFxQZXJjZW50YWdlIG9mIFJvd3Mgd2l0aCBib3VuZGFyeUNyb3NzID4gMCBwZXIgR3JvdXBcXCxcbiAgICAgICB4ID0gXFxHcm91cFxcLFxuICAgICAgIHkgPSBcXFBlcmNlbnRhZ2VcXCkgK1xuICB0aGVtZV9jbGFzc2ljKCkgKyB5bGltKDAsIDEwMClcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcYm91bmRhcnlDcm9zc1JhdGlvX0E0ODVcXClcbmhlaWdodCA8LSAzXG53aWR0aCA8LSAzXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYCJ9 -->

```r
```r
### Importing differential regulatory loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\)) %>%
  dplyr::mutate(group = \up\)
colnames(loop.up) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\, \group\)
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\)) %>%
  dplyr::mutate(group = \no\)
colnames(loop.no) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\, \group\)
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\)) %>%
  dplyr::mutate(group = \down\)
colnames(loop.down) <- c(\chr1\, \start1\, \end1\, \chr2\, \start2\, \end2\, \group\)

loops <- bind_rows(bind_rows(loop.up, loop.no), loop.down)

### Importing TAD boundary
tad_boundary <- fread(here(\../../result/TAD\, \TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed\))
colnames(tad_boundary) <- c(\chr\, \start\, \end\)
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = \_\),
                                               start = start -175000/2,
                                               end = end + 175000/2,
                                               center = (start + end)/2)
### Functions
checkBoundaryCross <- function(chrom1, start1, end2, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom1,
                                 center > start1,
                                 center < end2)
  return(length(temp$center))
}

### Check overlap
loops <- loops %>% rowwise() %>%
  dplyr::mutate(boundaryCross = checkBoundaryCross(chr1, start1, end2, tad_boundary))

### Plotting
summary_data <- loops %>%
  group_by(group) %>%
  summarise(percentage = mean(boundaryCross > 0) * 100)


p <- ggplot(summary_data, aes(x = group, y = percentage)) +
  geom_bar(stat = \identity\, fill = \skyblue\) +
  labs(title = \Percentage of Rows with boundaryCross > 0 per Group\,
       x = \Group\,
       y = \Percentage\) +
  theme_classic() + ylim(0, 100)

fileName <- paste0(\boundaryCrossRatio_A485\)
height <- 3
width <- 3
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



## [2.20] Checking how many loops cross the boundary?
Previously, I tried to check the percentage of loops crossing the boundary per group which wasn't fruitful.
This time, try to do this on the differential loops.
#### dTAG

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJNVDBGRVNVNUhJRXhQVEVFZ1JFSmNibXhwWW5KaGNua29YQ0p6YVcxd2JHVkRZV05vWlZ3aUtWeHViR2xpY21GeWVTaGNJa3hQVEVGY0lpbGNibXh2YkdGRVFpQTlJR3h2WVdSU1pXZHBiMjVFUWloY0lpOVdiMngxYldWekwxVkxTa2xPWDFOVFJDOUhaVzV2YldsamMxOHdNMTlCYm1Gc2VYTnBjMTlYYjNKcmFXNW5MM0psWm1WeVpXNWpaUzlNVDB4QlEyOXlaVjlqWVdOb1pXUXZiVzB4TUZ3aUtWeHVYRzRqSUVaVlRrTlVTVTlPVTF4dVpYaDBjbUZqZEVGdVkyaHZjaUE4TFNCbWRXNWpkR2x2Ymloc2IyOXdLWHRjYmlBZ1lXNWphRzl5TVNBOExTQnNiMjl3SUNVK0pTQmtjR3g1Y2pvNmMyVnNaV04wS0dNb01Td2dNaXdnTXlrcFhHNGdJR052Ykc1aGJXVnpLR0Z1WTJodmNqRXBJRHd0SUdNb1hDSmphSEpjSWl3Z1hDSnpkR0Z5ZEZ3aUxDQmNJbVZ1WkZ3aUtWeHVJQ0JoYm1Ob2IzSXlJRHd0SUd4dmIzQWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9ZeWcwTENBMUxDQTJLU2xjYmlBZ1kyOXNibUZ0WlhNb1lXNWphRzl5TWlrZ1BDMGdZeWhjSW1Ob2Nsd2lMQ0JjSW5OMFlYSjBYQ0lzSUZ3aVpXNWtYQ0lwWEc0Z0lHRnVZMmh2Y25NZ1BDMGdjbVZrZFdObEtHMWhhMlZIVW1GdVoyVnpSbkp2YlVSaGRHRkdjbUZ0WlNoaWFXNWtYM0p2ZDNNb1lXNWphRzl5TVN3Z1lXNWphRzl5TWlrcEtWeHVJQ0FnSUhKbGRIVnliaWhoYm1Ob2IzSnpLVnh1ZlZ4dVhHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuIyBMT0FESU5HIExPTEEgREJcbmxpYnJhcnkoXFxzaW1wbGVDYWNoZVxcKVxubGlicmFyeShcXExPTEFcXClcbmxvbGFEQiA9IGxvYWRSZWdpb25EQihcXC9Wb2x1bWVzL1VLSklOX1NTRC9HZW5vbWljc18wM19BbmFseXNpc19Xb3JraW5nL3JlZmVyZW5jZS9MT0xBQ29yZV9jYWNoZWQvbW0xMFxcKVxuXG4jIEZVTkNUSU9OU1xuZXh0cmFjdEFuY2hvciA8LSBmdW5jdGlvbihsb29wKXtcbiAgYW5jaG9yMSA8LSBsb29wICU+JSBkcGx5cjo6c2VsZWN0KGMoMSwgMiwgMykpXG4gIGNvbG5hbWVzKGFuY2hvcjEpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuICBhbmNob3IyIDwtIGxvb3AgJT4lIGRwbHlyOjpzZWxlY3QoYyg0LCA1LCA2KSlcbiAgY29sbmFtZXMoYW5jaG9yMikgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG4gIGFuY2hvcnMgPC0gcmVkdWNlKG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShiaW5kX3Jvd3MoYW5jaG9yMSwgYW5jaG9yMikpKVxuICAgIHJldHVybihhbmNob3JzKVxufVxuXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
# LOADING LOLA DB
library(\simpleCache\)
library(\LOLA\)
lolaDB = loadRegionDB(\/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/reference/LOLACore_cached/mm10\)

# FUNCTIONS
extractAnchor <- function(loop){
  anchor1 <- loop %>% dplyr::select(c(1, 2, 3))
  colnames(anchor1) <- c(\chr\, \start\, \end\)
  anchor2 <- loop %>% dplyr::select(c(4, 5, 6))
  colnames(anchor2) <- c(\chr\, \start\, \end\)
  anchors <- reduce(makeGRangesFromDataFrame(bind_rows(anchor1, anchor2)))
    return(anchors)
}



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5Qk1UMEZFU1U1SElFeFBURUVnUkVKY2JteHBZbkpoY25rb1hGeHphVzF3YkdWRFlXTm9aVnhjS1Z4dWJHbGljbUZ5ZVNoY1hFeFBURUZjWENsY2JteHZiR0ZFUWlBOUlHeHZZV1JTWldkcGIyNUVRaWhjWEM5V2IyeDFiV1Z6TDFWTFNrbE9YMU5UUkM5SFpXNXZiV2xqYzE4d00xOUJibUZzZVhOcGMxOVhiM0pyYVc1bkwzSmxabVZ5Wlc1alpTOU1UMHhCUTI5eVpWOWpZV05vWldRdmJXMHhNRnhjS1Z4dVhHNGpJRVpWVGtOVVNVOU9VMXh1WlhoMGNtRmpkRUZ1WTJodmNpQThMU0JtZFc1amRHbHZiaWhzYjI5d0tYdGNiaUFnWVc1amFHOXlNU0E4TFNCc2IyOXdJQ1UrSlNCa2NHeDVjam82YzJWc1pXTjBLR01vTVN3Z01pd2dNeWtwWEc0Z0lHTnZiRzVoYldWektHRnVZMmh2Y2pFcElEd3RJR01vWEZ4amFISmNYQ3dnWEZ4emRHRnlkRnhjTENCY1hHVnVaRnhjS1Z4dUlDQmhibU5vYjNJeUlEd3RJR3h2YjNBZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1l5ZzBMQ0ExTENBMktTbGNiaUFnWTI5c2JtRnRaWE1vWVc1amFHOXlNaWtnUEMwZ1l5aGNYR05vY2x4Y0xDQmNYSE4wWVhKMFhGd3NJRnhjWlc1a1hGd3BYRzRnSUdGdVkyaHZjbk1nUEMwZ2NtVmtkV05sS0cxaGEyVkhVbUZ1WjJWelJuSnZiVVJoZEdGR2NtRnRaU2hpYVc1a1gzSnZkM01vWVc1amFHOXlNU3dnWVc1amFHOXlNaWtwS1Z4dUlDQWdJSEpsZEhWeWJpaGhibU5vYjNKektWeHVmVnh1WEc1Z1lHQmNibUJnWUNKOSAtLT5cblxuYGBgclxuYGBgclxuIyBMT0FESU5HIExPTEEgREJcbmxpYnJhcnkoXFxzaW1wbGVDYWNoZVxcKVxubGlicmFyeShcXExPTEFcXClcbmxvbGFEQiA9IGxvYWRSZWdpb25EQihcXC9Wb2x1bWVzL1VLSklOX1NTRC9HZW5vbWljc18wM19BbmFseXNpc19Xb3JraW5nL3JlZmVyZW5jZS9MT0xBQ29yZV9jYWNoZWQvbW0xMFxcKVxuXG4jIEZVTkNUSU9OU1xuZXh0cmFjdEFuY2hvciA8LSBmdW5jdGlvbihsb29wKXtcbiAgYW5jaG9yMSA8LSBsb29wICU+JSBkcGx5cjo6c2VsZWN0KGMoMSwgMiwgMykpXG4gIGNvbG5hbWVzKGFuY2hvcjEpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuICBhbmNob3IyIDwtIGxvb3AgJT4lIGRwbHlyOjpzZWxlY3QoYyg0LCA1LCA2KSlcbiAgY29sbmFtZXMoYW5jaG9yMikgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG4gIGFuY2hvcnMgPC0gcmVkdWNlKG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShiaW5kX3Jvd3MoYW5jaG9yMSwgYW5jaG9yMikpKVxuICAgIHJldHVybihhbmNob3JzKVxufVxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBMT0FESU5HIExPTEEgREJcbmxpYnJhcnkoXFxzaW1wbGVDYWNoZVxcKVxubGlicmFyeShcXExPTEFcXClcbmxvbGFEQiA9IGxvYWRSZWdpb25EQihcXC9Wb2x1bWVzL1VLSklOX1NTRC9HZW5vbWljc18wM19BbmFseXNpc19Xb3JraW5nL3JlZmVyZW5jZS9MT0xBQ29yZV9jYWNoZWQvbW0xMFxcKVxuXG4jIEZVTkNUSU9OU1xuZXh0cmFjdEFuY2hvciA8LSBmdW5jdGlvbihsb29wKXtcbiAgYW5jaG9yMSA8LSBsb29wICU+JSBkcGx5cjo6c2VsZWN0KGMoMSwgMiwgMykpXG4gIGNvbG5hbWVzKGFuY2hvcjEpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuICBhbmNob3IyIDwtIGxvb3AgJT4lIGRwbHlyOjpzZWxlY3QoYyg0LCA1LCA2KSlcbiAgY29sbmFtZXMoYW5jaG9yMikgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG4gIGFuY2hvcnMgPC0gcmVkdWNlKG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShiaW5kX3Jvd3MoYW5jaG9yMSwgYW5jaG9yMikpKVxuICAgIHJldHVybihhbmNob3JzKVxufVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
# LOADING LOLA DB
library(\simpleCache\)
library(\LOLA\)
lolaDB = loadRegionDB(\/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/reference/LOLACore_cached/mm10\)

# FUNCTIONS
extractAnchor <- function(loop){
  anchor1 <- loop %>% dplyr::select(c(1, 2, 3))
  colnames(anchor1) <- c(\chr\, \start\, \end\)
  anchor2 <- loop %>% dplyr::select(c(4, 5, 6))
  colnames(anchor2) <- c(\chr\, \start\, \end\)
  anchors <- reduce(makeGRangesFromDataFrame(bind_rows(anchor1, anchor2)))
    return(anchors)
}

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### A485

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXCIpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcImNoclwiLCBcInN0YXJ0XCIsIFwiZW5kXCIpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcIikpICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcIlAtUFwiLCBcIlAtRVwiLCBcIkUtRVwiKSlcbmFuY2hvci5hbGwgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5hbGwpKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5hbGwsIGF0YWMuZ3IpXG5hbmNob3IuYWxsIDwtIHBpbnRlcnNlY3QoYW5jaG9yLmFsbFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cblxubG9vcC4xIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfRzF2c0FzeW5jX2JvdGhSZXRhaW5lZC5iZWRwZVwiKSlcbmFuY2hvci4xIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuMSkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLjEsIGF0YWMuZ3IpXG5hbmNob3IuMSA8LSBwaW50ZXJzZWN0KGFuY2hvci4xW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AuMiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0cxdnNBc3luY19Bc3luY1NwZWNpZmljUGVydC5iZWRwZVwiKSlcbmFuY2hvci4yIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuMikpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLjIsIGF0YWMuZ3IpXG5hbmNob3IuMiA8LSBwaW50ZXJzZWN0KGFuY2hvci4yW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AuMyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0cxdnNBc3luY19HMVNwZWNpZmljUGVydC5iZWRwZVwiKSlcbmFuY2hvci4zIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuMykpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLjMsIGF0YWMuZ3IpXG5hbmNob3IuMyA8LSBwaW50ZXJzZWN0KGFuY2hvci4zW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AuNCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0cxdnNBc3luY19ib3RoUGVydC5iZWRwZVwiKSlcbmFuY2hvci40IDwtIChleHRyYWN0QW5jaG9yKGxvb3AuNCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLjQsIGF0YWMuZ3IpXG5hbmNob3IuNCA8LSBwaW50ZXJzZWN0KGFuY2hvci40W3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cblxuYW5jaG9ycyA8LSBsaXN0KGFuY2hvci4xLCBhbmNob3IuMiwgYW5jaG9yLjMsIGFuY2hvci40KVxudGJzIDwtIGxpc3QoKVxudGVtcHMgPC0gbGlzdCgpXG5cbiMgUHJvY2VzcyBjbHVzdGVycyBjMSB0byBjOFxuZm9yIChpIGluIDE6NCkge1xuICBcbiAgYW5jaG9yIDwtIGFuY2hvcnNbW2ldXVxuICAjIFJ1biBMT0xBXG4gIHJlc3VsdCA8LSBydW5MT0xBKGFuY2hvciwgYW5jaG9yLmFsbCwgbG9sYURCKVxuICB0YiA8LSBhc190aWJibGUocmVzdWx0KVxuICBcbiAgIyBGaWx0ZXIgYW5kIHN1bW1hcml6ZVxuICB0YiA8LSB0YiAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpKSAlPiVcbiAgICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcImVtYnJ5b25pYyBzdGVtIGNlbGxcIikgJT4lXG4gICAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lXG4gICAgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4gICAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxuICBcbiAgIyBTdG9yZSB0YlxuICB0YnNbW2ldXSA8LSB0YlxuICBcbiAgIyBTZWxlY3QgYW5kIHJlbmFtZSBvZGRzUmF0aW9cbiAgdGVtcCA8LSB0YiAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIG9kZHNSYXRpbylcbiAgY29sbmFtZXModGVtcCkgPC0gYyhcInRhcmdldFwiLCBwYXN0ZTAoXCJPUl9jXCIsIGkpKVxuICBcbiAgIyBTdG9yZSB0ZW1wXG4gIHRlbXBzW1tpXV0gPC0gdGVtcFxufVxuXG4jIE1lcmdlIGFsbCB0ZW1wIHRhYmxlcyBpbnRvIG9uZVxudGVtcCA8LSBSZWR1Y2UoZnVuY3Rpb24oeCwgeSkgZnVsbF9qb2luKHgsIHksIGJ5ID0gXCJ0YXJnZXRcIiksIHRlbXBzKSAlPiVcbiAgbXV0YXRlX2FsbCh+cmVwbGFjZV9uYSguLCAxKSlcbmNvbG5hbWVzKHRlbXApIDwtIGMoXCJ0YXJnZXRcIiwgXCJib3RoUmV0YWluZWRcIiwgXCJBc3luY1NwZWNpZmljUGVydHVyYlwiLCBcIkcxU3BlY2lmaWNQZXJ0dXJiXCIsIFwiYm90aFBlcnR1cmJcIilcbmRhdGEgPC0gdGVtcCAlPiUgY29sdW1uX3RvX3Jvd25hbWVzKFwidGFyZ2V0XCIpICU+JSBhcy5tYXRyaXgoKVxuXG5saWJyYXJ5KGNpcmNsaXplKVxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoMSwgbWF4KGRhdGEpKSwgYyhcIndoaXRlXCIsIFwicmVkXCIpKVxuXG5cbiNmdml6X25iY2x1c3QoZGF0YSwga21lYW5zLCBtZXRob2QgPSBcIndzc1wiKVxuXG5wIDwtIEhlYXRtYXAoXG4gIGRhdGEsXG4gIG5hbWUgPSBcIk9kZHMgUmF0aW9cIiwgICAgICAgICAgICAgICAgICAgIyBOYW1lIG9mIHRoZSBoZWF0bWFwIGxlZ2VuZFxuICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSwgICAgICAgICAgICAjIFJlbW92ZSBjb2x1bW4gZGVuZHJvZ3JhbVxuICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gIGNvbCA9IGNvbF9mdW4sXG4gIGJvcmRlciA9IFRSVUVcbilcblxuXG5cbmBgYCJ9 -->\n\n```r\natac <- fread(here(refDir, \\GSM3106257_ATAC_ESC_1.bed\\)) %>% dplyr::select(V1, V2, V3)\ncolnames(atac) <- c(\\chr\\, \\start\\, \\end\\)\natac.gr <- makeGRangesFromDataFrame(atac)\n\n# LOADING LOOPS\n### Importing differential regulatory loops & extract anchor\nloop.all <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\)) %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\))\nanchor.all <- (extractAnchor(loop.all))\noverlaps <- findOverlaps(anchor.all, atac.gr)\nanchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\n\n\nloop.1 <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\\))\nanchor.1 <- (extractAnchor(loop.1))\noverlaps <- findOverlaps(anchor.1, atac.gr)\nanchor.1 <- pintersect(anchor.1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.2 <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\\))\nanchor.2 <- (extractAnchor(loop.2))\noverlaps <- findOverlaps(anchor.2, atac.gr)\nanchor.2 <- pintersect(anchor.2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.3 <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\\))\nanchor.3 <- (extractAnchor(loop.3))\noverlaps <- findOverlaps(anchor.3, atac.gr)\nanchor.3 <- pintersect(anchor.3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.4 <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\\))\nanchor.4 <- (extractAnchor(loop.4))\noverlaps <- findOverlaps(anchor.4, atac.gr)\nanchor.4 <- pintersect(anchor.4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\n\nanchors <- list(anchor.1, anchor.2, anchor.3, anchor.4)\ntbs <- list()\ntemps <- list()\n\n# Process clusters c1 to c8\nfor (i in 1:4) {\n  \n  anchor <- anchors[[i]]\n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ncolnames(temp) <- c(\\target\\, \\bothRetained\\, \\AsyncSpecificPerturb\\, \\G1SpecificPerturb\\, \\bothPerturb\\)\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\)) %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



loop.1 <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\))
anchor.1 <- (extractAnchor(loop.1))
overlaps <- findOverlaps(anchor.1, atac.gr)
anchor.1 <- pintersect(anchor.1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.2 <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\))
anchor.2 <- (extractAnchor(loop.2))
overlaps <- findOverlaps(anchor.2, atac.gr)
anchor.2 <- pintersect(anchor.2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.3 <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\))
anchor.3 <- (extractAnchor(loop.3))
overlaps <- findOverlaps(anchor.3, atac.gr)
anchor.3 <- pintersect(anchor.3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.4 <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\))
anchor.4 <- (extractAnchor(loop.4))
overlaps <- findOverlaps(anchor.4, atac.gr)
anchor.4 <- pintersect(anchor.4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


anchors <- list(anchor.1, anchor.2, anchor.3, anchor.4)
tbs <- list()
temps <- list()

# Process clusters c1 to c8
for (i in 1:4) {
  
  anchor <- anchors[[i]]
  # Run LOLA
  result <- runLOLA(anchor, anchor.all, lolaDB)
  tb <- as_tibble(result)
  
  # Filter and summarize
  tb <- tb %>%
    dplyr::mutate(target = toupper(antibody)) %>%
    filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
    dplyr::filter(qValue < alpha) %>%
    dplyr::group_by(target) %>%
    slice_min(meanRnk, with_ties = FALSE)
  
  # Store tb
  tbs[[i]] <- tb
  
  # Select and rename oddsRatio
  temp <- tb %>% dplyr::select(target, oddsRatio)
  colnames(temp) <- c(\target\, paste0(\OR_c\, i))
  
  # Store temp
  temps[[i]] <- temp
}

# Merge all temp tables into one
temp <- Reduce(function(x, y) full_join(x, y, by = \target\), temps) %>%
  mutate_all(~replace_na(., 1))
colnames(temp) <- c(\target\, \bothRetained\, \AsyncSpecificPerturb\, \G1SpecificPerturb\, \bothPerturb\)
data <- temp %>% column_to_rownames(\target\) %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSlcbmFuY2hvci5hbGwgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5hbGwpKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5hbGwsIGF0YWMuZ3IpXG5hbmNob3IuYWxsIDwtIHBpbnRlcnNlY3QoYW5jaG9yLmFsbFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cblxubG9vcC4xIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfRzF2c0FzeW5jX2JvdGhSZXRhaW5lZC5iZWRwZVxcKSlcbmFuY2hvci4xIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuMSkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLjEsIGF0YWMuZ3IpXG5hbmNob3IuMSA8LSBwaW50ZXJzZWN0KGFuY2hvci4xW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AuMiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0cxdnNBc3luY19Bc3luY1NwZWNpZmljUGVydC5iZWRwZVxcKSlcbmFuY2hvci4yIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuMikpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLjIsIGF0YWMuZ3IpXG5hbmNob3IuMiA8LSBwaW50ZXJzZWN0KGFuY2hvci4yW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AuMyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0cxdnNBc3luY19HMVNwZWNpZmljUGVydC5iZWRwZVxcKSlcbmFuY2hvci4zIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuMykpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLjMsIGF0YWMuZ3IpXG5hbmNob3IuMyA8LSBwaW50ZXJzZWN0KGFuY2hvci4zW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AuNCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0cxdnNBc3luY19ib3RoUGVydC5iZWRwZVxcKSlcbmFuY2hvci40IDwtIChleHRyYWN0QW5jaG9yKGxvb3AuNCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLjQsIGF0YWMuZ3IpXG5hbmNob3IuNCA8LSBwaW50ZXJzZWN0KGFuY2hvci40W3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cblxuYW5jaG9ycyA8LSBsaXN0KGFuY2hvci4xLCBhbmNob3IuMiwgYW5jaG9yLjMsIGFuY2hvci40KVxudGJzIDwtIGxpc3QoKVxudGVtcHMgPC0gbGlzdCgpXG5cbiMgUHJvY2VzcyBjbHVzdGVycyBjMSB0byBjOFxuZm9yIChpIGluIDE6NCkge1xuICBcbiAgYW5jaG9yIDwtIGFuY2hvcnNbW2ldXVxuICAjIFJ1biBMT0xBXG4gIHJlc3VsdCA8LSBydW5MT0xBKGFuY2hvciwgYW5jaG9yLmFsbCwgbG9sYURCKVxuICB0YiA8LSBhc190aWJibGUocmVzdWx0KVxuICBcbiAgIyBGaWx0ZXIgYW5kIHN1bW1hcml6ZVxuICB0YiA8LSB0YiAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpKSAlPiVcbiAgICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lXG4gICAgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4gICAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxuICBcbiAgIyBTdG9yZSB0YlxuICB0YnNbW2ldXSA8LSB0YlxuICBcbiAgIyBTZWxlY3QgYW5kIHJlbmFtZSBvZGRzUmF0aW9cbiAgdGVtcCA8LSB0YiAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIG9kZHNSYXRpbylcbiAgY29sbmFtZXModGVtcCkgPC0gYyhcXHRhcmdldFxcLCBwYXN0ZTAoXFxPUl9jXFwsIGkpKVxuICBcbiAgIyBTdG9yZSB0ZW1wXG4gIHRlbXBzW1tpXV0gPC0gdGVtcFxufVxuXG4jIE1lcmdlIGFsbCB0ZW1wIHRhYmxlcyBpbnRvIG9uZVxudGVtcCA8LSBSZWR1Y2UoZnVuY3Rpb24oeCwgeSkgZnVsbF9qb2luKHgsIHksIGJ5ID0gXFx0YXJnZXRcXCksIHRlbXBzKSAlPiVcbiAgbXV0YXRlX2FsbCh+cmVwbGFjZV9uYSguLCAxKSlcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFx0YXJnZXRcXCwgXFxib3RoUmV0YWluZWRcXCwgXFxBc3luY1NwZWNpZmljUGVydHVyYlxcLCBcXEcxU3BlY2lmaWNQZXJ0dXJiXFwsIFxcYm90aFBlcnR1cmJcXClcbmRhdGEgPC0gdGVtcCAlPiUgY29sdW1uX3RvX3Jvd25hbWVzKFxcdGFyZ2V0XFwpICU+JSBhcy5tYXRyaXgoKVxuXG5saWJyYXJ5KGNpcmNsaXplKVxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoMSwgbWF4KGRhdGEpKSwgYyhcXHdoaXRlXFwsIFxccmVkXFwpKVxuXG5cbiNmdml6X25iY2x1c3QoZGF0YSwga21lYW5zLCBtZXRob2QgPSBcXHdzc1xcKVxuXG5wIDwtIEhlYXRtYXAoXG4gIGRhdGEsXG4gIG5hbWUgPSBcXE9kZHMgUmF0aW9cXCwgICAgICAgICAgICAgICAgICAgIyBOYW1lIG9mIHRoZSBoZWF0bWFwIGxlZ2VuZFxuICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSwgICAgICAgICAgICAjIFJlbW92ZSBjb2x1bW4gZGVuZHJvZ3JhbVxuICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gIGNvbCA9IGNvbF9mdW4sXG4gIGJvcmRlciA9IFRSVUVcbilcblxuXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\natac <- fread(here(refDir, \\GSM3106257_ATAC_ESC_1.bed\\)) %>% dplyr::select(V1, V2, V3)\ncolnames(atac) <- c(\\chr\\, \\start\\, \\end\\)\natac.gr <- makeGRangesFromDataFrame(atac)\n\n# LOADING LOOPS\n### Importing differential regulatory loops & extract anchor\nloop.all <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\)) %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\))\nanchor.all <- (extractAnchor(loop.all))\noverlaps <- findOverlaps(anchor.all, atac.gr)\nanchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\n\n\nloop.1 <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\\))\nanchor.1 <- (extractAnchor(loop.1))\noverlaps <- findOverlaps(anchor.1, atac.gr)\nanchor.1 <- pintersect(anchor.1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.2 <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\\))\nanchor.2 <- (extractAnchor(loop.2))\noverlaps <- findOverlaps(anchor.2, atac.gr)\nanchor.2 <- pintersect(anchor.2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.3 <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\\))\nanchor.3 <- (extractAnchor(loop.3))\noverlaps <- findOverlaps(anchor.3, atac.gr)\nanchor.3 <- pintersect(anchor.3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nloop.4 <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\\))\nanchor.4 <- (extractAnchor(loop.4))\noverlaps <- findOverlaps(anchor.4, atac.gr)\nanchor.4 <- pintersect(anchor.4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\n\nanchors <- list(anchor.1, anchor.2, anchor.3, anchor.4)\ntbs <- list()\ntemps <- list()\n\n# Process clusters c1 to c8\nfor (i in 1:4) {\n  \n  anchor <- anchors[[i]]\n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ncolnames(temp) <- c(\\target\\, \\bothRetained\\, \\AsyncSpecificPerturb\\, \\G1SpecificPerturb\\, \\bothPerturb\\)\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSlcbmFuY2hvci5hbGwgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5hbGwpKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5hbGwsIGF0YWMuZ3IpXG5hbmNob3IuYWxsIDwtIHBpbnRlcnNlY3QoYW5jaG9yLmFsbFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cblxubG9vcC4xIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfRzF2c0FzeW5jX2JvdGhSZXRhaW5lZC5iZWRwZVxcKSlcbmFuY2hvci4xIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuMSkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLjEsIGF0YWMuZ3IpXG5hbmNob3IuMSA8LSBwaW50ZXJzZWN0KGFuY2hvci4xW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AuMiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0cxdnNBc3luY19Bc3luY1NwZWNpZmljUGVydC5iZWRwZVxcKSlcbmFuY2hvci4yIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuMikpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLjIsIGF0YWMuZ3IpXG5hbmNob3IuMiA8LSBwaW50ZXJzZWN0KGFuY2hvci4yW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AuMyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0cxdnNBc3luY19HMVNwZWNpZmljUGVydC5iZWRwZVxcKSlcbmFuY2hvci4zIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuMykpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLjMsIGF0YWMuZ3IpXG5hbmNob3IuMyA8LSBwaW50ZXJzZWN0KGFuY2hvci4zW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AuNCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0cxdnNBc3luY19ib3RoUGVydC5iZWRwZVxcKSlcbmFuY2hvci40IDwtIChleHRyYWN0QW5jaG9yKGxvb3AuNCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLjQsIGF0YWMuZ3IpXG5hbmNob3IuNCA8LSBwaW50ZXJzZWN0KGFuY2hvci40W3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cblxuYW5jaG9ycyA8LSBsaXN0KGFuY2hvci4xLCBhbmNob3IuMiwgYW5jaG9yLjMsIGFuY2hvci40KVxudGJzIDwtIGxpc3QoKVxudGVtcHMgPC0gbGlzdCgpXG5cbiMgUHJvY2VzcyBjbHVzdGVycyBjMSB0byBjOFxuZm9yIChpIGluIDE6NCkge1xuICBcbiAgYW5jaG9yIDwtIGFuY2hvcnNbW2ldXVxuICAjIFJ1biBMT0xBXG4gIHJlc3VsdCA8LSBydW5MT0xBKGFuY2hvciwgYW5jaG9yLmFsbCwgbG9sYURCKVxuICB0YiA8LSBhc190aWJibGUocmVzdWx0KVxuICBcbiAgIyBGaWx0ZXIgYW5kIHN1bW1hcml6ZVxuICB0YiA8LSB0YiAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpKSAlPiVcbiAgICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lXG4gICAgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4gICAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxuICBcbiAgIyBTdG9yZSB0YlxuICB0YnNbW2ldXSA8LSB0YlxuICBcbiAgIyBTZWxlY3QgYW5kIHJlbmFtZSBvZGRzUmF0aW9cbiAgdGVtcCA8LSB0YiAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIG9kZHNSYXRpbylcbiAgY29sbmFtZXModGVtcCkgPC0gYyhcXHRhcmdldFxcLCBwYXN0ZTAoXFxPUl9jXFwsIGkpKVxuICBcbiAgIyBTdG9yZSB0ZW1wXG4gIHRlbXBzW1tpXV0gPC0gdGVtcFxufVxuXG4jIE1lcmdlIGFsbCB0ZW1wIHRhYmxlcyBpbnRvIG9uZVxudGVtcCA8LSBSZWR1Y2UoZnVuY3Rpb24oeCwgeSkgZnVsbF9qb2luKHgsIHksIGJ5ID0gXFx0YXJnZXRcXCksIHRlbXBzKSAlPiVcbiAgbXV0YXRlX2FsbCh+cmVwbGFjZV9uYSguLCAxKSlcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFx0YXJnZXRcXCwgXFxib3RoUmV0YWluZWRcXCwgXFxBc3luY1NwZWNpZmljUGVydHVyYlxcLCBcXEcxU3BlY2lmaWNQZXJ0dXJiXFwsIFxcYm90aFBlcnR1cmJcXClcbmRhdGEgPC0gdGVtcCAlPiUgY29sdW1uX3RvX3Jvd25hbWVzKFxcdGFyZ2V0XFwpICU+JSBhcy5tYXRyaXgoKVxuXG5saWJyYXJ5KGNpcmNsaXplKVxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoMSwgbWF4KGRhdGEpKSwgYyhcXHdoaXRlXFwsIFxccmVkXFwpKVxuXG5cbiNmdml6X25iY2x1c3QoZGF0YSwga21lYW5zLCBtZXRob2QgPSBcXHdzc1xcKVxuXG5wIDwtIEhlYXRtYXAoXG4gIGRhdGEsXG4gIG5hbWUgPSBcXE9kZHMgUmF0aW9cXCwgICAgICAgICAgICAgICAgICAgIyBOYW1lIG9mIHRoZSBoZWF0bWFwIGxlZ2VuZFxuICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSwgICAgICAgICAgICAjIFJlbW92ZSBjb2x1bW4gZGVuZHJvZ3JhbVxuICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gIGNvbCA9IGNvbF9mdW4sXG4gIGJvcmRlciA9IFRSVUVcbilcblxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\)) %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



loop.1 <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\))
anchor.1 <- (extractAnchor(loop.1))
overlaps <- findOverlaps(anchor.1, atac.gr)
anchor.1 <- pintersect(anchor.1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.2 <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\))
anchor.2 <- (extractAnchor(loop.2))
overlaps <- findOverlaps(anchor.2, atac.gr)
anchor.2 <- pintersect(anchor.2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.3 <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\))
anchor.3 <- (extractAnchor(loop.3))
overlaps <- findOverlaps(anchor.3, atac.gr)
anchor.3 <- pintersect(anchor.3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.4 <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\))
anchor.4 <- (extractAnchor(loop.4))
overlaps <- findOverlaps(anchor.4, atac.gr)
anchor.4 <- pintersect(anchor.4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


anchors <- list(anchor.1, anchor.2, anchor.3, anchor.4)
tbs <- list()
temps <- list()

# Process clusters c1 to c8
for (i in 1:4) {
  
  anchor <- anchors[[i]]
  # Run LOLA
  result <- runLOLA(anchor, anchor.all, lolaDB)
  tb <- as_tibble(result)
  
  # Filter and summarize
  tb <- tb %>%
    dplyr::mutate(target = toupper(antibody)) %>%
    filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
    dplyr::filter(qValue < alpha) %>%
    dplyr::group_by(target) %>%
    slice_min(meanRnk, with_ties = FALSE)
  
  # Store tb
  tbs[[i]] <- tb
  
  # Select and rename oddsRatio
  temp <- tb %>% dplyr::select(target, oddsRatio)
  colnames(temp) <- c(\target\, paste0(\OR_c\, i))
  
  # Store temp
  temps[[i]] <- temp
}

# Merge all temp tables into one
temp <- Reduce(function(x, y) full_join(x, y, by = \target\), temps) %>%
  mutate_all(~replace_na(., 1))
colnames(temp) <- c(\target\, \bothRetained\, \AsyncSpecificPerturb\, \G1SpecificPerturb\, \bothPerturb\)
data <- temp %>% column_to_rownames(\target\) %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



## [2.21] LOLA on differential loop anchors
##### LOADING LOLA

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZWFJoWXlBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYQ0pIVTAwek1UQTJNalUzWDBGVVFVTmZSVk5EWHpFdVltVmtYQ0lwS1NBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoV01Td2dWaklzSUZZektWeHVZMjlzYm1GdFpYTW9ZWFJoWXlrZ1BDMGdZeWhjSW1Ob2Nsd2lMQ0JjSW5OMFlYSjBYQ0lzSUZ3aVpXNWtYQ0lwWEc1aGRHRmpMbWR5SUR3dElHMWhhMlZIVW1GdVoyVnpSbkp2YlVSaGRHRkdjbUZ0WlNoaGRHRmpLVnh1WEc0aklFeFBRVVJKVGtjZ1RFOVBVRk5jYmlNakl5QkpiWEJ2Y25ScGJtY2daR2xtWm1WeVpXNTBhV0ZzSUhKbFozVnNZWFJ2Y25rZ2JHOXZjSE1nSmlCbGVIUnlZV04wSUdGdVkyaHZjbHh1Ykc5dmNDNWhiR3dnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVM1MGMzWmNJaWtwSUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0VGdWJtOHlJQ1ZwYmlVZ1l5aGNJbEF0VUZ3aUxDQmNJbEF0UlZ3aUxDQmNJa1V0UlZ3aUtTbGNibUZ1WTJodmNpNWhiR3dnUEMwZ0tHVjRkSEpoWTNSQmJtTm9iM0lvYkc5dmNDNWhiR3dwS1Z4dWIzWmxjbXhoY0hNZ1BDMGdabWx1WkU5MlpYSnNZWEJ6S0dGdVkyaHZjaTVoYkd3c0lHRjBZV011WjNJcFhHNWhibU5vYjNJdVlXeHNJRHd0SUhCcGJuUmxjbk5sWTNRb1lXNWphRzl5TG1Gc2JGdHhkV1Z5ZVVocGRITW9iM1psY214aGNITXBYU3dnWVhSaFl5NW5jbHR6ZFdKcVpXTjBTR2wwY3lodmRtVnliR0Z3Y3lsZEtWeHVYRzVjYm14dmIzQXVkWEFnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5d1pTMXdaVjlrVkVGSGRuTkVUVk5QWDFWUVgyUnBabVl3TGpJdVltVmtjR1ZjSWlrcFhHNWhibU5vYjNJdWRYQWdQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1MWNDa3BYRzV2ZG1WeWJHRndjeUE4TFNCbWFXNWtUM1psY214aGNITW9ZVzVqYUc5eUxuVndMQ0JoZEdGakxtZHlLVnh1WVc1amFHOXlMblZ3SUR3dElIQnBiblJsY25ObFkzUW9ZVzVqYUc5eUxuVndXM0YxWlhKNVNHbDBjeWh2ZG1WeWJHRndjeWxkTENCaGRHRmpMbWR5VzNOMVltcGxZM1JJYVhSektHOTJaWEpzWVhCektWMHBYRzVjYm14dmIzQXVibThnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5d1pTMXdaVjlrVkVGSGRuTkVUVk5QWDA1UFgyUnBabVl3TGpJdVltVmtjR1ZjSWlrcFhHNWhibU5vYjNJdWJtOGdQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1dWJ5a3BYRzV2ZG1WeWJHRndjeUE4TFNCbWFXNWtUM1psY214aGNITW9ZVzVqYUc5eUxtNXZMQ0JoZEdGakxtZHlLVnh1WVc1amFHOXlMbTV2SUR3dElIQnBiblJsY25ObFkzUW9ZVzVqYUc5eUxtNXZXM0YxWlhKNVNHbDBjeWh2ZG1WeWJHRndjeWxkTENCaGRHRmpMbWR5VzNOMVltcGxZM1JJYVhSektHOTJaWEpzWVhCektWMHBYRzVjYm14dmIzQXVkWEJ1YnlBOExTQmlhVzVrWDNKdmQzTW9iRzl2Y0M1MWNDd2diRzl2Y0M1dWJ5bGNibUZ1WTJodmNpNTFjRzV2SUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0d4dmIzQXVkWEJ1YnlrcFhHNXZkbVZ5YkdGd2N5QThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG5Wd2JtOHNJR0YwWVdNdVozSXBYRzVoYm1Ob2IzSXVkWEJ1YnlBOExTQndhVzUwWlhKelpXTjBLR0Z1WTJodmNpNTFjRzV2VzNGMVpYSjVTR2wwY3lodmRtVnliR0Z3Y3lsZExDQmhkR0ZqTG1keVczTjFZbXBsWTNSSWFYUnpLRzkyWlhKc1lYQnpLVjBwWEc1Y2JteHZiM0F1Wkc5M2JpQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2dYQ0pqYUhKdmJXOWZZMjl1YzE5aGJtNXZTR2xsY21GeVkyaDVYM0JsTFhCbFgyUlVRVWQyYzBSTlUwOWZSRTlYVGw5a2FXWm1NQzR5TG1KbFpIQmxYQ0lwS1Z4dVlXNWphRzl5TG1SdmQyNGdQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1a2IzZHVLU2xjYm05MlpYSnNZWEJ6SUR3dElHWnBibVJQZG1WeWJHRndjeWhoYm1Ob2IzSXVaRzkzYml3Z1lYUmhZeTVuY2lsY2JtRnVZMmh2Y2k1a2IzZHVJRHd0SUhCcGJuUmxjbk5sWTNRb1lXNWphRzl5TG1SdmQyNWJjWFZsY25sSWFYUnpLRzkyWlhKc1lYQnpLVjBzSUdGMFlXTXVaM0piYzNWaWFtVmpkRWhwZEhNb2IzWmxjbXhoY0hNcFhTbGNibHh1WEc1Y2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5hdGFjIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXEdTTTMxMDYyNTdfQVRBQ19FU0NfMS5iZWRcXCkpICU+JSBkcGx5cjo6c2VsZWN0KFYxLCBWMiwgVjMpXG5jb2xuYW1lcyhhdGFjKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbmF0YWMuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGF0YWMpXG5cbiMgTE9BRElORyBMT09QU1xuIyMjIEltcG9ydGluZyBkaWZmZXJlbnRpYWwgcmVndWxhdG9yeSBsb29wcyAmIGV4dHJhY3QgYW5jaG9yXG5sb29wLmFsbCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5LnRzdlxcKSkgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpKVxuYW5jaG9yLmFsbCA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmFsbCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmFsbCwgYXRhYy5ncilcbmFuY2hvci5hbGwgPC0gcGludGVyc2VjdChhbmNob3IuYWxsW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX2RUQUd2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci51cCA8LSAoZXh0cmFjdEFuY2hvcihsb29wLnVwKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IudXAsIGF0YWMuZ3IpXG5hbmNob3IudXAgPC0gcGludGVyc2VjdChhbmNob3IudXBbcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX2RUQUd2c0RNU09fTk9fZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci5ubyA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3Iubm8sIGF0YWMuZ3IpXG5hbmNob3Iubm8gPC0gcGludGVyc2VjdChhbmNob3Iubm9bcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxubG9vcC51cG5vIDwtIGJpbmRfcm93cyhsb29wLnVwLCBsb29wLm5vKVxuYW5jaG9yLnVwbm8gPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cG5vKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IudXBubywgYXRhYy5ncilcbmFuY2hvci51cG5vIDwtIHBpbnRlcnNlY3QoYW5jaG9yLnVwbm9bcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IuZG93biA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5kb3duLCBhdGFjLmdyKVxuYW5jaG9yLmRvd24gPC0gcGludGVyc2VjdChhbmNob3IuZG93bltxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\)) %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.upno <- bind_rows(loop.up, loop.no)
anchor.upno <- (extractAnchor(loop.upno))
overlaps <- findOverlaps(anchor.upno, atac.gr)
anchor.upno <- pintersect(anchor.upno[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVlYUmhZeUE4TFNCbWNtVmhaQ2hvWlhKbEtISmxaa1JwY2l3Z1hGeEhVMDB6TVRBMk1qVTNYMEZVUVVOZlJWTkRYekV1WW1Wa1hGd3BLU0FsUGlVZ1pIQnNlWEk2T25ObGJHVmpkQ2hXTVN3Z1ZqSXNJRll6S1Z4dVkyOXNibUZ0WlhNb1lYUmhZeWtnUEMwZ1l5aGNYR05vY2x4Y0xDQmNYSE4wWVhKMFhGd3NJRnhjWlc1a1hGd3BYRzVoZEdGakxtZHlJRHd0SUcxaGEyVkhVbUZ1WjJWelJuSnZiVVJoZEdGR2NtRnRaU2hoZEdGaktWeHVYRzRqSUV4UFFVUkpUa2NnVEU5UFVGTmNiaU1qSXlCSmJYQnZjblJwYm1jZ1pHbG1abVZ5Wlc1MGFXRnNJSEpsWjNWc1lYUnZjbmtnYkc5dmNITWdKaUJsZUhSeVlXTjBJR0Z1WTJodmNseHViRzl2Y0M1aGJHd2dQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lUzUwYzNaY1hDa3BJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRUZ1Ym04eUlDVnBiaVVnWXloY1hGQXRVRnhjTENCY1hGQXRSVnhjTENCY1hFVXRSVnhjS1NsY2JtRnVZMmh2Y2k1aGJHd2dQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1aGJHd3BLVnh1YjNabGNteGhjSE1nUEMwZ1ptbHVaRTkyWlhKc1lYQnpLR0Z1WTJodmNpNWhiR3dzSUdGMFlXTXVaM0lwWEc1aGJtTm9iM0l1WVd4c0lEd3RJSEJwYm5SbGNuTmxZM1FvWVc1amFHOXlMbUZzYkZ0eGRXVnllVWhwZEhNb2IzWmxjbXhoY0hNcFhTd2dZWFJoWXk1bmNsdHpkV0pxWldOMFNHbDBjeWh2ZG1WeWJHRndjeWxkS1Z4dVhHNWNibXh2YjNBdWRYQWdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lVjl3WlMxd1pWOWtWRUZIZG5ORVRWTlBYMVZRWDJScFptWXdMakl1WW1Wa2NHVmNYQ2twWEc1aGJtTm9iM0l1ZFhBZ1BDMGdLR1Y0ZEhKaFkzUkJibU5vYjNJb2JHOXZjQzUxY0NrcFhHNXZkbVZ5YkdGd2N5QThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG5Wd0xDQmhkR0ZqTG1keUtWeHVZVzVqYUc5eUxuVndJRHd0SUhCcGJuUmxjbk5sWTNRb1lXNWphRzl5TG5Wd1czRjFaWEo1U0dsMGN5aHZkbVZ5YkdGd2N5bGRMQ0JoZEdGakxtZHlXM04xWW1wbFkzUklhWFJ6S0c5MlpYSnNZWEJ6S1YwcFhHNWNibXh2YjNBdWJtOGdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lVjl3WlMxd1pWOWtWRUZIZG5ORVRWTlBYMDVQWDJScFptWXdMakl1WW1Wa2NHVmNYQ2twWEc1aGJtTm9iM0l1Ym04Z1BDMGdLR1Y0ZEhKaFkzUkJibU5vYjNJb2JHOXZjQzV1YnlrcFhHNXZkbVZ5YkdGd2N5QThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG01dkxDQmhkR0ZqTG1keUtWeHVZVzVqYUc5eUxtNXZJRHd0SUhCcGJuUmxjbk5sWTNRb1lXNWphRzl5TG01dlczRjFaWEo1U0dsMGN5aHZkbVZ5YkdGd2N5bGRMQ0JoZEdGakxtZHlXM04xWW1wbFkzUklhWFJ6S0c5MlpYSnNZWEJ6S1YwcFhHNWNibXh2YjNBdWRYQnVieUE4TFNCaWFXNWtYM0p2ZDNNb2JHOXZjQzUxY0N3Z2JHOXZjQzV1YnlsY2JtRnVZMmh2Y2k1MWNHNXZJRHd0SUNobGVIUnlZV04wUVc1amFHOXlLR3h2YjNBdWRYQnVieWtwWEc1dmRtVnliR0Z3Y3lBOExTQm1hVzVrVDNabGNteGhjSE1vWVc1amFHOXlMblZ3Ym04c0lHRjBZV011WjNJcFhHNWhibU5vYjNJdWRYQnVieUE4TFNCd2FXNTBaWEp6WldOMEtHRnVZMmh2Y2k1MWNHNXZXM0YxWlhKNVNHbDBjeWh2ZG1WeWJHRndjeWxkTENCaGRHRmpMbWR5VzNOMVltcGxZM1JJYVhSektHOTJaWEpzWVhCektWMHBYRzVjYm14dmIzQXVaRzkzYmlBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z1hGeGphSEp2Ylc5ZlkyOXVjMTloYm01dlNHbGxjbUZ5WTJoNVgzQmxMWEJsWDJSVVFVZDJjMFJOVTA5ZlJFOVhUbDlrYVdabU1DNHlMbUpsWkhCbFhGd3BLVnh1WVc1amFHOXlMbVJ2ZDI0Z1BDMGdLR1Y0ZEhKaFkzUkJibU5vYjNJb2JHOXZjQzVrYjNkdUtTbGNibTkyWlhKc1lYQnpJRHd0SUdacGJtUlBkbVZ5YkdGd2N5aGhibU5vYjNJdVpHOTNiaXdnWVhSaFl5NW5jaWxjYm1GdVkyaHZjaTVrYjNkdUlEd3RJSEJwYm5SbGNuTmxZM1FvWVc1amFHOXlMbVJ2ZDI1YmNYVmxjbmxJYVhSektHOTJaWEpzWVhCektWMHNJR0YwWVdNdVozSmJjM1ZpYW1WamRFaHBkSE1vYjNabGNteGhjSE1wWFNsY2JseHVYRzVjYm1CZ1lGeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSlcbmFuY2hvci5hbGwgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5hbGwpKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5hbGwsIGF0YWMuZ3IpXG5hbmNob3IuYWxsIDwtIHBpbnRlcnNlY3QoYW5jaG9yLmFsbFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwLCBhdGFjLmdyKVxuYW5jaG9yLnVwIDwtIHBpbnRlcnNlY3QoYW5jaG9yLnVwW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3Iubm8gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5ubykpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLm5vLCBhdGFjLmdyKVxuYW5jaG9yLm5vIDwtIHBpbnRlcnNlY3QoYW5jaG9yLm5vW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AudXBubyA8LSBiaW5kX3Jvd3MobG9vcC51cCwgbG9vcC5ubylcbmFuY2hvci51cG5vIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXBubykpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwbm8sIGF0YWMuZ3IpXG5hbmNob3IudXBubyA8LSBwaW50ZXJzZWN0KGFuY2hvci51cG5vW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX2RUQUd2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLmRvd24gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5kb3duKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuZG93biwgYXRhYy5ncilcbmFuY2hvci5kb3duIDwtIHBpbnRlcnNlY3QoYW5jaG9yLmRvd25bcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxuXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSlcbmFuY2hvci5hbGwgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5hbGwpKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5hbGwsIGF0YWMuZ3IpXG5hbmNob3IuYWxsIDwtIHBpbnRlcnNlY3QoYW5jaG9yLmFsbFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwLCBhdGFjLmdyKVxuYW5jaG9yLnVwIDwtIHBpbnRlcnNlY3QoYW5jaG9yLnVwW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3Iubm8gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5ubykpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLm5vLCBhdGFjLmdyKVxuYW5jaG9yLm5vIDwtIHBpbnRlcnNlY3QoYW5jaG9yLm5vW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AudXBubyA8LSBiaW5kX3Jvd3MobG9vcC51cCwgbG9vcC5ubylcbmFuY2hvci51cG5vIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXBubykpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwbm8sIGF0YWMuZ3IpXG5hbmNob3IudXBubyA8LSBwaW50ZXJzZWN0KGFuY2hvci51cG5vW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX2RUQUd2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLmRvd24gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5kb3duKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuZG93biwgYXRhYy5ncilcbmFuY2hvci5kb3duIDwtIHBpbnRlcnNlY3QoYW5jaG9yLmRvd25bcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\)) %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.upno <- bind_rows(loop.up, loop.no)
anchor.upno <- (extractAnchor(loop.upno))
overlaps <- findOverlaps(anchor.upno, atac.gr)
anchor.upno <- pintersect(anchor.upno[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### dTAG, Comparing to Async
##### - Limited to ATAC-seq signal, reg loop backgroupd

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n# RUNNING LOLA\nlolaDir <- here(\"../../result/lola\")\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\"), sep = \"\\t\")\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\"), sep = \"\\t\")\n\n# UPNO\nresult = runLOLA(anchor.upno, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\"), sep = \"\\t\")\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\"), sep = \"\\t\")\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\"target\", \"OR_up\")\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\"target\", \"OR_no\")\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\"target\", \"OR_down\")\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\"target\")), temp.down, by = c(\"target\")) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\"white\", \"red\"))\n\n\n#fviz_nbclust(data, kmeans, method = \"wss\")\n\n# p <- Heatmap(\n#   data,\n#   name = \"Odds Ratio\",                   # Name of the heatmap legend\n#   cluster_columns = FALSE,            # Remove column dendrogram\n#   row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)\n#   show_row_dend = FALSE,\n#   col = col_fun                       # Use the red gradient color scale\n# )\n# \n# fileName <- paste0(\"anchorLOLA_dTAG_vs_DMSO_diff0.2_regAnchorBackground_atac\")\n# height <- 7\n# width <- 3.5\n# png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\n# print(p)\n# dev.off()\n# \n\n\n### Visualizing p-value and OR\nalpha <- 0.05\n# tb.up <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\")) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \"UP\") %>%\n#   filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.no <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\")) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \"NO\") %>%\n#   filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n\ntb.upno <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \"UP/NO\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.upno %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_upno_atac_pub.tsv\"), sep = \"\\t\")\n\ntb.down <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \"DOWN\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.down %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_down_atac_pub.tsv\"), sep = \"\\t\")\n\n\ntemp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.upno, temp.down)\n\n# order <- c((temp %>% dplyr::filter(group == \"UP/NO\") %>% arrange(desc(oddsRatio)))$target, \n#            (temp %>% dplyr::filter(group == \"DOWN\") %>% arrange(desc(oddsRatio)))$target)\n\n# temp$target <- factor(temp$target, levels = rev(order))\ntemp$group <- factor(temp$group, levels = c(\"UP/NO\", \"DOWN\"))\n\ntargetList <- c(\"POLR2A\", \"CTR9\",\n                \"AFF4\", \"ELL2\",\n                \"MED1\", \"MED12\",\n                \"TBP\", \"TAF1\", \"TAF3\",\n                \"E2F1\", \"YY1\", \"NIPBL\", \n                \"EP300\", \"DPY30\", \"SETDB1\",\n                \"RAD21\", \"SMC1A\", \"SMC3\", \"CTCF\",\n                \"SUZ12\", \"PHF19\"\n)\ntemp <- temp %>% dplyr::filter(target %in% targetList)\ntemp$target <- factor(temp$target, levels = rev(targetList))\n\n\nqValueLogMax <- 50\ntemp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))\n\np <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \"white\", high = \"#CB333A\",\n                      limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n# p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n#   geom_point() + theme_bw() + \n#   scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n#   scale_color_gradient(low = \"blue\", high = \"red\",\n#                        guide = guide_colorbar(\n#                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n#                          barheight = 15/5.08    # Adjust height of the color bar\n#                        )) +\n#   labs(x = NULL, y = NULL)  +\n#   theme(\n#     axis.title = element_text(\n#       size = fontSizeS,\n#       family = fontType,\n#       color = \"#000000\"\n#     ),\n#     axis.text = element_text(\n#       size = fontSizeS,\n#       family = fontType,\n#       color = \"#000000\"\n#     ),\n#     axis.text.x = element_text(\n#       angle = 45,      # Rotate x-axis labels 45 degrees\n#       hjust = 1,       # Adjust horizontal justification\n#       vjust = 1        # Adjust vertical justification\n#     ),\n#     axis.line = element_line(\n#       color = \"#000000\",\n#       size = lineThick*mmToLineUnit,\n#       lineend = \"square\"\n#     ),\n#     axis.ticks = element_line(\n#       color = \"#000000\",\n#       size = lineThick*mmToLineUnit,\n#       lineend = \"square\"\n#     ),\n#     panel.background = element_rect(fill = \"transparent\"),\n#     legend.text = element_text(family = fontType, size = fontSizeS),\n#     legend.title = element_text(family = fontType, size = fontSizeS)\n#   )\n\nfileName <- paste0(\"anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac_upno\")\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(1.9)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\), sep = \\\\t\\)\n\n# UPNO\nresult = runLOLA(anchor.upno, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\), sep = \\\\t\\)\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\n# p <- Heatmap(\n#   data,\n#   name = \\Odds Ratio\\,                   # Name of the heatmap legend\n#   cluster_columns = FALSE,            # Remove column dendrogram\n#   row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)\n#   show_row_dend = FALSE,\n#   col = col_fun                       # Use the red gradient color scale\n# )\n# \n# fileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_regAnchorBackground_atac\\)\n# height <- 7\n# width <- 3.5\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n# \n\n\n### Visualizing p-value and OR\nalpha <- 0.05\n# tb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\UP\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\NO\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n\ntb.upno <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\UP/NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.upno %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_atac_pub.tsv\\), sep = \\\\t\\)\n\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.down %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac_pub.tsv\\), sep = \\\\t\\)\n\n\ntemp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.upno, temp.down)\n\n# order <- c((temp %>% dplyr::filter(group == \\UP/NO\\) %>% arrange(desc(oddsRatio)))$target, \n#            (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\n\n# temp$target <- factor(temp$target, levels = rev(order))\ntemp$group <- factor(temp$group, levels = c(\\UP/NO\\, \\DOWN\\))\n\ntargetList <- c(\\POLR2A\\, \\CTR9\\,\n                \\AFF4\\, \\ELL2\\,\n                \\MED1\\, \\MED12\\,\n                \\TBP\\, \\TAF1\\, \\TAF3\\,\n                \\E2F1\\, \\YY1\\, \\NIPBL\\, \n                \\EP300\\, \\DPY30\\, \\SETDB1\\,\n                \\RAD21\\, \\SMC1A\\, \\SMC3\\, \\CTCF\\,\n                \\SUZ12\\, \\PHF19\\\n)\ntemp <- temp %>% dplyr::filter(target %in% targetList)\ntemp$target <- factor(temp$target, levels = rev(targetList))\n\n\nqValueLogMax <- 50\ntemp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))\n\np <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n# p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n#   geom_point() + theme_bw() + \n#   scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n#   scale_color_gradient(low = \\blue\\, high = \\red\\,\n#                        guide = guide_colorbar(\n#                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n#                          barheight = 15/5.08    # Adjust height of the color bar\n#                        )) +\n#   labs(x = NULL, y = NULL)  +\n#   theme(\n#     axis.title = element_text(\n#       size = fontSizeS,\n#       family = fontType,\n#       color = \\#000000\\\n#     ),\n#     axis.text = element_text(\n#       size = fontSizeS,\n#       family = fontType,\n#       color = \\#000000\\\n#     ),\n#     axis.text.x = element_text(\n#       angle = 45,      # Rotate x-axis labels 45 degrees\n#       hjust = 1,       # Adjust horizontal justification\n#       vjust = 1        # Adjust vertical justification\n#     ),\n#     axis.line = element_line(\n#       color = \\#000000\\,\n#       size = lineThick*mmToLineUnit,\n#       lineend = \\square\\\n#     ),\n#     axis.ticks = element_line(\n#       color = \\#000000\\,\n#       size = lineThick*mmToLineUnit,\n#       lineend = \\square\\\n#     ),\n#     panel.background = element_rect(fill = \\transparent\\),\n#     legend.text = element_text(family = fontType, size = fontSizeS),\n#     legend.title = element_text(family = fontType, size = fontSizeS)\n#   )\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac_upno\\)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(1.9)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# RUNNING LOLA
lolaDir <- here(\../../result/lola\)
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\), sep = \\t\)

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\), sep = \\t\)

# UPNO
result = runLOLA(anchor.upno, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\), sep = \\t\)

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\), sep = \\t\)


### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c(\target\, \OR_up\)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c(\target\, \OR_no\)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c(\target\, \OR_down\)


temp <- full_join(full_join(temp.up, temp.no, by = c(\target\)), temp.down, by = c(\target\)) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

# p <- Heatmap(
#   data,
#   name = \Odds Ratio\,                   # Name of the heatmap legend
#   cluster_columns = FALSE,            # Remove column dendrogram
#   row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)
#   show_row_dend = FALSE,
#   col = col_fun                       # Use the red gradient color scale
# )
# 
# fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_diff0.2_regAnchorBackground_atac\)
# height <- 7
# width <- 3.5
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()
# 


### Visualizing p-value and OR
alpha <- 0.05
# tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \UP\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \NO\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)

tb.upno <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = \UP/NO\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.upno %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_upno_atac_pub.tsv\), sep = \\t\)

tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = \DOWN\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.down %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_atac_pub.tsv\), sep = \\t\)


temp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.upno, temp.down)

# order <- c((temp %>% dplyr::filter(group == \UP/NO\) %>% arrange(desc(oddsRatio)))$target, 
#            (temp %>% dplyr::filter(group == \DOWN\) %>% arrange(desc(oddsRatio)))$target)

# temp$target <- factor(temp$target, levels = rev(order))
temp$group <- factor(temp$group, levels = c(\UP/NO\, \DOWN\))

targetList <- c(\POLR2A\, \CTR9\,
                \AFF4\, \ELL2\,
                \MED1\, \MED12\,
                \TBP\, \TAF1\, \TAF3\,
                \E2F1\, \YY1\, \NIPBL\, 
                \EP300\, \DPY30\, \SETDB1\,
                \RAD21\, \SMC1A\, \SMC3\, \CTCF\,
                \SUZ12\, \PHF19\
)
temp <- temp %>% dplyr::filter(target %in% targetList)
temp$target <- factor(temp$target, levels = rev(targetList))


qValueLogMax <- 50
temp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))

p <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = \white\, high = \#CB333A\,
                      limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )
# p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
#   geom_point() + theme_bw() + 
#   scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
#   scale_color_gradient(low = \blue\, high = \red\,
#                        guide = guide_colorbar(
#                          barwidth = 1.5/5.08,  # Adjust width of the color bar
#                          barheight = 15/5.08    # Adjust height of the color bar
#                        )) +
#   labs(x = NULL, y = NULL)  +
#   theme(
#     axis.title = element_text(
#       size = fontSizeS,
#       family = fontType,
#       color = \#000000\
#     ),
#     axis.text = element_text(
#       size = fontSizeS,
#       family = fontType,
#       color = \#000000\
#     ),
#     axis.text.x = element_text(
#       angle = 45,      # Rotate x-axis labels 45 degrees
#       hjust = 1,       # Adjust horizontal justification
#       vjust = 1        # Adjust vertical justification
#     ),
#     axis.line = element_line(
#       color = \#000000\,
#       size = lineThick*mmToLineUnit,
#       lineend = \square\
#     ),
#     axis.ticks = element_line(
#       color = \#000000\,
#       size = lineThick*mmToLineUnit,
#       lineend = \square\
#     ),
#     panel.background = element_rect(fill = \transparent\),
#     legend.text = element_text(family = fontType, size = fontSizeS),
#     legend.title = element_text(family = fontType, size = fontSizeS)
#   )

fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac_upno\)
width <- panelSize(1.5)*mmToInch
height <- panelSize(1.9)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\), sep = \\\\t\\)\n\n# UPNO\nresult = runLOLA(anchor.upno, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\), sep = \\\\t\\)\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\n# p <- Heatmap(\n#   data,\n#   name = \\Odds Ratio\\,                   # Name of the heatmap legend\n#   cluster_columns = FALSE,            # Remove column dendrogram\n#   row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)\n#   show_row_dend = FALSE,\n#   col = col_fun                       # Use the red gradient color scale\n# )\n# \n# fileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_regAnchorBackground_atac\\)\n# height <- 7\n# width <- 3.5\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n# \n\n\n### Visualizing p-value and OR\nalpha <- 0.05\n# tb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\UP\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\NO\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n\ntb.upno <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\UP/NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.upno %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_atac_pub.tsv\\), sep = \\\\t\\)\n\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.down %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac_pub.tsv\\), sep = \\\\t\\)\n\n\ntemp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.upno, temp.down)\n\n# order <- c((temp %>% dplyr::filter(group == \\UP/NO\\) %>% arrange(desc(oddsRatio)))$target, \n#            (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\n\n# temp$target <- factor(temp$target, levels = rev(order))\ntemp$group <- factor(temp$group, levels = c(\\UP/NO\\, \\DOWN\\))\n\ntargetList <- c(\\POLR2A\\, \\CTR9\\,\n                \\AFF4\\, \\ELL2\\,\n                \\MED1\\, \\MED12\\,\n                \\TBP\\, \\TAF1\\, \\TAF3\\,\n                \\E2F1\\, \\YY1\\, \\NIPBL\\, \n                \\EP300\\, \\DPY30\\, \\SETDB1\\,\n                \\RAD21\\, \\SMC1A\\, \\SMC3\\, \\CTCF\\,\n                \\SUZ12\\, \\PHF19\\\n)\ntemp <- temp %>% dplyr::filter(target %in% targetList)\ntemp$target <- factor(temp$target, levels = rev(targetList))\n\n\nqValueLogMax <- 50\ntemp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))\n\np <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n# p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n#   geom_point() + theme_bw() + \n#   scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n#   scale_color_gradient(low = \\blue\\, high = \\red\\,\n#                        guide = guide_colorbar(\n#                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n#                          barheight = 15/5.08    # Adjust height of the color bar\n#                        )) +\n#   labs(x = NULL, y = NULL)  +\n#   theme(\n#     axis.title = element_text(\n#       size = fontSizeS,\n#       family = fontType,\n#       color = \\#000000\\\n#     ),\n#     axis.text = element_text(\n#       size = fontSizeS,\n#       family = fontType,\n#       color = \\#000000\\\n#     ),\n#     axis.text.x = element_text(\n#       angle = 45,      # Rotate x-axis labels 45 degrees\n#       hjust = 1,       # Adjust horizontal justification\n#       vjust = 1        # Adjust vertical justification\n#     ),\n#     axis.line = element_line(\n#       color = \\#000000\\,\n#       size = lineThick*mmToLineUnit,\n#       lineend = \\square\\\n#     ),\n#     axis.ticks = element_line(\n#       color = \\#000000\\,\n#       size = lineThick*mmToLineUnit,\n#       lineend = \\square\\\n#     ),\n#     panel.background = element_rect(fill = \\transparent\\),\n#     legend.text = element_text(family = fontType, size = fontSizeS),\n#     legend.title = element_text(family = fontType, size = fontSizeS)\n#   )\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac_upno\\)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(1.9)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\), sep = \\\\t\\)\n\n# UPNO\nresult = runLOLA(anchor.upno, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\), sep = \\\\t\\)\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\n# p <- Heatmap(\n#   data,\n#   name = \\Odds Ratio\\,                   # Name of the heatmap legend\n#   cluster_columns = FALSE,            # Remove column dendrogram\n#   row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)\n#   show_row_dend = FALSE,\n#   col = col_fun                       # Use the red gradient color scale\n# )\n# \n# fileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_regAnchorBackground_atac\\)\n# height <- 7\n# width <- 3.5\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n# \n\n\n### Visualizing p-value and OR\nalpha <- 0.05\n# tb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\UP\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\NO\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n\ntb.upno <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\UP/NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.upno %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_atac_pub.tsv\\), sep = \\\\t\\)\n\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.down %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac_pub.tsv\\), sep = \\\\t\\)\n\n\ntemp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.upno, temp.down)\n\n# order <- c((temp %>% dplyr::filter(group == \\UP/NO\\) %>% arrange(desc(oddsRatio)))$target, \n#            (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\n\n# temp$target <- factor(temp$target, levels = rev(order))\ntemp$group <- factor(temp$group, levels = c(\\UP/NO\\, \\DOWN\\))\n\ntargetList <- c(\\POLR2A\\, \\CTR9\\,\n                \\AFF4\\, \\ELL2\\,\n                \\MED1\\, \\MED12\\,\n                \\TBP\\, \\TAF1\\, \\TAF3\\,\n                \\E2F1\\, \\YY1\\, \\NIPBL\\, \n                \\EP300\\, \\DPY30\\, \\SETDB1\\,\n                \\RAD21\\, \\SMC1A\\, \\SMC3\\, \\CTCF\\,\n                \\SUZ12\\, \\PHF19\\\n)\ntemp <- temp %>% dplyr::filter(target %in% targetList)\ntemp$target <- factor(temp$target, levels = rev(targetList))\n\n\nqValueLogMax <- 50\ntemp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))\n\np <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n# p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n#   geom_point() + theme_bw() + \n#   scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n#   scale_color_gradient(low = \\blue\\, high = \\red\\,\n#                        guide = guide_colorbar(\n#                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n#                          barheight = 15/5.08    # Adjust height of the color bar\n#                        )) +\n#   labs(x = NULL, y = NULL)  +\n#   theme(\n#     axis.title = element_text(\n#       size = fontSizeS,\n#       family = fontType,\n#       color = \\#000000\\\n#     ),\n#     axis.text = element_text(\n#       size = fontSizeS,\n#       family = fontType,\n#       color = \\#000000\\\n#     ),\n#     axis.text.x = element_text(\n#       angle = 45,      # Rotate x-axis labels 45 degrees\n#       hjust = 1,       # Adjust horizontal justification\n#       vjust = 1        # Adjust vertical justification\n#     ),\n#     axis.line = element_line(\n#       color = \\#000000\\,\n#       size = lineThick*mmToLineUnit,\n#       lineend = \\square\\\n#     ),\n#     axis.ticks = element_line(\n#       color = \\#000000\\,\n#       size = lineThick*mmToLineUnit,\n#       lineend = \\square\\\n#     ),\n#     panel.background = element_rect(fill = \\transparent\\),\n#     legend.text = element_text(family = fontType, size = fontSizeS),\n#     legend.title = element_text(family = fontType, size = fontSizeS)\n#   )\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac_upno\\)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(1.9)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\), sep = \\\\t\\)\n\n# UPNO\nresult = runLOLA(anchor.upno, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\), sep = \\\\t\\)\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\n# p <- Heatmap(\n#   data,\n#   name = \\Odds Ratio\\,                   # Name of the heatmap legend\n#   cluster_columns = FALSE,            # Remove column dendrogram\n#   row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)\n#   show_row_dend = FALSE,\n#   col = col_fun                       # Use the red gradient color scale\n# )\n# \n# fileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_regAnchorBackground_atac\\)\n# height <- 7\n# width <- 3.5\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n# \n\n\n### Visualizing p-value and OR\nalpha <- 0.05\n# tb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\UP\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\NO\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n\ntb.upno <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\UP/NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.upno %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_atac_pub.tsv\\), sep = \\\\t\\)\n\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.down %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac_pub.tsv\\), sep = \\\\t\\)\n\n\ntemp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.upno, temp.down)\n\n# order <- c((temp %>% dplyr::filter(group == \\UP/NO\\) %>% arrange(desc(oddsRatio)))$target, \n#            (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\n\n# temp$target <- factor(temp$target, levels = rev(order))\ntemp$group <- factor(temp$group, levels = c(\\UP/NO\\, \\DOWN\\))\n\ntargetList <- c(\\POLR2A\\, \\CTR9\\,\n                \\AFF4\\, \\ELL2\\,\n                \\MED1\\, \\MED12\\,\n                \\TBP\\, \\TAF1\\, \\TAF3\\,\n                \\E2F1\\, \\YY1\\, \\NIPBL\\, \n                \\EP300\\, \\DPY30\\, \\SETDB1\\,\n                \\RAD21\\, \\SMC1A\\, \\SMC3\\, \\CTCF\\,\n                \\SUZ12\\, \\PHF19\\\n)\ntemp <- temp %>% dplyr::filter(target %in% targetList)\ntemp$target <- factor(temp$target, levels = rev(targetList))\n\n\nqValueLogMax <- 50\ntemp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))\n\np <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n# p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n#   geom_point() + theme_bw() + \n#   scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n#   scale_color_gradient(low = \\blue\\, high = \\red\\,\n#                        guide = guide_colorbar(\n#                          barwidth = 1.5/5.08,  # Adjust width of the color bar\n#                          barheight = 15/5.08    # Adjust height of the color bar\n#                        )) +\n#   labs(x = NULL, y = NULL)  +\n#   theme(\n#     axis.title = element_text(\n#       size = fontSizeS,\n#       family = fontType,\n#       color = \\#000000\\\n#     ),\n#     axis.text = element_text(\n#       size = fontSizeS,\n#       family = fontType,\n#       color = \\#000000\\\n#     ),\n#     axis.text.x = element_text(\n#       angle = 45,      # Rotate x-axis labels 45 degrees\n#       hjust = 1,       # Adjust horizontal justification\n#       vjust = 1        # Adjust vertical justification\n#     ),\n#     axis.line = element_line(\n#       color = \\#000000\\,\n#       size = lineThick*mmToLineUnit,\n#       lineend = \\square\\\n#     ),\n#     axis.ticks = element_line(\n#       color = \\#000000\\,\n#       size = lineThick*mmToLineUnit,\n#       lineend = \\square\\\n#     ),\n#     panel.background = element_rect(fill = \\transparent\\),\n#     legend.text = element_text(family = fontType, size = fontSizeS),\n#     legend.title = element_text(family = fontType, size = fontSizeS)\n#   )\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac_upno\\)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(1.9)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r
# RUNNING LOLA
lolaDir <- here(\../../result/lola\)
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\), sep = \\t\)

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\), sep = \\t\)

# UPNO
result = runLOLA(anchor.upno, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\), sep = \\t\)

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\), sep = \\t\)


### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c(\target\, \OR_up\)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c(\target\, \OR_no\)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c(\target\, \OR_down\)


temp <- full_join(full_join(temp.up, temp.no, by = c(\target\)), temp.down, by = c(\target\)) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

# p <- Heatmap(
#   data,
#   name = \Odds Ratio\,                   # Name of the heatmap legend
#   cluster_columns = FALSE,            # Remove column dendrogram
#   row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)
#   show_row_dend = FALSE,
#   col = col_fun                       # Use the red gradient color scale
# )
# 
# fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_diff0.2_regAnchorBackground_atac\)
# height <- 7
# width <- 3.5
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()
# 


### Visualizing p-value and OR
alpha <- 0.05
# tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \UP\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \NO\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)

tb.upno <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = \UP/NO\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.upno %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_upno_atac_pub.tsv\), sep = \\t\)

tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = \DOWN\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.down %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_atac_pub.tsv\), sep = \\t\)


temp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.upno, temp.down)

# order <- c((temp %>% dplyr::filter(group == \UP/NO\) %>% arrange(desc(oddsRatio)))$target, 
#            (temp %>% dplyr::filter(group == \DOWN\) %>% arrange(desc(oddsRatio)))$target)

# temp$target <- factor(temp$target, levels = rev(order))
temp$group <- factor(temp$group, levels = c(\UP/NO\, \DOWN\))

targetList <- c(\POLR2A\, \CTR9\,
                \AFF4\, \ELL2\,
                \MED1\, \MED12\,
                \TBP\, \TAF1\, \TAF3\,
                \E2F1\, \YY1\, \NIPBL\, 
                \EP300\, \DPY30\, \SETDB1\,
                \RAD21\, \SMC1A\, \SMC3\, \CTCF\,
                \SUZ12\, \PHF19\
)
temp <- temp %>% dplyr::filter(target %in% targetList)
temp$target <- factor(temp$target, levels = rev(targetList))


qValueLogMax <- 50
temp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))

p <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = \white\, high = \#CB333A\,
                      limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )
# p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
#   geom_point() + theme_bw() + 
#   scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
#   scale_color_gradient(low = \blue\, high = \red\,
#                        guide = guide_colorbar(
#                          barwidth = 1.5/5.08,  # Adjust width of the color bar
#                          barheight = 15/5.08    # Adjust height of the color bar
#                        )) +
#   labs(x = NULL, y = NULL)  +
#   theme(
#     axis.title = element_text(
#       size = fontSizeS,
#       family = fontType,
#       color = \#000000\
#     ),
#     axis.text = element_text(
#       size = fontSizeS,
#       family = fontType,
#       color = \#000000\
#     ),
#     axis.text.x = element_text(
#       angle = 45,      # Rotate x-axis labels 45 degrees
#       hjust = 1,       # Adjust horizontal justification
#       vjust = 1        # Adjust vertical justification
#     ),
#     axis.line = element_line(
#       color = \#000000\,
#       size = lineThick*mmToLineUnit,
#       lineend = \square\
#     ),
#     axis.ticks = element_line(
#       color = \#000000\,
#       size = lineThick*mmToLineUnit,
#       lineend = \square\
#     ),
#     panel.background = element_rect(fill = \transparent\),
#     legend.text = element_text(family = fontType, size = fontSizeS),
#     legend.title = element_text(family = fontType, size = fontSizeS)
#   )

fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac_upno\)
width <- panelSize(1.5)*mmToInch
height <- panelSize(1.9)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### dTAG
##### - Limiting to ATAC-seq signal, reg loop background

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n### 241015 Testing on subset of loops\nanchor.c1 <- extractAnchor(loop.cluster1)\noverlaps <- findOverlaps(anchor.c1, atac.gr)\nanchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c2 <- extractAnchor(loop.cluster2)\noverlaps <- findOverlaps(anchor.c2, atac.gr)\nanchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c3 <- extractAnchor(loop.cluster3)\noverlaps <- findOverlaps(anchor.c3, atac.gr)\nanchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c4 <- extractAnchor(loop.cluster4)\noverlaps <- findOverlaps(anchor.c4, atac.gr)\nanchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c5 <- extractAnchor(loop.cluster5)\noverlaps <- findOverlaps(anchor.c5, atac.gr)\nanchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c6 <- extractAnchor(loop.cluster6)\noverlaps <- findOverlaps(anchor.c6, atac.gr)\nanchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c7 <- extractAnchor(loop.cluster7)\noverlaps <- findOverlaps(anchor.c7, atac.gr)\nanchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c8 <- extractAnchor(loop.cluster8)\noverlaps <- findOverlaps(anchor.c8, atac.gr)\nanchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nresult = runLOLA(anchor.c1, anchor.all, lolaDB)\ntb.c1 = as_tibble(result)\n\nresult = runLOLA(anchor.c2, anchor.all, lolaDB)\ntb.c2 = as_tibble(result)\n\nresult = runLOLA(anchor.c3, anchor.all, lolaDB)\ntb.c3 = as_tibble(result)\n\nresult = runLOLA(anchor.c4, anchor.all, lolaDB)\ntb.c4 = as_tibble(result)\nresult = runLOLA(anchor.c5, anchor.all, lolaDB)\ntb.c5 = as_tibble(result)\n\nresult = runLOLA(anchor.c6, anchor.all, lolaDB)\ntb.c6 = as_tibble(result)\n\nresult = runLOLA(anchor.c7, anchor.all, lolaDB)\ntb.c7 = as_tibble(result)\n\nresult = runLOLA(anchor.c8, anchor.all, lolaDB)\ntb.c8 = as_tibble(result)\n\n### HEATMAP\nalpha <- 0.05\ntb.c1 <- tb.c1 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c2 <- tb.c2 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c3 <- tb.c3 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c4 <- tb.c4 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c5 <- tb.c5 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c6 <- tb.c6 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c7 <- tb.c7 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c8 <- tb.c8 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c1) <- c(\"target\", \"OR_c1\")\ntemp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c2) <- c(\"target\", \"OR_c2\")\ntemp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c3) <- c(\"target\", \"OR_c3\")\ntemp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c4) <- c(\"target\", \"OR_c4\")\ntemp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c5) <- c(\"target\", \"OR_c5\")\ntemp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c6) <- c(\"target\", \"OR_c6\")\ntemp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c7) <- c(\"target\", \"OR_c7\")\ntemp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c8) <- c(\"target\", \"OR_c8\")\n\ntemp <- full_join(temp.c1, temp.c2, by = \"target\") %>%\n  full_join(temp.c3, by = \"target\") %>%\n  full_join(temp.c4, by = \"target\") %>%\n  full_join(temp.c5, by = \"target\") %>%\n  full_join(temp.c6, by = \"target\") %>%\n  full_join(temp.c7, by = \"target\") %>%\n  full_join(temp.c8, by = \"target\") %>%\n  mutate_all(~replace_na(., 1))\n\ndata <- temp %>% column_to_rownames(\"target\") %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\"white\", \"red\"))\n\n\n#fviz_nbclust(data, kmeans, method = \"wss\")\n\np <- Heatmap(\n  data,\n  name = \"Odds Ratio\",                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\n\n# Initialize lists to store results\nanchors <- list()\ntbs <- list()\ntemps <- list()\n\n# Process clusters c1 to c8\nfor (i in 1:4) {\n  # Extract anchor\n  loop_cluster <- get(paste0(\"loop.cluster\", i))\n  anchor <- extractAnchor(loop_cluster)\n  \n  # Find overlaps and intersect\n  overlaps <- findOverlaps(anchor, atac.gr)\n  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n  \n  # Store anchor\n  anchors[[i]] <- anchor\n  \n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\"target\", paste0(\"OR_c\", i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \"target\"), temps) %>%\n  mutate_all(~replace_na(., 1))\ndata <- temp %>% column_to_rownames(\"target\") %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\"white\", \"red\"))\n\n\n#fviz_nbclust(data, kmeans, method = \"wss\")\n\np <- Heatmap(\n  data,\n  name = \"Odds Ratio\",                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```"} -->\n\n```r\n### 241015 Testing on subset of loops\nanchor.c1 <- extractAnchor(loop.cluster1)\noverlaps <- findOverlaps(anchor.c1, atac.gr)\nanchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c2 <- extractAnchor(loop.cluster2)\noverlaps <- findOverlaps(anchor.c2, atac.gr)\nanchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c3 <- extractAnchor(loop.cluster3)\noverlaps <- findOverlaps(anchor.c3, atac.gr)\nanchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c4 <- extractAnchor(loop.cluster4)\noverlaps <- findOverlaps(anchor.c4, atac.gr)\nanchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c5 <- extractAnchor(loop.cluster5)\noverlaps <- findOverlaps(anchor.c5, atac.gr)\nanchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c6 <- extractAnchor(loop.cluster6)\noverlaps <- findOverlaps(anchor.c6, atac.gr)\nanchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c7 <- extractAnchor(loop.cluster7)\noverlaps <- findOverlaps(anchor.c7, atac.gr)\nanchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c8 <- extractAnchor(loop.cluster8)\noverlaps <- findOverlaps(anchor.c8, atac.gr)\nanchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nresult = runLOLA(anchor.c1, anchor.all, lolaDB)\ntb.c1 = as_tibble(result)\n\nresult = runLOLA(anchor.c2, anchor.all, lolaDB)\ntb.c2 = as_tibble(result)\n\nresult = runLOLA(anchor.c3, anchor.all, lolaDB)\ntb.c3 = as_tibble(result)\n\nresult = runLOLA(anchor.c4, anchor.all, lolaDB)\ntb.c4 = as_tibble(result)\nresult = runLOLA(anchor.c5, anchor.all, lolaDB)\ntb.c5 = as_tibble(result)\n\nresult = runLOLA(anchor.c6, anchor.all, lolaDB)\ntb.c6 = as_tibble(result)\n\nresult = runLOLA(anchor.c7, anchor.all, lolaDB)\ntb.c7 = as_tibble(result)\n\nresult = runLOLA(anchor.c8, anchor.all, lolaDB)\ntb.c8 = as_tibble(result)\n\n### HEATMAP\nalpha <- 0.05\ntb.c1 <- tb.c1 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c2 <- tb.c2 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c3 <- tb.c3 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c4 <- tb.c4 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c5 <- tb.c5 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c6 <- tb.c6 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c7 <- tb.c7 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c8 <- tb.c8 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c1) <- c(\\target\\, \\OR_c1\\)\ntemp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c2) <- c(\\target\\, \\OR_c2\\)\ntemp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c3) <- c(\\target\\, \\OR_c3\\)\ntemp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c4) <- c(\\target\\, \\OR_c4\\)\ntemp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c5) <- c(\\target\\, \\OR_c5\\)\ntemp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c6) <- c(\\target\\, \\OR_c6\\)\ntemp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c7) <- c(\\target\\, \\OR_c7\\)\ntemp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c8) <- c(\\target\\, \\OR_c8\\)\n\ntemp <- full_join(temp.c1, temp.c2, by = \\target\\) %>%\n  full_join(temp.c3, by = \\target\\) %>%\n  full_join(temp.c4, by = \\target\\) %>%\n  full_join(temp.c5, by = \\target\\) %>%\n  full_join(temp.c6, by = \\target\\) %>%\n  full_join(temp.c7, by = \\target\\) %>%\n  full_join(temp.c8, by = \\target\\) %>%\n  mutate_all(~replace_na(., 1))\n\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\n\n# Initialize lists to store results\nanchors <- list()\ntbs <- list()\ntemps <- list()\n\n# Process clusters c1 to c8\nfor (i in 1:4) {\n  # Extract anchor\n  loop_cluster <- get(paste0(\\loop.cluster\\, i))\n  anchor <- extractAnchor(loop_cluster)\n  \n  # Find overlaps and intersect\n  overlaps <- findOverlaps(anchor, atac.gr)\n  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n  \n  # Store anchor\n  anchors[[i]] <- anchor\n  \n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```\n\n<!-- rnb-source-end -->\n"} -->
### 241015 Testing on subset of loops
anchor.c1 <- extractAnchor(loop.cluster1)
overlaps <- findOverlaps(anchor.c1, atac.gr)
anchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c2 <- extractAnchor(loop.cluster2)
overlaps <- findOverlaps(anchor.c2, atac.gr)
anchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c3 <- extractAnchor(loop.cluster3)
overlaps <- findOverlaps(anchor.c3, atac.gr)
anchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c4 <- extractAnchor(loop.cluster4)
overlaps <- findOverlaps(anchor.c4, atac.gr)
anchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c5 <- extractAnchor(loop.cluster5)
overlaps <- findOverlaps(anchor.c5, atac.gr)
anchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c6 <- extractAnchor(loop.cluster6)
overlaps <- findOverlaps(anchor.c6, atac.gr)
anchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c7 <- extractAnchor(loop.cluster7)
overlaps <- findOverlaps(anchor.c7, atac.gr)
anchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c8 <- extractAnchor(loop.cluster8)
overlaps <- findOverlaps(anchor.c8, atac.gr)
anchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

result = runLOLA(anchor.c1, anchor.all, lolaDB)
tb.c1 = as_tibble(result)

result = runLOLA(anchor.c2, anchor.all, lolaDB)
tb.c2 = as_tibble(result)

result = runLOLA(anchor.c3, anchor.all, lolaDB)
tb.c3 = as_tibble(result)

result = runLOLA(anchor.c4, anchor.all, lolaDB)
tb.c4 = as_tibble(result)
result = runLOLA(anchor.c5, anchor.all, lolaDB)
tb.c5 = as_tibble(result)

result = runLOLA(anchor.c6, anchor.all, lolaDB)
tb.c6 = as_tibble(result)

result = runLOLA(anchor.c7, anchor.all, lolaDB)
tb.c7 = as_tibble(result)

result = runLOLA(anchor.c8, anchor.all, lolaDB)
tb.c8 = as_tibble(result)

### HEATMAP
alpha <- 0.05
tb.c1 <- tb.c1 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c2 <- tb.c2 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c3 <- tb.c3 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c4 <- tb.c4 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c5 <- tb.c5 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c6 <- tb.c6 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c7 <- tb.c7 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c8 <- tb.c8 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)
colnames(temp.c1) <- c(\target\, \OR_c1\)
temp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)
colnames(temp.c2) <- c(\target\, \OR_c2\)
temp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)
colnames(temp.c3) <- c(\target\, \OR_c3\)
temp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)
colnames(temp.c4) <- c(\target\, \OR_c4\)
temp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)
colnames(temp.c5) <- c(\target\, \OR_c5\)
temp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)
colnames(temp.c6) <- c(\target\, \OR_c6\)
temp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)
colnames(temp.c7) <- c(\target\, \OR_c7\)
temp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)
colnames(temp.c8) <- c(\target\, \OR_c8\)

temp <- full_join(temp.c1, temp.c2, by = \target\) %>%
  full_join(temp.c3, by = \target\) %>%
  full_join(temp.c4, by = \target\) %>%
  full_join(temp.c5, by = \target\) %>%
  full_join(temp.c6, by = \target\) %>%
  full_join(temp.c7, by = \target\) %>%
  full_join(temp.c8, by = \target\) %>%
  mutate_all(~replace_na(., 1))

data <- temp %>% column_to_rownames(\target\) %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)


# Initialize lists to store results
anchors <- list()
tbs <- list()
temps <- list()

# Process clusters c1 to c8
for (i in 1:4) {
  # Extract anchor
  loop_cluster <- get(paste0(\loop.cluster\, i))
  anchor <- extractAnchor(loop_cluster)
  
  # Find overlaps and intersect
  overlaps <- findOverlaps(anchor, atac.gr)
  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
  
  # Store anchor
  anchors[[i]] <- anchor
  
  # Run LOLA
  result <- runLOLA(anchor, anchor.all, lolaDB)
  tb <- as_tibble(result)
  
  # Filter and summarize
  tb <- tb %>%
    dplyr::mutate(target = toupper(antibody)) %>%
    filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
    dplyr::filter(qValue < alpha) %>%
    dplyr::group_by(target) %>%
    slice_min(meanRnk, with_ties = FALSE)
  
  # Store tb
  tbs[[i]] <- tb
  
  # Select and rename oddsRatio
  temp <- tb %>% dplyr::select(target, oddsRatio)
  colnames(temp) <- c(\target\, paste0(\OR_c\, i))
  
  # Store temp
  temps[[i]] <- temp
}

# Merge all temp tables into one
temp <- Reduce(function(x, y) full_join(x, y, by = \target\), temps) %>%
  mutate_all(~replace_na(., 1))
data <- temp %>% column_to_rownames(\target\) %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n### 241015 Testing on subset of loops\nanchor.c1 <- extractAnchor(loop.cluster1)\noverlaps <- findOverlaps(anchor.c1, atac.gr)\nanchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c2 <- extractAnchor(loop.cluster2)\noverlaps <- findOverlaps(anchor.c2, atac.gr)\nanchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c3 <- extractAnchor(loop.cluster3)\noverlaps <- findOverlaps(anchor.c3, atac.gr)\nanchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c4 <- extractAnchor(loop.cluster4)\noverlaps <- findOverlaps(anchor.c4, atac.gr)\nanchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c5 <- extractAnchor(loop.cluster5)\noverlaps <- findOverlaps(anchor.c5, atac.gr)\nanchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c6 <- extractAnchor(loop.cluster6)\noverlaps <- findOverlaps(anchor.c6, atac.gr)\nanchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c7 <- extractAnchor(loop.cluster7)\noverlaps <- findOverlaps(anchor.c7, atac.gr)\nanchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c8 <- extractAnchor(loop.cluster8)\noverlaps <- findOverlaps(anchor.c8, atac.gr)\nanchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nresult = runLOLA(anchor.c1, anchor.all, lolaDB)\ntb.c1 = as_tibble(result)\n\nresult = runLOLA(anchor.c2, anchor.all, lolaDB)\ntb.c2 = as_tibble(result)\n\nresult = runLOLA(anchor.c3, anchor.all, lolaDB)\ntb.c3 = as_tibble(result)\n\nresult = runLOLA(anchor.c4, anchor.all, lolaDB)\ntb.c4 = as_tibble(result)\nresult = runLOLA(anchor.c5, anchor.all, lolaDB)\ntb.c5 = as_tibble(result)\n\nresult = runLOLA(anchor.c6, anchor.all, lolaDB)\ntb.c6 = as_tibble(result)\n\nresult = runLOLA(anchor.c7, anchor.all, lolaDB)\ntb.c7 = as_tibble(result)\n\nresult = runLOLA(anchor.c8, anchor.all, lolaDB)\ntb.c8 = as_tibble(result)\n\n### HEATMAP\nalpha <- 0.05\ntb.c1 <- tb.c1 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c2 <- tb.c2 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c3 <- tb.c3 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c4 <- tb.c4 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c5 <- tb.c5 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c6 <- tb.c6 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c7 <- tb.c7 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c8 <- tb.c8 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c1) <- c(\\target\\, \\OR_c1\\)\ntemp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c2) <- c(\\target\\, \\OR_c2\\)\ntemp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c3) <- c(\\target\\, \\OR_c3\\)\ntemp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c4) <- c(\\target\\, \\OR_c4\\)\ntemp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c5) <- c(\\target\\, \\OR_c5\\)\ntemp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c6) <- c(\\target\\, \\OR_c6\\)\ntemp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c7) <- c(\\target\\, \\OR_c7\\)\ntemp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c8) <- c(\\target\\, \\OR_c8\\)\n\ntemp <- full_join(temp.c1, temp.c2, by = \\target\\) %>%\n  full_join(temp.c3, by = \\target\\) %>%\n  full_join(temp.c4, by = \\target\\) %>%\n  full_join(temp.c5, by = \\target\\) %>%\n  full_join(temp.c6, by = \\target\\) %>%\n  full_join(temp.c7, by = \\target\\) %>%\n  full_join(temp.c8, by = \\target\\) %>%\n  mutate_all(~replace_na(., 1))\n\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\n\n# Initialize lists to store results\nanchors <- list()\ntbs <- list()\ntemps <- list()\n\n# Process clusters c1 to c8\nfor (i in 1:4) {\n  # Extract anchor\n  loop_cluster <- get(paste0(\\loop.cluster\\, i))\n  anchor <- extractAnchor(loop_cluster)\n  \n  # Find overlaps and intersect\n  overlaps <- findOverlaps(anchor, atac.gr)\n  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n  \n  # Store anchor\n  anchors[[i]] <- anchor\n  \n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```\n```"} -->\n\n```r\n```r\n### 241015 Testing on subset of loops\nanchor.c1 <- extractAnchor(loop.cluster1)\noverlaps <- findOverlaps(anchor.c1, atac.gr)\nanchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c2 <- extractAnchor(loop.cluster2)\noverlaps <- findOverlaps(anchor.c2, atac.gr)\nanchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c3 <- extractAnchor(loop.cluster3)\noverlaps <- findOverlaps(anchor.c3, atac.gr)\nanchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c4 <- extractAnchor(loop.cluster4)\noverlaps <- findOverlaps(anchor.c4, atac.gr)\nanchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c5 <- extractAnchor(loop.cluster5)\noverlaps <- findOverlaps(anchor.c5, atac.gr)\nanchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c6 <- extractAnchor(loop.cluster6)\noverlaps <- findOverlaps(anchor.c6, atac.gr)\nanchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c7 <- extractAnchor(loop.cluster7)\noverlaps <- findOverlaps(anchor.c7, atac.gr)\nanchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c8 <- extractAnchor(loop.cluster8)\noverlaps <- findOverlaps(anchor.c8, atac.gr)\nanchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nresult = runLOLA(anchor.c1, anchor.all, lolaDB)\ntb.c1 = as_tibble(result)\n\nresult = runLOLA(anchor.c2, anchor.all, lolaDB)\ntb.c2 = as_tibble(result)\n\nresult = runLOLA(anchor.c3, anchor.all, lolaDB)\ntb.c3 = as_tibble(result)\n\nresult = runLOLA(anchor.c4, anchor.all, lolaDB)\ntb.c4 = as_tibble(result)\nresult = runLOLA(anchor.c5, anchor.all, lolaDB)\ntb.c5 = as_tibble(result)\n\nresult = runLOLA(anchor.c6, anchor.all, lolaDB)\ntb.c6 = as_tibble(result)\n\nresult = runLOLA(anchor.c7, anchor.all, lolaDB)\ntb.c7 = as_tibble(result)\n\nresult = runLOLA(anchor.c8, anchor.all, lolaDB)\ntb.c8 = as_tibble(result)\n\n### HEATMAP\nalpha <- 0.05\ntb.c1 <- tb.c1 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c2 <- tb.c2 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c3 <- tb.c3 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c4 <- tb.c4 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c5 <- tb.c5 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c6 <- tb.c6 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c7 <- tb.c7 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c8 <- tb.c8 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c1) <- c(\\target\\, \\OR_c1\\)\ntemp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c2) <- c(\\target\\, \\OR_c2\\)\ntemp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c3) <- c(\\target\\, \\OR_c3\\)\ntemp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c4) <- c(\\target\\, \\OR_c4\\)\ntemp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c5) <- c(\\target\\, \\OR_c5\\)\ntemp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c6) <- c(\\target\\, \\OR_c6\\)\ntemp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c7) <- c(\\target\\, \\OR_c7\\)\ntemp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c8) <- c(\\target\\, \\OR_c8\\)\n\ntemp <- full_join(temp.c1, temp.c2, by = \\target\\) %>%\n  full_join(temp.c3, by = \\target\\) %>%\n  full_join(temp.c4, by = \\target\\) %>%\n  full_join(temp.c5, by = \\target\\) %>%\n  full_join(temp.c6, by = \\target\\) %>%\n  full_join(temp.c7, by = \\target\\) %>%\n  full_join(temp.c8, by = \\target\\) %>%\n  mutate_all(~replace_na(., 1))\n\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\n\n# Initialize lists to store results\nanchors <- list()\ntbs <- list()\ntemps <- list()\n\n# Process clusters c1 to c8\nfor (i in 1:4) {\n  # Extract anchor\n  loop_cluster <- get(paste0(\\loop.cluster\\, i))\n  anchor <- extractAnchor(loop_cluster)\n  \n  # Find overlaps and intersect\n  overlaps <- findOverlaps(anchor, atac.gr)\n  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n  \n  # Store anchor\n  anchors[[i]] <- anchor\n  \n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n### 241015 Testing on subset of loops\nanchor.c1 <- extractAnchor(loop.cluster1)\noverlaps <- findOverlaps(anchor.c1, atac.gr)\nanchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c2 <- extractAnchor(loop.cluster2)\noverlaps <- findOverlaps(anchor.c2, atac.gr)\nanchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c3 <- extractAnchor(loop.cluster3)\noverlaps <- findOverlaps(anchor.c3, atac.gr)\nanchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c4 <- extractAnchor(loop.cluster4)\noverlaps <- findOverlaps(anchor.c4, atac.gr)\nanchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c5 <- extractAnchor(loop.cluster5)\noverlaps <- findOverlaps(anchor.c5, atac.gr)\nanchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c6 <- extractAnchor(loop.cluster6)\noverlaps <- findOverlaps(anchor.c6, atac.gr)\nanchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c7 <- extractAnchor(loop.cluster7)\noverlaps <- findOverlaps(anchor.c7, atac.gr)\nanchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c8 <- extractAnchor(loop.cluster8)\noverlaps <- findOverlaps(anchor.c8, atac.gr)\nanchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nresult = runLOLA(anchor.c1, anchor.all, lolaDB)\ntb.c1 = as_tibble(result)\n\nresult = runLOLA(anchor.c2, anchor.all, lolaDB)\ntb.c2 = as_tibble(result)\n\nresult = runLOLA(anchor.c3, anchor.all, lolaDB)\ntb.c3 = as_tibble(result)\n\nresult = runLOLA(anchor.c4, anchor.all, lolaDB)\ntb.c4 = as_tibble(result)\nresult = runLOLA(anchor.c5, anchor.all, lolaDB)\ntb.c5 = as_tibble(result)\n\nresult = runLOLA(anchor.c6, anchor.all, lolaDB)\ntb.c6 = as_tibble(result)\n\nresult = runLOLA(anchor.c7, anchor.all, lolaDB)\ntb.c7 = as_tibble(result)\n\nresult = runLOLA(anchor.c8, anchor.all, lolaDB)\ntb.c8 = as_tibble(result)\n\n### HEATMAP\nalpha <- 0.05\ntb.c1 <- tb.c1 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c2 <- tb.c2 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c3 <- tb.c3 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c4 <- tb.c4 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c5 <- tb.c5 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c6 <- tb.c6 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c7 <- tb.c7 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c8 <- tb.c8 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c1) <- c(\\target\\, \\OR_c1\\)\ntemp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c2) <- c(\\target\\, \\OR_c2\\)\ntemp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c3) <- c(\\target\\, \\OR_c3\\)\ntemp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c4) <- c(\\target\\, \\OR_c4\\)\ntemp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c5) <- c(\\target\\, \\OR_c5\\)\ntemp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c6) <- c(\\target\\, \\OR_c6\\)\ntemp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c7) <- c(\\target\\, \\OR_c7\\)\ntemp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c8) <- c(\\target\\, \\OR_c8\\)\n\ntemp <- full_join(temp.c1, temp.c2, by = \\target\\) %>%\n  full_join(temp.c3, by = \\target\\) %>%\n  full_join(temp.c4, by = \\target\\) %>%\n  full_join(temp.c5, by = \\target\\) %>%\n  full_join(temp.c6, by = \\target\\) %>%\n  full_join(temp.c7, by = \\target\\) %>%\n  full_join(temp.c8, by = \\target\\) %>%\n  mutate_all(~replace_na(., 1))\n\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\n\n# Initialize lists to store results\nanchors <- list()\ntbs <- list()\ntemps <- list()\n\n# Process clusters c1 to c8\nfor (i in 1:4) {\n  # Extract anchor\n  loop_cluster <- get(paste0(\\loop.cluster\\, i))\n  anchor <- extractAnchor(loop_cluster)\n  \n  # Find overlaps and intersect\n  overlaps <- findOverlaps(anchor, atac.gr)\n  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n  \n  # Store anchor\n  anchors[[i]] <- anchor\n  \n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```\n```"} -->

```r
```r
### 241015 Testing on subset of loops
anchor.c1 <- extractAnchor(loop.cluster1)
overlaps <- findOverlaps(anchor.c1, atac.gr)
anchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c2 <- extractAnchor(loop.cluster2)
overlaps <- findOverlaps(anchor.c2, atac.gr)
anchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c3 <- extractAnchor(loop.cluster3)
overlaps <- findOverlaps(anchor.c3, atac.gr)
anchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c4 <- extractAnchor(loop.cluster4)
overlaps <- findOverlaps(anchor.c4, atac.gr)
anchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c5 <- extractAnchor(loop.cluster5)
overlaps <- findOverlaps(anchor.c5, atac.gr)
anchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c6 <- extractAnchor(loop.cluster6)
overlaps <- findOverlaps(anchor.c6, atac.gr)
anchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c7 <- extractAnchor(loop.cluster7)
overlaps <- findOverlaps(anchor.c7, atac.gr)
anchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c8 <- extractAnchor(loop.cluster8)
overlaps <- findOverlaps(anchor.c8, atac.gr)
anchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

result = runLOLA(anchor.c1, anchor.all, lolaDB)
tb.c1 = as_tibble(result)

result = runLOLA(anchor.c2, anchor.all, lolaDB)
tb.c2 = as_tibble(result)

result = runLOLA(anchor.c3, anchor.all, lolaDB)
tb.c3 = as_tibble(result)

result = runLOLA(anchor.c4, anchor.all, lolaDB)
tb.c4 = as_tibble(result)
result = runLOLA(anchor.c5, anchor.all, lolaDB)
tb.c5 = as_tibble(result)

result = runLOLA(anchor.c6, anchor.all, lolaDB)
tb.c6 = as_tibble(result)

result = runLOLA(anchor.c7, anchor.all, lolaDB)
tb.c7 = as_tibble(result)

result = runLOLA(anchor.c8, anchor.all, lolaDB)
tb.c8 = as_tibble(result)

### HEATMAP
alpha <- 0.05
tb.c1 <- tb.c1 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c2 <- tb.c2 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c3 <- tb.c3 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c4 <- tb.c4 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c5 <- tb.c5 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c6 <- tb.c6 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c7 <- tb.c7 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c8 <- tb.c8 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)
colnames(temp.c1) <- c(\target\, \OR_c1\)
temp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)
colnames(temp.c2) <- c(\target\, \OR_c2\)
temp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)
colnames(temp.c3) <- c(\target\, \OR_c3\)
temp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)
colnames(temp.c4) <- c(\target\, \OR_c4\)
temp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)
colnames(temp.c5) <- c(\target\, \OR_c5\)
temp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)
colnames(temp.c6) <- c(\target\, \OR_c6\)
temp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)
colnames(temp.c7) <- c(\target\, \OR_c7\)
temp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)
colnames(temp.c8) <- c(\target\, \OR_c8\)

temp <- full_join(temp.c1, temp.c2, by = \target\) %>%
  full_join(temp.c3, by = \target\) %>%
  full_join(temp.c4, by = \target\) %>%
  full_join(temp.c5, by = \target\) %>%
  full_join(temp.c6, by = \target\) %>%
  full_join(temp.c7, by = \target\) %>%
  full_join(temp.c8, by = \target\) %>%
  mutate_all(~replace_na(., 1))

data <- temp %>% column_to_rownames(\target\) %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)


# Initialize lists to store results
anchors <- list()
tbs <- list()
temps <- list()

# Process clusters c1 to c8
for (i in 1:4) {
  # Extract anchor
  loop_cluster <- get(paste0(\loop.cluster\, i))
  anchor <- extractAnchor(loop_cluster)
  
  # Find overlaps and intersect
  overlaps <- findOverlaps(anchor, atac.gr)
  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
  
  # Store anchor
  anchors[[i]] <- anchor
  
  # Run LOLA
  result <- runLOLA(anchor, anchor.all, lolaDB)
  tb <- as_tibble(result)
  
  # Filter and summarize
  tb <- tb %>%
    dplyr::mutate(target = toupper(antibody)) %>%
    filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
    dplyr::filter(qValue < alpha) %>%
    dplyr::group_by(target) %>%
    slice_min(meanRnk, with_ties = FALSE)
  
  # Store tb
  tbs[[i]] <- tb
  
  # Select and rename oddsRatio
  temp <- tb %>% dplyr::select(target, oddsRatio)
  colnames(temp) <- c(\target\, paste0(\OR_c\, i))
  
  # Store temp
  temps[[i]] <- temp
}

# Merge all temp tables into one
temp <- Reduce(function(x, y) full_join(x, y, by = \target\), temps) %>%
  mutate_all(~replace_na(., 1))
data <- temp %>% column_to_rownames(\target\) %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZWFJoWXlBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYQ0pIVTAwek1UQTJNalUzWDBGVVFVTmZSVk5EWHpFdVltVmtYQ0lwS1NBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoV01Td2dWaklzSUZZektWeHVZMjlzYm1GdFpYTW9ZWFJoWXlrZ1BDMGdZeWhjSW1Ob2Nsd2lMQ0JjSW5OMFlYSjBYQ0lzSUZ3aVpXNWtYQ0lwWEc1aGRHRmpMbWR5SUR3dElHMWhhMlZIVW1GdVoyVnpSbkp2YlVSaGRHRkdjbUZ0WlNoaGRHRmpLVnh1WEc0aklFeFBRVVJKVGtjZ1RFOVBVRk5jYmlNakl5QkpiWEJ2Y25ScGJtY2daR2xtWm1WeVpXNTBhV0ZzSUhKbFozVnNZWFJ2Y25rZ2JHOXZjSE1nSmlCbGVIUnlZV04wSUdGdVkyaHZjbHh1Ykc5dmNDNWhiR3dnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVM1MGMzWmNJaWtwWEc1aGJtTm9iM0l1WVd4c0lEd3RJQ2hsZUhSeVlXTjBRVzVqYUc5eUtHeHZiM0F1WVd4c0tTbGNibTkyWlhKc1lYQnpJRHd0SUdacGJtUlBkbVZ5YkdGd2N5aGhibU5vYjNJdVlXeHNMQ0JoZEdGakxtZHlLVnh1WVc1amFHOXlMbUZzYkNBOExTQndhVzUwWlhKelpXTjBLR0Z1WTJodmNpNWhiR3hiY1hWbGNubElhWFJ6S0c5MlpYSnNZWEJ6S1Ywc0lHRjBZV011WjNKYmMzVmlhbVZqZEVocGRITW9iM1psY214aGNITXBYU2xjYmx4dWJHOXZjQzUxY0NBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z1hDSmphSEp2Ylc5ZlkyOXVjMTloYm01dlNHbGxjbUZ5WTJoNVgyRnNiRjlrVkVGSGRuTkVUVk5QWDFWUVgyUnBabVl3TGpJdVltVmtjR1ZjSWlrcFhHNWhibU5vYjNJdWRYQWdQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1MWNDa3BYRzV2ZG1WeWJHRndjeUE4TFNCbWFXNWtUM1psY214aGNITW9ZVzVqYUc5eUxuVndMQ0JoZEdGakxtZHlLVnh1WVc1amFHOXlMblZ3SUR3dElIQnBiblJsY25ObFkzUW9ZVzVqYUc5eUxuVndXM0YxWlhKNVNHbDBjeWh2ZG1WeWJHRndjeWxkTENCaGRHRmpMbWR5VzNOMVltcGxZM1JJYVhSektHOTJaWEpzWVhCektWMHBYRzVjYm14dmIzQXVibThnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5aGJHeGZaRlJCUjNaelJFMVRUMTlPVDE5a2FXWm1NQzR5TG1KbFpIQmxYQ0lwS1Z4dVlXNWphRzl5TG01dklEd3RJQ2hsZUhSeVlXTjBRVzVqYUc5eUtHeHZiM0F1Ym04cEtWeHViM1psY214aGNITWdQQzBnWm1sdVpFOTJaWEpzWVhCektHRnVZMmh2Y2k1dWJ5d2dZWFJoWXk1bmNpbGNibUZ1WTJodmNpNXVieUE4TFNCd2FXNTBaWEp6WldOMEtHRnVZMmh2Y2k1dWIxdHhkV1Z5ZVVocGRITW9iM1psY214aGNITXBYU3dnWVhSaFl5NW5jbHR6ZFdKcVpXTjBTR2wwY3lodmRtVnliR0Z3Y3lsZEtWeHVYRzVzYjI5d0xuVndibThnUEMwZ1ltbHVaRjl5YjNkektHeHZiM0F1ZFhBc0lHeHZiM0F1Ym04cFhHNWhibU5vYjNJdWRYQnVieUE4TFNBb1pYaDBjbUZqZEVGdVkyaHZjaWhzYjI5d0xuVndibThwS1Z4dWIzWmxjbXhoY0hNZ1BDMGdabWx1WkU5MlpYSnNZWEJ6S0dGdVkyaHZjaTUxY0c1dkxDQmhkR0ZqTG1keUtWeHVZVzVqYUc5eUxuVndibThnUEMwZ2NHbHVkR1Z5YzJWamRDaGhibU5vYjNJdWRYQnViMXR4ZFdWeWVVaHBkSE1vYjNabGNteGhjSE1wWFN3Z1lYUmhZeTVuY2x0emRXSnFaV04wU0dsMGN5aHZkbVZ5YkdGd2N5bGRLVnh1WEc1Y2JteHZiM0JPZFcwZ1BDMGdibkp2ZHloc2IyOXdMblZ3Ym04cFhHNWNiaU1nVTJWc1pXTjBhVzVuSUhOaGJXVWdiblZ0WW1WeUlHOW1JR1Y0ZEhKbGJXVWdaRzkzYmlCc2IyOXdjMXh1Ykc5dmNDNWtiM2R1SUR3dElHeHZiM0F1WVd4c0lDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHUnBabVpmWkZSQlIxOUVUVk5QSUR3Z0xUQXVNaWtnSlQ0bElHUndiSGx5T2pwaGNuSmhibWRsS0dScFptWmZaRlJCUjE5RVRWTlBLU0FsUGlVZ2MyeHBZMlZmYUdWaFpDaHVJRDBnYkc5dmNFNTFiU2xjYm1GdVkyaHZjaTVrYjNkdUlEd3RJQ2hsZUhSeVlXTjBRVzVqYUc5eUtHeHZiM0F1Wkc5M2Jpa3BYRzV2ZG1WeWJHRndjeUE4TFNCbWFXNWtUM1psY214aGNITW9ZVzVqYUc5eUxtUnZkMjRzSUdGMFlXTXVaM0lwWEc1aGJtTm9iM0l1Wkc5M2JpQThMU0J3YVc1MFpYSnpaV04wS0dGdVkyaHZjaTVrYjNkdVczRjFaWEo1U0dsMGN5aHZkbVZ5YkdGd2N5bGRMQ0JoZEdGakxtZHlXM04xWW1wbFkzUklhWFJ6S0c5MlpYSnNZWEJ6S1YwcFhHNWNibUJnWUNKOSAtLT5cblxuYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpXG5hbmNob3IuYWxsIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuYWxsKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuYWxsLCBhdGFjLmdyKVxuYW5jaG9yLmFsbCA8LSBwaW50ZXJzZWN0KGFuY2hvci5hbGxbcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwLCBhdGFjLmdyKVxuYW5jaG9yLnVwIDwtIHBpbnRlcnNlY3QoYW5jaG9yLnVwW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLm5vIDwtIChleHRyYWN0QW5jaG9yKGxvb3Aubm8pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5ubywgYXRhYy5ncilcbmFuY2hvci5ubyA8LSBwaW50ZXJzZWN0KGFuY2hvci5ub1txdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wLnVwbm8gPC0gYmluZF9yb3dzKGxvb3AudXAsIGxvb3Aubm8pXG5hbmNob3IudXBubyA8LSAoZXh0cmFjdEFuY2hvcihsb29wLnVwbm8pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci51cG5vLCBhdGFjLmdyKVxuYW5jaG9yLnVwbm8gPC0gcGludGVyc2VjdChhbmNob3IudXBub1txdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cbmxvb3BOdW0gPC0gbnJvdyhsb29wLnVwbm8pXG5cbiMgU2VsZWN0aW5nIHNhbWUgbnVtYmVyIG9mIGV4dHJlbWUgZG93biBsb29wc1xubG9vcC5kb3duIDwtIGxvb3AuYWxsICU+JSBkcGx5cjo6ZmlsdGVyKGRpZmZfZFRBR19ETVNPIDwgLTAuMikgJT4lIGRwbHlyOjphcnJhbmdlKGRpZmZfZFRBR19ETVNPKSAlPiUgc2xpY2VfaGVhZChuID0gbG9vcE51bSlcbmFuY2hvci5kb3duIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuZG93bikpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmRvd24sIGF0YWMuZ3IpXG5hbmNob3IuZG93biA8LSBwaW50ZXJzZWN0KGFuY2hvci5kb3duW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.upno <- bind_rows(loop.up, loop.no)
anchor.upno <- (extractAnchor(loop.upno))
overlaps <- findOverlaps(anchor.upno, atac.gr)
anchor.upno <- pintersect(anchor.upno[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loopNum <- nrow(loop.upno)

# Selecting same number of extreme down loops
loop.down <- loop.all %>% dplyr::filter(diff_dTAG_DMSO < -0.2) %>% dplyr::arrange(diff_dTAG_DMSO) %>% slice_head(n = loopNum)
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVlYUmhZeUE4TFNCbWNtVmhaQ2hvWlhKbEtISmxaa1JwY2l3Z1hGeEhVMDB6TVRBMk1qVTNYMEZVUVVOZlJWTkRYekV1WW1Wa1hGd3BLU0FsUGlVZ1pIQnNlWEk2T25ObGJHVmpkQ2hXTVN3Z1ZqSXNJRll6S1Z4dVkyOXNibUZ0WlhNb1lYUmhZeWtnUEMwZ1l5aGNYR05vY2x4Y0xDQmNYSE4wWVhKMFhGd3NJRnhjWlc1a1hGd3BYRzVoZEdGakxtZHlJRHd0SUcxaGEyVkhVbUZ1WjJWelJuSnZiVVJoZEdGR2NtRnRaU2hoZEdGaktWeHVYRzRqSUV4UFFVUkpUa2NnVEU5UFVGTmNiaU1qSXlCSmJYQnZjblJwYm1jZ1pHbG1abVZ5Wlc1MGFXRnNJSEpsWjNWc1lYUnZjbmtnYkc5dmNITWdKaUJsZUhSeVlXTjBJR0Z1WTJodmNseHViRzl2Y0M1aGJHd2dQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lUzUwYzNaY1hDa3BYRzVoYm1Ob2IzSXVZV3hzSUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0d4dmIzQXVZV3hzS1NsY2JtOTJaWEpzWVhCeklEd3RJR1pwYm1SUGRtVnliR0Z3Y3loaGJtTm9iM0l1WVd4c0xDQmhkR0ZqTG1keUtWeHVZVzVqYUc5eUxtRnNiQ0E4TFNCd2FXNTBaWEp6WldOMEtHRnVZMmh2Y2k1aGJHeGJjWFZsY25sSWFYUnpLRzkyWlhKc1lYQnpLVjBzSUdGMFlXTXVaM0piYzNWaWFtVmpkRWhwZEhNb2IzWmxjbXhoY0hNcFhTbGNibHh1Ykc5dmNDNTFjQ0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnWEZ4amFISnZiVzlmWTI5dWMxOWhibTV2U0dsbGNtRnlZMmg1WDJGc2JGOWtWRUZIZG5ORVRWTlBYMVZRWDJScFptWXdMakl1WW1Wa2NHVmNYQ2twWEc1aGJtTm9iM0l1ZFhBZ1BDMGdLR1Y0ZEhKaFkzUkJibU5vYjNJb2JHOXZjQzUxY0NrcFhHNXZkbVZ5YkdGd2N5QThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG5Wd0xDQmhkR0ZqTG1keUtWeHVZVzVqYUc5eUxuVndJRHd0SUhCcGJuUmxjbk5sWTNRb1lXNWphRzl5TG5Wd1czRjFaWEo1U0dsMGN5aHZkbVZ5YkdGd2N5bGRMQ0JoZEdGakxtZHlXM04xWW1wbFkzUklhWFJ6S0c5MlpYSnNZWEJ6S1YwcFhHNWNibXh2YjNBdWJtOGdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lVjloYkd4ZlpGUkJSM1p6UkUxVFQxOU9UMTlrYVdabU1DNHlMbUpsWkhCbFhGd3BLVnh1WVc1amFHOXlMbTV2SUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0d4dmIzQXVibThwS1Z4dWIzWmxjbXhoY0hNZ1BDMGdabWx1WkU5MlpYSnNZWEJ6S0dGdVkyaHZjaTV1Ynl3Z1lYUmhZeTVuY2lsY2JtRnVZMmh2Y2k1dWJ5QThMU0J3YVc1MFpYSnpaV04wS0dGdVkyaHZjaTV1YjF0eGRXVnllVWhwZEhNb2IzWmxjbXhoY0hNcFhTd2dZWFJoWXk1bmNsdHpkV0pxWldOMFNHbDBjeWh2ZG1WeWJHRndjeWxkS1Z4dVhHNXNiMjl3TG5Wd2JtOGdQQzBnWW1sdVpGOXliM2R6S0d4dmIzQXVkWEFzSUd4dmIzQXVibThwWEc1aGJtTm9iM0l1ZFhCdWJ5QThMU0FvWlhoMGNtRmpkRUZ1WTJodmNpaHNiMjl3TG5Wd2JtOHBLVnh1YjNabGNteGhjSE1nUEMwZ1ptbHVaRTkyWlhKc1lYQnpLR0Z1WTJodmNpNTFjRzV2TENCaGRHRmpMbWR5S1Z4dVlXNWphRzl5TG5Wd2JtOGdQQzBnY0dsdWRHVnljMlZqZENoaGJtTm9iM0l1ZFhCdWIxdHhkV1Z5ZVVocGRITW9iM1psY214aGNITXBYU3dnWVhSaFl5NW5jbHR6ZFdKcVpXTjBTR2wwY3lodmRtVnliR0Z3Y3lsZEtWeHVYRzVjYm14dmIzQk9kVzBnUEMwZ2JuSnZkeWhzYjI5d0xuVndibThwWEc1Y2JpTWdVMlZzWldOMGFXNW5JSE5oYldVZ2JuVnRZbVZ5SUc5bUlHVjRkSEpsYldVZ1pHOTNiaUJzYjI5d2MxeHViRzl2Y0M1a2IzZHVJRHd0SUd4dmIzQXVZV3hzSUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0dScFptWmZaRlJCUjE5RVRWTlBJRHdnTFRBdU1pa2dKVDRsSUdSd2JIbHlPanBoY25KaGJtZGxLR1JwWm1aZlpGUkJSMTlFVFZOUEtTQWxQaVVnYzJ4cFkyVmZhR1ZoWkNodUlEMGdiRzl2Y0U1MWJTbGNibUZ1WTJodmNpNWtiM2R1SUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0d4dmIzQXVaRzkzYmlrcFhHNXZkbVZ5YkdGd2N5QThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG1SdmQyNHNJR0YwWVdNdVozSXBYRzVoYm1Ob2IzSXVaRzkzYmlBOExTQndhVzUwWlhKelpXTjBLR0Z1WTJodmNpNWtiM2R1VzNGMVpYSjVTR2wwY3lodmRtVnliR0Z3Y3lsZExDQmhkR0ZqTG1keVczTjFZbXBsWTNSSWFYUnpLRzkyWlhKc1lYQnpLVjBwWEc1Y2JtQmdZRnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbmBgYHJcbmF0YWMgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcR1NNMzEwNjI1N19BVEFDX0VTQ18xLmJlZFxcKSkgJT4lIGRwbHlyOjpzZWxlY3QoVjEsIFYyLCBWMylcbmNvbG5hbWVzKGF0YWMpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuYXRhYy5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoYXRhYylcblxuIyBMT0FESU5HIExPT1BTXG4jIyMgSW1wb3J0aW5nIGRpZmZlcmVudGlhbCByZWd1bGF0b3J5IGxvb3BzICYgZXh0cmFjdCBhbmNob3Jcbmxvb3AuYWxsIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHkudHN2XFwpKVxuYW5jaG9yLmFsbCA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmFsbCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmFsbCwgYXRhYy5ncilcbmFuY2hvci5hbGwgPC0gcGludGVyc2VjdChhbmNob3IuYWxsW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLnVwIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXApKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci51cCwgYXRhYy5ncilcbmFuY2hvci51cCA8LSBwaW50ZXJzZWN0KGFuY2hvci51cFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX2RUQUd2c0RNU09fTk9fZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci5ubyA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3Iubm8sIGF0YWMuZ3IpXG5hbmNob3Iubm8gPC0gcGludGVyc2VjdChhbmNob3Iubm9bcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxubG9vcC51cG5vIDwtIGJpbmRfcm93cyhsb29wLnVwLCBsb29wLm5vKVxuYW5jaG9yLnVwbm8gPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cG5vKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IudXBubywgYXRhYy5ncilcbmFuY2hvci51cG5vIDwtIHBpbnRlcnNlY3QoYW5jaG9yLnVwbm9bcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxuXG5sb29wTnVtIDwtIG5yb3cobG9vcC51cG5vKVxuXG4jIFNlbGVjdGluZyBzYW1lIG51bWJlciBvZiBleHRyZW1lIGRvd24gbG9vcHNcbmxvb3AuZG93biA8LSBsb29wLmFsbCAlPiUgZHBseXI6OmZpbHRlcihkaWZmX2RUQUdfRE1TTyA8IC0wLjIpICU+JSBkcGx5cjo6YXJyYW5nZShkaWZmX2RUQUdfRE1TTykgJT4lIHNsaWNlX2hlYWQobiA9IGxvb3BOdW0pXG5hbmNob3IuZG93biA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5kb3duLCBhdGFjLmdyKVxuYW5jaG9yLmRvd24gPC0gcGludGVyc2VjdChhbmNob3IuZG93bltxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpXG5hbmNob3IuYWxsIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuYWxsKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuYWxsLCBhdGFjLmdyKVxuYW5jaG9yLmFsbCA8LSBwaW50ZXJzZWN0KGFuY2hvci5hbGxbcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwLCBhdGFjLmdyKVxuYW5jaG9yLnVwIDwtIHBpbnRlcnNlY3QoYW5jaG9yLnVwW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLm5vIDwtIChleHRyYWN0QW5jaG9yKGxvb3Aubm8pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5ubywgYXRhYy5ncilcbmFuY2hvci5ubyA8LSBwaW50ZXJzZWN0KGFuY2hvci5ub1txdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wLnVwbm8gPC0gYmluZF9yb3dzKGxvb3AudXAsIGxvb3Aubm8pXG5hbmNob3IudXBubyA8LSAoZXh0cmFjdEFuY2hvcihsb29wLnVwbm8pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci51cG5vLCBhdGFjLmdyKVxuYW5jaG9yLnVwbm8gPC0gcGludGVyc2VjdChhbmNob3IudXBub1txdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cbmxvb3BOdW0gPC0gbnJvdyhsb29wLnVwbm8pXG5cbiMgU2VsZWN0aW5nIHNhbWUgbnVtYmVyIG9mIGV4dHJlbWUgZG93biBsb29wc1xubG9vcC5kb3duIDwtIGxvb3AuYWxsICU+JSBkcGx5cjo6ZmlsdGVyKGRpZmZfZFRBR19ETVNPIDwgLTAuMikgJT4lIGRwbHlyOjphcnJhbmdlKGRpZmZfZFRBR19ETVNPKSAlPiUgc2xpY2VfaGVhZChuID0gbG9vcE51bSlcbmFuY2hvci5kb3duIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuZG93bikpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmRvd24sIGF0YWMuZ3IpXG5hbmNob3IuZG93biA8LSBwaW50ZXJzZWN0KGFuY2hvci5kb3duW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmBgYFxuYGBgIn0= -->

```r
```r
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.upno <- bind_rows(loop.up, loop.no)
anchor.upno <- (extractAnchor(loop.upno))
overlaps <- findOverlaps(anchor.upno, atac.gr)
anchor.upno <- pintersect(anchor.upno[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loopNum <- nrow(loop.upno)

# Selecting same number of extreme down loops
loop.down <- loop.all %>% dplyr::filter(diff_dTAG_DMSO < -0.2) %>% dplyr::arrange(diff_dTAG_DMSO) %>% slice_head(n = loopNum)
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n# RUNNING LOLA\nlolaDir <- here(\"../../result/lola\")\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\"), sep = \"\\t\")\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\"), sep = \"\\t\")\n\n# UPNO\nresult = runLOLA(anchor.upno, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\"), sep = \"\\t\")\n\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\"), sep = \"\\t\")\n\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\"target\", \"OR_up\")\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\"target\", \"OR_no\")\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\"target\", \"OR_down\")\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\"target\")), temp.down, by = c(\"target\")) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\"white\", \"red\"))\n\n\n#fviz_nbclust(data, kmeans, method = \"wss\")\n\n# p <- Heatmap(\n#   data,\n#   name = \"Odds Ratio\",                   # Name of the heatmap legend\n#   cluster_columns = FALSE,            # Remove column dendrogram\n#   row_km = 10,                         # Define the number of k-means clusters for rows (adjust as needed)\n#   show_row_dend = FALSE,\n#   col = col_fun,\n#   border = TRUE\n# )\n# \n# fileName <- paste0(\"anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_allAnchorBackground_atac\")\n# height <- 7\n# width <- 3.5\n# png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\n# print(p)\n# dev.off()\n\n\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\n# tb.up <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\")) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \"UP\") %>%\n#   filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.no <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\")) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \"NO\") %>%\n#   filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\ntb.upno <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \"UP/NO\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.upno %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac_pub.tsv\"), sep = \"\\t\")\ntb.down <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \"DOWN\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.down %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac_pub.tsv\"), sep = \"\\t\")\n\n# temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\n# temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.upno, temp.down)\n# \n# order <- c((temp %>% dplyr::filter(group == \"UP/NO\") %>% arrange(desc(oddsRatio)))$target, \n#            (temp %>% dplyr::filter(group == \"DOWN\") %>% arrange(desc(oddsRatio)))$target)\n# temp$target <- factor(temp$target, levels = rev(order))\ntemp$group <- factor(temp$group, levels = c(\"UP/NO\", \"DOWN\"))\n\n\ntargetList <- c(\"POLR2A\", \"CTR9\",\n                \"AFF4\", \"ELL2\",\n                \"MED1\", \"MED12\",\n                \"TBP\", \"TAF1\", \"TAF3\",\n                \"ESRRB\", \"KLF4\", \"NANOG\", \"POU5F1\", \"SOX2\", \"STAT3\", \"E2F1\", \"YY1\",\n                \"EP300\", \"DPY30\", \"EZH2\", \"KDM2B\", \"KDB4B\", \"KDM4C\", \"KDM6B\", \"RBBP5\",\n                \"RAD21\", \"SMC1A\", \"SMC3\", \"CTCF\",\n                \"JARID2\", \"SUZ12\"\n)\ntemp <- temp %>% dplyr::filter(target %in% targetList)\n\ntemp$target <- factor(temp$target, levels = rev(targetList))\n# MAX qValueLog to 50\nqValueLogMax <- 50\ntemp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))\np <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 0.5*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \"white\", high = \"#CB333A\",\n                      limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- paste0(\"anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_OR_qValue_allAnchorBackground_atac_ordered\")\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(2.5)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n```"} -->\n\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n# UPNO\nresult = runLOLA(anchor.upno, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\n# p <- Heatmap(\n#   data,\n#   name = \\Odds Ratio\\,                   # Name of the heatmap legend\n#   cluster_columns = FALSE,            # Remove column dendrogram\n#   row_km = 10,                         # Define the number of k-means clusters for rows (adjust as needed)\n#   show_row_dend = FALSE,\n#   col = col_fun,\n#   border = TRUE\n# )\n# \n# fileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_allAnchorBackground_atac\\)\n# height <- 7\n# width <- 3.5\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n\n\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\n# tb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\UP\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\NO\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\ntb.upno <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\UP/NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.upno %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac_pub.tsv\\), sep = \\\\t\\)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.down %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac_pub.tsv\\), sep = \\\\t\\)\n\n# temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\n# temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.upno, temp.down)\n# \n# order <- c((temp %>% dplyr::filter(group == \\UP/NO\\) %>% arrange(desc(oddsRatio)))$target, \n#            (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\n# temp$target <- factor(temp$target, levels = rev(order))\ntemp$group <- factor(temp$group, levels = c(\\UP/NO\\, \\DOWN\\))\n\n\ntargetList <- c(\\POLR2A\\, \\CTR9\\,\n                \\AFF4\\, \\ELL2\\,\n                \\MED1\\, \\MED12\\,\n                \\TBP\\, \\TAF1\\, \\TAF3\\,\n                \\ESRRB\\, \\KLF4\\, \\NANOG\\, \\POU5F1\\, \\SOX2\\, \\STAT3\\, \\E2F1\\, \\YY1\\,\n                \\EP300\\, \\DPY30\\, \\EZH2\\, \\KDM2B\\, \\KDB4B\\, \\KDM4C\\, \\KDM6B\\, \\RBBP5\\,\n                \\RAD21\\, \\SMC1A\\, \\SMC3\\, \\CTCF\\,\n                \\JARID2\\, \\SUZ12\\\n)\ntemp <- temp %>% dplyr::filter(target %in% targetList)\n\ntemp$target <- factor(temp$target, levels = rev(targetList))\n# MAX qValueLog to 50\nqValueLogMax <- 50\ntemp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))\np <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 0.5*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_OR_qValue_allAnchorBackground_atac_ordered\\)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(2.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
# RUNNING LOLA
lolaDir <- here(\../../result/lola\)
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
#fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\), sep = \\t\)

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
#fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\), sep = \\t\)

# UPNO
result = runLOLA(anchor.upno, anchor.all, lolaDB)
tb = as_tibble(result)
#fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\), sep = \\t\)


# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
#fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\), sep = \\t\)



### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c(\target\, \OR_up\)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c(\target\, \OR_no\)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c(\target\, \OR_down\)


temp <- full_join(full_join(temp.up, temp.no, by = c(\target\)), temp.down, by = c(\target\)) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

# p <- Heatmap(
#   data,
#   name = \Odds Ratio\,                   # Name of the heatmap legend
#   cluster_columns = FALSE,            # Remove column dendrogram
#   row_km = 10,                         # Define the number of k-means clusters for rows (adjust as needed)
#   show_row_dend = FALSE,
#   col = col_fun,
#   border = TRUE
# )
# 
# fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_allAnchorBackground_atac\)
# height <- 7
# width <- 3.5
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()




### Visualizing p-value and OR
alpha <- 0.05
# tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \UP\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \NO\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
tb.upno <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = \UP/NO\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.upno %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac_pub.tsv\), sep = \\t\)
tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = \DOWN\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.down %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac_pub.tsv\), sep = \\t\)

# temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
# temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.upno, temp.down)
# 
# order <- c((temp %>% dplyr::filter(group == \UP/NO\) %>% arrange(desc(oddsRatio)))$target, 
#            (temp %>% dplyr::filter(group == \DOWN\) %>% arrange(desc(oddsRatio)))$target)
# temp$target <- factor(temp$target, levels = rev(order))
temp$group <- factor(temp$group, levels = c(\UP/NO\, \DOWN\))


targetList <- c(\POLR2A\, \CTR9\,
                \AFF4\, \ELL2\,
                \MED1\, \MED12\,
                \TBP\, \TAF1\, \TAF3\,
                \ESRRB\, \KLF4\, \NANOG\, \POU5F1\, \SOX2\, \STAT3\, \E2F1\, \YY1\,
                \EP300\, \DPY30\, \EZH2\, \KDM2B\, \KDB4B\, \KDM4C\, \KDM6B\, \RBBP5\,
                \RAD21\, \SMC1A\, \SMC3\, \CTCF\,
                \JARID2\, \SUZ12\
)
temp <- temp %>% dplyr::filter(target %in% targetList)

temp$target <- factor(temp$target, levels = rev(targetList))
# MAX qValueLog to 50
qValueLogMax <- 50
temp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))
p <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 0.5*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = \white\, high = \#CB333A\,
                      limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_OR_qValue_allAnchorBackground_atac_ordered\)
width <- panelSize(1.5)*mmToInch
height <- panelSize(2.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n# UPNO\nresult = runLOLA(anchor.upno, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\n# p <- Heatmap(\n#   data,\n#   name = \\Odds Ratio\\,                   # Name of the heatmap legend\n#   cluster_columns = FALSE,            # Remove column dendrogram\n#   row_km = 10,                         # Define the number of k-means clusters for rows (adjust as needed)\n#   show_row_dend = FALSE,\n#   col = col_fun,\n#   border = TRUE\n# )\n# \n# fileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_allAnchorBackground_atac\\)\n# height <- 7\n# width <- 3.5\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n\n\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\n# tb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\UP\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\NO\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\ntb.upno <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\UP/NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.upno %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac_pub.tsv\\), sep = \\\\t\\)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.down %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac_pub.tsv\\), sep = \\\\t\\)\n\n# temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\n# temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.upno, temp.down)\n# \n# order <- c((temp %>% dplyr::filter(group == \\UP/NO\\) %>% arrange(desc(oddsRatio)))$target, \n#            (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\n# temp$target <- factor(temp$target, levels = rev(order))\ntemp$group <- factor(temp$group, levels = c(\\UP/NO\\, \\DOWN\\))\n\n\ntargetList <- c(\\POLR2A\\, \\CTR9\\,\n                \\AFF4\\, \\ELL2\\,\n                \\MED1\\, \\MED12\\,\n                \\TBP\\, \\TAF1\\, \\TAF3\\,\n                \\ESRRB\\, \\KLF4\\, \\NANOG\\, \\POU5F1\\, \\SOX2\\, \\STAT3\\, \\E2F1\\, \\YY1\\,\n                \\EP300\\, \\DPY30\\, \\EZH2\\, \\KDM2B\\, \\KDB4B\\, \\KDM4C\\, \\KDM6B\\, \\RBBP5\\,\n                \\RAD21\\, \\SMC1A\\, \\SMC3\\, \\CTCF\\,\n                \\JARID2\\, \\SUZ12\\\n)\ntemp <- temp %>% dplyr::filter(target %in% targetList)\n\ntemp$target <- factor(temp$target, levels = rev(targetList))\n# MAX qValueLog to 50\nqValueLogMax <- 50\ntemp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))\np <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 0.5*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_OR_qValue_allAnchorBackground_atac_ordered\\)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(2.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n```\n```"} -->\n\n```r\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n# UPNO\nresult = runLOLA(anchor.upno, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\n# p <- Heatmap(\n#   data,\n#   name = \\Odds Ratio\\,                   # Name of the heatmap legend\n#   cluster_columns = FALSE,            # Remove column dendrogram\n#   row_km = 10,                         # Define the number of k-means clusters for rows (adjust as needed)\n#   show_row_dend = FALSE,\n#   col = col_fun,\n#   border = TRUE\n# )\n# \n# fileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_allAnchorBackground_atac\\)\n# height <- 7\n# width <- 3.5\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n\n\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\n# tb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\UP\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\NO\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\ntb.upno <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\UP/NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.upno %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac_pub.tsv\\), sep = \\\\t\\)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.down %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac_pub.tsv\\), sep = \\\\t\\)\n\n# temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\n# temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.upno, temp.down)\n# \n# order <- c((temp %>% dplyr::filter(group == \\UP/NO\\) %>% arrange(desc(oddsRatio)))$target, \n#            (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\n# temp$target <- factor(temp$target, levels = rev(order))\ntemp$group <- factor(temp$group, levels = c(\\UP/NO\\, \\DOWN\\))\n\n\ntargetList <- c(\\POLR2A\\, \\CTR9\\,\n                \\AFF4\\, \\ELL2\\,\n                \\MED1\\, \\MED12\\,\n                \\TBP\\, \\TAF1\\, \\TAF3\\,\n                \\ESRRB\\, \\KLF4\\, \\NANOG\\, \\POU5F1\\, \\SOX2\\, \\STAT3\\, \\E2F1\\, \\YY1\\,\n                \\EP300\\, \\DPY30\\, \\EZH2\\, \\KDM2B\\, \\KDB4B\\, \\KDM4C\\, \\KDM6B\\, \\RBBP5\\,\n                \\RAD21\\, \\SMC1A\\, \\SMC3\\, \\CTCF\\,\n                \\JARID2\\, \\SUZ12\\\n)\ntemp <- temp %>% dplyr::filter(target %in% targetList)\n\ntemp$target <- factor(temp$target, levels = rev(targetList))\n# MAX qValueLog to 50\nqValueLogMax <- 50\ntemp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))\np <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 0.5*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_OR_qValue_allAnchorBackground_atac_ordered\\)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(2.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n# UPNO\nresult = runLOLA(anchor.upno, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\n#fwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\n# p <- Heatmap(\n#   data,\n#   name = \\Odds Ratio\\,                   # Name of the heatmap legend\n#   cluster_columns = FALSE,            # Remove column dendrogram\n#   row_km = 10,                         # Define the number of k-means clusters for rows (adjust as needed)\n#   show_row_dend = FALSE,\n#   col = col_fun,\n#   border = TRUE\n# )\n# \n# fileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_allAnchorBackground_atac\\)\n# height <- 7\n# width <- 3.5\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n\n\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\n# tb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\UP\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\NO\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\ntb.upno <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\UP/NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.upno %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac_pub.tsv\\), sep = \\\\t\\)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log10(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\nfwrite(tb.down %>% dplyr::select(c(24, 16, 20,\n                                   4, 25, 5,\n                                   7, 8, 9, 10, 11,\n                                   12, 13, 14)), here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac_pub.tsv\\), sep = \\\\t\\)\n\n# temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\n# temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.upno, temp.down)\n# \n# order <- c((temp %>% dplyr::filter(group == \\UP/NO\\) %>% arrange(desc(oddsRatio)))$target, \n#            (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\n# temp$target <- factor(temp$target, levels = rev(order))\ntemp$group <- factor(temp$group, levels = c(\\UP/NO\\, \\DOWN\\))\n\n\ntargetList <- c(\\POLR2A\\, \\CTR9\\,\n                \\AFF4\\, \\ELL2\\,\n                \\MED1\\, \\MED12\\,\n                \\TBP\\, \\TAF1\\, \\TAF3\\,\n                \\ESRRB\\, \\KLF4\\, \\NANOG\\, \\POU5F1\\, \\SOX2\\, \\STAT3\\, \\E2F1\\, \\YY1\\,\n                \\EP300\\, \\DPY30\\, \\EZH2\\, \\KDM2B\\, \\KDB4B\\, \\KDM4C\\, \\KDM6B\\, \\RBBP5\\,\n                \\RAD21\\, \\SMC1A\\, \\SMC3\\, \\CTCF\\,\n                \\JARID2\\, \\SUZ12\\\n)\ntemp <- temp %>% dplyr::filter(target %in% targetList)\n\ntemp$target <- factor(temp$target, levels = rev(targetList))\n# MAX qValueLog to 50\nqValueLogMax <- 50\ntemp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))\np <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 0.5*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here\n  scale_fill_gradient(low = \\white\\, high = \\#CB333A\\,\n                      limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + \n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_OR_qValue_allAnchorBackground_atac_ordered\\)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(2.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n```\n```"} -->

```r
```r
# RUNNING LOLA
lolaDir <- here(\../../result/lola\)
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
#fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\), sep = \\t\)

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
#fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\), sep = \\t\)

# UPNO
result = runLOLA(anchor.upno, anchor.all, lolaDB)
tb = as_tibble(result)
#fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\), sep = \\t\)


# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
#fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\), sep = \\t\)



### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c(\target\, \OR_up\)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c(\target\, \OR_no\)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c(\target\, \OR_down\)


temp <- full_join(full_join(temp.up, temp.no, by = c(\target\)), temp.down, by = c(\target\)) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

# p <- Heatmap(
#   data,
#   name = \Odds Ratio\,                   # Name of the heatmap legend
#   cluster_columns = FALSE,            # Remove column dendrogram
#   row_km = 10,                         # Define the number of k-means clusters for rows (adjust as needed)
#   show_row_dend = FALSE,
#   col = col_fun,
#   border = TRUE
# )
# 
# fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_allAnchorBackground_atac\)
# height <- 7
# width <- 3.5
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()




### Visualizing p-value and OR
alpha <- 0.05
# tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \UP\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \NO\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
tb.upno <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = \UP/NO\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.upno %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac_pub.tsv\), sep = \\t\)
tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = \DOWN\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.down %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac_pub.tsv\), sep = \\t\)

# temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
# temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.upno, temp.down)
# 
# order <- c((temp %>% dplyr::filter(group == \UP/NO\) %>% arrange(desc(oddsRatio)))$target, 
#            (temp %>% dplyr::filter(group == \DOWN\) %>% arrange(desc(oddsRatio)))$target)
# temp$target <- factor(temp$target, levels = rev(order))
temp$group <- factor(temp$group, levels = c(\UP/NO\, \DOWN\))


targetList <- c(\POLR2A\, \CTR9\,
                \AFF4\, \ELL2\,
                \MED1\, \MED12\,
                \TBP\, \TAF1\, \TAF3\,
                \ESRRB\, \KLF4\, \NANOG\, \POU5F1\, \SOX2\, \STAT3\, \E2F1\, \YY1\,
                \EP300\, \DPY30\, \EZH2\, \KDM2B\, \KDB4B\, \KDM4C\, \KDM6B\, \RBBP5\,
                \RAD21\, \SMC1A\, \SMC3\, \CTCF\,
                \JARID2\, \SUZ12\
)
temp <- temp %>% dplyr::filter(target %in% targetList)

temp$target <- factor(temp$target, levels = rev(targetList))
# MAX qValueLog to 50
qValueLogMax <- 50
temp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))
p <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 0.5*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = \white\, high = \#CB333A\,
                      limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_OR_qValue_allAnchorBackground_atac_ordered\)
width <- panelSize(1.5)*mmToInch
height <- panelSize(2.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




##### - Limited to ATAC-seq signal, all loop backgroup

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZWFJoWXlBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYQ0pIVTAwek1UQTJNalUzWDBGVVFVTmZSVk5EWHpFdVltVmtYQ0lwS1NBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoV01Td2dWaklzSUZZektWeHVZMjlzYm1GdFpYTW9ZWFJoWXlrZ1BDMGdZeWhjSW1Ob2Nsd2lMQ0JjSW5OMFlYSjBYQ0lzSUZ3aVpXNWtYQ0lwWEc1aGRHRmpMbWR5SUR3dElHMWhhMlZIVW1GdVoyVnpSbkp2YlVSaGRHRkdjbUZ0WlNoaGRHRmpLVnh1WEc0aklFeFBRVVJKVGtjZ1RFOVBVRk5jYmlNakl5QkpiWEJ2Y25ScGJtY2daR2xtWm1WeVpXNTBhV0ZzSUhKbFozVnNZWFJ2Y25rZ2JHOXZjSE1nSmlCbGVIUnlZV04wSUdGdVkyaHZjbHh1Ykc5dmNDNWhiR3dnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVM1MGMzWmNJaWtwWEc1aGJtTm9iM0l1WVd4c0lEd3RJQ2hsZUhSeVlXTjBRVzVqYUc5eUtHeHZiM0F1WVd4c0tTbGNibTkyWlhKc1lYQnpJRHd0SUdacGJtUlBkbVZ5YkdGd2N5aGhibU5vYjNJdVlXeHNMQ0JoZEdGakxtZHlLVnh1WVc1amFHOXlMbUZzYkNBOExTQndhVzUwWlhKelpXTjBLR0Z1WTJodmNpNWhiR3hiY1hWbGNubElhWFJ6S0c5MlpYSnNZWEJ6S1Ywc0lHRjBZV011WjNKYmMzVmlhbVZqZEVocGRITW9iM1psY214aGNITXBYU2xjYmx4dWJHOXZjQzUxY0NBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z1hDSmphSEp2Ylc5ZlkyOXVjMTloYm01dlNHbGxjbUZ5WTJoNVgyeHZaMDlGWDJGc2JGOWtWRUZIZG5ORVRWTlBYMVZRWDJScFptWXdMalV1WW1Wa2NHVmNJaWtwWEc1aGJtTm9iM0l1ZFhBZ1BDMGdLR1Y0ZEhKaFkzUkJibU5vYjNJb2JHOXZjQzUxY0NrcFhHNXZkbVZ5YkdGd2N5QThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG5Wd0xDQmhkR0ZqTG1keUtWeHVZVzVqYUc5eUxuVndJRHd0SUhCcGJuUmxjbk5sWTNRb1lXNWphRzl5TG5Wd1czRjFaWEo1U0dsMGN5aHZkbVZ5YkdGd2N5bGRMQ0JoZEdGakxtZHlXM04xWW1wbFkzUklhWFJ6S0c5MlpYSnNZWEJ6S1YwcFhHNWNibXh2YjNBdWJtOGdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRndpWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lVjlzYjJkUFJWOWhiR3hmWkZSQlIzWnpSRTFUVDE5T1QxOWthV1ptTUM0MUxtSmxaSEJsWENJcEtWeHVZVzVqYUc5eUxtNXZJRHd0SUNobGVIUnlZV04wUVc1amFHOXlLR3h2YjNBdWJtOHBLVnh1YjNabGNteGhjSE1nUEMwZ1ptbHVaRTkyWlhKc1lYQnpLR0Z1WTJodmNpNXVieXdnWVhSaFl5NW5jaWxjYm1GdVkyaHZjaTV1YnlBOExTQndhVzUwWlhKelpXTjBLR0Z1WTJodmNpNXViMXR4ZFdWeWVVaHBkSE1vYjNabGNteGhjSE1wWFN3Z1lYUmhZeTVuY2x0emRXSnFaV04wU0dsMGN5aHZkbVZ5YkdGd2N5bGRLVnh1WEc1Y2JteHZiM0F1Wkc5M2JpQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2dYQ0pqYUhKdmJXOWZZMjl1YzE5aGJtNXZTR2xsY21GeVkyaDVYMnh2WjA5RlgyRnNiRjlrVkVGSGRuTkVUVk5QWDBSUFYwNWZaR2xtWmpBdU5TNWlaV1J3WlZ3aUtTbGNibUZ1WTJodmNpNWtiM2R1SUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0d4dmIzQXVaRzkzYmlrcFhHNXZkbVZ5YkdGd2N5QThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG1SdmQyNHNJR0YwWVdNdVozSXBYRzVoYm1Ob2IzSXVaRzkzYmlBOExTQndhVzUwWlhKelpXTjBLR0Z1WTJodmNpNWtiM2R1VzNGMVpYSjVTR2wwY3lodmRtVnliR0Z3Y3lsZExDQmhkR0ZqTG1keVczTjFZbXBsWTNSSWFYUnpLRzkyWlhKc1lYQnpLVjBwWEc1Y2JseHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpXG5hbmNob3IuYWxsIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuYWxsKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuYWxsLCBhdGFjLmdyKVxuYW5jaG9yLmFsbCA8LSBwaW50ZXJzZWN0KGFuY2hvci5hbGxbcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2xvZ09FX2FsbF9kVEFHdnNETVNPX1VQX2RpZmYwLjUuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwLCBhdGFjLmdyKVxuYW5jaG9yLnVwIDwtIHBpbnRlcnNlY3QoYW5jaG9yLnVwW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9sb2dPRV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC41LmJlZHBlXFwpKVxuYW5jaG9yLm5vIDwtIChleHRyYWN0QW5jaG9yKGxvb3Aubm8pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5ubywgYXRhYy5ncilcbmFuY2hvci5ubyA8LSBwaW50ZXJzZWN0KGFuY2hvci5ub1txdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2xvZ09FX2FsbF9kVEFHdnNETVNPX0RPV05fZGlmZjAuNS5iZWRwZVxcKSlcbmFuY2hvci5kb3duIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuZG93bikpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmRvd24sIGF0YWMuZ3IpXG5hbmNob3IuZG93biA8LSBwaW50ZXJzZWN0KGFuY2hvci5kb3duW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_logOE_all_dTAGvsDMSO_UP_diff0.5.bedpe\))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_logOE_all_dTAGvsDMSO_NO_diff0.5.bedpe\))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_logOE_all_dTAGvsDMSO_DOWN_diff0.5.bedpe\))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVlYUmhZeUE4TFNCbWNtVmhaQ2hvWlhKbEtISmxaa1JwY2l3Z1hGeEhVMDB6TVRBMk1qVTNYMEZVUVVOZlJWTkRYekV1WW1Wa1hGd3BLU0FsUGlVZ1pIQnNlWEk2T25ObGJHVmpkQ2hXTVN3Z1ZqSXNJRll6S1Z4dVkyOXNibUZ0WlhNb1lYUmhZeWtnUEMwZ1l5aGNYR05vY2x4Y0xDQmNYSE4wWVhKMFhGd3NJRnhjWlc1a1hGd3BYRzVoZEdGakxtZHlJRHd0SUcxaGEyVkhVbUZ1WjJWelJuSnZiVVJoZEdGR2NtRnRaU2hoZEdGaktWeHVYRzRqSUV4UFFVUkpUa2NnVEU5UFVGTmNiaU1qSXlCSmJYQnZjblJwYm1jZ1pHbG1abVZ5Wlc1MGFXRnNJSEpsWjNWc1lYUnZjbmtnYkc5dmNITWdKaUJsZUhSeVlXTjBJR0Z1WTJodmNseHViRzl2Y0M1aGJHd2dQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lUzUwYzNaY1hDa3BYRzVoYm1Ob2IzSXVZV3hzSUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0d4dmIzQXVZV3hzS1NsY2JtOTJaWEpzWVhCeklEd3RJR1pwYm1SUGRtVnliR0Z3Y3loaGJtTm9iM0l1WVd4c0xDQmhkR0ZqTG1keUtWeHVZVzVqYUc5eUxtRnNiQ0E4TFNCd2FXNTBaWEp6WldOMEtHRnVZMmh2Y2k1aGJHeGJjWFZsY25sSWFYUnpLRzkyWlhKc1lYQnpLVjBzSUdGMFlXTXVaM0piYzNWaWFtVmpkRWhwZEhNb2IzWmxjbXhoY0hNcFhTbGNibHh1Ykc5dmNDNTFjQ0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnWEZ4amFISnZiVzlmWTI5dWMxOWhibTV2U0dsbGNtRnlZMmg1WDJ4dlowOUZYMkZzYkY5a1ZFRkhkbk5FVFZOUFgxVlFYMlJwWm1Zd0xqVXVZbVZrY0dWY1hDa3BYRzVoYm1Ob2IzSXVkWEFnUEMwZ0tHVjRkSEpoWTNSQmJtTm9iM0lvYkc5dmNDNTFjQ2twWEc1dmRtVnliR0Z3Y3lBOExTQm1hVzVrVDNabGNteGhjSE1vWVc1amFHOXlMblZ3TENCaGRHRmpMbWR5S1Z4dVlXNWphRzl5TG5Wd0lEd3RJSEJwYm5SbGNuTmxZM1FvWVc1amFHOXlMblZ3VzNGMVpYSjVTR2wwY3lodmRtVnliR0Z3Y3lsZExDQmhkR0ZqTG1keVczTjFZbXBsWTNSSWFYUnpLRzkyWlhKc1lYQnpLVjBwWEc1Y2JteHZiM0F1Ym04Z1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGeGNZMmh5YjIxdlgyTnZibk5mWVc1dWIwaHBaWEpoY21Ob2VWOXNiMmRQUlY5aGJHeGZaRlJCUjNaelJFMVRUMTlPVDE5a2FXWm1NQzQxTG1KbFpIQmxYRndwS1Z4dVlXNWphRzl5TG01dklEd3RJQ2hsZUhSeVlXTjBRVzVqYUc5eUtHeHZiM0F1Ym04cEtWeHViM1psY214aGNITWdQQzBnWm1sdVpFOTJaWEpzWVhCektHRnVZMmh2Y2k1dWJ5d2dZWFJoWXk1bmNpbGNibUZ1WTJodmNpNXVieUE4TFNCd2FXNTBaWEp6WldOMEtHRnVZMmh2Y2k1dWIxdHhkV1Z5ZVVocGRITW9iM1psY214aGNITXBYU3dnWVhSaFl5NW5jbHR6ZFdKcVpXTjBTR2wwY3lodmRtVnliR0Z3Y3lsZEtWeHVYRzVjYm14dmIzQXVaRzkzYmlBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z1hGeGphSEp2Ylc5ZlkyOXVjMTloYm01dlNHbGxjbUZ5WTJoNVgyeHZaMDlGWDJGc2JGOWtWRUZIZG5ORVRWTlBYMFJQVjA1ZlpHbG1aakF1TlM1aVpXUndaVnhjS1NsY2JtRnVZMmh2Y2k1a2IzZHVJRHd0SUNobGVIUnlZV04wUVc1amFHOXlLR3h2YjNBdVpHOTNiaWtwWEc1dmRtVnliR0Z3Y3lBOExTQm1hVzVrVDNabGNteGhjSE1vWVc1amFHOXlMbVJ2ZDI0c0lHRjBZV011WjNJcFhHNWhibU5vYjNJdVpHOTNiaUE4TFNCd2FXNTBaWEp6WldOMEtHRnVZMmh2Y2k1a2IzZHVXM0YxWlhKNVNHbDBjeWh2ZG1WeWJHRndjeWxkTENCaGRHRmpMbWR5VzNOMVltcGxZM1JJYVhSektHOTJaWEpzWVhCektWMHBYRzVjYmx4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbmF0YWMgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcR1NNMzEwNjI1N19BVEFDX0VTQ18xLmJlZFxcKSkgJT4lIGRwbHlyOjpzZWxlY3QoVjEsIFYyLCBWMylcbmNvbG5hbWVzKGF0YWMpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuYXRhYy5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoYXRhYylcblxuIyBMT0FESU5HIExPT1BTXG4jIyMgSW1wb3J0aW5nIGRpZmZlcmVudGlhbCByZWd1bGF0b3J5IGxvb3BzICYgZXh0cmFjdCBhbmNob3Jcbmxvb3AuYWxsIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHkudHN2XFwpKVxuYW5jaG9yLmFsbCA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmFsbCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmFsbCwgYXRhYy5ncilcbmFuY2hvci5hbGwgPC0gcGludGVyc2VjdChhbmNob3IuYWxsW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9sb2dPRV9hbGxfZFRBR3ZzRE1TT19VUF9kaWZmMC41LmJlZHBlXFwpKVxuYW5jaG9yLnVwIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXApKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci51cCwgYXRhYy5ncilcbmFuY2hvci51cCA8LSBwaW50ZXJzZWN0KGFuY2hvci51cFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfbG9nT0VfYWxsX2RUQUd2c0RNU09fTk9fZGlmZjAuNS5iZWRwZVxcKSlcbmFuY2hvci5ubyA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3Iubm8sIGF0YWMuZ3IpXG5hbmNob3Iubm8gPC0gcGludGVyc2VjdChhbmNob3Iubm9bcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxuXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9sb2dPRV9hbGxfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjUuYmVkcGVcXCkpXG5hbmNob3IuZG93biA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5kb3duLCBhdGFjLmdyKVxuYW5jaG9yLmRvd24gPC0gcGludGVyc2VjdChhbmNob3IuZG93bltxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpXG5hbmNob3IuYWxsIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuYWxsKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuYWxsLCBhdGFjLmdyKVxuYW5jaG9yLmFsbCA8LSBwaW50ZXJzZWN0KGFuY2hvci5hbGxbcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2xvZ09FX2FsbF9kVEFHdnNETVNPX1VQX2RpZmYwLjUuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwLCBhdGFjLmdyKVxuYW5jaG9yLnVwIDwtIHBpbnRlcnNlY3QoYW5jaG9yLnVwW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9sb2dPRV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC41LmJlZHBlXFwpKVxuYW5jaG9yLm5vIDwtIChleHRyYWN0QW5jaG9yKGxvb3Aubm8pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5ubywgYXRhYy5ncilcbmFuY2hvci5ubyA8LSBwaW50ZXJzZWN0KGFuY2hvci5ub1txdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2xvZ09FX2FsbF9kVEFHdnNETVNPX0RPV05fZGlmZjAuNS5iZWRwZVxcKSlcbmFuY2hvci5kb3duIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuZG93bikpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmRvd24sIGF0YWMuZ3IpXG5hbmNob3IuZG93biA8LSBwaW50ZXJzZWN0KGFuY2hvci5kb3duW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cblxuYGBgXG5gYGAifQ== -->

```r
```r
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_logOE_all_dTAGvsDMSO_UP_diff0.5.bedpe\))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_logOE_all_dTAGvsDMSO_NO_diff0.5.bedpe\))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_logOE_all_dTAGvsDMSO_DOWN_diff0.5.bedpe\))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBSVU5OSU5HIExPTEFcbmxvbGFEaXIgPC0gaGVyZShcIi4uLy4uL3Jlc3VsdC9sb2xhXCIpXG5kaXIuY3JlYXRlKGxvbGFEaXIsIHNob3dXYXJuaW5ncyA9IEZBTFNFLCByZWN1cnNpdmUgPSBUUlVFKVxuXG4jIFVQXG5yZXN1bHQgPSBydW5MT0xBKGFuY2hvci51cCwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFwiTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV91cF9hbGxMb29wc19hdGFjLnRzdlwiKSwgc2VwID0gXCJcXHRcIilcblxuIyBOT1xucmVzdWx0ID0gcnVuTE9MQShhbmNob3Iubm8sIGFuY2hvci5hbGwsIGxvbGFEQilcbnRiID0gYXNfdGliYmxlKHJlc3VsdClcbmZ3cml0ZSh0YiwgaGVyZShsb2xhRGlyLCBcIkxPTEFfZFRBR192c19ETVNPX2xvZ09FX2RpZmYwLjVfbm9fYWxsTG9vcHNfYXRhYy50c3ZcIiksIHNlcCA9IFwiXFx0XCIpXG5cbiMgRE9XTlxucmVzdWx0ID0gcnVuTE9MQShhbmNob3IuZG93biwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFwiTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9kb3duX2FsbExvb3BzX2F0YWMudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuXG5cblxuIyMjIEhFQVRNQVBcbmFscGhhIDwtIDAuMDVcbnRiLnVwIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXCJMT0xBX2RUQUdfdnNfRE1TT19sb2dPRV9kaWZmMC41X3VwX2FsbExvb3BzX2F0YWMudHN2XCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFwiZW1icnlvbmljIHN0ZW0gY2VsbFwiKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG50Yi5ubyA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFwiTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9ub19hbGxMb29wc19hdGFjLnRzdlwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSkpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcImVtYnJ5b25pYyBzdGVtIGNlbGxcIikgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIuZG93biA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFwiTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9kb3duX2FsbExvb3BzX2F0YWMudHN2XCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFwiZW1icnlvbmljIHN0ZW0gY2VsbFwiKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG5cbnRlbXAudXAgPC0gdGIudXAgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLnVwKSA8LSBjKFwidGFyZ2V0XCIsIFwiT1JfdXBcIilcbnRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLm5vKSA8LSBjKFwidGFyZ2V0XCIsIFwiT1Jfbm9cIilcbnRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvKVxuY29sbmFtZXModGVtcC5kb3duKSA8LSBjKFwidGFyZ2V0XCIsIFwiT1JfZG93blwiKVxuXG5cbnRlbXAgPC0gZnVsbF9qb2luKGZ1bGxfam9pbih0ZW1wLnVwLCB0ZW1wLm5vLCBieSA9IGMoXCJ0YXJnZXRcIikpLCB0ZW1wLmRvd24sIGJ5ID0gYyhcInRhcmdldFwiKSkgJT4lIG11dGF0ZV9hbGwofnJlcGxhY2VfbmEoLiwgMSkpXG5cbmRhdGEgPC0gYXMubWF0cml4KHRlbXBbMjo0XSlcbnJvd25hbWVzKGRhdGEpIDwtIHRlbXAkdGFyZ2V0XG5cbmxpYnJhcnkoY2lyY2xpemUpXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYyhtaW4oZGF0YSksIG1heChkYXRhKSksIGMoXCJ3aGl0ZVwiLCBcInJlZFwiKSlcblxuXG4jZnZpel9uYmNsdXN0KGRhdGEsIGttZWFucywgbWV0aG9kID0gXCJ3c3NcIilcblxucCA8LSBIZWF0bWFwKFxuICBkYXRhLFxuICBuYW1lID0gXCJPZGRzIFJhdGlvXCIsICAgICAgICAgICAgICAgICAgICMgTmFtZSBvZiB0aGUgaGVhdG1hcCBsZWdlbmRcbiAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsICAgICAgICAgICAgIyBSZW1vdmUgY29sdW1uIGRlbmRyb2dyYW1cbiAgcm93X2ttID0gNCwgICAgICAgICAgICAgICAgICAgICAgICAjIERlZmluZSB0aGUgbnVtYmVyIG9mIGstbWVhbnMgY2x1c3RlcnMgZm9yIHJvd3MgKGFkanVzdCBhcyBuZWVkZWQpXG4gIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgY29sID0gY29sX2Z1bixcbiAgYm9yZGVyID0gVFJVRVxuKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJhbmNob3JMT0xBX2RUQUdfdnNfRE1TT19sb2dPRV9kaWZmMC41X2FsbExvb3BzX2FsbEFuY2hvckJhY2tncm91bmRfYXRhY1wiKVxuaGVpZ2h0IDwtIDdcbndpZHRoIDwtIDMuNVxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cbiMjIyMjIyMjIyMjI1xuIyBcbiMgIyMjIFZpc3VhbGl6aW5nIHAtdmFsdWUgYW5kIE9SXG4jIGFscGhhIDwtIDAuMDVcbiMgdGIudXAgPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcIkxPTEFfZFRBR192c19ETVNPX2xvZ09FX2RpZmYwLjVfdXBfYWxsTG9vcHNfYXRhYy50c3ZcIikpICU+JVxuIyAgIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSksXG4jICAgICAgICAgICAgICAgICBxVmFsdWVMb2cgPSAtbG9nMihxVmFsdWUpLFxuIyAgICAgICAgICAgICAgICAgZ3JvdXAgPSBcIlVQXCIpICU+JVxuIyAgIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFwiZW1icnlvbmljIHN0ZW0gY2VsbFwiKSAlPiVcbiMgICBkcGx5cjo6ZmlsdGVyKHFWYWx1ZSA8IGFscGhhKSAlPiUgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4jICAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxuIyB0Yi5ubyA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFwiTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9ub19hbGxMb29wc19hdGFjLnRzdlwiKSkgJT4lXG4jICAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSxcbiMgICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4jICAgICAgICAgICAgICAgICBncm91cCA9IFwiTk9cIikgJT4lXG4jICAgZmlsdGVyKHN0cl90b19sb3dlcihjZWxsVHlwZSkgPT0gXCJlbWJyeW9uaWMgc3RlbSBjZWxsXCIpICU+JVxuIyAgIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiMgICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG4jIHRiLmRvd24gPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcIkxPTEFfZFRBR192c19ETVNPX2xvZ09FX2RpZmYwLjVfZG93bl9hbGxMb29wc19hdGFjLnRzdlwiKSkgJT4lXG4jICAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSxcbiMgICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4jICAgICAgICAgICAgICAgICBncm91cCA9IFwiRE9XTlwiKSAlPiVcbiMgICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcImVtYnJ5b25pYyBzdGVtIGNlbGxcIikgJT4lXG4jICAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuIyAgIHNsaWNlX21pbihtZWFuUm5rLCB3aXRoX3RpZXMgPSBGQUxTRSlcbiMgXG4jIHRlbXAudXAgPC0gdGIudXAgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8sIHFWYWx1ZUxvZywgZ3JvdXApXG4jIHRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8sIHFWYWx1ZUxvZywgZ3JvdXApXG4jIHRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvLCBxVmFsdWVMb2csIGdyb3VwKVxuIyBcbiMgdGVtcCA8LSBiaW5kX3Jvd3ModGVtcC51cCwgdGVtcC5kb3duKVxuIyBcbiMgb3JkZXIgPC0gYygodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcIlVQXCIpICU+JSBhcnJhbmdlKGRlc2Mob2Rkc1JhdGlvKSkpJHRhcmdldCwgXG4jICAgICAgICAgICAgKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXCJET1dOXCIpICU+JSBhcnJhbmdlKGRlc2Mob2Rkc1JhdGlvKSkpJHRhcmdldClcbiMgdGVtcCR0YXJnZXQgPC0gZmFjdG9yKHRlbXAkdGFyZ2V0LCBsZXZlbHMgPSByZXYob3JkZXIpKVxuIyBwIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGdyb3VwLCB5ID0gdGFyZ2V0LCBjb2xvciA9IHFWYWx1ZUxvZywgc2l6ZSA9IG9kZHNSYXRpbykpICtcbiMgICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfZ3JhZGllbnQobG93ID0gXCJibHVlXCIsIGhpZ2ggPSBcInJlZFwiKSArXG4jICAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICArICAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygxLCAzKSkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gcGFzdGUwKFwiYW5jaG9yTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9hbGxMb29wc19PUl9hbGxBbmNob3JCYWNrZ3JvdW5kX2F0YWNcIilcbiMgaGVpZ2h0IDwtM1xuIyB3aWR0aCA8LSAyXG4jIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG4jIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5cblxuYGBgIn0= -->\n\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv\\), sep = \\\\t\\)\n\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  row_km = 4,                        # Define the number of k-means clusters for rows (adjust as needed)\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_allLoops_allAnchorBackground_atac\\)\nheight <- 7\nwidth <- 3.5\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n############\n# \n# ### Visualizing p-value and OR\n# alpha <- 0.05\n# tb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\UP\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\NO\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\DOWN\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# \n# temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\n# temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\n# temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n# \n# temp <- bind_rows(temp.up, temp.down)\n# \n# order <- c((temp %>% dplyr::filter(group == \\UP\\) %>% arrange(desc(oddsRatio)))$target, \n#            (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\n# temp$target <- factor(temp$target, levels = rev(order))\n# p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n#   geom_point() + theme_bw() + scale_color_gradient(low = \\blue\\, high = \\red\\) +\n#   labs(x = NULL, y = NULL)  +   scale_size_continuous(range = c(1, 3)) +\n#   theme(axis.text = element_text(size = 6),  # Set axis text size\n#         axis.title = element_text(size = 6), # Set axis title size (if not removed)\n#         legend.text = element_text(size = 6), # Set legend text size\n#         legend.title = element_text(size = 6)) \n# \n# fileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_allLoops_OR_allAnchorBackground_atac\\)\n# height <-3\n# width <- 2\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
# RUNNING LOLA
lolaDir <- here(\../../result/lola\)
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv\), sep = \\t\)

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv\), sep = \\t\)

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv\), sep = \\t\)



### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c(\target\, \OR_up\)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c(\target\, \OR_no\)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c(\target\, \OR_down\)


temp <- full_join(full_join(temp.up, temp.no, by = c(\target\)), temp.down, by = c(\target\)) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 4,                        # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)

fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_allLoops_allAnchorBackground_atac\)
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


############
# 
# ### Visualizing p-value and OR
# alpha <- 0.05
# tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \UP\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \NO\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \DOWN\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# 
# temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
# temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
# temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)
# 
# temp <- bind_rows(temp.up, temp.down)
# 
# order <- c((temp %>% dplyr::filter(group == \UP\) %>% arrange(desc(oddsRatio)))$target, 
#            (temp %>% dplyr::filter(group == \DOWN\) %>% arrange(desc(oddsRatio)))$target)
# temp$target <- factor(temp$target, levels = rev(order))
# p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
#   geom_point() + theme_bw() + scale_color_gradient(low = \blue\, high = \red\) +
#   labs(x = NULL, y = NULL)  +   scale_size_continuous(range = c(1, 3)) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_allLoops_OR_allAnchorBackground_atac\)
# height <-3
# width <- 2
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBSVU5OSU5HIExPTEFcbmxvbGFEaXIgPC0gaGVyZShcXC4uLy4uL3Jlc3VsdC9sb2xhXFwpXG5kaXIuY3JlYXRlKGxvbGFEaXIsIHNob3dXYXJuaW5ncyA9IEZBTFNFLCByZWN1cnNpdmUgPSBUUlVFKVxuXG4jIFVQXG5yZXN1bHQgPSBydW5MT0xBKGFuY2hvci51cCwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFxcTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV91cF9hbGxMb29wc19hdGFjLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcblxuIyBOT1xucmVzdWx0ID0gcnVuTE9MQShhbmNob3Iubm8sIGFuY2hvci5hbGwsIGxvbGFEQilcbnRiID0gYXNfdGliYmxlKHJlc3VsdClcbmZ3cml0ZSh0YiwgaGVyZShsb2xhRGlyLCBcXExPTEFfZFRBR192c19ETVNPX2xvZ09FX2RpZmYwLjVfbm9fYWxsTG9vcHNfYXRhYy50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5cbiMgRE9XTlxucmVzdWx0ID0gcnVuTE9MQShhbmNob3IuZG93biwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFxcTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9kb3duX2FsbExvb3BzX2F0YWMudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG5cblxuIyMjIEhFQVRNQVBcbmFscGhhIDwtIDAuMDVcbnRiLnVwIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXFxMT0xBX2RUQUdfdnNfRE1TT19sb2dPRV9kaWZmMC41X3VwX2FsbExvb3BzX2F0YWMudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG50Yi5ubyA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFxcTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9ub19hbGxMb29wc19hdGFjLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSkpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIuZG93biA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFxcTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9kb3duX2FsbExvb3BzX2F0YWMudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG5cbnRlbXAudXAgPC0gdGIudXAgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLnVwKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1JfdXBcXClcbnRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLm5vKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1Jfbm9cXClcbnRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvKVxuY29sbmFtZXModGVtcC5kb3duKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1JfZG93blxcKVxuXG5cbnRlbXAgPC0gZnVsbF9qb2luKGZ1bGxfam9pbih0ZW1wLnVwLCB0ZW1wLm5vLCBieSA9IGMoXFx0YXJnZXRcXCkpLCB0ZW1wLmRvd24sIGJ5ID0gYyhcXHRhcmdldFxcKSkgJT4lIG11dGF0ZV9hbGwofnJlcGxhY2VfbmEoLiwgMSkpXG5cbmRhdGEgPC0gYXMubWF0cml4KHRlbXBbMjo0XSlcbnJvd25hbWVzKGRhdGEpIDwtIHRlbXAkdGFyZ2V0XG5cbmxpYnJhcnkoY2lyY2xpemUpXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYyhtaW4oZGF0YSksIG1heChkYXRhKSksIGMoXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuXG4jZnZpel9uYmNsdXN0KGRhdGEsIGttZWFucywgbWV0aG9kID0gXFx3c3NcXClcblxucCA8LSBIZWF0bWFwKFxuICBkYXRhLFxuICBuYW1lID0gXFxPZGRzIFJhdGlvXFwsICAgICAgICAgICAgICAgICAgICMgTmFtZSBvZiB0aGUgaGVhdG1hcCBsZWdlbmRcbiAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsICAgICAgICAgICAgIyBSZW1vdmUgY29sdW1uIGRlbmRyb2dyYW1cbiAgcm93X2ttID0gNCwgICAgICAgICAgICAgICAgICAgICAgICAjIERlZmluZSB0aGUgbnVtYmVyIG9mIGstbWVhbnMgY2x1c3RlcnMgZm9yIHJvd3MgKGFkanVzdCBhcyBuZWVkZWQpXG4gIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgY29sID0gY29sX2Z1bixcbiAgYm9yZGVyID0gVFJVRVxuKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxhbmNob3JMT0xBX2RUQUdfdnNfRE1TT19sb2dPRV9kaWZmMC41X2FsbExvb3BzX2FsbEFuY2hvckJhY2tncm91bmRfYXRhY1xcKVxuaGVpZ2h0IDwtIDdcbndpZHRoIDwtIDMuNVxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cbiMjIyMjIyMjIyMjI1xuIyBcbiMgIyMjIFZpc3VhbGl6aW5nIHAtdmFsdWUgYW5kIE9SXG4jIGFscGhhIDwtIDAuMDVcbiMgdGIudXAgPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcXExPTEFfZFRBR192c19ETVNPX2xvZ09FX2RpZmYwLjVfdXBfYWxsTG9vcHNfYXRhYy50c3ZcXCkpICU+JVxuIyAgIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSksXG4jICAgICAgICAgICAgICAgICBxVmFsdWVMb2cgPSAtbG9nMihxVmFsdWUpLFxuIyAgICAgICAgICAgICAgICAgZ3JvdXAgPSBcXFVQXFwpICU+JVxuIyAgIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiMgICBkcGx5cjo6ZmlsdGVyKHFWYWx1ZSA8IGFscGhhKSAlPiUgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4jICAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxuIyB0Yi5ubyA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFxcTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9ub19hbGxMb29wc19hdGFjLnRzdlxcKSkgJT4lXG4jICAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSxcbiMgICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4jICAgICAgICAgICAgICAgICBncm91cCA9IFxcTk9cXCkgJT4lXG4jICAgZmlsdGVyKHN0cl90b19sb3dlcihjZWxsVHlwZSkgPT0gXFxlbWJyeW9uaWMgc3RlbSBjZWxsXFwpICU+JVxuIyAgIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiMgICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG4jIHRiLmRvd24gPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcXExPTEFfZFRBR192c19ETVNPX2xvZ09FX2RpZmYwLjVfZG93bl9hbGxMb29wc19hdGFjLnRzdlxcKSkgJT4lXG4jICAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSxcbiMgICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4jICAgICAgICAgICAgICAgICBncm91cCA9IFxcRE9XTlxcKSAlPiVcbiMgICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4jICAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuIyAgIHNsaWNlX21pbihtZWFuUm5rLCB3aXRoX3RpZXMgPSBGQUxTRSlcbiMgXG4jIHRlbXAudXAgPC0gdGIudXAgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8sIHFWYWx1ZUxvZywgZ3JvdXApXG4jIHRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8sIHFWYWx1ZUxvZywgZ3JvdXApXG4jIHRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvLCBxVmFsdWVMb2csIGdyb3VwKVxuIyBcbiMgdGVtcCA8LSBiaW5kX3Jvd3ModGVtcC51cCwgdGVtcC5kb3duKVxuIyBcbiMgb3JkZXIgPC0gYygodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXFVQXFwpICU+JSBhcnJhbmdlKGRlc2Mob2Rkc1JhdGlvKSkpJHRhcmdldCwgXG4jICAgICAgICAgICAgKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxET1dOXFwpICU+JSBhcnJhbmdlKGRlc2Mob2Rkc1JhdGlvKSkpJHRhcmdldClcbiMgdGVtcCR0YXJnZXQgPC0gZmFjdG9yKHRlbXAkdGFyZ2V0LCBsZXZlbHMgPSByZXYob3JkZXIpKVxuIyBwIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGdyb3VwLCB5ID0gdGFyZ2V0LCBjb2xvciA9IHFWYWx1ZUxvZywgc2l6ZSA9IG9kZHNSYXRpbykpICtcbiMgICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfZ3JhZGllbnQobG93ID0gXFxibHVlXFwsIGhpZ2ggPSBcXHJlZFxcKSArXG4jICAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICArICAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygxLCAzKSkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gcGFzdGUwKFxcYW5jaG9yTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9hbGxMb29wc19PUl9hbGxBbmNob3JCYWNrZ3JvdW5kX2F0YWNcXClcbiMgaGVpZ2h0IDwtM1xuIyB3aWR0aCA8LSAyXG4jIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG4jIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5cblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv\\), sep = \\\\t\\)\n\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  row_km = 4,                        # Define the number of k-means clusters for rows (adjust as needed)\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_allLoops_allAnchorBackground_atac\\)\nheight <- 7\nwidth <- 3.5\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n############\n# \n# ### Visualizing p-value and OR\n# alpha <- 0.05\n# tb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\UP\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\NO\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# tb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv\\)) %>%\n#   dplyr::mutate(target = toupper(antibody),\n#                 qValueLog = -log2(qValue),\n#                 group = \\DOWN\\) %>%\n#   filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n#   slice_min(meanRnk, with_ties = FALSE)\n# \n# temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\n# temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\n# temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n# \n# temp <- bind_rows(temp.up, temp.down)\n# \n# order <- c((temp %>% dplyr::filter(group == \\UP\\) %>% arrange(desc(oddsRatio)))$target, \n#            (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\n# temp$target <- factor(temp$target, levels = rev(order))\n# p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n#   geom_point() + theme_bw() + scale_color_gradient(low = \\blue\\, high = \\red\\) +\n#   labs(x = NULL, y = NULL)  +   scale_size_continuous(range = c(1, 3)) +\n#   theme(axis.text = element_text(size = 6),  # Set axis text size\n#         axis.title = element_text(size = 6), # Set axis title size (if not removed)\n#         legend.text = element_text(size = 6), # Set legend text size\n#         legend.title = element_text(size = 6)) \n# \n# fileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_allLoops_OR_allAnchorBackground_atac\\)\n# height <-3\n# width <- 2\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\n# svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n# print(p)\n# dev.off()\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBSVU5OSU5HIExPTEFcbmxvbGFEaXIgPC0gaGVyZShcXC4uLy4uL3Jlc3VsdC9sb2xhXFwpXG5kaXIuY3JlYXRlKGxvbGFEaXIsIHNob3dXYXJuaW5ncyA9IEZBTFNFLCByZWN1cnNpdmUgPSBUUlVFKVxuXG4jIFVQXG5yZXN1bHQgPSBydW5MT0xBKGFuY2hvci51cCwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFxcTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV91cF9hbGxMb29wc19hdGFjLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcblxuIyBOT1xucmVzdWx0ID0gcnVuTE9MQShhbmNob3Iubm8sIGFuY2hvci5hbGwsIGxvbGFEQilcbnRiID0gYXNfdGliYmxlKHJlc3VsdClcbmZ3cml0ZSh0YiwgaGVyZShsb2xhRGlyLCBcXExPTEFfZFRBR192c19ETVNPX2xvZ09FX2RpZmYwLjVfbm9fYWxsTG9vcHNfYXRhYy50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5cbiMgRE9XTlxucmVzdWx0ID0gcnVuTE9MQShhbmNob3IuZG93biwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFxcTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9kb3duX2FsbExvb3BzX2F0YWMudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG5cblxuIyMjIEhFQVRNQVBcbmFscGhhIDwtIDAuMDVcbnRiLnVwIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXFxMT0xBX2RUQUdfdnNfRE1TT19sb2dPRV9kaWZmMC41X3VwX2FsbExvb3BzX2F0YWMudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG50Yi5ubyA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFxcTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9ub19hbGxMb29wc19hdGFjLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSkpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIuZG93biA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFxcTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9kb3duX2FsbExvb3BzX2F0YWMudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG5cbnRlbXAudXAgPC0gdGIudXAgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLnVwKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1JfdXBcXClcbnRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLm5vKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1Jfbm9cXClcbnRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvKVxuY29sbmFtZXModGVtcC5kb3duKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1JfZG93blxcKVxuXG5cbnRlbXAgPC0gZnVsbF9qb2luKGZ1bGxfam9pbih0ZW1wLnVwLCB0ZW1wLm5vLCBieSA9IGMoXFx0YXJnZXRcXCkpLCB0ZW1wLmRvd24sIGJ5ID0gYyhcXHRhcmdldFxcKSkgJT4lIG11dGF0ZV9hbGwofnJlcGxhY2VfbmEoLiwgMSkpXG5cbmRhdGEgPC0gYXMubWF0cml4KHRlbXBbMjo0XSlcbnJvd25hbWVzKGRhdGEpIDwtIHRlbXAkdGFyZ2V0XG5cbmxpYnJhcnkoY2lyY2xpemUpXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYyhtaW4oZGF0YSksIG1heChkYXRhKSksIGMoXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuXG4jZnZpel9uYmNsdXN0KGRhdGEsIGttZWFucywgbWV0aG9kID0gXFx3c3NcXClcblxucCA8LSBIZWF0bWFwKFxuICBkYXRhLFxuICBuYW1lID0gXFxPZGRzIFJhdGlvXFwsICAgICAgICAgICAgICAgICAgICMgTmFtZSBvZiB0aGUgaGVhdG1hcCBsZWdlbmRcbiAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsICAgICAgICAgICAgIyBSZW1vdmUgY29sdW1uIGRlbmRyb2dyYW1cbiAgcm93X2ttID0gNCwgICAgICAgICAgICAgICAgICAgICAgICAjIERlZmluZSB0aGUgbnVtYmVyIG9mIGstbWVhbnMgY2x1c3RlcnMgZm9yIHJvd3MgKGFkanVzdCBhcyBuZWVkZWQpXG4gIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgY29sID0gY29sX2Z1bixcbiAgYm9yZGVyID0gVFJVRVxuKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxhbmNob3JMT0xBX2RUQUdfdnNfRE1TT19sb2dPRV9kaWZmMC41X2FsbExvb3BzX2FsbEFuY2hvckJhY2tncm91bmRfYXRhY1xcKVxuaGVpZ2h0IDwtIDdcbndpZHRoIDwtIDMuNVxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cbiMjIyMjIyMjIyMjI1xuIyBcbiMgIyMjIFZpc3VhbGl6aW5nIHAtdmFsdWUgYW5kIE9SXG4jIGFscGhhIDwtIDAuMDVcbiMgdGIudXAgPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcXExPTEFfZFRBR192c19ETVNPX2xvZ09FX2RpZmYwLjVfdXBfYWxsTG9vcHNfYXRhYy50c3ZcXCkpICU+JVxuIyAgIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSksXG4jICAgICAgICAgICAgICAgICBxVmFsdWVMb2cgPSAtbG9nMihxVmFsdWUpLFxuIyAgICAgICAgICAgICAgICAgZ3JvdXAgPSBcXFVQXFwpICU+JVxuIyAgIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiMgICBkcGx5cjo6ZmlsdGVyKHFWYWx1ZSA8IGFscGhhKSAlPiUgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4jICAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxuIyB0Yi5ubyA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFxcTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9ub19hbGxMb29wc19hdGFjLnRzdlxcKSkgJT4lXG4jICAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSxcbiMgICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4jICAgICAgICAgICAgICAgICBncm91cCA9IFxcTk9cXCkgJT4lXG4jICAgZmlsdGVyKHN0cl90b19sb3dlcihjZWxsVHlwZSkgPT0gXFxlbWJyeW9uaWMgc3RlbSBjZWxsXFwpICU+JVxuIyAgIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiMgICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG4jIHRiLmRvd24gPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcXExPTEFfZFRBR192c19ETVNPX2xvZ09FX2RpZmYwLjVfZG93bl9hbGxMb29wc19hdGFjLnRzdlxcKSkgJT4lXG4jICAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSxcbiMgICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4jICAgICAgICAgICAgICAgICBncm91cCA9IFxcRE9XTlxcKSAlPiVcbiMgICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4jICAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuIyAgIHNsaWNlX21pbihtZWFuUm5rLCB3aXRoX3RpZXMgPSBGQUxTRSlcbiMgXG4jIHRlbXAudXAgPC0gdGIudXAgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8sIHFWYWx1ZUxvZywgZ3JvdXApXG4jIHRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8sIHFWYWx1ZUxvZywgZ3JvdXApXG4jIHRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvLCBxVmFsdWVMb2csIGdyb3VwKVxuIyBcbiMgdGVtcCA8LSBiaW5kX3Jvd3ModGVtcC51cCwgdGVtcC5kb3duKVxuIyBcbiMgb3JkZXIgPC0gYygodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXFVQXFwpICU+JSBhcnJhbmdlKGRlc2Mob2Rkc1JhdGlvKSkpJHRhcmdldCwgXG4jICAgICAgICAgICAgKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxET1dOXFwpICU+JSBhcnJhbmdlKGRlc2Mob2Rkc1JhdGlvKSkpJHRhcmdldClcbiMgdGVtcCR0YXJnZXQgPC0gZmFjdG9yKHRlbXAkdGFyZ2V0LCBsZXZlbHMgPSByZXYob3JkZXIpKVxuIyBwIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGdyb3VwLCB5ID0gdGFyZ2V0LCBjb2xvciA9IHFWYWx1ZUxvZywgc2l6ZSA9IG9kZHNSYXRpbykpICtcbiMgICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfZ3JhZGllbnQobG93ID0gXFxibHVlXFwsIGhpZ2ggPSBcXHJlZFxcKSArXG4jICAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICArICAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygxLCAzKSkgK1xuIyAgIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuIyAgICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuIyAgICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuIyAgICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuIyBcbiMgZmlsZU5hbWUgPC0gcGFzdGUwKFxcYW5jaG9yTE9MQV9kVEFHX3ZzX0RNU09fbG9nT0VfZGlmZjAuNV9hbGxMb29wc19PUl9hbGxBbmNob3JCYWNrZ3JvdW5kX2F0YWNcXClcbiMgaGVpZ2h0IDwtM1xuIyB3aWR0aCA8LSAyXG4jIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG4jIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5cblxuYGBgXG5gYGAifQ== -->

```r
```r
# RUNNING LOLA
lolaDir <- here(\../../result/lola\)
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv\), sep = \\t\)

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv\), sep = \\t\)

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv\), sep = \\t\)



### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c(\target\, \OR_up\)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c(\target\, \OR_no\)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c(\target\, \OR_down\)


temp <- full_join(full_join(temp.up, temp.no, by = c(\target\)), temp.down, by = c(\target\)) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 4,                        # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)

fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_allLoops_allAnchorBackground_atac\)
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


############
# 
# ### Visualizing p-value and OR
# alpha <- 0.05
# tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \UP\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \NO\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv\)) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = \DOWN\) %>%
#   filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# 
# temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
# temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
# temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)
# 
# temp <- bind_rows(temp.up, temp.down)
# 
# order <- c((temp %>% dplyr::filter(group == \UP\) %>% arrange(desc(oddsRatio)))$target, 
#            (temp %>% dplyr::filter(group == \DOWN\) %>% arrange(desc(oddsRatio)))$target)
# temp$target <- factor(temp$target, levels = rev(order))
# p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
#   geom_point() + theme_bw() + scale_color_gradient(low = \blue\, high = \red\) +
#   labs(x = NULL, y = NULL)  +   scale_size_continuous(range = c(1, 3)) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_allLoops_OR_allAnchorBackground_atac\)
# height <-3
# width <- 2
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
# print(p)
# dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### dTAG, obsexp

##### - Limited to ATAC-seq signal, all loop backgroup

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZWFJoWXlBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYQ0pIVTAwek1UQTJNalUzWDBGVVFVTmZSVk5EWHpFdVltVmtYQ0lwS1NBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoV01Td2dWaklzSUZZektWeHVZMjlzYm1GdFpYTW9ZWFJoWXlrZ1BDMGdZeWhjSW1Ob2Nsd2lMQ0JjSW5OMFlYSjBYQ0lzSUZ3aVpXNWtYQ0lwWEc1aGRHRmpMbWR5SUR3dElHMWhhMlZIVW1GdVoyVnpSbkp2YlVSaGRHRkdjbUZ0WlNoaGRHRmpLVnh1WEc0aklFeFBRVVJKVGtjZ1RFOVBVRk5jYmlNakl5QkpiWEJ2Y25ScGJtY2daR2xtWm1WeVpXNTBhV0ZzSUhKbFozVnNZWFJ2Y25rZ2JHOXZjSE1nSmlCbGVIUnlZV04wSUdGdVkyaHZjbHh1Ykc5dmNDNWhiR3dnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVM1MGMzWmNJaWtwSUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0VGdWJtOHlJQ1ZwYmlVZ1l5aGNJbEF0VUZ3aUxDQmNJbEF0UlZ3aUxDQmNJa1V0UlZ3aUtTbGNibUZ1WTJodmNpNWhiR3dnUEMwZ0tHVjRkSEpoWTNSQmJtTm9iM0lvYkc5dmNDNWhiR3dwS1Z4dWIzWmxjbXhoY0hNZ1BDMGdabWx1WkU5MlpYSnNZWEJ6S0dGdVkyaHZjaTVoYkd3c0lHRjBZV011WjNJcFhHNWhibU5vYjNJdVlXeHNJRHd0SUhCcGJuUmxjbk5sWTNRb1lXNWphRzl5TG1Gc2JGdHhkV1Z5ZVVocGRITW9iM1psY214aGNITXBYU3dnWVhSaFl5NW5jbHR6ZFdKcVpXTjBTR2wwY3lodmRtVnliR0Z3Y3lsZEtWeHVYRzVjYm14dmIzQXVkWEFnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5c2IyZFBSVjl3WlMxd1pWOWtWRUZIZG5ORVRWTlBYMVZRWDJScFptWXdMalV1WW1Wa2NHVmNJaWtwWEc1aGJtTm9iM0l1ZFhBZ1BDMGdLR1Y0ZEhKaFkzUkJibU5vYjNJb2JHOXZjQzUxY0NrcFhHNXZkbVZ5YkdGd2N5QThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG5Wd0xDQmhkR0ZqTG1keUtWeHVZVzVqYUc5eUxuVndJRHd0SUhCcGJuUmxjbk5sWTNRb1lXNWphRzl5TG5Wd1czRjFaWEo1U0dsMGN5aHZkbVZ5YkdGd2N5bGRMQ0JoZEdGakxtZHlXM04xWW1wbFkzUklhWFJ6S0c5MlpYSnNZWEJ6S1YwcFhHNWNibXh2YjNBdWJtOGdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRndpWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lVjlzYjJkUFJWOXdaUzF3WlY5a1ZFRkhkbk5FVFZOUFgwNVBYMlJwWm1Zd0xqVXVZbVZrY0dWY0lpa3BYRzVoYm1Ob2IzSXVibThnUEMwZ0tHVjRkSEpoWTNSQmJtTm9iM0lvYkc5dmNDNXVieWtwWEc1dmRtVnliR0Z3Y3lBOExTQm1hVzVrVDNabGNteGhjSE1vWVc1amFHOXlMbTV2TENCaGRHRmpMbWR5S1Z4dVlXNWphRzl5TG01dklEd3RJSEJwYm5SbGNuTmxZM1FvWVc1amFHOXlMbTV2VzNGMVpYSjVTR2wwY3lodmRtVnliR0Z3Y3lsZExDQmhkR0ZqTG1keVczTjFZbXBsWTNSSWFYUnpLRzkyWlhKc1lYQnpLVjBwWEc1Y2JseHViRzl2Y0M1a2IzZHVJRHd0SUdaeVpXRmtLR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0JjSW1Ob2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxmYkc5blQwVmZjR1V0Y0dWZlpGUkJSM1p6UkUxVFQxOUVUMWRPWDJScFptWXdMalV1WW1Wa2NHVmNJaWtwWEc1aGJtTm9iM0l1Wkc5M2JpQThMU0FvWlhoMGNtRmpkRUZ1WTJodmNpaHNiMjl3TG1SdmQyNHBLVnh1YjNabGNteGhjSE1nUEMwZ1ptbHVaRTkyWlhKc1lYQnpLR0Z1WTJodmNpNWtiM2R1TENCaGRHRmpMbWR5S1Z4dVlXNWphRzl5TG1SdmQyNGdQQzBnY0dsdWRHVnljMlZqZENoaGJtTm9iM0l1Wkc5M2JsdHhkV1Z5ZVVocGRITW9iM1psY214aGNITXBYU3dnWVhSaFl5NW5jbHR6ZFdKcVpXTjBTR2wwY3lodmRtVnliR0Z3Y3lsZEtWeHVYRzVjYmx4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG5hdGFjIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXEdTTTMxMDYyNTdfQVRBQ19FU0NfMS5iZWRcXCkpICU+JSBkcGx5cjo6c2VsZWN0KFYxLCBWMiwgVjMpXG5jb2xuYW1lcyhhdGFjKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbmF0YWMuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGF0YWMpXG5cbiMgTE9BRElORyBMT09QU1xuIyMjIEltcG9ydGluZyBkaWZmZXJlbnRpYWwgcmVndWxhdG9yeSBsb29wcyAmIGV4dHJhY3QgYW5jaG9yXG5sb29wLmFsbCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5LnRzdlxcKSkgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpKVxuYW5jaG9yLmFsbCA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmFsbCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmFsbCwgYXRhYy5ncilcbmFuY2hvci5hbGwgPC0gcGludGVyc2VjdChhbmNob3IuYWxsW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2xvZ09FX3BlLXBlX2RUQUd2c0RNU09fVVBfZGlmZjAuNS5iZWRwZVxcKSlcbmFuY2hvci51cCA8LSAoZXh0cmFjdEFuY2hvcihsb29wLnVwKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IudXAsIGF0YWMuZ3IpXG5hbmNob3IudXAgPC0gcGludGVyc2VjdChhbmNob3IudXBbcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2xvZ09FX3BlLXBlX2RUQUd2c0RNU09fTk9fZGlmZjAuNS5iZWRwZVxcKSlcbmFuY2hvci5ubyA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3Iubm8sIGF0YWMuZ3IpXG5hbmNob3Iubm8gPC0gcGludGVyc2VjdChhbmNob3Iubm9bcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxuXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9sb2dPRV9wZS1wZV9kVEFHdnNETVNPX0RPV05fZGlmZjAuNS5iZWRwZVxcKSlcbmFuY2hvci5kb3duIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuZG93bikpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmRvd24sIGF0YWMuZ3IpXG5hbmNob3IuZG93biA8LSBwaW50ZXJzZWN0KGFuY2hvci5kb3duW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cblxuXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\)) %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_logOE_pe-pe_dTAGvsDMSO_UP_diff0.5.bedpe\))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_logOE_pe-pe_dTAGvsDMSO_NO_diff0.5.bedpe\))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_logOE_pe-pe_dTAGvsDMSO_DOWN_diff0.5.bedpe\))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVlYUmhZeUE4TFNCbWNtVmhaQ2hvWlhKbEtISmxaa1JwY2l3Z1hGeEhVMDB6TVRBMk1qVTNYMEZVUVVOZlJWTkRYekV1WW1Wa1hGd3BLU0FsUGlVZ1pIQnNlWEk2T25ObGJHVmpkQ2hXTVN3Z1ZqSXNJRll6S1Z4dVkyOXNibUZ0WlhNb1lYUmhZeWtnUEMwZ1l5aGNYR05vY2x4Y0xDQmNYSE4wWVhKMFhGd3NJRnhjWlc1a1hGd3BYRzVoZEdGakxtZHlJRHd0SUcxaGEyVkhVbUZ1WjJWelJuSnZiVVJoZEdGR2NtRnRaU2hoZEdGaktWeHVYRzRqSUV4UFFVUkpUa2NnVEU5UFVGTmNiaU1qSXlCSmJYQnZjblJwYm1jZ1pHbG1abVZ5Wlc1MGFXRnNJSEpsWjNWc1lYUnZjbmtnYkc5dmNITWdKaUJsZUhSeVlXTjBJR0Z1WTJodmNseHViRzl2Y0M1aGJHd2dQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lUzUwYzNaY1hDa3BJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRUZ1Ym04eUlDVnBiaVVnWXloY1hGQXRVRnhjTENCY1hGQXRSVnhjTENCY1hFVXRSVnhjS1NsY2JtRnVZMmh2Y2k1aGJHd2dQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1aGJHd3BLVnh1YjNabGNteGhjSE1nUEMwZ1ptbHVaRTkyWlhKc1lYQnpLR0Z1WTJodmNpNWhiR3dzSUdGMFlXTXVaM0lwWEc1aGJtTm9iM0l1WVd4c0lEd3RJSEJwYm5SbGNuTmxZM1FvWVc1amFHOXlMbUZzYkZ0eGRXVnllVWhwZEhNb2IzWmxjbXhoY0hNcFhTd2dZWFJoWXk1bmNsdHpkV0pxWldOMFNHbDBjeWh2ZG1WeWJHRndjeWxkS1Z4dVhHNWNibXh2YjNBdWRYQWdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lVjlzYjJkUFJWOXdaUzF3WlY5a1ZFRkhkbk5FVFZOUFgxVlFYMlJwWm1Zd0xqVXVZbVZrY0dWY1hDa3BYRzVoYm1Ob2IzSXVkWEFnUEMwZ0tHVjRkSEpoWTNSQmJtTm9iM0lvYkc5dmNDNTFjQ2twWEc1dmRtVnliR0Z3Y3lBOExTQm1hVzVrVDNabGNteGhjSE1vWVc1amFHOXlMblZ3TENCaGRHRmpMbWR5S1Z4dVlXNWphRzl5TG5Wd0lEd3RJSEJwYm5SbGNuTmxZM1FvWVc1amFHOXlMblZ3VzNGMVpYSjVTR2wwY3lodmRtVnliR0Z3Y3lsZExDQmhkR0ZqTG1keVczTjFZbXBsWTNSSWFYUnpLRzkyWlhKc1lYQnpLVjBwWEc1Y2JteHZiM0F1Ym04Z1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGeGNZMmh5YjIxdlgyTnZibk5mWVc1dWIwaHBaWEpoY21Ob2VWOXNiMmRQUlY5d1pTMXdaVjlrVkVGSGRuTkVUVk5QWDA1UFgyUnBabVl3TGpVdVltVmtjR1ZjWENrcFhHNWhibU5vYjNJdWJtOGdQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1dWJ5a3BYRzV2ZG1WeWJHRndjeUE4TFNCbWFXNWtUM1psY214aGNITW9ZVzVqYUc5eUxtNXZMQ0JoZEdGakxtZHlLVnh1WVc1amFHOXlMbTV2SUR3dElIQnBiblJsY25ObFkzUW9ZVzVqYUc5eUxtNXZXM0YxWlhKNVNHbDBjeWh2ZG1WeWJHRndjeWxkTENCaGRHRmpMbWR5VzNOMVltcGxZM1JJYVhSektHOTJaWEpzWVhCektWMHBYRzVjYmx4dWJHOXZjQzVrYjNkdUlEd3RJR1p5WldGa0tHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQmNYR05vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGZiRzluVDBWZmNHVXRjR1ZmWkZSQlIzWnpSRTFUVDE5RVQxZE9YMlJwWm1Zd0xqVXVZbVZrY0dWY1hDa3BYRzVoYm1Ob2IzSXVaRzkzYmlBOExTQW9aWGgwY21GamRFRnVZMmh2Y2loc2IyOXdMbVJ2ZDI0cEtWeHViM1psY214aGNITWdQQzBnWm1sdVpFOTJaWEpzWVhCektHRnVZMmh2Y2k1a2IzZHVMQ0JoZEdGakxtZHlLVnh1WVc1amFHOXlMbVJ2ZDI0Z1BDMGdjR2x1ZEdWeWMyVmpkQ2hoYm1Ob2IzSXVaRzkzYmx0eGRXVnllVWhwZEhNb2IzWmxjbXhoY0hNcFhTd2dZWFJoWXk1bmNsdHpkV0pxWldOMFNHbDBjeWh2ZG1WeWJHRndjeWxkS1Z4dVhHNWNibHh1WUdCZ1hHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSlcbmFuY2hvci5hbGwgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5hbGwpKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5hbGwsIGF0YWMuZ3IpXG5hbmNob3IuYWxsIDwtIHBpbnRlcnNlY3QoYW5jaG9yLmFsbFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9sb2dPRV9wZS1wZV9kVEFHdnNETVNPX1VQX2RpZmYwLjUuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwLCBhdGFjLmdyKVxuYW5jaG9yLnVwIDwtIHBpbnRlcnNlY3QoYW5jaG9yLnVwW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9sb2dPRV9wZS1wZV9kVEFHdnNETVNPX05PX2RpZmYwLjUuYmVkcGVcXCkpXG5hbmNob3Iubm8gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5ubykpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLm5vLCBhdGFjLmdyKVxuYW5jaG9yLm5vIDwtIHBpbnRlcnNlY3QoYW5jaG9yLm5vW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cblxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfbG9nT0VfcGUtcGVfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjUuYmVkcGVcXCkpXG5hbmNob3IuZG93biA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5kb3duLCBhdGFjLmdyKVxuYW5jaG9yLmRvd24gPC0gcGludGVyc2VjdChhbmNob3IuZG93bltxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cblxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSlcbmFuY2hvci5hbGwgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5hbGwpKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5hbGwsIGF0YWMuZ3IpXG5hbmNob3IuYWxsIDwtIHBpbnRlcnNlY3QoYW5jaG9yLmFsbFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9sb2dPRV9wZS1wZV9kVEFHdnNETVNPX1VQX2RpZmYwLjUuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwLCBhdGFjLmdyKVxuYW5jaG9yLnVwIDwtIHBpbnRlcnNlY3QoYW5jaG9yLnVwW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9sb2dPRV9wZS1wZV9kVEFHdnNETVNPX05PX2RpZmYwLjUuYmVkcGVcXCkpXG5hbmNob3Iubm8gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5ubykpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLm5vLCBhdGFjLmdyKVxuYW5jaG9yLm5vIDwtIHBpbnRlcnNlY3QoYW5jaG9yLm5vW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cblxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfbG9nT0VfcGUtcGVfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjUuYmVkcGVcXCkpXG5hbmNob3IuZG93biA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5kb3duLCBhdGFjLmdyKVxuYW5jaG9yLmRvd24gPC0gcGludGVyc2VjdChhbmNob3IuZG93bltxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cblxuYGBgXG5gYGAifQ== -->

```r
```r
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\)) %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_logOE_pe-pe_dTAGvsDMSO_UP_diff0.5.bedpe\))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_logOE_pe-pe_dTAGvsDMSO_NO_diff0.5.bedpe\))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_logOE_pe-pe_dTAGvsDMSO_DOWN_diff0.5.bedpe\))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n# RUNNING LOLA\nlolaDir <- here(\"../../result/lola\")\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \"LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\"), sep = \"\\t\")\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \"LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\"), sep = \"\\t\")\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \"LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\"), sep = \"\\t\")\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\"target\", \"OR_up\")\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\"target\", \"OR_no\")\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\"target\", \"OR_down\")\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\"target\")), temp.down, by = c(\"target\")) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\"white\", \"red\"))\n\n\n#fviz_nbclust(data, kmeans, method = \"wss\")\n\np <- Heatmap(\n  data,\n  name = \"Odds Ratio\",                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)\n  show_row_dend = FALSE,\n  col = col_fun                       # Use the red gradient color scale\n)\n\nfileName <- paste0(\"anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_pe-peLoops_regAnchorBackground_atac\")\nheight <- 7\nwidth <- 3.5\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \"UP\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \"NO\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \"LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\")) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \"DOWN\") %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.up, temp.down)\n\norder <- c((temp %>% dplyr::filter(group == \"UP\") %>% arrange(desc(oddsRatio)))$target, \n           (temp %>% dplyr::filter(group == \"DOWN\") %>% arrange(desc(oddsRatio)))$target)\ntemp$target <- factor(temp$target, levels = rev(order))\np <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n  geom_point() + theme_bw() + scale_color_gradient(low = \"blue\", high = \"red\") +\n  labs(x = NULL, y = NULL)  +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\nfileName <- paste0(\"anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac\")\nheight <-3\nwidth <- 2\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n\n### 241015 Testing on subset of loops\nanchor.c1 <- extractAnchor(loop.cluster1)\noverlaps <- findOverlaps(anchor.c1, atac.gr)\nanchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c2 <- extractAnchor(loop.cluster2)\noverlaps <- findOverlaps(anchor.c2, atac.gr)\nanchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c3 <- extractAnchor(loop.cluster3)\noverlaps <- findOverlaps(anchor.c3, atac.gr)\nanchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c4 <- extractAnchor(loop.cluster4)\noverlaps <- findOverlaps(anchor.c4, atac.gr)\nanchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c5 <- extractAnchor(loop.cluster5)\noverlaps <- findOverlaps(anchor.c5, atac.gr)\nanchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c6 <- extractAnchor(loop.cluster6)\noverlaps <- findOverlaps(anchor.c6, atac.gr)\nanchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c7 <- extractAnchor(loop.cluster7)\noverlaps <- findOverlaps(anchor.c7, atac.gr)\nanchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c8 <- extractAnchor(loop.cluster8)\noverlaps <- findOverlaps(anchor.c8, atac.gr)\nanchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nresult = runLOLA(anchor.c1, anchor.all, lolaDB)\ntb.c1 = as_tibble(result)\n\nresult = runLOLA(anchor.c2, anchor.all, lolaDB)\ntb.c2 = as_tibble(result)\n\nresult = runLOLA(anchor.c3, anchor.all, lolaDB)\ntb.c3 = as_tibble(result)\n\nresult = runLOLA(anchor.c4, anchor.all, lolaDB)\ntb.c4 = as_tibble(result)\nresult = runLOLA(anchor.c5, anchor.all, lolaDB)\ntb.c5 = as_tibble(result)\n\nresult = runLOLA(anchor.c6, anchor.all, lolaDB)\ntb.c6 = as_tibble(result)\n\nresult = runLOLA(anchor.c7, anchor.all, lolaDB)\ntb.c7 = as_tibble(result)\n\nresult = runLOLA(anchor.c8, anchor.all, lolaDB)\ntb.c8 = as_tibble(result)\n\n### HEATMAP\nalpha <- 0.05\ntb.c1 <- tb.c1 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c2 <- tb.c2 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c3 <- tb.c3 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c4 <- tb.c4 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c5 <- tb.c5 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c6 <- tb.c6 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c7 <- tb.c7 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c8 <- tb.c8 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c1) <- c(\"target\", \"OR_c1\")\ntemp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c2) <- c(\"target\", \"OR_c2\")\ntemp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c3) <- c(\"target\", \"OR_c3\")\ntemp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c4) <- c(\"target\", \"OR_c4\")\ntemp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c5) <- c(\"target\", \"OR_c5\")\ntemp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c6) <- c(\"target\", \"OR_c6\")\ntemp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c7) <- c(\"target\", \"OR_c7\")\ntemp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c8) <- c(\"target\", \"OR_c8\")\n\ntemp <- full_join(temp.c1, temp.c2, by = \"target\") %>%\n  full_join(temp.c3, by = \"target\") %>%\n  full_join(temp.c4, by = \"target\") %>%\n  full_join(temp.c5, by = \"target\") %>%\n  full_join(temp.c6, by = \"target\") %>%\n  full_join(temp.c7, by = \"target\") %>%\n  full_join(temp.c8, by = \"target\") %>%\n  mutate_all(~replace_na(., 1))\n\ndata <- temp %>% column_to_rownames(\"target\") %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\"white\", \"red\"))\n\n\n#fviz_nbclust(data, kmeans, method = \"wss\")\n\np <- Heatmap(\n  data,\n  name = \"Odds Ratio\",                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\n\n# Initialize lists to store results\nanchors <- list()\ntbs <- list()\ntemps <- list()\n\n# Process clusters c1 to c8\nfor (i in 1:4) {\n  # Extract anchor\n  loop_cluster <- get(paste0(\"loop.cluster\", i))\n  anchor <- extractAnchor(loop_cluster)\n  \n  # Find overlaps and intersect\n  overlaps <- findOverlaps(anchor, atac.gr)\n  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n  \n  # Store anchor\n  anchors[[i]] <- anchor\n  \n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\"target\", paste0(\"OR_c\", i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \"target\"), temps) %>%\n  mutate_all(~replace_na(., 1))\ndata <- temp %>% column_to_rownames(\"target\") %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\"white\", \"red\"))\n\n\n#fviz_nbclust(data, kmeans, method = \"wss\")\n\np <- Heatmap(\n  data,\n  name = \"Odds Ratio\",                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```"} -->\n\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\\), sep = \\\\t\\)\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)\n  show_row_dend = FALSE,\n  col = col_fun                       # Use the red gradient color scale\n)\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_pe-peLoops_regAnchorBackground_atac\\)\nheight <- 7\nwidth <- 3.5\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\UP\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.up, temp.down)\n\norder <- c((temp %>% dplyr::filter(group == \\UP\\) %>% arrange(desc(oddsRatio)))$target, \n           (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\ntemp$target <- factor(temp$target, levels = rev(order))\np <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n  geom_point() + theme_bw() + scale_color_gradient(low = \\blue\\, high = \\red\\) +\n  labs(x = NULL, y = NULL)  +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac\\)\nheight <-3\nwidth <- 2\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n\n### 241015 Testing on subset of loops\nanchor.c1 <- extractAnchor(loop.cluster1)\noverlaps <- findOverlaps(anchor.c1, atac.gr)\nanchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c2 <- extractAnchor(loop.cluster2)\noverlaps <- findOverlaps(anchor.c2, atac.gr)\nanchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c3 <- extractAnchor(loop.cluster3)\noverlaps <- findOverlaps(anchor.c3, atac.gr)\nanchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c4 <- extractAnchor(loop.cluster4)\noverlaps <- findOverlaps(anchor.c4, atac.gr)\nanchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c5 <- extractAnchor(loop.cluster5)\noverlaps <- findOverlaps(anchor.c5, atac.gr)\nanchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c6 <- extractAnchor(loop.cluster6)\noverlaps <- findOverlaps(anchor.c6, atac.gr)\nanchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c7 <- extractAnchor(loop.cluster7)\noverlaps <- findOverlaps(anchor.c7, atac.gr)\nanchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c8 <- extractAnchor(loop.cluster8)\noverlaps <- findOverlaps(anchor.c8, atac.gr)\nanchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nresult = runLOLA(anchor.c1, anchor.all, lolaDB)\ntb.c1 = as_tibble(result)\n\nresult = runLOLA(anchor.c2, anchor.all, lolaDB)\ntb.c2 = as_tibble(result)\n\nresult = runLOLA(anchor.c3, anchor.all, lolaDB)\ntb.c3 = as_tibble(result)\n\nresult = runLOLA(anchor.c4, anchor.all, lolaDB)\ntb.c4 = as_tibble(result)\nresult = runLOLA(anchor.c5, anchor.all, lolaDB)\ntb.c5 = as_tibble(result)\n\nresult = runLOLA(anchor.c6, anchor.all, lolaDB)\ntb.c6 = as_tibble(result)\n\nresult = runLOLA(anchor.c7, anchor.all, lolaDB)\ntb.c7 = as_tibble(result)\n\nresult = runLOLA(anchor.c8, anchor.all, lolaDB)\ntb.c8 = as_tibble(result)\n\n### HEATMAP\nalpha <- 0.05\ntb.c1 <- tb.c1 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c2 <- tb.c2 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c3 <- tb.c3 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c4 <- tb.c4 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c5 <- tb.c5 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c6 <- tb.c6 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c7 <- tb.c7 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c8 <- tb.c8 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c1) <- c(\\target\\, \\OR_c1\\)\ntemp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c2) <- c(\\target\\, \\OR_c2\\)\ntemp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c3) <- c(\\target\\, \\OR_c3\\)\ntemp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c4) <- c(\\target\\, \\OR_c4\\)\ntemp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c5) <- c(\\target\\, \\OR_c5\\)\ntemp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c6) <- c(\\target\\, \\OR_c6\\)\ntemp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c7) <- c(\\target\\, \\OR_c7\\)\ntemp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c8) <- c(\\target\\, \\OR_c8\\)\n\ntemp <- full_join(temp.c1, temp.c2, by = \\target\\) %>%\n  full_join(temp.c3, by = \\target\\) %>%\n  full_join(temp.c4, by = \\target\\) %>%\n  full_join(temp.c5, by = \\target\\) %>%\n  full_join(temp.c6, by = \\target\\) %>%\n  full_join(temp.c7, by = \\target\\) %>%\n  full_join(temp.c8, by = \\target\\) %>%\n  mutate_all(~replace_na(., 1))\n\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\n\n# Initialize lists to store results\nanchors <- list()\ntbs <- list()\ntemps <- list()\n\n# Process clusters c1 to c8\nfor (i in 1:4) {\n  # Extract anchor\n  loop_cluster <- get(paste0(\\loop.cluster\\, i))\n  anchor <- extractAnchor(loop_cluster)\n  \n  # Find overlaps and intersect\n  overlaps <- findOverlaps(anchor, atac.gr)\n  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n  \n  # Store anchor\n  anchors[[i]] <- anchor\n  \n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```\n\n<!-- rnb-source-end -->\n"} -->
# RUNNING LOLA
lolaDir <- here(\../../result/lola\)
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\), sep = \\t\)

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\), sep = \\t\)

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\), sep = \\t\)


### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c(\target\, \OR_up\)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c(\target\, \OR_no\)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c(\target\, \OR_down\)


temp <- full_join(full_join(temp.up, temp.no, by = c(\target\)), temp.down, by = c(\target\)) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun                       # Use the red gradient color scale
)

fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_pe-peLoops_regAnchorBackground_atac\)
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



### Visualizing p-value and OR
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \UP\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \NO\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \DOWN\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.up, temp.down)

order <- c((temp %>% dplyr::filter(group == \UP\) %>% arrange(desc(oddsRatio)))$target, 
           (temp %>% dplyr::filter(group == \DOWN\) %>% arrange(desc(oddsRatio)))$target)
temp$target <- factor(temp$target, levels = rev(order))
p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
  geom_point() + theme_bw() + scale_color_gradient(low = \blue\, high = \red\) +
  labs(x = NULL, y = NULL)  +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac\)
height <-3
width <- 2
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()





### 241015 Testing on subset of loops
anchor.c1 <- extractAnchor(loop.cluster1)
overlaps <- findOverlaps(anchor.c1, atac.gr)
anchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c2 <- extractAnchor(loop.cluster2)
overlaps <- findOverlaps(anchor.c2, atac.gr)
anchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c3 <- extractAnchor(loop.cluster3)
overlaps <- findOverlaps(anchor.c3, atac.gr)
anchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c4 <- extractAnchor(loop.cluster4)
overlaps <- findOverlaps(anchor.c4, atac.gr)
anchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c5 <- extractAnchor(loop.cluster5)
overlaps <- findOverlaps(anchor.c5, atac.gr)
anchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c6 <- extractAnchor(loop.cluster6)
overlaps <- findOverlaps(anchor.c6, atac.gr)
anchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c7 <- extractAnchor(loop.cluster7)
overlaps <- findOverlaps(anchor.c7, atac.gr)
anchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c8 <- extractAnchor(loop.cluster8)
overlaps <- findOverlaps(anchor.c8, atac.gr)
anchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

result = runLOLA(anchor.c1, anchor.all, lolaDB)
tb.c1 = as_tibble(result)

result = runLOLA(anchor.c2, anchor.all, lolaDB)
tb.c2 = as_tibble(result)

result = runLOLA(anchor.c3, anchor.all, lolaDB)
tb.c3 = as_tibble(result)

result = runLOLA(anchor.c4, anchor.all, lolaDB)
tb.c4 = as_tibble(result)
result = runLOLA(anchor.c5, anchor.all, lolaDB)
tb.c5 = as_tibble(result)

result = runLOLA(anchor.c6, anchor.all, lolaDB)
tb.c6 = as_tibble(result)

result = runLOLA(anchor.c7, anchor.all, lolaDB)
tb.c7 = as_tibble(result)

result = runLOLA(anchor.c8, anchor.all, lolaDB)
tb.c8 = as_tibble(result)

### HEATMAP
alpha <- 0.05
tb.c1 <- tb.c1 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c2 <- tb.c2 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c3 <- tb.c3 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c4 <- tb.c4 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c5 <- tb.c5 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c6 <- tb.c6 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c7 <- tb.c7 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c8 <- tb.c8 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)
colnames(temp.c1) <- c(\target\, \OR_c1\)
temp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)
colnames(temp.c2) <- c(\target\, \OR_c2\)
temp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)
colnames(temp.c3) <- c(\target\, \OR_c3\)
temp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)
colnames(temp.c4) <- c(\target\, \OR_c4\)
temp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)
colnames(temp.c5) <- c(\target\, \OR_c5\)
temp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)
colnames(temp.c6) <- c(\target\, \OR_c6\)
temp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)
colnames(temp.c7) <- c(\target\, \OR_c7\)
temp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)
colnames(temp.c8) <- c(\target\, \OR_c8\)

temp <- full_join(temp.c1, temp.c2, by = \target\) %>%
  full_join(temp.c3, by = \target\) %>%
  full_join(temp.c4, by = \target\) %>%
  full_join(temp.c5, by = \target\) %>%
  full_join(temp.c6, by = \target\) %>%
  full_join(temp.c7, by = \target\) %>%
  full_join(temp.c8, by = \target\) %>%
  mutate_all(~replace_na(., 1))

data <- temp %>% column_to_rownames(\target\) %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)


# Initialize lists to store results
anchors <- list()
tbs <- list()
temps <- list()

# Process clusters c1 to c8
for (i in 1:4) {
  # Extract anchor
  loop_cluster <- get(paste0(\loop.cluster\, i))
  anchor <- extractAnchor(loop_cluster)
  
  # Find overlaps and intersect
  overlaps <- findOverlaps(anchor, atac.gr)
  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
  
  # Store anchor
  anchors[[i]] <- anchor
  
  # Run LOLA
  result <- runLOLA(anchor, anchor.all, lolaDB)
  tb <- as_tibble(result)
  
  # Filter and summarize
  tb <- tb %>%
    dplyr::mutate(target = toupper(antibody)) %>%
    filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
    dplyr::filter(qValue < alpha) %>%
    dplyr::group_by(target) %>%
    slice_min(meanRnk, with_ties = FALSE)
  
  # Store tb
  tbs[[i]] <- tb
  
  # Select and rename oddsRatio
  temp <- tb %>% dplyr::select(target, oddsRatio)
  colnames(temp) <- c(\target\, paste0(\OR_c\, i))
  
  # Store temp
  temps[[i]] <- temp
}

# Merge all temp tables into one
temp <- Reduce(function(x, y) full_join(x, y, by = \target\), temps) %>%
  mutate_all(~replace_na(., 1))
data <- temp %>% column_to_rownames(\target\) %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\\), sep = \\\\t\\)\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)\n  show_row_dend = FALSE,\n  col = col_fun                       # Use the red gradient color scale\n)\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_pe-peLoops_regAnchorBackground_atac\\)\nheight <- 7\nwidth <- 3.5\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\UP\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.up, temp.down)\n\norder <- c((temp %>% dplyr::filter(group == \\UP\\) %>% arrange(desc(oddsRatio)))$target, \n           (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\ntemp$target <- factor(temp$target, levels = rev(order))\np <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n  geom_point() + theme_bw() + scale_color_gradient(low = \\blue\\, high = \\red\\) +\n  labs(x = NULL, y = NULL)  +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac\\)\nheight <-3\nwidth <- 2\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n\n### 241015 Testing on subset of loops\nanchor.c1 <- extractAnchor(loop.cluster1)\noverlaps <- findOverlaps(anchor.c1, atac.gr)\nanchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c2 <- extractAnchor(loop.cluster2)\noverlaps <- findOverlaps(anchor.c2, atac.gr)\nanchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c3 <- extractAnchor(loop.cluster3)\noverlaps <- findOverlaps(anchor.c3, atac.gr)\nanchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c4 <- extractAnchor(loop.cluster4)\noverlaps <- findOverlaps(anchor.c4, atac.gr)\nanchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c5 <- extractAnchor(loop.cluster5)\noverlaps <- findOverlaps(anchor.c5, atac.gr)\nanchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c6 <- extractAnchor(loop.cluster6)\noverlaps <- findOverlaps(anchor.c6, atac.gr)\nanchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c7 <- extractAnchor(loop.cluster7)\noverlaps <- findOverlaps(anchor.c7, atac.gr)\nanchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c8 <- extractAnchor(loop.cluster8)\noverlaps <- findOverlaps(anchor.c8, atac.gr)\nanchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nresult = runLOLA(anchor.c1, anchor.all, lolaDB)\ntb.c1 = as_tibble(result)\n\nresult = runLOLA(anchor.c2, anchor.all, lolaDB)\ntb.c2 = as_tibble(result)\n\nresult = runLOLA(anchor.c3, anchor.all, lolaDB)\ntb.c3 = as_tibble(result)\n\nresult = runLOLA(anchor.c4, anchor.all, lolaDB)\ntb.c4 = as_tibble(result)\nresult = runLOLA(anchor.c5, anchor.all, lolaDB)\ntb.c5 = as_tibble(result)\n\nresult = runLOLA(anchor.c6, anchor.all, lolaDB)\ntb.c6 = as_tibble(result)\n\nresult = runLOLA(anchor.c7, anchor.all, lolaDB)\ntb.c7 = as_tibble(result)\n\nresult = runLOLA(anchor.c8, anchor.all, lolaDB)\ntb.c8 = as_tibble(result)\n\n### HEATMAP\nalpha <- 0.05\ntb.c1 <- tb.c1 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c2 <- tb.c2 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c3 <- tb.c3 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c4 <- tb.c4 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c5 <- tb.c5 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c6 <- tb.c6 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c7 <- tb.c7 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c8 <- tb.c8 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c1) <- c(\\target\\, \\OR_c1\\)\ntemp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c2) <- c(\\target\\, \\OR_c2\\)\ntemp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c3) <- c(\\target\\, \\OR_c3\\)\ntemp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c4) <- c(\\target\\, \\OR_c4\\)\ntemp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c5) <- c(\\target\\, \\OR_c5\\)\ntemp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c6) <- c(\\target\\, \\OR_c6\\)\ntemp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c7) <- c(\\target\\, \\OR_c7\\)\ntemp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c8) <- c(\\target\\, \\OR_c8\\)\n\ntemp <- full_join(temp.c1, temp.c2, by = \\target\\) %>%\n  full_join(temp.c3, by = \\target\\) %>%\n  full_join(temp.c4, by = \\target\\) %>%\n  full_join(temp.c5, by = \\target\\) %>%\n  full_join(temp.c6, by = \\target\\) %>%\n  full_join(temp.c7, by = \\target\\) %>%\n  full_join(temp.c8, by = \\target\\) %>%\n  mutate_all(~replace_na(., 1))\n\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\n\n# Initialize lists to store results\nanchors <- list()\ntbs <- list()\ntemps <- list()\n\n# Process clusters c1 to c8\nfor (i in 1:4) {\n  # Extract anchor\n  loop_cluster <- get(paste0(\\loop.cluster\\, i))\n  anchor <- extractAnchor(loop_cluster)\n  \n  # Find overlaps and intersect\n  overlaps <- findOverlaps(anchor, atac.gr)\n  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n  \n  # Store anchor\n  anchors[[i]] <- anchor\n  \n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```\n```"} -->\n\n```r\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\\), sep = \\\\t\\)\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)\n  show_row_dend = FALSE,\n  col = col_fun                       # Use the red gradient color scale\n)\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_pe-peLoops_regAnchorBackground_atac\\)\nheight <- 7\nwidth <- 3.5\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\UP\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.up, temp.down)\n\norder <- c((temp %>% dplyr::filter(group == \\UP\\) %>% arrange(desc(oddsRatio)))$target, \n           (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\ntemp$target <- factor(temp$target, levels = rev(order))\np <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n  geom_point() + theme_bw() + scale_color_gradient(low = \\blue\\, high = \\red\\) +\n  labs(x = NULL, y = NULL)  +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac\\)\nheight <-3\nwidth <- 2\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n\n### 241015 Testing on subset of loops\nanchor.c1 <- extractAnchor(loop.cluster1)\noverlaps <- findOverlaps(anchor.c1, atac.gr)\nanchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c2 <- extractAnchor(loop.cluster2)\noverlaps <- findOverlaps(anchor.c2, atac.gr)\nanchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c3 <- extractAnchor(loop.cluster3)\noverlaps <- findOverlaps(anchor.c3, atac.gr)\nanchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c4 <- extractAnchor(loop.cluster4)\noverlaps <- findOverlaps(anchor.c4, atac.gr)\nanchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c5 <- extractAnchor(loop.cluster5)\noverlaps <- findOverlaps(anchor.c5, atac.gr)\nanchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c6 <- extractAnchor(loop.cluster6)\noverlaps <- findOverlaps(anchor.c6, atac.gr)\nanchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c7 <- extractAnchor(loop.cluster7)\noverlaps <- findOverlaps(anchor.c7, atac.gr)\nanchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c8 <- extractAnchor(loop.cluster8)\noverlaps <- findOverlaps(anchor.c8, atac.gr)\nanchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nresult = runLOLA(anchor.c1, anchor.all, lolaDB)\ntb.c1 = as_tibble(result)\n\nresult = runLOLA(anchor.c2, anchor.all, lolaDB)\ntb.c2 = as_tibble(result)\n\nresult = runLOLA(anchor.c3, anchor.all, lolaDB)\ntb.c3 = as_tibble(result)\n\nresult = runLOLA(anchor.c4, anchor.all, lolaDB)\ntb.c4 = as_tibble(result)\nresult = runLOLA(anchor.c5, anchor.all, lolaDB)\ntb.c5 = as_tibble(result)\n\nresult = runLOLA(anchor.c6, anchor.all, lolaDB)\ntb.c6 = as_tibble(result)\n\nresult = runLOLA(anchor.c7, anchor.all, lolaDB)\ntb.c7 = as_tibble(result)\n\nresult = runLOLA(anchor.c8, anchor.all, lolaDB)\ntb.c8 = as_tibble(result)\n\n### HEATMAP\nalpha <- 0.05\ntb.c1 <- tb.c1 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c2 <- tb.c2 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c3 <- tb.c3 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c4 <- tb.c4 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c5 <- tb.c5 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c6 <- tb.c6 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c7 <- tb.c7 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c8 <- tb.c8 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c1) <- c(\\target\\, \\OR_c1\\)\ntemp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c2) <- c(\\target\\, \\OR_c2\\)\ntemp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c3) <- c(\\target\\, \\OR_c3\\)\ntemp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c4) <- c(\\target\\, \\OR_c4\\)\ntemp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c5) <- c(\\target\\, \\OR_c5\\)\ntemp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c6) <- c(\\target\\, \\OR_c6\\)\ntemp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c7) <- c(\\target\\, \\OR_c7\\)\ntemp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c8) <- c(\\target\\, \\OR_c8\\)\n\ntemp <- full_join(temp.c1, temp.c2, by = \\target\\) %>%\n  full_join(temp.c3, by = \\target\\) %>%\n  full_join(temp.c4, by = \\target\\) %>%\n  full_join(temp.c5, by = \\target\\) %>%\n  full_join(temp.c6, by = \\target\\) %>%\n  full_join(temp.c7, by = \\target\\) %>%\n  full_join(temp.c8, by = \\target\\) %>%\n  mutate_all(~replace_na(., 1))\n\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\n\n# Initialize lists to store results\nanchors <- list()\ntbs <- list()\ntemps <- list()\n\n# Process clusters c1 to c8\nfor (i in 1:4) {\n  # Extract anchor\n  loop_cluster <- get(paste0(\\loop.cluster\\, i))\n  anchor <- extractAnchor(loop_cluster)\n  \n  # Find overlaps and intersect\n  overlaps <- findOverlaps(anchor, atac.gr)\n  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n  \n  # Store anchor\n  anchors[[i]] <- anchor\n  \n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\\), sep = \\\\t\\)\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)\n  show_row_dend = FALSE,\n  col = col_fun                       # Use the red gradient color scale\n)\n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_pe-peLoops_regAnchorBackground_atac\\)\nheight <- 7\nwidth <- 3.5\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\UP\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.up, temp.down)\n\norder <- c((temp %>% dplyr::filter(group == \\UP\\) %>% arrange(desc(oddsRatio)))$target, \n           (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\ntemp$target <- factor(temp$target, levels = rev(order))\np <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n  geom_point() + theme_bw() + scale_color_gradient(low = \\blue\\, high = \\red\\) +\n  labs(x = NULL, y = NULL)  +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\nfileName <- paste0(\\anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac\\)\nheight <-3\nwidth <- 2\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n\n### 241015 Testing on subset of loops\nanchor.c1 <- extractAnchor(loop.cluster1)\noverlaps <- findOverlaps(anchor.c1, atac.gr)\nanchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c2 <- extractAnchor(loop.cluster2)\noverlaps <- findOverlaps(anchor.c2, atac.gr)\nanchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c3 <- extractAnchor(loop.cluster3)\noverlaps <- findOverlaps(anchor.c3, atac.gr)\nanchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c4 <- extractAnchor(loop.cluster4)\noverlaps <- findOverlaps(anchor.c4, atac.gr)\nanchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c5 <- extractAnchor(loop.cluster5)\noverlaps <- findOverlaps(anchor.c5, atac.gr)\nanchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c6 <- extractAnchor(loop.cluster6)\noverlaps <- findOverlaps(anchor.c6, atac.gr)\nanchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c7 <- extractAnchor(loop.cluster7)\noverlaps <- findOverlaps(anchor.c7, atac.gr)\nanchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nanchor.c8 <- extractAnchor(loop.cluster8)\noverlaps <- findOverlaps(anchor.c8, atac.gr)\nanchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\nresult = runLOLA(anchor.c1, anchor.all, lolaDB)\ntb.c1 = as_tibble(result)\n\nresult = runLOLA(anchor.c2, anchor.all, lolaDB)\ntb.c2 = as_tibble(result)\n\nresult = runLOLA(anchor.c3, anchor.all, lolaDB)\ntb.c3 = as_tibble(result)\n\nresult = runLOLA(anchor.c4, anchor.all, lolaDB)\ntb.c4 = as_tibble(result)\nresult = runLOLA(anchor.c5, anchor.all, lolaDB)\ntb.c5 = as_tibble(result)\n\nresult = runLOLA(anchor.c6, anchor.all, lolaDB)\ntb.c6 = as_tibble(result)\n\nresult = runLOLA(anchor.c7, anchor.all, lolaDB)\ntb.c7 = as_tibble(result)\n\nresult = runLOLA(anchor.c8, anchor.all, lolaDB)\ntb.c8 = as_tibble(result)\n\n### HEATMAP\nalpha <- 0.05\ntb.c1 <- tb.c1 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c2 <- tb.c2 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c3 <- tb.c3 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c4 <- tb.c4 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.c5 <- tb.c5 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c6 <- tb.c6 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c7 <- tb.c7 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntb.c8 <- tb.c8 %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>%\n  dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c1) <- c(\\target\\, \\OR_c1\\)\ntemp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c2) <- c(\\target\\, \\OR_c2\\)\ntemp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c3) <- c(\\target\\, \\OR_c3\\)\ntemp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c4) <- c(\\target\\, \\OR_c4\\)\ntemp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c5) <- c(\\target\\, \\OR_c5\\)\ntemp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c6) <- c(\\target\\, \\OR_c6\\)\ntemp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c7) <- c(\\target\\, \\OR_c7\\)\ntemp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)\ncolnames(temp.c8) <- c(\\target\\, \\OR_c8\\)\n\ntemp <- full_join(temp.c1, temp.c2, by = \\target\\) %>%\n  full_join(temp.c3, by = \\target\\) %>%\n  full_join(temp.c4, by = \\target\\) %>%\n  full_join(temp.c5, by = \\target\\) %>%\n  full_join(temp.c6, by = \\target\\) %>%\n  full_join(temp.c7, by = \\target\\) %>%\n  full_join(temp.c8, by = \\target\\) %>%\n  mutate_all(~replace_na(., 1))\n\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\n\n# Initialize lists to store results\nanchors <- list()\ntbs <- list()\ntemps <- list()\n\n# Process clusters c1 to c8\nfor (i in 1:4) {\n  # Extract anchor\n  loop_cluster <- get(paste0(\\loop.cluster\\, i))\n  anchor <- extractAnchor(loop_cluster)\n  \n  # Find overlaps and intersect\n  overlaps <- findOverlaps(anchor, atac.gr)\n  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n  \n  # Store anchor\n  anchors[[i]] <- anchor\n  \n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```\n```"} -->

```r
```r
# RUNNING LOLA
lolaDir <- here(\../../result/lola\)
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\), sep = \\t\)

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\), sep = \\t\)

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\), sep = \\t\)


### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c(\target\, \OR_up\)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c(\target\, \OR_no\)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c(\target\, \OR_down\)


temp <- full_join(full_join(temp.up, temp.no, by = c(\target\)), temp.down, by = c(\target\)) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun                       # Use the red gradient color scale
)

fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_pe-peLoops_regAnchorBackground_atac\)
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



### Visualizing p-value and OR
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \UP\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \NO\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \DOWN\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.up, temp.down)

order <- c((temp %>% dplyr::filter(group == \UP\) %>% arrange(desc(oddsRatio)))$target, 
           (temp %>% dplyr::filter(group == \DOWN\) %>% arrange(desc(oddsRatio)))$target)
temp$target <- factor(temp$target, levels = rev(order))
p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
  geom_point() + theme_bw() + scale_color_gradient(low = \blue\, high = \red\) +
  labs(x = NULL, y = NULL)  +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac\)
height <-3
width <- 2
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()





### 241015 Testing on subset of loops
anchor.c1 <- extractAnchor(loop.cluster1)
overlaps <- findOverlaps(anchor.c1, atac.gr)
anchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c2 <- extractAnchor(loop.cluster2)
overlaps <- findOverlaps(anchor.c2, atac.gr)
anchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c3 <- extractAnchor(loop.cluster3)
overlaps <- findOverlaps(anchor.c3, atac.gr)
anchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c4 <- extractAnchor(loop.cluster4)
overlaps <- findOverlaps(anchor.c4, atac.gr)
anchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c5 <- extractAnchor(loop.cluster5)
overlaps <- findOverlaps(anchor.c5, atac.gr)
anchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c6 <- extractAnchor(loop.cluster6)
overlaps <- findOverlaps(anchor.c6, atac.gr)
anchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c7 <- extractAnchor(loop.cluster7)
overlaps <- findOverlaps(anchor.c7, atac.gr)
anchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c8 <- extractAnchor(loop.cluster8)
overlaps <- findOverlaps(anchor.c8, atac.gr)
anchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

result = runLOLA(anchor.c1, anchor.all, lolaDB)
tb.c1 = as_tibble(result)

result = runLOLA(anchor.c2, anchor.all, lolaDB)
tb.c2 = as_tibble(result)

result = runLOLA(anchor.c3, anchor.all, lolaDB)
tb.c3 = as_tibble(result)

result = runLOLA(anchor.c4, anchor.all, lolaDB)
tb.c4 = as_tibble(result)
result = runLOLA(anchor.c5, anchor.all, lolaDB)
tb.c5 = as_tibble(result)

result = runLOLA(anchor.c6, anchor.all, lolaDB)
tb.c6 = as_tibble(result)

result = runLOLA(anchor.c7, anchor.all, lolaDB)
tb.c7 = as_tibble(result)

result = runLOLA(anchor.c8, anchor.all, lolaDB)
tb.c8 = as_tibble(result)

### HEATMAP
alpha <- 0.05
tb.c1 <- tb.c1 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c2 <- tb.c2 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c3 <- tb.c3 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c4 <- tb.c4 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c5 <- tb.c5 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c6 <- tb.c6 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c7 <- tb.c7 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c8 <- tb.c8 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)
colnames(temp.c1) <- c(\target\, \OR_c1\)
temp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)
colnames(temp.c2) <- c(\target\, \OR_c2\)
temp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)
colnames(temp.c3) <- c(\target\, \OR_c3\)
temp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)
colnames(temp.c4) <- c(\target\, \OR_c4\)
temp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)
colnames(temp.c5) <- c(\target\, \OR_c5\)
temp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)
colnames(temp.c6) <- c(\target\, \OR_c6\)
temp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)
colnames(temp.c7) <- c(\target\, \OR_c7\)
temp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)
colnames(temp.c8) <- c(\target\, \OR_c8\)

temp <- full_join(temp.c1, temp.c2, by = \target\) %>%
  full_join(temp.c3, by = \target\) %>%
  full_join(temp.c4, by = \target\) %>%
  full_join(temp.c5, by = \target\) %>%
  full_join(temp.c6, by = \target\) %>%
  full_join(temp.c7, by = \target\) %>%
  full_join(temp.c8, by = \target\) %>%
  mutate_all(~replace_na(., 1))

data <- temp %>% column_to_rownames(\target\) %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)


# Initialize lists to store results
anchors <- list()
tbs <- list()
temps <- list()

# Process clusters c1 to c8
for (i in 1:4) {
  # Extract anchor
  loop_cluster <- get(paste0(\loop.cluster\, i))
  anchor <- extractAnchor(loop_cluster)
  
  # Find overlaps and intersect
  overlaps <- findOverlaps(anchor, atac.gr)
  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
  
  # Store anchor
  anchors[[i]] <- anchor
  
  # Run LOLA
  result <- runLOLA(anchor, anchor.all, lolaDB)
  tb <- as_tibble(result)
  
  # Filter and summarize
  tb <- tb %>%
    dplyr::mutate(target = toupper(antibody)) %>%
    filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
    dplyr::filter(qValue < alpha) %>%
    dplyr::group_by(target) %>%
    slice_min(meanRnk, with_ties = FALSE)
  
  # Store tb
  tbs[[i]] <- tb
  
  # Select and rename oddsRatio
  temp <- tb %>% dplyr::select(target, oddsRatio)
  colnames(temp) <- c(\target\, paste0(\OR_c\, i))
  
  # Store temp
  temps[[i]] <- temp
}

# Merge all temp tables into one
temp <- Reduce(function(x, y) full_join(x, y, by = \target\), temps) %>%
  mutate_all(~replace_na(., 1))
data <- temp %>% column_to_rownames(\target\) %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Limiting to ATAC-seq signal, reg loop background

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZWFJoWXlBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYQ0pIVTAwek1UQTJNalUzWDBGVVFVTmZSVk5EWHpFdVltVmtYQ0lwS1NBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoV01Td2dWaklzSUZZektWeHVZMjlzYm1GdFpYTW9ZWFJoWXlrZ1BDMGdZeWhjSW1Ob2Nsd2lMQ0JjSW5OMFlYSjBYQ0lzSUZ3aVpXNWtYQ0lwWEc1aGRHRmpMbWR5SUR3dElHMWhhMlZIVW1GdVoyVnpSbkp2YlVSaGRHRkdjbUZ0WlNoaGRHRmpLVnh1WEc0aklFeFBRVVJKVGtjZ1RFOVBVRk5jYmlNakl5QkpiWEJ2Y25ScGJtY2daR2xtWm1WeVpXNTBhV0ZzSUhKbFozVnNZWFJ2Y25rZ2JHOXZjSE1nSmlCbGVIUnlZV04wSUdGdVkyaHZjbHh1Ykc5dmNDNWhiR3dnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVM1MGMzWmNJaWtwWEc1aGJtTm9iM0l1WVd4c0lEd3RJQ2hsZUhSeVlXTjBRVzVqYUc5eUtHeHZiM0F1WVd4c0tTbGNibTkyWlhKc1lYQnpJRHd0SUdacGJtUlBkbVZ5YkdGd2N5aGhibU5vYjNJdVlXeHNMQ0JoZEdGakxtZHlLVnh1WVc1amFHOXlMbUZzYkNBOExTQndhVzUwWlhKelpXTjBLR0Z1WTJodmNpNWhiR3hiY1hWbGNubElhWFJ6S0c5MlpYSnNZWEJ6S1Ywc0lHRjBZV011WjNKYmMzVmlhbVZqZEVocGRITW9iM1psY214aGNITXBYU2xjYmx4dWJHOXZjQzUxY0NBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z1hDSmphSEp2Ylc5ZlkyOXVjMTloYm01dlNHbGxjbUZ5WTJoNVgyRnNiRjlCTkRnMWRuTkVUVk5QWDFWUVgyUnBabVl3TGpJdVltVmtjR1ZjSWlrcFhHNWhibU5vYjNJdWRYQWdQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1MWNDa3BYRzV2ZG1WeWJHRndjeUE4TFNCbWFXNWtUM1psY214aGNITW9ZVzVqYUc5eUxuVndMQ0JoZEdGakxtZHlLVnh1WVc1amFHOXlMblZ3SUR3dElIQnBiblJsY25ObFkzUW9ZVzVqYUc5eUxuVndXM0YxWlhKNVNHbDBjeWh2ZG1WeWJHRndjeWxkTENCaGRHRmpMbWR5VzNOMVltcGxZM1JJYVhSektHOTJaWEpzWVhCektWMHBYRzVjYm14dmIzQXVaRzkzYmlBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z1hDSmphSEp2Ylc5ZlkyOXVjMTloYm01dlNHbGxjbUZ5WTJoNVgyRnNiRjlCTkRnMWRuTkVUVk5QWDBSUFYwNWZaR2xtWmpBdU1pNWlaV1J3WlZ3aUtTbGNibUZ1WTJodmNpNWtiM2R1SUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0d4dmIzQXVaRzkzYmlrcFhHNXZkbVZ5YkdGd2N5QThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG1SdmQyNHNJR0YwWVdNdVozSXBYRzVoYm1Ob2IzSXVaRzkzYmlBOExTQndhVzUwWlhKelpXTjBLR0Z1WTJodmNpNWtiM2R1VzNGMVpYSjVTR2wwY3lodmRtVnliR0Z3Y3lsZExDQmhkR0ZqTG1keVczTjFZbXBsWTNSSWFYUnpLRzkyWlhKc1lYQnpLVjBwWEc1Y2JteHZiM0JPZFcwZ1BDMGdibkp2ZHloc2IyOXdMbVJ2ZDI0cFhHNWNiaU1nVTJWc1pXTjBhVzVuSUhOaGJXVWdiblZ0WW1WeUlHOW1JR1Y0ZEhKbGJXVWdibThnYkc5dmNITmNibXh2YjNBdWJtOGdQQzBnYkc5dmNDNWhiR3dnSlQ0bElGeHVJQ0JrY0d4NWNqbzZiWFYwWVhSbEtHRmljMFJwWm1ZZ1BTQmhZbk1vWkdsbVpsOUJORGcxWDBSTlUwOHBLU0FsUGlWY2JpQWdaSEJzZVhJNk9tWnBiSFJsY2loaFluTkVhV1ptSUR3Z01DNHlLU0FsUGlWY2JpQWdaSEJzZVhJNk9tRnljbUZ1WjJVb1lXSnpSR2xtWmlrZ0pUNGxJSE5zYVdObFgyaGxZV1FvYmlBOUlHeHZiM0JPZFcwcFhHNWhibU5vYjNJdWJtOGdQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1dWJ5a3BYRzV2ZG1WeWJHRndjeUE4TFNCbWFXNWtUM1psY214aGNITW9ZVzVqYUc5eUxtNXZMQ0JoZEdGakxtZHlLVnh1WVc1amFHOXlMbTV2SUR3dElIQnBiblJsY25ObFkzUW9ZVzVqYUc5eUxtNXZXM0YxWlhKNVNHbDBjeWh2ZG1WeWJHRndjeWxkTENCaGRHRmpMbWR5VzNOMVltcGxZM1JJYVhSektHOTJaWEpzWVhCektWMHBYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmF0YWMgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcR1NNMzEwNjI1N19BVEFDX0VTQ18xLmJlZFxcKSkgJT4lIGRwbHlyOjpzZWxlY3QoVjEsIFYyLCBWMylcbmNvbG5hbWVzKGF0YWMpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuYXRhYy5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoYXRhYylcblxuIyBMT0FESU5HIExPT1BTXG4jIyMgSW1wb3J0aW5nIGRpZmZlcmVudGlhbCByZWd1bGF0b3J5IGxvb3BzICYgZXh0cmFjdCBhbmNob3Jcbmxvb3AuYWxsIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHkudHN2XFwpKVxuYW5jaG9yLmFsbCA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmFsbCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmFsbCwgYXRhYy5ncilcbmFuY2hvci5hbGwgPC0gcGludGVyc2VjdChhbmNob3IuYWxsW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLnVwIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXApKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci51cCwgYXRhYy5ncilcbmFuY2hvci51cCA8LSBwaW50ZXJzZWN0KGFuY2hvci51cFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IuZG93biA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5kb3duLCBhdGFjLmdyKVxuYW5jaG9yLmRvd24gPC0gcGludGVyc2VjdChhbmNob3IuZG93bltxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wTnVtIDwtIG5yb3cobG9vcC5kb3duKVxuXG4jIFNlbGVjdGluZyBzYW1lIG51bWJlciBvZiBleHRyZW1lIG5vIGxvb3BzXG5sb29wLm5vIDwtIGxvb3AuYWxsICU+JSBcbiAgZHBseXI6Om11dGF0ZShhYnNEaWZmID0gYWJzKGRpZmZfQTQ4NV9ETVNPKSkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoYWJzRGlmZiA8IDAuMikgJT4lXG4gIGRwbHlyOjphcnJhbmdlKGFic0RpZmYpICU+JSBzbGljZV9oZWFkKG4gPSBsb29wTnVtKVxuYW5jaG9yLm5vIDwtIChleHRyYWN0QW5jaG9yKGxvb3Aubm8pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5ubywgYXRhYy5ncilcbmFuY2hvci5ubyA8LSBwaW50ZXJzZWN0KGFuY2hvci5ub1txdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loopNum <- nrow(loop.down)

# Selecting same number of extreme no loops
loop.no <- loop.all %>% 
  dplyr::mutate(absDiff = abs(diff_A485_DMSO)) %>%
  dplyr::filter(absDiff < 0.2) %>%
  dplyr::arrange(absDiff) %>% slice_head(n = loopNum)
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVlYUmhZeUE4TFNCbWNtVmhaQ2hvWlhKbEtISmxaa1JwY2l3Z1hGeEhVMDB6TVRBMk1qVTNYMEZVUVVOZlJWTkRYekV1WW1Wa1hGd3BLU0FsUGlVZ1pIQnNlWEk2T25ObGJHVmpkQ2hXTVN3Z1ZqSXNJRll6S1Z4dVkyOXNibUZ0WlhNb1lYUmhZeWtnUEMwZ1l5aGNYR05vY2x4Y0xDQmNYSE4wWVhKMFhGd3NJRnhjWlc1a1hGd3BYRzVoZEdGakxtZHlJRHd0SUcxaGEyVkhVbUZ1WjJWelJuSnZiVVJoZEdGR2NtRnRaU2hoZEdGaktWeHVYRzRqSUV4UFFVUkpUa2NnVEU5UFVGTmNiaU1qSXlCSmJYQnZjblJwYm1jZ1pHbG1abVZ5Wlc1MGFXRnNJSEpsWjNWc1lYUnZjbmtnYkc5dmNITWdKaUJsZUhSeVlXTjBJR0Z1WTJodmNseHViRzl2Y0M1aGJHd2dQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lUzUwYzNaY1hDa3BYRzVoYm1Ob2IzSXVZV3hzSUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0d4dmIzQXVZV3hzS1NsY2JtOTJaWEpzWVhCeklEd3RJR1pwYm1SUGRtVnliR0Z3Y3loaGJtTm9iM0l1WVd4c0xDQmhkR0ZqTG1keUtWeHVZVzVqYUc5eUxtRnNiQ0E4TFNCd2FXNTBaWEp6WldOMEtHRnVZMmh2Y2k1aGJHeGJjWFZsY25sSWFYUnpLRzkyWlhKc1lYQnpLVjBzSUdGMFlXTXVaM0piYzNWaWFtVmpkRWhwZEhNb2IzWmxjbXhoY0hNcFhTbGNibHh1Ykc5dmNDNTFjQ0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnWEZ4amFISnZiVzlmWTI5dWMxOWhibTV2U0dsbGNtRnlZMmg1WDJGc2JGOUJORGcxZG5ORVRWTlBYMVZRWDJScFptWXdMakl1WW1Wa2NHVmNYQ2twWEc1aGJtTm9iM0l1ZFhBZ1BDMGdLR1Y0ZEhKaFkzUkJibU5vYjNJb2JHOXZjQzUxY0NrcFhHNXZkbVZ5YkdGd2N5QThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG5Wd0xDQmhkR0ZqTG1keUtWeHVZVzVqYUc5eUxuVndJRHd0SUhCcGJuUmxjbk5sWTNRb1lXNWphRzl5TG5Wd1czRjFaWEo1U0dsMGN5aHZkbVZ5YkdGd2N5bGRMQ0JoZEdGakxtZHlXM04xWW1wbFkzUklhWFJ6S0c5MlpYSnNZWEJ6S1YwcFhHNWNibXh2YjNBdVpHOTNiaUE4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnWEZ4amFISnZiVzlmWTI5dWMxOWhibTV2U0dsbGNtRnlZMmg1WDJGc2JGOUJORGcxZG5ORVRWTlBYMFJQVjA1ZlpHbG1aakF1TWk1aVpXUndaVnhjS1NsY2JtRnVZMmh2Y2k1a2IzZHVJRHd0SUNobGVIUnlZV04wUVc1amFHOXlLR3h2YjNBdVpHOTNiaWtwWEc1dmRtVnliR0Z3Y3lBOExTQm1hVzVrVDNabGNteGhjSE1vWVc1amFHOXlMbVJ2ZDI0c0lHRjBZV011WjNJcFhHNWhibU5vYjNJdVpHOTNiaUE4TFNCd2FXNTBaWEp6WldOMEtHRnVZMmh2Y2k1a2IzZHVXM0YxWlhKNVNHbDBjeWh2ZG1WeWJHRndjeWxkTENCaGRHRmpMbWR5VzNOMVltcGxZM1JJYVhSektHOTJaWEpzWVhCektWMHBYRzVjYm14dmIzQk9kVzBnUEMwZ2JuSnZkeWhzYjI5d0xtUnZkMjRwWEc1Y2JpTWdVMlZzWldOMGFXNW5JSE5oYldVZ2JuVnRZbVZ5SUc5bUlHVjRkSEpsYldVZ2JtOGdiRzl2Y0hOY2JteHZiM0F1Ym04Z1BDMGdiRzl2Y0M1aGJHd2dKVDRsSUZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0dGaWMwUnBabVlnUFNCaFluTW9aR2xtWmw5Qk5EZzFYMFJOVTA4cEtTQWxQaVZjYmlBZ1pIQnNlWEk2T21acGJIUmxjaWhoWW5ORWFXWm1JRHdnTUM0eUtTQWxQaVZjYmlBZ1pIQnNlWEk2T21GeWNtRnVaMlVvWVdKelJHbG1aaWtnSlQ0bElITnNhV05sWDJobFlXUW9iaUE5SUd4dmIzQk9kVzBwWEc1aGJtTm9iM0l1Ym04Z1BDMGdLR1Y0ZEhKaFkzUkJibU5vYjNJb2JHOXZjQzV1YnlrcFhHNXZkbVZ5YkdGd2N5QThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG01dkxDQmhkR0ZqTG1keUtWeHVZVzVqYUc5eUxtNXZJRHd0SUhCcGJuUmxjbk5sWTNRb1lXNWphRzl5TG01dlczRjFaWEo1U0dsMGN5aHZkbVZ5YkdGd2N5bGRMQ0JoZEdGakxtZHlXM04xWW1wbFkzUklhWFJ6S0c5MlpYSnNZWEJ6S1YwcFhHNWdZR0JjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbmBgYHJcbmF0YWMgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcR1NNMzEwNjI1N19BVEFDX0VTQ18xLmJlZFxcKSkgJT4lIGRwbHlyOjpzZWxlY3QoVjEsIFYyLCBWMylcbmNvbG5hbWVzKGF0YWMpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuYXRhYy5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoYXRhYylcblxuIyBMT0FESU5HIExPT1BTXG4jIyMgSW1wb3J0aW5nIGRpZmZlcmVudGlhbCByZWd1bGF0b3J5IGxvb3BzICYgZXh0cmFjdCBhbmNob3Jcbmxvb3AuYWxsIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHkudHN2XFwpKVxuYW5jaG9yLmFsbCA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmFsbCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmFsbCwgYXRhYy5ncilcbmFuY2hvci5hbGwgPC0gcGludGVyc2VjdChhbmNob3IuYWxsW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLnVwIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXApKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci51cCwgYXRhYy5ncilcbmFuY2hvci51cCA8LSBwaW50ZXJzZWN0KGFuY2hvci51cFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IuZG93biA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5kb3duLCBhdGFjLmdyKVxuYW5jaG9yLmRvd24gPC0gcGludGVyc2VjdChhbmNob3IuZG93bltxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wTnVtIDwtIG5yb3cobG9vcC5kb3duKVxuXG4jIFNlbGVjdGluZyBzYW1lIG51bWJlciBvZiBleHRyZW1lIG5vIGxvb3BzXG5sb29wLm5vIDwtIGxvb3AuYWxsICU+JSBcbiAgZHBseXI6Om11dGF0ZShhYnNEaWZmID0gYWJzKGRpZmZfQTQ4NV9ETVNPKSkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoYWJzRGlmZiA8IDAuMikgJT4lXG4gIGRwbHlyOjphcnJhbmdlKGFic0RpZmYpICU+JSBzbGljZV9oZWFkKG4gPSBsb29wTnVtKVxuYW5jaG9yLm5vIDwtIChleHRyYWN0QW5jaG9yKGxvb3Aubm8pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5ubywgYXRhYy5ncilcbmFuY2hvci5ubyA8LSBwaW50ZXJzZWN0KGFuY2hvci5ub1txdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpXG5hbmNob3IuYWxsIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuYWxsKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuYWxsLCBhdGFjLmdyKVxuYW5jaG9yLmFsbCA8LSBwaW50ZXJzZWN0KGFuY2hvci5hbGxbcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9BNDg1dnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwLCBhdGFjLmdyKVxuYW5jaG9yLnVwIDwtIHBpbnRlcnNlY3QoYW5jaG9yLnVwW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9BNDg1dnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci5kb3duIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuZG93bikpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmRvd24sIGF0YWMuZ3IpXG5hbmNob3IuZG93biA8LSBwaW50ZXJzZWN0KGFuY2hvci5kb3duW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbmxvb3BOdW0gPC0gbnJvdyhsb29wLmRvd24pXG5cbiMgU2VsZWN0aW5nIHNhbWUgbnVtYmVyIG9mIGV4dHJlbWUgbm8gbG9vcHNcbmxvb3Aubm8gPC0gbG9vcC5hbGwgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGFic0RpZmYgPSBhYnMoZGlmZl9BNDg1X0RNU08pKSAlPiVcbiAgZHBseXI6OmZpbHRlcihhYnNEaWZmIDwgMC4yKSAlPiVcbiAgZHBseXI6OmFycmFuZ2UoYWJzRGlmZikgJT4lIHNsaWNlX2hlYWQobiA9IGxvb3BOdW0pXG5hbmNob3Iubm8gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5ubykpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLm5vLCBhdGFjLmdyKVxuYW5jaG9yLm5vIDwtIHBpbnRlcnNlY3QoYW5jaG9yLm5vW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5gYGBcbmBgYCJ9 -->

```r
```r
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loopNum <- nrow(loop.down)

# Selecting same number of extreme no loops
loop.no <- loop.all %>% 
  dplyr::mutate(absDiff = abs(diff_A485_DMSO)) %>%
  dplyr::filter(absDiff < 0.2) %>%
  dplyr::arrange(absDiff) %>% slice_head(n = loopNum)
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBSVU5OSU5HIExPTEFcbmxvbGFEaXIgPC0gaGVyZShcIi4uLy4uL3Jlc3VsdC9sb2xhXCIpXG5kaXIuY3JlYXRlKGxvbGFEaXIsIHNob3dXYXJuaW5ncyA9IEZBTFNFLCByZWN1cnNpdmUgPSBUUlVFKVxuXG4jIFVQXG5yZXN1bHQgPSBydW5MT0xBKGFuY2hvci51cCwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFwiTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl91cF9hbGxMb29wc19leHRyZW1lX2F0YWMudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuXG4jIE5PXG5yZXN1bHQgPSBydW5MT0xBKGFuY2hvci5ubywgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFwiTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9ub19hbGxMb29wc19leHRyZW1lX2F0YWMudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuXG4jIERPV05cbnJlc3VsdCA9IHJ1bkxPTEEoYW5jaG9yLmRvd24sIGFuY2hvci5hbGwsIGxvbGFEQilcbnRiID0gYXNfdGliYmxlKHJlc3VsdClcbmZ3cml0ZSh0YiwgaGVyZShsb2xhRGlyLCBcIkxPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfZG93bl9hbGxMb29wc19leHRyZW1lX2F0YWMudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuXG5cblxuIyMjIEhFQVRNQVBcbmFscGhhIDwtIDAuMDVcbnRiLnVwIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXCJMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX3VwX2FsbExvb3BzX2V4dHJlbWVfYXRhYy50c3ZcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpKSAlPiVcbiAgZmlsdGVyKHN0cl90b19sb3dlcihjZWxsVHlwZSkgPT0gXCJlbWJyeW9uaWMgc3RlbSBjZWxsXCIpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHFWYWx1ZSA8IGFscGhhKSAlPiUgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4gIHNsaWNlX21pbihtZWFuUm5rLCB3aXRoX3RpZXMgPSBGQUxTRSlcbnRiLm5vIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXCJMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX25vX2FsbExvb3BzX2V4dHJlbWVfYXRhYy50c3ZcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpKSAlPiVcbiAgZmlsdGVyKHN0cl90b19sb3dlcihjZWxsVHlwZSkgPT0gXCJlbWJyeW9uaWMgc3RlbSBjZWxsXCIpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHFWYWx1ZSA8IGFscGhhKSAlPiUgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4gIHNsaWNlX21pbihtZWFuUm5rLCB3aXRoX3RpZXMgPSBGQUxTRSlcbnRiLmRvd24gPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcIkxPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfZG93bl9hbGxMb29wc19leHRyZW1lX2F0YWMudHN2XCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFwiZW1icnlvbmljIHN0ZW0gY2VsbFwiKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG5cbnRlbXAudXAgPC0gdGIudXAgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLnVwKSA8LSBjKFwidGFyZ2V0XCIsIFwiT1JfdXBcIilcbnRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLm5vKSA8LSBjKFwidGFyZ2V0XCIsIFwiT1Jfbm9cIilcbnRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvKVxuY29sbmFtZXModGVtcC5kb3duKSA8LSBjKFwidGFyZ2V0XCIsIFwiT1JfZG93blwiKVxuXG5cbnRlbXAgPC0gZnVsbF9qb2luKGZ1bGxfam9pbih0ZW1wLnVwLCB0ZW1wLm5vLCBieSA9IGMoXCJ0YXJnZXRcIikpLCB0ZW1wLmRvd24sIGJ5ID0gYyhcInRhcmdldFwiKSkgJT4lIG11dGF0ZV9hbGwofnJlcGxhY2VfbmEoLiwgMSkpXG5cbmRhdGEgPC0gYXMubWF0cml4KHRlbXBbMjo0XSlcbnJvd25hbWVzKGRhdGEpIDwtIHRlbXAkdGFyZ2V0XG5cbmxpYnJhcnkoY2lyY2xpemUpXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYyhtaW4oZGF0YSksIG1heChkYXRhKSksIGMoXCJ3aGl0ZVwiLCBcInJlZFwiKSlcblxuXG4jZnZpel9uYmNsdXN0KGRhdGEsIGttZWFucywgbWV0aG9kID0gXCJ3c3NcIilcblxucCA8LSBIZWF0bWFwKFxuICBkYXRhLFxuICBuYW1lID0gXCJPZGRzIFJhdGlvXCIsICAgICAgICAgICAgICAgICAgICMgTmFtZSBvZiB0aGUgaGVhdG1hcCBsZWdlbmRcbiAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsICAgICAgICAgICAgIyBSZW1vdmUgY29sdW1uIGRlbmRyb2dyYW1cbiAgcm93X2ttID0gNSwgICAgICAgICAgICAgICAgICAgICAgICAgIyBEZWZpbmUgdGhlIG51bWJlciBvZiBrLW1lYW5zIGNsdXN0ZXJzIGZvciByb3dzIChhZGp1c3QgYXMgbmVlZGVkKVxuICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gIGNvbCA9IGNvbF9mdW4sXG4gIGJvcmRlciA9IFRSVUVcbilcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwiYW5jaG9yTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9hbGxMb29wc19leHRyZW1lX3JlZ0FuY2hvckJhY2tncm91bmRfYXRhY1wiKVxuaGVpZ2h0IDwtIDdcbndpZHRoIDwtIDMuNVxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cblxuXG4jIyMgVmlzdWFsaXppbmcgcC12YWx1ZSBhbmQgT1JcbmFscGhhIDwtIDAuMDVcbnRiLnVwIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXCJMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX3VwX2FsbExvb3BzX2V4dHJlbWVfYXRhYy50c3ZcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpLFxuICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4gICAgICAgICAgICAgICAgZ3JvdXAgPSBcIlVQXCIpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcImVtYnJ5b25pYyBzdGVtIGNlbGxcIikgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIubm8gPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcIkxPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfbm9fYWxsTG9vcHNfZXh0cmVtZV9hdGFjLnRzdlwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSksXG4gICAgICAgICAgICAgICAgcVZhbHVlTG9nID0gLWxvZzIocVZhbHVlKSxcbiAgICAgICAgICAgICAgICBncm91cCA9IFwiTk9cIikgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFwiZW1icnlvbmljIHN0ZW0gY2VsbFwiKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG50Yi5kb3duIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXCJMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX2Rvd25fYWxsTG9vcHNfZXh0cmVtZV9hdGFjLnRzdlwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSksXG4gICAgICAgICAgICAgICAgcVZhbHVlTG9nID0gLWxvZzIocVZhbHVlKSxcbiAgICAgICAgICAgICAgICBncm91cCA9IFwiRE9XTlwiKSAlPiVcbiAgZmlsdGVyKHN0cl90b19sb3dlcihjZWxsVHlwZSkgPT0gXCJlbWJyeW9uaWMgc3RlbSBjZWxsXCIpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHFWYWx1ZSA8IGFscGhhKSAlPiUgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4gIHNsaWNlX21pbihtZWFuUm5rLCB3aXRoX3RpZXMgPSBGQUxTRSlcblxudGVtcC51cCA8LSB0Yi51cCAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIG9kZHNSYXRpbywgcVZhbHVlTG9nLCBncm91cClcbnRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8sIHFWYWx1ZUxvZywgZ3JvdXApXG50ZW1wLmRvd24gPC0gdGIuZG93biAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIG9kZHNSYXRpbywgcVZhbHVlTG9nLCBncm91cClcblxudGVtcCA8LSBiaW5kX3Jvd3ModGVtcC51cCwgdGVtcC5kb3duKVxuXG5vcmRlciA8LSB1bmlxdWUoYygodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcIlVQXCIpICU+JSBhcnJhbmdlKGRlc2Mob2Rkc1JhdGlvKSkpJHRhcmdldCwgXG4gICAgICAgICAgICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IFwiRE9XTlwiKSAlPiUgYXJyYW5nZShkZXNjKG9kZHNSYXRpbykpKSR0YXJnZXQpKVxudGVtcCR0YXJnZXQgPC0gZmFjdG9yKHRlbXAkdGFyZ2V0LCBsZXZlbHMgPSByZXYob3JkZXIpKVxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBncm91cCwgeSA9IHRhcmdldCwgY29sb3IgPSBxVmFsdWVMb2csIHNpemUgPSBvZGRzUmF0aW8pKSArXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl9ncmFkaWVudChsb3cgPSBcImJsdWVcIiwgaGlnaCA9IFwicmVkXCIpICtcbiAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICArICAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygxLCAzKSkgK1xuICB0aGVtZShheGlzLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAgIyBTZXQgYXhpcyB0ZXh0IHNpemVcbiAgICAgICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICMgU2V0IGF4aXMgdGl0bGUgc2l6ZSAoaWYgbm90IHJlbW92ZWQpXG4gICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuICAgICAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpKSBcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwiYW5jaG9yTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9hbGxMb29wc19leHRyZW1lX09SX3FWYWx1ZV9yZWdBbmNob3JCYWNrZ3JvdW5kX2F0YWNcIilcbmhlaWdodCA8LTNcbndpZHRoIDwtIDJcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYCJ9 -->\n\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  row_km = 5,                         # Define the number of k-means clusters for rows (adjust as needed)\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\nfileName <- paste0(\\anchorLOLA_A485_vs_DMSO_diff0.2_allLoops_extreme_regAnchorBackground_atac\\)\nheight <- 7\nwidth <- 3.5\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\UP\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.up, temp.down)\n\norder <- unique(c((temp %>% dplyr::filter(group == \\UP\\) %>% arrange(desc(oddsRatio)))$target, \n           (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target))\ntemp$target <- factor(temp$target, levels = rev(order))\np <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n  geom_point() + theme_bw() + scale_color_gradient(low = \\blue\\, high = \\red\\) +\n  labs(x = NULL, y = NULL)  +   scale_size_continuous(range = c(1, 3)) +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\nfileName <- paste0(\\anchorLOLA_A485_vs_DMSO_diff0.2_allLoops_extreme_OR_qValue_regAnchorBackground_atac\\)\nheight <-3\nwidth <- 2\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# RUNNING LOLA
lolaDir <- here(\../../result/lola\)
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\), sep = \\t\)

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\), sep = \\t\)

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\), sep = \\t\)



### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c(\target\, \OR_up\)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c(\target\, \OR_no\)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c(\target\, \OR_down\)


temp <- full_join(full_join(temp.up, temp.no, by = c(\target\)), temp.down, by = c(\target\)) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 5,                         # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)

fileName <- paste0(\anchorLOLA_A485_vs_DMSO_diff0.2_allLoops_extreme_regAnchorBackground_atac\)
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()




### Visualizing p-value and OR
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \UP\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \NO\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \DOWN\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.up, temp.down)

order <- unique(c((temp %>% dplyr::filter(group == \UP\) %>% arrange(desc(oddsRatio)))$target, 
           (temp %>% dplyr::filter(group == \DOWN\) %>% arrange(desc(oddsRatio)))$target))
temp$target <- factor(temp$target, levels = rev(order))
p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
  geom_point() + theme_bw() + scale_color_gradient(low = \blue\, high = \red\) +
  labs(x = NULL, y = NULL)  +   scale_size_continuous(range = c(1, 3)) +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- paste0(\anchorLOLA_A485_vs_DMSO_diff0.2_allLoops_extreme_OR_qValue_regAnchorBackground_atac\)
height <-3
width <- 2
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBSVU5OSU5HIExPTEFcbmxvbGFEaXIgPC0gaGVyZShcXC4uLy4uL3Jlc3VsdC9sb2xhXFwpXG5kaXIuY3JlYXRlKGxvbGFEaXIsIHNob3dXYXJuaW5ncyA9IEZBTFNFLCByZWN1cnNpdmUgPSBUUlVFKVxuXG4jIFVQXG5yZXN1bHQgPSBydW5MT0xBKGFuY2hvci51cCwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl91cF9hbGxMb29wc19leHRyZW1lX2F0YWMudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG4jIE5PXG5yZXN1bHQgPSBydW5MT0xBKGFuY2hvci5ubywgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9ub19hbGxMb29wc19leHRyZW1lX2F0YWMudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG4jIERPV05cbnJlc3VsdCA9IHJ1bkxPTEEoYW5jaG9yLmRvd24sIGFuY2hvci5hbGwsIGxvbGFEQilcbnRiID0gYXNfdGliYmxlKHJlc3VsdClcbmZ3cml0ZSh0YiwgaGVyZShsb2xhRGlyLCBcXExPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfZG93bl9hbGxMb29wc19leHRyZW1lX2F0YWMudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG5cblxuIyMjIEhFQVRNQVBcbmFscGhhIDwtIDAuMDVcbnRiLnVwIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXFxMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX3VwX2FsbExvb3BzX2V4dHJlbWVfYXRhYy50c3ZcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpKSAlPiVcbiAgZmlsdGVyKHN0cl90b19sb3dlcihjZWxsVHlwZSkgPT0gXFxlbWJyeW9uaWMgc3RlbSBjZWxsXFwpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHFWYWx1ZSA8IGFscGhhKSAlPiUgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4gIHNsaWNlX21pbihtZWFuUm5rLCB3aXRoX3RpZXMgPSBGQUxTRSlcbnRiLm5vIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXFxMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX25vX2FsbExvb3BzX2V4dHJlbWVfYXRhYy50c3ZcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpKSAlPiVcbiAgZmlsdGVyKHN0cl90b19sb3dlcihjZWxsVHlwZSkgPT0gXFxlbWJyeW9uaWMgc3RlbSBjZWxsXFwpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHFWYWx1ZSA8IGFscGhhKSAlPiUgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4gIHNsaWNlX21pbihtZWFuUm5rLCB3aXRoX3RpZXMgPSBGQUxTRSlcbnRiLmRvd24gPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcXExPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfZG93bl9hbGxMb29wc19leHRyZW1lX2F0YWMudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG5cbnRlbXAudXAgPC0gdGIudXAgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLnVwKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1JfdXBcXClcbnRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLm5vKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1Jfbm9cXClcbnRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvKVxuY29sbmFtZXModGVtcC5kb3duKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1JfZG93blxcKVxuXG5cbnRlbXAgPC0gZnVsbF9qb2luKGZ1bGxfam9pbih0ZW1wLnVwLCB0ZW1wLm5vLCBieSA9IGMoXFx0YXJnZXRcXCkpLCB0ZW1wLmRvd24sIGJ5ID0gYyhcXHRhcmdldFxcKSkgJT4lIG11dGF0ZV9hbGwofnJlcGxhY2VfbmEoLiwgMSkpXG5cbmRhdGEgPC0gYXMubWF0cml4KHRlbXBbMjo0XSlcbnJvd25hbWVzKGRhdGEpIDwtIHRlbXAkdGFyZ2V0XG5cbmxpYnJhcnkoY2lyY2xpemUpXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYyhtaW4oZGF0YSksIG1heChkYXRhKSksIGMoXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuXG4jZnZpel9uYmNsdXN0KGRhdGEsIGttZWFucywgbWV0aG9kID0gXFx3c3NcXClcblxucCA8LSBIZWF0bWFwKFxuICBkYXRhLFxuICBuYW1lID0gXFxPZGRzIFJhdGlvXFwsICAgICAgICAgICAgICAgICAgICMgTmFtZSBvZiB0aGUgaGVhdG1hcCBsZWdlbmRcbiAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsICAgICAgICAgICAgIyBSZW1vdmUgY29sdW1uIGRlbmRyb2dyYW1cbiAgcm93X2ttID0gNSwgICAgICAgICAgICAgICAgICAgICAgICAgIyBEZWZpbmUgdGhlIG51bWJlciBvZiBrLW1lYW5zIGNsdXN0ZXJzIGZvciByb3dzIChhZGp1c3QgYXMgbmVlZGVkKVxuICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gIGNvbCA9IGNvbF9mdW4sXG4gIGJvcmRlciA9IFRSVUVcbilcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcYW5jaG9yTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9hbGxMb29wc19leHRyZW1lX3JlZ0FuY2hvckJhY2tncm91bmRfYXRhY1xcKVxuaGVpZ2h0IDwtIDdcbndpZHRoIDwtIDMuNVxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cblxuXG4jIyMgVmlzdWFsaXppbmcgcC12YWx1ZSBhbmQgT1JcbmFscGhhIDwtIDAuMDVcbnRiLnVwIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXFxMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX3VwX2FsbExvb3BzX2V4dHJlbWVfYXRhYy50c3ZcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpLFxuICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4gICAgICAgICAgICAgICAgZ3JvdXAgPSBcXFVQXFwpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIubm8gPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcXExPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfbm9fYWxsTG9vcHNfZXh0cmVtZV9hdGFjLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSksXG4gICAgICAgICAgICAgICAgcVZhbHVlTG9nID0gLWxvZzIocVZhbHVlKSxcbiAgICAgICAgICAgICAgICBncm91cCA9IFxcTk9cXCkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG50Yi5kb3duIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXFxMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX2Rvd25fYWxsTG9vcHNfZXh0cmVtZV9hdGFjLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSksXG4gICAgICAgICAgICAgICAgcVZhbHVlTG9nID0gLWxvZzIocVZhbHVlKSxcbiAgICAgICAgICAgICAgICBncm91cCA9IFxcRE9XTlxcKSAlPiVcbiAgZmlsdGVyKHN0cl90b19sb3dlcihjZWxsVHlwZSkgPT0gXFxlbWJyeW9uaWMgc3RlbSBjZWxsXFwpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHFWYWx1ZSA8IGFscGhhKSAlPiUgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4gIHNsaWNlX21pbihtZWFuUm5rLCB3aXRoX3RpZXMgPSBGQUxTRSlcblxudGVtcC51cCA8LSB0Yi51cCAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIG9kZHNSYXRpbywgcVZhbHVlTG9nLCBncm91cClcbnRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8sIHFWYWx1ZUxvZywgZ3JvdXApXG50ZW1wLmRvd24gPC0gdGIuZG93biAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIG9kZHNSYXRpbywgcVZhbHVlTG9nLCBncm91cClcblxudGVtcCA8LSBiaW5kX3Jvd3ModGVtcC51cCwgdGVtcC5kb3duKVxuXG5vcmRlciA8LSB1bmlxdWUoYygodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXFVQXFwpICU+JSBhcnJhbmdlKGRlc2Mob2Rkc1JhdGlvKSkpJHRhcmdldCwgXG4gICAgICAgICAgICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IFxcRE9XTlxcKSAlPiUgYXJyYW5nZShkZXNjKG9kZHNSYXRpbykpKSR0YXJnZXQpKVxudGVtcCR0YXJnZXQgPC0gZmFjdG9yKHRlbXAkdGFyZ2V0LCBsZXZlbHMgPSByZXYob3JkZXIpKVxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBncm91cCwgeSA9IHRhcmdldCwgY29sb3IgPSBxVmFsdWVMb2csIHNpemUgPSBvZGRzUmF0aW8pKSArXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl9ncmFkaWVudChsb3cgPSBcXGJsdWVcXCwgaGlnaCA9IFxccmVkXFwpICtcbiAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICArICAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygxLCAzKSkgK1xuICB0aGVtZShheGlzLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAgIyBTZXQgYXhpcyB0ZXh0IHNpemVcbiAgICAgICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICMgU2V0IGF4aXMgdGl0bGUgc2l6ZSAoaWYgbm90IHJlbW92ZWQpXG4gICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuICAgICAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpKSBcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcYW5jaG9yTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9hbGxMb29wc19leHRyZW1lX09SX3FWYWx1ZV9yZWdBbmNob3JCYWNrZ3JvdW5kX2F0YWNcXClcbmhlaWdodCA8LTNcbndpZHRoIDwtIDJcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\), sep = \\\\t\\)\n\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  row_km = 5,                         # Define the number of k-means clusters for rows (adjust as needed)\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n\nfileName <- paste0(\\anchorLOLA_A485_vs_DMSO_diff0.2_allLoops_extreme_regAnchorBackground_atac\\)\nheight <- 7\nwidth <- 3.5\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\UP\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.up, temp.down)\n\norder <- unique(c((temp %>% dplyr::filter(group == \\UP\\) %>% arrange(desc(oddsRatio)))$target, \n           (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target))\ntemp$target <- factor(temp$target, levels = rev(order))\np <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n  geom_point() + theme_bw() + scale_color_gradient(low = \\blue\\, high = \\red\\) +\n  labs(x = NULL, y = NULL)  +   scale_size_continuous(range = c(1, 3)) +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\nfileName <- paste0(\\anchorLOLA_A485_vs_DMSO_diff0.2_allLoops_extreme_OR_qValue_regAnchorBackground_atac\\)\nheight <-3\nwidth <- 2\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBSVU5OSU5HIExPTEFcbmxvbGFEaXIgPC0gaGVyZShcXC4uLy4uL3Jlc3VsdC9sb2xhXFwpXG5kaXIuY3JlYXRlKGxvbGFEaXIsIHNob3dXYXJuaW5ncyA9IEZBTFNFLCByZWN1cnNpdmUgPSBUUlVFKVxuXG4jIFVQXG5yZXN1bHQgPSBydW5MT0xBKGFuY2hvci51cCwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl91cF9hbGxMb29wc19leHRyZW1lX2F0YWMudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG4jIE5PXG5yZXN1bHQgPSBydW5MT0xBKGFuY2hvci5ubywgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9ub19hbGxMb29wc19leHRyZW1lX2F0YWMudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG4jIERPV05cbnJlc3VsdCA9IHJ1bkxPTEEoYW5jaG9yLmRvd24sIGFuY2hvci5hbGwsIGxvbGFEQilcbnRiID0gYXNfdGliYmxlKHJlc3VsdClcbmZ3cml0ZSh0YiwgaGVyZShsb2xhRGlyLCBcXExPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfZG93bl9hbGxMb29wc19leHRyZW1lX2F0YWMudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG5cblxuIyMjIEhFQVRNQVBcbmFscGhhIDwtIDAuMDVcbnRiLnVwIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXFxMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX3VwX2FsbExvb3BzX2V4dHJlbWVfYXRhYy50c3ZcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpKSAlPiVcbiAgZmlsdGVyKHN0cl90b19sb3dlcihjZWxsVHlwZSkgPT0gXFxlbWJyeW9uaWMgc3RlbSBjZWxsXFwpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHFWYWx1ZSA8IGFscGhhKSAlPiUgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4gIHNsaWNlX21pbihtZWFuUm5rLCB3aXRoX3RpZXMgPSBGQUxTRSlcbnRiLm5vIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXFxMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX25vX2FsbExvb3BzX2V4dHJlbWVfYXRhYy50c3ZcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpKSAlPiVcbiAgZmlsdGVyKHN0cl90b19sb3dlcihjZWxsVHlwZSkgPT0gXFxlbWJyeW9uaWMgc3RlbSBjZWxsXFwpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHFWYWx1ZSA8IGFscGhhKSAlPiUgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4gIHNsaWNlX21pbihtZWFuUm5rLCB3aXRoX3RpZXMgPSBGQUxTRSlcbnRiLmRvd24gPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcXExPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfZG93bl9hbGxMb29wc19leHRyZW1lX2F0YWMudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG5cbnRlbXAudXAgPC0gdGIudXAgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLnVwKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1JfdXBcXClcbnRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLm5vKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1Jfbm9cXClcbnRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvKVxuY29sbmFtZXModGVtcC5kb3duKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1JfZG93blxcKVxuXG5cbnRlbXAgPC0gZnVsbF9qb2luKGZ1bGxfam9pbih0ZW1wLnVwLCB0ZW1wLm5vLCBieSA9IGMoXFx0YXJnZXRcXCkpLCB0ZW1wLmRvd24sIGJ5ID0gYyhcXHRhcmdldFxcKSkgJT4lIG11dGF0ZV9hbGwofnJlcGxhY2VfbmEoLiwgMSkpXG5cbmRhdGEgPC0gYXMubWF0cml4KHRlbXBbMjo0XSlcbnJvd25hbWVzKGRhdGEpIDwtIHRlbXAkdGFyZ2V0XG5cbmxpYnJhcnkoY2lyY2xpemUpXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYyhtaW4oZGF0YSksIG1heChkYXRhKSksIGMoXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuXG4jZnZpel9uYmNsdXN0KGRhdGEsIGttZWFucywgbWV0aG9kID0gXFx3c3NcXClcblxucCA8LSBIZWF0bWFwKFxuICBkYXRhLFxuICBuYW1lID0gXFxPZGRzIFJhdGlvXFwsICAgICAgICAgICAgICAgICAgICMgTmFtZSBvZiB0aGUgaGVhdG1hcCBsZWdlbmRcbiAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsICAgICAgICAgICAgIyBSZW1vdmUgY29sdW1uIGRlbmRyb2dyYW1cbiAgcm93X2ttID0gNSwgICAgICAgICAgICAgICAgICAgICAgICAgIyBEZWZpbmUgdGhlIG51bWJlciBvZiBrLW1lYW5zIGNsdXN0ZXJzIGZvciByb3dzIChhZGp1c3QgYXMgbmVlZGVkKVxuICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gIGNvbCA9IGNvbF9mdW4sXG4gIGJvcmRlciA9IFRSVUVcbilcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcYW5jaG9yTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9hbGxMb29wc19leHRyZW1lX3JlZ0FuY2hvckJhY2tncm91bmRfYXRhY1xcKVxuaGVpZ2h0IDwtIDdcbndpZHRoIDwtIDMuNVxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cblxuXG4jIyMgVmlzdWFsaXppbmcgcC12YWx1ZSBhbmQgT1JcbmFscGhhIDwtIDAuMDVcbnRiLnVwIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXFxMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX3VwX2FsbExvb3BzX2V4dHJlbWVfYXRhYy50c3ZcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpLFxuICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4gICAgICAgICAgICAgICAgZ3JvdXAgPSBcXFVQXFwpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIubm8gPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcXExPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfbm9fYWxsTG9vcHNfZXh0cmVtZV9hdGFjLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSksXG4gICAgICAgICAgICAgICAgcVZhbHVlTG9nID0gLWxvZzIocVZhbHVlKSxcbiAgICAgICAgICAgICAgICBncm91cCA9IFxcTk9cXCkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG50Yi5kb3duIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXFxMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX2Rvd25fYWxsTG9vcHNfZXh0cmVtZV9hdGFjLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSksXG4gICAgICAgICAgICAgICAgcVZhbHVlTG9nID0gLWxvZzIocVZhbHVlKSxcbiAgICAgICAgICAgICAgICBncm91cCA9IFxcRE9XTlxcKSAlPiVcbiAgZmlsdGVyKHN0cl90b19sb3dlcihjZWxsVHlwZSkgPT0gXFxlbWJyeW9uaWMgc3RlbSBjZWxsXFwpICU+JVxuICBkcGx5cjo6ZmlsdGVyKHFWYWx1ZSA8IGFscGhhKSAlPiUgZHBseXI6Omdyb3VwX2J5KHRhcmdldCkgJT4lXG4gIHNsaWNlX21pbihtZWFuUm5rLCB3aXRoX3RpZXMgPSBGQUxTRSlcblxudGVtcC51cCA8LSB0Yi51cCAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIG9kZHNSYXRpbywgcVZhbHVlTG9nLCBncm91cClcbnRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8sIHFWYWx1ZUxvZywgZ3JvdXApXG50ZW1wLmRvd24gPC0gdGIuZG93biAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIG9kZHNSYXRpbywgcVZhbHVlTG9nLCBncm91cClcblxudGVtcCA8LSBiaW5kX3Jvd3ModGVtcC51cCwgdGVtcC5kb3duKVxuXG5vcmRlciA8LSB1bmlxdWUoYygodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXFVQXFwpICU+JSBhcnJhbmdlKGRlc2Mob2Rkc1JhdGlvKSkpJHRhcmdldCwgXG4gICAgICAgICAgICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IFxcRE9XTlxcKSAlPiUgYXJyYW5nZShkZXNjKG9kZHNSYXRpbykpKSR0YXJnZXQpKVxudGVtcCR0YXJnZXQgPC0gZmFjdG9yKHRlbXAkdGFyZ2V0LCBsZXZlbHMgPSByZXYob3JkZXIpKVxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBncm91cCwgeSA9IHRhcmdldCwgY29sb3IgPSBxVmFsdWVMb2csIHNpemUgPSBvZGRzUmF0aW8pKSArXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl9ncmFkaWVudChsb3cgPSBcXGJsdWVcXCwgaGlnaCA9IFxccmVkXFwpICtcbiAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICArICAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygxLCAzKSkgK1xuICB0aGVtZShheGlzLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAgIyBTZXQgYXhpcyB0ZXh0IHNpemVcbiAgICAgICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICMgU2V0IGF4aXMgdGl0bGUgc2l6ZSAoaWYgbm90IHJlbW92ZWQpXG4gICAgICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgbGVnZW5kIHRleHQgc2l6ZVxuICAgICAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpKSBcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcYW5jaG9yTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9hbGxMb29wc19leHRyZW1lX09SX3FWYWx1ZV9yZWdBbmNob3JCYWNrZ3JvdW5kX2F0YWNcXClcbmhlaWdodCA8LTNcbndpZHRoIDwtIDJcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
# RUNNING LOLA
lolaDir <- here(\../../result/lola\)
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\), sep = \\t\)

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\), sep = \\t\)

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\), sep = \\t\)



### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c(\target\, \OR_up\)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c(\target\, \OR_no\)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c(\target\, \OR_down\)


temp <- full_join(full_join(temp.up, temp.no, by = c(\target\)), temp.down, by = c(\target\)) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 5,                         # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)

fileName <- paste0(\anchorLOLA_A485_vs_DMSO_diff0.2_allLoops_extreme_regAnchorBackground_atac\)
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()




### Visualizing p-value and OR
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \UP\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \NO\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \DOWN\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.up, temp.down)

order <- unique(c((temp %>% dplyr::filter(group == \UP\) %>% arrange(desc(oddsRatio)))$target, 
           (temp %>% dplyr::filter(group == \DOWN\) %>% arrange(desc(oddsRatio)))$target))
temp$target <- factor(temp$target, levels = rev(order))
p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
  geom_point() + theme_bw() + scale_color_gradient(low = \blue\, high = \red\) +
  labs(x = NULL, y = NULL)  +   scale_size_continuous(range = c(1, 3)) +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- paste0(\anchorLOLA_A485_vs_DMSO_diff0.2_allLoops_extreme_OR_qValue_regAnchorBackground_atac\)
height <-3
width <- 2
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



### A485
##### - Limited to ATAC-seq signal, all loop backgroupd

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZWFJoWXlBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYQ0pIVTAwek1UQTJNalUzWDBGVVFVTmZSVk5EWHpFdVltVmtYQ0lwS1NBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoV01Td2dWaklzSUZZektWeHVZMjlzYm1GdFpYTW9ZWFJoWXlrZ1BDMGdZeWhjSW1Ob2Nsd2lMQ0JjSW5OMFlYSjBYQ0lzSUZ3aVpXNWtYQ0lwWEc1aGRHRmpMbWR5SUR3dElHMWhhMlZIVW1GdVoyVnpSbkp2YlVSaGRHRkdjbUZ0WlNoaGRHRmpLVnh1WEc0aklFeFBRVVJKVGtjZ1RFOVBVRk5jYmlNakl5QkpiWEJ2Y25ScGJtY2daR2xtWm1WeVpXNTBhV0ZzSUhKbFozVnNZWFJ2Y25rZ2JHOXZjSE1nSmlCbGVIUnlZV04wSUdGdVkyaHZjbHh1Ykc5dmNDNWhiR3dnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVM1MGMzWmNJaWtwSUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0VGdWJtOHlJQ1ZwYmlVZ1l5aGNJbEF0VUZ3aUxDQmNJbEF0UlZ3aUxDQmNJa1V0UlZ3aUtTbGNibUZ1WTJodmNpNWhiR3dnUEMwZ0tHVjRkSEpoWTNSQmJtTm9iM0lvYkc5dmNDNWhiR3dwS1Z4dWIzWmxjbXhoY0hNZ1BDMGdabWx1WkU5MlpYSnNZWEJ6S0dGdVkyaHZjaTVoYkd3c0lHRjBZV011WjNJcFhHNWhibU5vYjNJdVlXeHNJRHd0SUhCcGJuUmxjbk5sWTNRb1lXNWphRzl5TG1Gc2JGdHhkV1Z5ZVVocGRITW9iM1psY214aGNITXBYU3dnWVhSaFl5NW5jbHR6ZFdKcVpXTjBTR2wwY3lodmRtVnliR0Z3Y3lsZEtWeHVYRzVzYjI5d0xuVndJRHd0SUdaeVpXRmtLR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0JjSW1Ob2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxmY0dVdGNHVmZRVFE0TlhaelJFMVRUMTlWVUY5a2FXWm1NQzR5TG1KbFpIQmxYQ0lwS1Z4dVlXNWphRzl5TG5Wd0lEd3RJQ2hsZUhSeVlXTjBRVzVqYUc5eUtHeHZiM0F1ZFhBcEtWeHViM1psY214aGNITWdQQzBnWm1sdVpFOTJaWEpzWVhCektHRnVZMmh2Y2k1MWNDd2dZWFJoWXk1bmNpbGNibUZ1WTJodmNpNTFjQ0E4TFNCd2FXNTBaWEp6WldOMEtHRnVZMmh2Y2k1MWNGdHhkV1Z5ZVVocGRITW9iM1psY214aGNITXBYU3dnWVhSaFl5NW5jbHR6ZFdKcVpXTjBTR2wwY3lodmRtVnliR0Z3Y3lsZEtWeHVYRzVzYjI5d0xtNXZJRHd0SUdaeVpXRmtLR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0JjSW1Ob2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxmY0dVdGNHVmZRVFE0TlhaelJFMVRUMTlPVDE5a2FXWm1NQzR5TG1KbFpIQmxYQ0lwS1Z4dVlXNWphRzl5TG01dklEd3RJQ2hsZUhSeVlXTjBRVzVqYUc5eUtHeHZiM0F1Ym04cEtWeHViM1psY214aGNITWdQQzBnWm1sdVpFOTJaWEpzWVhCektHRnVZMmh2Y2k1dWJ5d2dZWFJoWXk1bmNpbGNibUZ1WTJodmNpNXVieUE4TFNCd2FXNTBaWEp6WldOMEtHRnVZMmh2Y2k1dWIxdHhkV1Z5ZVVocGRITW9iM1psY214aGNITXBYU3dnWVhSaFl5NW5jbHR6ZFdKcVpXTjBTR2wwY3lodmRtVnliR0Z3Y3lsZEtWeHVYRzVzYjI5d0xtUnZkMjRnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5d1pTMXdaVjlCTkRnMWRuTkVUVk5QWDBSUFYwNWZaR2xtWmpBdU1pNWlaV1J3WlZ3aUtTbGNibUZ1WTJodmNpNWtiM2R1SUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0d4dmIzQXVaRzkzYmlrcFhHNXZkbVZ5YkdGd2N5QThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG1SdmQyNHNJR0YwWVdNdVozSXBYRzVoYm1Ob2IzSXVaRzkzYmlBOExTQndhVzUwWlhKelpXTjBLR0Z1WTJodmNpNWtiM2R1VzNGMVpYSjVTR2wwY3lodmRtVnliR0Z3Y3lsZExDQmhkR0ZqTG1keVczTjFZbXBsWTNSSWFYUnpLRzkyWlhKc1lYQnpLVjBwWEc1Y2JseHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSlcbmFuY2hvci5hbGwgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5hbGwpKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5hbGwsIGF0YWMuZ3IpXG5hbmNob3IuYWxsIDwtIHBpbnRlcnNlY3QoYW5jaG9yLmFsbFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wLnVwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLnVwIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXApKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci51cCwgYXRhYy5ncilcbmFuY2hvci51cCA8LSBwaW50ZXJzZWN0KGFuY2hvci51cFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLm5vIDwtIChleHRyYWN0QW5jaG9yKGxvb3Aubm8pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5ubywgYXRhYy5ncilcbmFuY2hvci5ubyA8LSBwaW50ZXJzZWN0KGFuY2hvci5ub1txdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci5kb3duIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuZG93bikpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmRvd24sIGF0YWMuZ3IpXG5hbmNob3IuZG93biA8LSBwaW50ZXJzZWN0KGFuY2hvci5kb3duW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\)) %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVlYUmhZeUE4TFNCbWNtVmhaQ2hvWlhKbEtISmxaa1JwY2l3Z1hGeEhVMDB6TVRBMk1qVTNYMEZVUVVOZlJWTkRYekV1WW1Wa1hGd3BLU0FsUGlVZ1pIQnNlWEk2T25ObGJHVmpkQ2hXTVN3Z1ZqSXNJRll6S1Z4dVkyOXNibUZ0WlhNb1lYUmhZeWtnUEMwZ1l5aGNYR05vY2x4Y0xDQmNYSE4wWVhKMFhGd3NJRnhjWlc1a1hGd3BYRzVoZEdGakxtZHlJRHd0SUcxaGEyVkhVbUZ1WjJWelJuSnZiVVJoZEdGR2NtRnRaU2hoZEdGaktWeHVYRzRqSUV4UFFVUkpUa2NnVEU5UFVGTmNiaU1qSXlCSmJYQnZjblJwYm1jZ1pHbG1abVZ5Wlc1MGFXRnNJSEpsWjNWc1lYUnZjbmtnYkc5dmNITWdKaUJsZUhSeVlXTjBJR0Z1WTJodmNseHViRzl2Y0M1aGJHd2dQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lUzUwYzNaY1hDa3BJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRUZ1Ym04eUlDVnBiaVVnWXloY1hGQXRVRnhjTENCY1hGQXRSVnhjTENCY1hFVXRSVnhjS1NsY2JtRnVZMmh2Y2k1aGJHd2dQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1aGJHd3BLVnh1YjNabGNteGhjSE1nUEMwZ1ptbHVaRTkyWlhKc1lYQnpLR0Z1WTJodmNpNWhiR3dzSUdGMFlXTXVaM0lwWEc1aGJtTm9iM0l1WVd4c0lEd3RJSEJwYm5SbGNuTmxZM1FvWVc1amFHOXlMbUZzYkZ0eGRXVnllVWhwZEhNb2IzWmxjbXhoY0hNcFhTd2dZWFJoWXk1bmNsdHpkV0pxWldOMFNHbDBjeWh2ZG1WeWJHRndjeWxkS1Z4dVhHNXNiMjl3TG5Wd0lEd3RJR1p5WldGa0tHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQmNYR05vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGZjR1V0Y0dWZlFUUTROWFp6UkUxVFQxOVZVRjlrYVdabU1DNHlMbUpsWkhCbFhGd3BLVnh1WVc1amFHOXlMblZ3SUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0d4dmIzQXVkWEFwS1Z4dWIzWmxjbXhoY0hNZ1BDMGdabWx1WkU5MlpYSnNZWEJ6S0dGdVkyaHZjaTUxY0N3Z1lYUmhZeTVuY2lsY2JtRnVZMmh2Y2k1MWNDQThMU0J3YVc1MFpYSnpaV04wS0dGdVkyaHZjaTUxY0Z0eGRXVnllVWhwZEhNb2IzWmxjbXhoY0hNcFhTd2dZWFJoWXk1bmNsdHpkV0pxWldOMFNHbDBjeWh2ZG1WeWJHRndjeWxkS1Z4dVhHNXNiMjl3TG01dklEd3RJR1p5WldGa0tHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQmNYR05vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGZjR1V0Y0dWZlFUUTROWFp6UkUxVFQxOU9UMTlrYVdabU1DNHlMbUpsWkhCbFhGd3BLVnh1WVc1amFHOXlMbTV2SUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0d4dmIzQXVibThwS1Z4dWIzWmxjbXhoY0hNZ1BDMGdabWx1WkU5MlpYSnNZWEJ6S0dGdVkyaHZjaTV1Ynl3Z1lYUmhZeTVuY2lsY2JtRnVZMmh2Y2k1dWJ5QThMU0J3YVc1MFpYSnpaV04wS0dGdVkyaHZjaTV1YjF0eGRXVnllVWhwZEhNb2IzWmxjbXhoY0hNcFhTd2dZWFJoWXk1bmNsdHpkV0pxWldOMFNHbDBjeWh2ZG1WeWJHRndjeWxkS1Z4dVhHNXNiMjl3TG1SdmQyNGdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lVjl3WlMxd1pWOUJORGcxZG5ORVRWTlBYMFJQVjA1ZlpHbG1aakF1TWk1aVpXUndaVnhjS1NsY2JtRnVZMmh2Y2k1a2IzZHVJRHd0SUNobGVIUnlZV04wUVc1amFHOXlLR3h2YjNBdVpHOTNiaWtwWEc1dmRtVnliR0Z3Y3lBOExTQm1hVzVrVDNabGNteGhjSE1vWVc1amFHOXlMbVJ2ZDI0c0lHRjBZV011WjNJcFhHNWhibU5vYjNJdVpHOTNiaUE4TFNCd2FXNTBaWEp6WldOMEtHRnVZMmh2Y2k1a2IzZHVXM0YxWlhKNVNHbDBjeWh2ZG1WeWJHRndjeWxkTENCaGRHRmpMbWR5VzNOMVltcGxZM1JJYVhSektHOTJaWEpzWVhCektWMHBYRzVjYmx4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbmF0YWMgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcR1NNMzEwNjI1N19BVEFDX0VTQ18xLmJlZFxcKSkgJT4lIGRwbHlyOjpzZWxlY3QoVjEsIFYyLCBWMylcbmNvbG5hbWVzKGF0YWMpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuYXRhYy5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoYXRhYylcblxuIyBMT0FESU5HIExPT1BTXG4jIyMgSW1wb3J0aW5nIGRpZmZlcmVudGlhbCByZWd1bGF0b3J5IGxvb3BzICYgZXh0cmFjdCBhbmNob3Jcbmxvb3AuYWxsIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHkudHN2XFwpKSAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCkpXG5hbmNob3IuYWxsIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuYWxsKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuYWxsLCBhdGFjLmdyKVxuYW5jaG9yLmFsbCA8LSBwaW50ZXJzZWN0KGFuY2hvci5hbGxbcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci51cCA8LSAoZXh0cmFjdEFuY2hvcihsb29wLnVwKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IudXAsIGF0YWMuZ3IpXG5hbmNob3IudXAgPC0gcGludGVyc2VjdChhbmNob3IudXBbcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fTk9fZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci5ubyA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3Iubm8sIGF0YWMuZ3IpXG5hbmNob3Iubm8gPC0gcGludGVyc2VjdChhbmNob3Iubm9bcXVlcnlIaXRzKG92ZXJsYXBzKV0sIGF0YWMuZ3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IuZG93biA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5kb3duLCBhdGFjLmdyKVxuYW5jaG9yLmRvd24gPC0gcGludGVyc2VjdChhbmNob3IuZG93bltxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuYXRhYyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxHU00zMTA2MjU3X0FUQUNfRVNDXzEuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuY29sbmFtZXMoYXRhYykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5hdGFjLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhdGFjKVxuXG4jIExPQURJTkcgTE9PUFNcbiMjIyBJbXBvcnRpbmcgZGlmZmVyZW50aWFsIHJlZ3VsYXRvcnkgbG9vcHMgJiBleHRyYWN0IGFuY2hvclxubG9vcC5hbGwgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSlcbmFuY2hvci5hbGwgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5hbGwpKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5hbGwsIGF0YWMuZ3IpXG5hbmNob3IuYWxsIDwtIHBpbnRlcnNlY3QoYW5jaG9yLmFsbFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wLnVwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLnVwIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXApKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci51cCwgYXRhYy5ncilcbmFuY2hvci51cCA8LSBwaW50ZXJzZWN0KGFuY2hvci51cFtxdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLm5vIDwtIChleHRyYWN0QW5jaG9yKGxvb3Aubm8pKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGFuY2hvci5ubywgYXRhYy5ncilcbmFuY2hvci5ubyA8LSBwaW50ZXJzZWN0KGFuY2hvci5ub1txdWVyeUhpdHMob3ZlcmxhcHMpXSwgYXRhYy5ncltzdWJqZWN0SGl0cyhvdmVybGFwcyldKVxuXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci5kb3duIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuZG93bikpXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmRvd24sIGF0YWMuZ3IpXG5hbmNob3IuZG93biA8LSBwaW50ZXJzZWN0KGFuY2hvci5kb3duW3F1ZXJ5SGl0cyhvdmVybGFwcyldLCBhdGFjLmdyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cblxuYGBgXG5gYGAifQ== -->

```r
```r
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\)) %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBSVU5OSU5HIExPTEFcbmxvbGFEaXIgPC0gaGVyZShcIi4uLy4uL3Jlc3VsdC9sb2xhXCIpXG5kaXIuY3JlYXRlKGxvbGFEaXIsIHNob3dXYXJuaW5ncyA9IEZBTFNFLCByZWN1cnNpdmUgPSBUUlVFKVxuXG4jIFVQXG5yZXN1bHQgPSBydW5MT0xBKGFuY2hvci51cCwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFwiTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl91cF9hdGFjLnRzdlwiKSwgc2VwID0gXCJcXHRcIilcblxuIyBOT1xucmVzdWx0ID0gcnVuTE9MQShhbmNob3Iubm8sIGFuY2hvci5hbGwsIGxvbGFEQilcbnRiID0gYXNfdGliYmxlKHJlc3VsdClcbmZ3cml0ZSh0YiwgaGVyZShsb2xhRGlyLCBcIkxPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfbm9fYXRhYy50c3ZcIiksIHNlcCA9IFwiXFx0XCIpXG5cbiMgRE9XTlxucmVzdWx0ID0gcnVuTE9MQShhbmNob3IuZG93biwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFwiTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9kb3duX2F0YWMudHN2XCIpLCBzZXAgPSBcIlxcdFwiKVxuXG5cblxuIyMjIEhFQVRNQVBcbmFscGhhIDwtIDAuMDVcbnRiLnVwIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXCJMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX3VwX2F0YWMudHN2XCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFwiZW1icnlvbmljIHN0ZW0gY2VsbFwiKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG50Yi5ubyA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFwiTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9ub19hdGFjLnRzdlwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSkpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcImVtYnJ5b25pYyBzdGVtIGNlbGxcIikgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIuZG93biA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFwiTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9kb3duX2F0YWMudHN2XCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFwiZW1icnlvbmljIHN0ZW0gY2VsbFwiKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG5cbnRlbXAudXAgPC0gdGIudXAgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLnVwKSA8LSBjKFwidGFyZ2V0XCIsIFwiT1JfdXBcIilcbnRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLm5vKSA8LSBjKFwidGFyZ2V0XCIsIFwiT1Jfbm9cIilcbnRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvKVxuY29sbmFtZXModGVtcC5kb3duKSA8LSBjKFwidGFyZ2V0XCIsIFwiT1JfZG93blwiKVxuXG5cbnRlbXAgPC0gZnVsbF9qb2luKGZ1bGxfam9pbih0ZW1wLnVwLCB0ZW1wLm5vLCBieSA9IGMoXCJ0YXJnZXRcIikpLCB0ZW1wLmRvd24sIGJ5ID0gYyhcInRhcmdldFwiKSkgJT4lIG11dGF0ZV9hbGwofnJlcGxhY2VfbmEoLiwgMSkpXG5cbmRhdGEgPC0gYXMubWF0cml4KHRlbXBbMjo0XSlcbnJvd25hbWVzKGRhdGEpIDwtIHRlbXAkdGFyZ2V0XG5cbmxpYnJhcnkoY2lyY2xpemUpXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYyhtaW4oZGF0YSksIG1heChkYXRhKSksIGMoXCJ3aGl0ZVwiLCBcInJlZFwiKSlcblxuXG5wIDwtIEhlYXRtYXAoXG4gIGRhdGEsXG4gIG5hbWUgPSBcIk9kZHMgUmF0aW9cIiwgICAgICAgICAgICAgICAgICAgIyBOYW1lIG9mIHRoZSBoZWF0bWFwIGxlZ2VuZFxuICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSwgICAgICAgICAgICAjIFJlbW92ZSBjb2x1bW4gZGVuZHJvZ3JhbVxuICByb3dfa20gPSA0LCAgICAgICAgICAgICAgICAgICAgICAgICAjIERlZmluZSB0aGUgbnVtYmVyIG9mIGstbWVhbnMgY2x1c3RlcnMgZm9yIHJvd3MgKGFkanVzdCBhcyBuZWVkZWQpXG4gIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgY29sID0gY29sX2Z1biAgICAgICAgICAgICAgICAgICAgICAgIyBVc2UgdGhlIHJlZCBncmFkaWVudCBjb2xvciBzY2FsZVxuKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJhbmNob3JMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX3JlZ0FuY2hvckJhY2tncm91bmRfYXRhY1wiKVxuaGVpZ2h0IDwtIDdcbndpZHRoIDwtIDMuNVxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cbiMjIyBWaXN1YWxpemluZyBwLXZhbHVlIGFuZCBPUlxuYWxwaGEgPC0gMC4wNVxudGIudXAgPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcIkxPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfdXBfYXRhYy50c3ZcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpLFxuICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4gICAgICAgICAgICAgICAgZ3JvdXAgPSBcIlVQXCIpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcImVtYnJ5b25pYyBzdGVtIGNlbGxcIikgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIubm8gPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcIkxPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfbm9fYXRhYy50c3ZcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpLFxuICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4gICAgICAgICAgICAgICAgZ3JvdXAgPSBcIk5PXCIpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcImVtYnJ5b25pYyBzdGVtIGNlbGxcIikgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIuZG93biA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFwiTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9kb3duX2F0YWMudHN2XCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSxcbiAgICAgICAgICAgICAgICBxVmFsdWVMb2cgPSAtbG9nMihxVmFsdWUpLFxuICAgICAgICAgICAgICAgIGdyb3VwID0gXCJET1dOXCIpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcImVtYnJ5b25pYyBzdGVtIGNlbGxcIikgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxuXG50ZW1wLnVwIDwtIHRiLnVwICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvLCBxVmFsdWVMb2csIGdyb3VwKVxudGVtcC5ubyA8LSB0Yi5ubyAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIG9kZHNSYXRpbywgcVZhbHVlTG9nLCBncm91cClcbnRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvLCBxVmFsdWVMb2csIGdyb3VwKVxuXG50ZW1wIDwtIGJpbmRfcm93cyh0ZW1wLnVwLCB0ZW1wLmRvd24pXG5cbm9yZGVyIDwtIGMoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXCJVUFwiKSAlPiUgYXJyYW5nZShkZXNjKG9kZHNSYXRpbykpKSR0YXJnZXQsIFxuICAgICAgICAgICAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcIkRPV05cIikgJT4lIGFycmFuZ2UoZGVzYyhvZGRzUmF0aW8pKSkkdGFyZ2V0KVxudGVtcCR0YXJnZXQgPC0gZmFjdG9yKHRlbXAkdGFyZ2V0LCBsZXZlbHMgPSByZXYob3JkZXIpKVxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBncm91cCwgeSA9IHRhcmdldCwgY29sb3IgPSBxVmFsdWVMb2csIHNpemUgPSBvZGRzUmF0aW8pKSArXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl9ncmFkaWVudChsb3cgPSBcImJsdWVcIiwgaGlnaCA9IFwicmVkXCIpICtcbiAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICArXG4gIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuICAgICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgYXhpcyB0aXRsZSBzaXplIChpZiBub3QgcmVtb3ZlZClcbiAgICAgICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBsZWdlbmQgdGV4dCBzaXplXG4gICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJhbmNob3JMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX09SX3FWYWx1ZV9yZWdBbmNob3JCYWNrZ3JvdW5kX2F0YWNcIilcbmhlaWdodCA8LTNcbndpZHRoIDwtIDJcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYCJ9 -->\n\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv\\), sep = \\\\t\\)\n\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)\n  show_row_dend = FALSE,\n  col = col_fun                       # Use the red gradient color scale\n)\n\nfileName <- paste0(\\anchorLOLA_A485_vs_DMSO_diff0.2_regAnchorBackground_atac\\)\nheight <- 7\nwidth <- 3.5\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\UP\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.up, temp.down)\n\norder <- c((temp %>% dplyr::filter(group == \\UP\\) %>% arrange(desc(oddsRatio)))$target, \n           (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\ntemp$target <- factor(temp$target, levels = rev(order))\np <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n  geom_point() + theme_bw() + scale_color_gradient(low = \\blue\\, high = \\red\\) +\n  labs(x = NULL, y = NULL)  +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\nfileName <- paste0(\\anchorLOLA_A485_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac\\)\nheight <-3\nwidth <- 2\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
# RUNNING LOLA
lolaDir <- here(\../../result/lola\)
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv\), sep = \\t\)

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv\), sep = \\t\)

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv\), sep = \\t\)



### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c(\target\, \OR_up\)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c(\target\, \OR_no\)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c(\target\, \OR_down\)


temp <- full_join(full_join(temp.up, temp.no, by = c(\target\)), temp.down, by = c(\target\)) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun                       # Use the red gradient color scale
)

fileName <- paste0(\anchorLOLA_A485_vs_DMSO_diff0.2_regAnchorBackground_atac\)
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


### Visualizing p-value and OR
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \UP\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \NO\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \DOWN\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.up, temp.down)

order <- c((temp %>% dplyr::filter(group == \UP\) %>% arrange(desc(oddsRatio)))$target, 
           (temp %>% dplyr::filter(group == \DOWN\) %>% arrange(desc(oddsRatio)))$target)
temp$target <- factor(temp$target, levels = rev(order))
p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
  geom_point() + theme_bw() + scale_color_gradient(low = \blue\, high = \red\) +
  labs(x = NULL, y = NULL)  +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- paste0(\anchorLOLA_A485_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac\)
height <-3
width <- 2
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBSVU5OSU5HIExPTEFcbmxvbGFEaXIgPC0gaGVyZShcXC4uLy4uL3Jlc3VsdC9sb2xhXFwpXG5kaXIuY3JlYXRlKGxvbGFEaXIsIHNob3dXYXJuaW5ncyA9IEZBTFNFLCByZWN1cnNpdmUgPSBUUlVFKVxuXG4jIFVQXG5yZXN1bHQgPSBydW5MT0xBKGFuY2hvci51cCwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl91cF9hdGFjLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcblxuIyBOT1xucmVzdWx0ID0gcnVuTE9MQShhbmNob3Iubm8sIGFuY2hvci5hbGwsIGxvbGFEQilcbnRiID0gYXNfdGliYmxlKHJlc3VsdClcbmZ3cml0ZSh0YiwgaGVyZShsb2xhRGlyLCBcXExPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfbm9fYXRhYy50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5cbiMgRE9XTlxucmVzdWx0ID0gcnVuTE9MQShhbmNob3IuZG93biwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9kb3duX2F0YWMudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG5cblxuIyMjIEhFQVRNQVBcbmFscGhhIDwtIDAuMDVcbnRiLnVwIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXFxMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX3VwX2F0YWMudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG50Yi5ubyA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9ub19hdGFjLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSkpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIuZG93biA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9kb3duX2F0YWMudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG5cbnRlbXAudXAgPC0gdGIudXAgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLnVwKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1JfdXBcXClcbnRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLm5vKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1Jfbm9cXClcbnRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvKVxuY29sbmFtZXModGVtcC5kb3duKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1JfZG93blxcKVxuXG5cbnRlbXAgPC0gZnVsbF9qb2luKGZ1bGxfam9pbih0ZW1wLnVwLCB0ZW1wLm5vLCBieSA9IGMoXFx0YXJnZXRcXCkpLCB0ZW1wLmRvd24sIGJ5ID0gYyhcXHRhcmdldFxcKSkgJT4lIG11dGF0ZV9hbGwofnJlcGxhY2VfbmEoLiwgMSkpXG5cbmRhdGEgPC0gYXMubWF0cml4KHRlbXBbMjo0XSlcbnJvd25hbWVzKGRhdGEpIDwtIHRlbXAkdGFyZ2V0XG5cbmxpYnJhcnkoY2lyY2xpemUpXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYyhtaW4oZGF0YSksIG1heChkYXRhKSksIGMoXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuXG5wIDwtIEhlYXRtYXAoXG4gIGRhdGEsXG4gIG5hbWUgPSBcXE9kZHMgUmF0aW9cXCwgICAgICAgICAgICAgICAgICAgIyBOYW1lIG9mIHRoZSBoZWF0bWFwIGxlZ2VuZFxuICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSwgICAgICAgICAgICAjIFJlbW92ZSBjb2x1bW4gZGVuZHJvZ3JhbVxuICByb3dfa20gPSA0LCAgICAgICAgICAgICAgICAgICAgICAgICAjIERlZmluZSB0aGUgbnVtYmVyIG9mIGstbWVhbnMgY2x1c3RlcnMgZm9yIHJvd3MgKGFkanVzdCBhcyBuZWVkZWQpXG4gIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgY29sID0gY29sX2Z1biAgICAgICAgICAgICAgICAgICAgICAgIyBVc2UgdGhlIHJlZCBncmFkaWVudCBjb2xvciBzY2FsZVxuKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxhbmNob3JMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX3JlZ0FuY2hvckJhY2tncm91bmRfYXRhY1xcKVxuaGVpZ2h0IDwtIDdcbndpZHRoIDwtIDMuNVxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cbiMjIyBWaXN1YWxpemluZyBwLXZhbHVlIGFuZCBPUlxuYWxwaGEgPC0gMC4wNVxudGIudXAgPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcXExPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfdXBfYXRhYy50c3ZcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpLFxuICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4gICAgICAgICAgICAgICAgZ3JvdXAgPSBcXFVQXFwpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIubm8gPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcXExPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfbm9fYXRhYy50c3ZcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpLFxuICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4gICAgICAgICAgICAgICAgZ3JvdXAgPSBcXE5PXFwpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIuZG93biA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9kb3duX2F0YWMudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSxcbiAgICAgICAgICAgICAgICBxVmFsdWVMb2cgPSAtbG9nMihxVmFsdWUpLFxuICAgICAgICAgICAgICAgIGdyb3VwID0gXFxET1dOXFwpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxuXG50ZW1wLnVwIDwtIHRiLnVwICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvLCBxVmFsdWVMb2csIGdyb3VwKVxudGVtcC5ubyA8LSB0Yi5ubyAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIG9kZHNSYXRpbywgcVZhbHVlTG9nLCBncm91cClcbnRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvLCBxVmFsdWVMb2csIGdyb3VwKVxuXG50ZW1wIDwtIGJpbmRfcm93cyh0ZW1wLnVwLCB0ZW1wLmRvd24pXG5cbm9yZGVyIDwtIGMoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxVUFxcKSAlPiUgYXJyYW5nZShkZXNjKG9kZHNSYXRpbykpKSR0YXJnZXQsIFxuICAgICAgICAgICAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXERPV05cXCkgJT4lIGFycmFuZ2UoZGVzYyhvZGRzUmF0aW8pKSkkdGFyZ2V0KVxudGVtcCR0YXJnZXQgPC0gZmFjdG9yKHRlbXAkdGFyZ2V0LCBsZXZlbHMgPSByZXYob3JkZXIpKVxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBncm91cCwgeSA9IHRhcmdldCwgY29sb3IgPSBxVmFsdWVMb2csIHNpemUgPSBvZGRzUmF0aW8pKSArXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl9ncmFkaWVudChsb3cgPSBcXGJsdWVcXCwgaGlnaCA9IFxccmVkXFwpICtcbiAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICArXG4gIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuICAgICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgYXhpcyB0aXRsZSBzaXplIChpZiBub3QgcmVtb3ZlZClcbiAgICAgICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBsZWdlbmQgdGV4dCBzaXplXG4gICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxhbmNob3JMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX09SX3FWYWx1ZV9yZWdBbmNob3JCYWNrZ3JvdW5kX2F0YWNcXClcbmhlaWdodCA8LTNcbndpZHRoIDwtIDJcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\n# RUNNING LOLA\nlolaDir <- here(\\../../result/lola\\)\ndir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)\n\n# UP\nresult = runLOLA(anchor.up, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv\\), sep = \\\\t\\)\n\n# NO\nresult = runLOLA(anchor.no, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv\\), sep = \\\\t\\)\n\n# DOWN\nresult = runLOLA(anchor.down, anchor.all, lolaDB)\ntb = as_tibble(result)\nfwrite(tb, here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv\\), sep = \\\\t\\)\n\n\n\n### HEATMAP\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody)) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio)\ncolnames(temp.up) <- c(\\target\\, \\OR_up\\)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio)\ncolnames(temp.no) <- c(\\target\\, \\OR_no\\)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio)\ncolnames(temp.down) <- c(\\target\\, \\OR_down\\)\n\n\ntemp <- full_join(full_join(temp.up, temp.no, by = c(\\target\\)), temp.down, by = c(\\target\\)) %>% mutate_all(~replace_na(., 1))\n\ndata <- as.matrix(temp[2:4])\nrownames(data) <- temp$target\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(min(data), max(data)), c(\\white\\, \\red\\))\n\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)\n  show_row_dend = FALSE,\n  col = col_fun                       # Use the red gradient color scale\n)\n\nfileName <- paste0(\\anchorLOLA_A485_vs_DMSO_diff0.2_regAnchorBackground_atac\\)\nheight <- 7\nwidth <- 3.5\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n### Visualizing p-value and OR\nalpha <- 0.05\ntb.up <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\UP\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.no <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\NO\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\ntb.down <- fread(here(lolaDir, \\LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv\\)) %>%\n  dplyr::mutate(target = toupper(antibody),\n                qValueLog = -log2(qValue),\n                group = \\DOWN\\) %>%\n  filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%\n  slice_min(meanRnk, with_ties = FALSE)\n\ntemp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)\ntemp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)\n\ntemp <- bind_rows(temp.up, temp.down)\n\norder <- c((temp %>% dplyr::filter(group == \\UP\\) %>% arrange(desc(oddsRatio)))$target, \n           (temp %>% dplyr::filter(group == \\DOWN\\) %>% arrange(desc(oddsRatio)))$target)\ntemp$target <- factor(temp$target, levels = rev(order))\np <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +\n  geom_point() + theme_bw() + scale_color_gradient(low = \\blue\\, high = \\red\\) +\n  labs(x = NULL, y = NULL)  +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\nfileName <- paste0(\\anchorLOLA_A485_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac\\)\nheight <-3\nwidth <- 2\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBSVU5OSU5HIExPTEFcbmxvbGFEaXIgPC0gaGVyZShcXC4uLy4uL3Jlc3VsdC9sb2xhXFwpXG5kaXIuY3JlYXRlKGxvbGFEaXIsIHNob3dXYXJuaW5ncyA9IEZBTFNFLCByZWN1cnNpdmUgPSBUUlVFKVxuXG4jIFVQXG5yZXN1bHQgPSBydW5MT0xBKGFuY2hvci51cCwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl91cF9hdGFjLnRzdlxcKSwgc2VwID0gXFxcXHRcXClcblxuIyBOT1xucmVzdWx0ID0gcnVuTE9MQShhbmNob3Iubm8sIGFuY2hvci5hbGwsIGxvbGFEQilcbnRiID0gYXNfdGliYmxlKHJlc3VsdClcbmZ3cml0ZSh0YiwgaGVyZShsb2xhRGlyLCBcXExPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfbm9fYXRhYy50c3ZcXCksIHNlcCA9IFxcXFx0XFwpXG5cbiMgRE9XTlxucmVzdWx0ID0gcnVuTE9MQShhbmNob3IuZG93biwgYW5jaG9yLmFsbCwgbG9sYURCKVxudGIgPSBhc190aWJibGUocmVzdWx0KVxuZndyaXRlKHRiLCBoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9kb3duX2F0YWMudHN2XFwpLCBzZXAgPSBcXFxcdFxcKVxuXG5cblxuIyMjIEhFQVRNQVBcbmFscGhhIDwtIDAuMDVcbnRiLnVwIDwtIGZyZWFkKGhlcmUobG9sYURpciwgXFxMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX3VwX2F0YWMudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG50Yi5ubyA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9ub19hdGFjLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUodGFyZ2V0ID0gdG91cHBlcihhbnRpYm9keSkpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIuZG93biA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9kb3duX2F0YWMudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSkgJT4lXG4gIGZpbHRlcihzdHJfdG9fbG93ZXIoY2VsbFR5cGUpID09IFxcZW1icnlvbmljIHN0ZW0gY2VsbFxcKSAlPiVcbiAgZHBseXI6OmZpbHRlcihxVmFsdWUgPCBhbHBoYSkgJT4lIGRwbHlyOjpncm91cF9ieSh0YXJnZXQpICU+JVxuICBzbGljZV9taW4obWVhblJuaywgd2l0aF90aWVzID0gRkFMU0UpXG5cbnRlbXAudXAgPC0gdGIudXAgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLnVwKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1JfdXBcXClcbnRlbXAubm8gPC0gdGIubm8gJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBvZGRzUmF0aW8pXG5jb2xuYW1lcyh0ZW1wLm5vKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1Jfbm9cXClcbnRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvKVxuY29sbmFtZXModGVtcC5kb3duKSA8LSBjKFxcdGFyZ2V0XFwsIFxcT1JfZG93blxcKVxuXG5cbnRlbXAgPC0gZnVsbF9qb2luKGZ1bGxfam9pbih0ZW1wLnVwLCB0ZW1wLm5vLCBieSA9IGMoXFx0YXJnZXRcXCkpLCB0ZW1wLmRvd24sIGJ5ID0gYyhcXHRhcmdldFxcKSkgJT4lIG11dGF0ZV9hbGwofnJlcGxhY2VfbmEoLiwgMSkpXG5cbmRhdGEgPC0gYXMubWF0cml4KHRlbXBbMjo0XSlcbnJvd25hbWVzKGRhdGEpIDwtIHRlbXAkdGFyZ2V0XG5cbmxpYnJhcnkoY2lyY2xpemUpXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYyhtaW4oZGF0YSksIG1heChkYXRhKSksIGMoXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuXG5wIDwtIEhlYXRtYXAoXG4gIGRhdGEsXG4gIG5hbWUgPSBcXE9kZHMgUmF0aW9cXCwgICAgICAgICAgICAgICAgICAgIyBOYW1lIG9mIHRoZSBoZWF0bWFwIGxlZ2VuZFxuICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSwgICAgICAgICAgICAjIFJlbW92ZSBjb2x1bW4gZGVuZHJvZ3JhbVxuICByb3dfa20gPSA0LCAgICAgICAgICAgICAgICAgICAgICAgICAjIERlZmluZSB0aGUgbnVtYmVyIG9mIGstbWVhbnMgY2x1c3RlcnMgZm9yIHJvd3MgKGFkanVzdCBhcyBuZWVkZWQpXG4gIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgY29sID0gY29sX2Z1biAgICAgICAgICAgICAgICAgICAgICAgIyBVc2UgdGhlIHJlZCBncmFkaWVudCBjb2xvciBzY2FsZVxuKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxhbmNob3JMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX3JlZ0FuY2hvckJhY2tncm91bmRfYXRhY1xcKVxuaGVpZ2h0IDwtIDdcbndpZHRoIDwtIDMuNVxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cbiMjIyBWaXN1YWxpemluZyBwLXZhbHVlIGFuZCBPUlxuYWxwaGEgPC0gMC4wNVxudGIudXAgPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcXExPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfdXBfYXRhYy50c3ZcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpLFxuICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4gICAgICAgICAgICAgICAgZ3JvdXAgPSBcXFVQXFwpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIubm8gPC0gZnJlYWQoaGVyZShsb2xhRGlyLCBcXExPTEFfQTQ4NV92c19ETVNPX2RpZmYwLjJfbm9fYXRhYy50c3ZcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHRhcmdldCA9IHRvdXBwZXIoYW50aWJvZHkpLFxuICAgICAgICAgICAgICAgIHFWYWx1ZUxvZyA9IC1sb2cyKHFWYWx1ZSksXG4gICAgICAgICAgICAgICAgZ3JvdXAgPSBcXE5PXFwpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxudGIuZG93biA8LSBmcmVhZChoZXJlKGxvbGFEaXIsIFxcTE9MQV9BNDg1X3ZzX0RNU09fZGlmZjAuMl9kb3duX2F0YWMudHN2XFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZSh0YXJnZXQgPSB0b3VwcGVyKGFudGlib2R5KSxcbiAgICAgICAgICAgICAgICBxVmFsdWVMb2cgPSAtbG9nMihxVmFsdWUpLFxuICAgICAgICAgICAgICAgIGdyb3VwID0gXFxET1dOXFwpICU+JVxuICBmaWx0ZXIoc3RyX3RvX2xvd2VyKGNlbGxUeXBlKSA9PSBcXGVtYnJ5b25pYyBzdGVtIGNlbGxcXCkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIocVZhbHVlIDwgYWxwaGEpICU+JSBkcGx5cjo6Z3JvdXBfYnkodGFyZ2V0KSAlPiVcbiAgc2xpY2VfbWluKG1lYW5SbmssIHdpdGhfdGllcyA9IEZBTFNFKVxuXG50ZW1wLnVwIDwtIHRiLnVwICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvLCBxVmFsdWVMb2csIGdyb3VwKVxudGVtcC5ubyA8LSB0Yi5ubyAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIG9kZHNSYXRpbywgcVZhbHVlTG9nLCBncm91cClcbnRlbXAuZG93biA8LSB0Yi5kb3duICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgb2Rkc1JhdGlvLCBxVmFsdWVMb2csIGdyb3VwKVxuXG50ZW1wIDwtIGJpbmRfcm93cyh0ZW1wLnVwLCB0ZW1wLmRvd24pXG5cbm9yZGVyIDwtIGMoKHRlbXAgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxVUFxcKSAlPiUgYXJyYW5nZShkZXNjKG9kZHNSYXRpbykpKSR0YXJnZXQsIFxuICAgICAgICAgICAodGVtcCAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXERPV05cXCkgJT4lIGFycmFuZ2UoZGVzYyhvZGRzUmF0aW8pKSkkdGFyZ2V0KVxudGVtcCR0YXJnZXQgPC0gZmFjdG9yKHRlbXAkdGFyZ2V0LCBsZXZlbHMgPSByZXYob3JkZXIpKVxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBncm91cCwgeSA9IHRhcmdldCwgY29sb3IgPSBxVmFsdWVMb2csIHNpemUgPSBvZGRzUmF0aW8pKSArXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl9ncmFkaWVudChsb3cgPSBcXGJsdWVcXCwgaGlnaCA9IFxccmVkXFwpICtcbiAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICArXG4gIHRoZW1lKGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICAjIFNldCBheGlzIHRleHQgc2l6ZVxuICAgICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgIyBTZXQgYXhpcyB0aXRsZSBzaXplIChpZiBub3QgcmVtb3ZlZClcbiAgICAgICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBsZWdlbmQgdGV4dCBzaXplXG4gICAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gNikpIFxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxhbmNob3JMT0xBX0E0ODVfdnNfRE1TT19kaWZmMC4yX09SX3FWYWx1ZV9yZWdBbmNob3JCYWNrZ3JvdW5kX2F0YWNcXClcbmhlaWdodCA8LTNcbndpZHRoIDwtIDJcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
# RUNNING LOLA
lolaDir <- here(\../../result/lola\)
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv\), sep = \\t\)

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv\), sep = \\t\)

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv\), sep = \\t\)



### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c(\target\, \OR_up\)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c(\target\, \OR_no\)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c(\target\, \OR_down\)


temp <- full_join(full_join(temp.up, temp.no, by = c(\target\)), temp.down, by = c(\target\)) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun                       # Use the red gradient color scale
)

fileName <- paste0(\anchorLOLA_A485_vs_DMSO_diff0.2_regAnchorBackground_atac\)
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()


### Visualizing p-value and OR
alpha <- 0.05
tb.up <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \UP\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \NO\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, \LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv\)) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = \DOWN\) %>%
  filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.up, temp.down)

order <- c((temp %>% dplyr::filter(group == \UP\) %>% arrange(desc(oddsRatio)))$target, 
           (temp %>% dplyr::filter(group == \DOWN\) %>% arrange(desc(oddsRatio)))$target)
temp$target <- factor(temp$target, levels = rev(order))
p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
  geom_point() + theme_bw() + scale_color_gradient(low = \blue\, high = \red\) +
  labs(x = NULL, y = NULL)  +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- paste0(\anchorLOLA_A485_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac\)
height <-3
width <- 2
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### - Limited to ATAC-seq signal, reg loop backgrouund 

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1nU1cxd2IzSjBhVzVuSUdkeWIzVndjMXh1WjNKdmRYQXhJRHd0SUdaeVpXRmtLR2hsY21Vb2NtVm1SR2x5TENCY0ltZGxibVZNYVhOMFgyUlVRVWRmZG5OZlJFMVRUMTlTVGtGZmJHOXZjRjluY205MWNERXVkSE4yWENJcEtTUm5aVzVsWEc1bmNtOTFjRElnUEMwZ1puSmxZV1FvYUdWeVpTaHlaV1pFYVhJc0lGd2laMlZ1WlV4cGMzUmZaRlJCUjE5MmMxOUVUVk5QWDFKT1FWOXNiMjl3WDJkeWIzVndNaTUwYzNaY0lpa3BKR2RsYm1WY2JtZHliM1Z3TlNBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYQ0puWlc1bFRHbHpkRjlrVkVGSFgzWnpYMFJOVTA5ZlVrNUJYMnh2YjNCZlozSnZkWEExTG5SemRsd2lLU2trWjJWdVpWeHVaM0p2ZFhBNElEd3RJR1p5WldGa0tHaGxjbVVvY21WbVJHbHlMQ0JjSW1kbGJtVk1hWE4wWDJSVVFVZGZkbk5mUkUxVFQxOVNUa0ZmYkc5dmNGOW5jbTkxY0RndWRITjJYQ0lwS1NSblpXNWxYRzVjYmlNaklFbHRjRzl5ZEdsdVp5QlNUa0V0YzJWeElGUlFUU0JtYjNJZ1JFMVRUMXh1ZEhCdExuTmxiR1ZqZEdWa0lEd3RJR1p5WldGa0tHaGxjbVVvY21WbVJHbHlMQ0JjSW5KbFlXUkRiM1Z1ZEM1bWFXeDBaWEpsWkM1VVVFMHVZV3hzTG5SemRsd2lLU2tnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvTVN3Z015d2dOQ3dnTlNsY2JtTnZiRzVoYldWektIUndiUzV6Wld4bFkzUmxaQ2tnUEMwZ1l5aGNJbVZ1YzJWdFlteGNJaXdnWENKeVpYQXhYQ0lzSUZ3aWNtVndNbHdpTENCY0luSmxjRE5jSWlsY2JseHVkSEJ0TG5ObGJHVmpkR1ZrSUR3dElIUndiUzV6Wld4bFkzUmxaQ0FsUGlVZ1pIQnNlWEk2T25KdmQzZHBjMlVvS1NBbFBpVmNiaUFnWkhCc2VYSTZPbTExZEdGMFpTaGNiaUFnWjNKdmRYQWdQU0JwWm1Wc2MyVW9aVzV6WlcxaWJDQWxhVzRsSUdkeWIzVndNU3dnWENKbmNtOTFjREZjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2FXWmxiSE5sS0dWdWMyVnRZbXdnSldsdUpTQm5jbTkxY0RJc0lGd2laM0p2ZFhBeVhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnBabVZzYzJVb1pXNXpaVzFpYkNBbGFXNGxJR2R5YjNWd05Td2dYQ0puY205MWNEVmNJaXhjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnBabVZzYzJVb1pXNXpaVzFpYkNBbGFXNGxJR2R5YjNWd09Dd2dYQ0puY205MWNEaGNJaXdnVGtFcEtTa3BLU0FsUGlVZ1hHNGdJR1J3YkhseU9qcG1hV3gwWlhJb0lXbHpMbTVoS0dkeWIzVndLU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHRkWFJoZEdVb1lYWm5WRkJOSUQwZ2JXVmhiaWh5WlhBeExDQnlaWEF5TENCeVpYQXpLU2xjYmx4dVhHNW5aM0JzYjNRb2RIQnRMbk5sYkdWamRHVmtMQ0JoWlhNb2VDQTlJR2R5YjNWd0xDQjVJRDBnWVhablZGQk5LU2tnSzF4dUlDQm5aVzl0WDNacGIyeHBiaWhoWlhNb1ptbHNiQ0E5SUdkeWIzVndLU3dnYzJodmR5NXNaV2RsYm1RZ1BTQkdRVXhUUlNrZ0sxeHVJQ0JuWlc5dFgySnZlSEJzYjNRb2QybGtkR2dnUFNBd0xqRXNJRzkxZEd4cFpYSXVjMmhoY0dVZ1BTQk9RU2tnS3lCY2JpQWdjMk5oYkdWZmVWOXNiMmN4TUNncElDdGNiaUFnZEdobGJXVmZZMnhoYzNOcFl5Z3BYRzVjYmx4dVhHNGdJSEFnUEMwZ1oyZHdiRzkwS0hSbGJYQXVkR0lzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCelkyOXlaU2twSUNzZ1oyVnZiVjkyYVc5c2FXNG9ZV1Z6S0dacGJHd2dQU0JuY205MWNDa3NJSE5vYjNjdWJHVm5aVzVrSUQwZ1JrRk1VMFVwSUNzZ1hHNGdJQ0FnWjJWdmJWOWliM2h3Ykc5MEtIZHBaSFJvSUQwZ01DNHhMQ0J2ZFhSc2FXVnlMbk5vWVhCbElEMGdUa0VwSUN0Y2JpQWdJQ0J6ZEdGMFgzTjFiVzFoY25rb1lXVnpLR2R5YjNWd0lEMGdaM0p2ZFhBcExDQm1kVzRnUFNCdFpXRnVMQ0JuWlc5dElEMGdYQ0p3YjJsdWRGd2lMQ0J6YUdGd1pTQTlJREl4TENCemFYcGxJRDBnTWl3Z1ptbHNiQ0E5SUZ3aWNtVmtYQ0lzSUdOdmJHOXlJRDBnWENKaWJHRmphMXdpS1NBclhHNGdJQ0FnZEdobGJXVmZZMnhoYzNOcFl5Z3BJQ3NnWTI5dmNtUmZZMkZ5ZEdWemFXRnVLSGxzYVcwZ1BTQmpLSGx0YVc0c0lIbHRZWGdwS1NBclhHNGdJQ0FnWVc1dWIzUmhkR1VvWENKMFpYaDBYQ0lzSUhnZ1BTQXhMQ0I1SUQwZ2VXMXBiaUFySURFc0lHeGhZbVZzSUQwZ2NHRnpkR1V3S0Z3aWNERXlPaUJjSWl3Z1kyOXVkbEIyWVd4MVpTaHdNVElwTENCY0lseGNibHdpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdYQ0p3TVRVNklGd2lMQ0JqYjI1MlVIWmhiSFZsS0hBeE5Ta3NJRndpWEZ4dVhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCY0luQXhPRG9nWENJc0lHTnZiblpRZG1Gc2RXVW9jREU0S1N3Z1hDSmNYRzVjSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRndpY0RJMU9pQmNJaXdnWTI5dWRsQjJZV3gxWlNod01qVXBMQ0JjSWx4Y2Jsd2lMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hDSndNamc2SUZ3aUxDQmpiMjUyVUhaaGJIVmxLSEF5T0Nrc0lGd2lYRnh1WENJc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjSW5BMU9Eb2dYQ0lzWTI5dWRsQjJZV3gxWlNnZ2NEVTRLU3dnWENKY1hHNWNJaWtzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXNJR2hxZFhOMElEMGdNQ3dnYzJsNlpTQTlJRE1wWEc0Z0lGeHVJQ0JjYmlBZ1ptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGd2lhVzV6ZFd4aGRHbHZibDl6WTI5eVpWOWNJaXdnYm05MFpTbGNiaUFnYUdWcFoyaDBJRHd0SUROY2JpQWdkMmxrZEdnZ1BDMGdNMXh1SUNCd2JtY29hR1Z5WlNobWFXZEVhWElzSUhCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWENJdWNHNW5YQ0lwS1N3Z2NtVnpJRDBnTmpBd0xDQjFibWwwSUQwZ1hDSnBibHdpTENCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzRnSUhCeWFXNTBLSEFwWEc0Z0lHUmxkaTV2Wm1Zb0tWeHVJQ0J6ZG1kc2FYUmxLR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ3aUxuTjJaMXdpS1Nrc0lDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc0Z0lIQnlhVzUwS0hBcFhHNGdJR1JsZGk1dlptWW9LVnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbiMjIEltcG9ydGluZyBncm91cHNcbmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAxLnRzdlxcKSkkZ2VuZVxuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDIudHN2XFwpKSRnZW5lXG5ncm91cDUgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwNS50c3ZcXCkpJGdlbmVcbmdyb3VwOCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA4LnRzdlxcKSkkZ2VuZVxuXG4jIyBJbXBvcnRpbmcgUk5BLXNlcSBUUE0gZm9yIERNU09cbnRwbS5zZWxlY3RlZCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxyZWFkQ291bnQuZmlsdGVyZWQuVFBNLmFsbC50c3ZcXCkpICU+JSBkcGx5cjo6c2VsZWN0KDEsIDMsIDQsIDUpXG5jb2xuYW1lcyh0cG0uc2VsZWN0ZWQpIDwtIGMoXFxlbnNlbWJsXFwsIFxccmVwMVxcLCBcXHJlcDJcXCwgXFxyZXAzXFwpXG5cbnRwbS5zZWxlY3RlZCA8LSB0cG0uc2VsZWN0ZWQgJT4lIGRwbHlyOjpyb3d3aXNlKCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gaWZlbHNlKGVuc2VtYmwgJWluJSBncm91cDEsIFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAyLCBcXGdyb3VwMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBncm91cDUsIFxcZ3JvdXA1XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBncm91cDgsIFxcZ3JvdXA4XFwsIE5BKSkpKSkgJT4lIFxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGF2Z1RQTSA9IG1lYW4ocmVwMSwgcmVwMiwgcmVwMykpXG5cblxuZ2dwbG90KHRwbS5zZWxlY3RlZCwgYWVzKHggPSBncm91cCwgeSA9IGF2Z1RQTSkpICtcbiAgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICtcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICsgXG4gIHNjYWxlX3lfbG9nMTAoKSArXG4gIHRoZW1lX2NsYXNzaWMoKVxuXG5cblxuICBwIDwtIGdncGxvdCh0ZW1wLnRiLCBhZXMoeCA9IGdyb3VwLCB5ID0gc2NvcmUpKSArIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArIFxuICAgIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gICAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIHRoZW1lX2NsYXNzaWMoKSArIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYyh5bWluLCB5bWF4KSkgK1xuICAgIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IHltaW4gKyAxLCBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE1OiBcXCwgY29udlB2YWx1ZShwMTUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTg6IFxcLCBjb252UHZhbHVlKHAxOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyNTogXFwsIGNvbnZQdmFsdWUocDI1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI4OiBcXCwgY29udlB2YWx1ZShwMjgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwNTg6IFxcLGNvbnZQdmFsdWUoIHA1OCksIFxcXFxuXFwpLFxuICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLCBoanVzdCA9IDAsIHNpemUgPSAzKVxuICBcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXGluc3VsYXRpb25fc2NvcmVfXFwsIG5vdGUpXG4gIGhlaWdodCA8LSAzXG4gIHdpZHRoIDwtIDNcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwKVxuICBkZXYub2ZmKClcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
## Importing groups
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene

## Importing RNA-seq TPM for DMSO
tpm.selected <- fread(here(refDir, \readCount.filtered.TPM.all.tsv\)) %>% dplyr::select(1, 3, 4, 5)
colnames(tpm.selected) <- c(\ensembl\, \rep1\, \rep2\, \rep3\)

tpm.selected <- tpm.selected %>% dplyr::rowwise() %>%
  dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\,
                        ifelse(ensembl %in% group5, \group5\,
                               ifelse(ensembl %in% group8, \group8\, NA))))) %>% 
  dplyr::filter(!is.na(group)) %>%
  dplyr::mutate(avgTPM = mean(rep1, rep2, rep3))


ggplot(tpm.selected, aes(x = group, y = avgTPM)) +
  geom_violin(aes(fill = group), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + 
  scale_y_log10() +
  theme_classic()



  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWdTVzF3YjNKMGFXNW5JR2R5YjNWd2MxeHVaM0p2ZFhBeElEd3RJR1p5WldGa0tHaGxjbVVvY21WbVJHbHlMQ0JjWEdkbGJtVk1hWE4wWDJSVVFVZGZkbk5mUkUxVFQxOVNUa0ZmYkc5dmNGOW5jbTkxY0RFdWRITjJYRndwS1NSblpXNWxYRzVuY205MWNESWdQQzBnWm5KbFlXUW9hR1Z5WlNoeVpXWkVhWElzSUZ4Y1oyVnVaVXhwYzNSZlpGUkJSMTkyYzE5RVRWTlBYMUpPUVY5c2IyOXdYMmR5YjNWd01pNTBjM1pjWENrcEpHZGxibVZjYm1keWIzVndOU0E4TFNCbWNtVmhaQ2hvWlhKbEtISmxaa1JwY2l3Z1hGeG5aVzVsVEdsemRGOWtWRUZIWDNaelgwUk5VMDlmVWs1QlgyeHZiM0JmWjNKdmRYQTFMblJ6ZGx4Y0tTa2taMlZ1WlZ4dVozSnZkWEE0SUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNYR2RsYm1WTWFYTjBYMlJVUVVkZmRuTmZSRTFUVDE5U1RrRmZiRzl2Y0Y5bmNtOTFjRGd1ZEhOMlhGd3BLU1JuWlc1bFhHNWNiaU1qSUVsdGNHOXlkR2x1WnlCU1RrRXRjMlZ4SUZSUVRTQm1iM0lnUkUxVFQxeHVkSEJ0TG5ObGJHVmpkR1ZrSUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNYSEpsWVdSRGIzVnVkQzVtYVd4MFpYSmxaQzVVVUUwdVlXeHNMblJ6ZGx4Y0tTa2dKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9NU3dnTXl3Z05Dd2dOU2xjYm1OdmJHNWhiV1Z6S0hSd2JTNXpaV3hsWTNSbFpDa2dQQzBnWXloY1hHVnVjMlZ0WW14Y1hDd2dYRnh5WlhBeFhGd3NJRnhjY21Wd01seGNMQ0JjWEhKbGNETmNYQ2xjYmx4dWRIQnRMbk5sYkdWamRHVmtJRHd0SUhSd2JTNXpaV3hsWTNSbFpDQWxQaVVnWkhCc2VYSTZPbkp2ZDNkcGMyVW9LU0FsUGlWY2JpQWdaSEJzZVhJNk9tMTFkR0YwWlNoY2JpQWdaM0p2ZFhBZ1BTQnBabVZzYzJVb1pXNXpaVzFpYkNBbGFXNGxJR2R5YjNWd01Td2dYRnhuY205MWNERmNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR1Z1YzJWdFltd2dKV2x1SlNCbmNtOTFjRElzSUZ4Y1ozSnZkWEF5WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCcFptVnNjMlVvWlc1elpXMWliQ0FsYVc0bElHZHliM1Z3TlN3Z1hGeG5jbTkxY0RWY1hDeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCcFptVnNjMlVvWlc1elpXMWliQ0FsYVc0bElHZHliM1Z3T0N3Z1hGeG5jbTkxY0RoY1hDd2dUa0VwS1NrcEtTQWxQaVVnWEc0Z0lHUndiSGx5T2pwbWFXeDBaWElvSVdsekxtNWhLR2R5YjNWd0tTa2dKVDRsWEc0Z0lHUndiSGx5T2pwdGRYUmhkR1VvWVhablZGQk5JRDBnYldWaGJpaHlaWEF4TENCeVpYQXlMQ0J5WlhBektTbGNibHh1WEc1blozQnNiM1FvZEhCdExuTmxiR1ZqZEdWa0xDQmhaWE1vZUNBOUlHZHliM1Z3TENCNUlEMGdZWFpuVkZCTktTa2dLMXh1SUNCblpXOXRYM1pwYjJ4cGJpaGhaWE1vWm1sc2JDQTlJR2R5YjNWd0tTd2djMmh2ZHk1c1pXZGxibVFnUFNCR1FVeFRSU2tnSzF4dUlDQm5aVzl0WDJKdmVIQnNiM1FvZDJsa2RHZ2dQU0F3TGpFc0lHOTFkR3hwWlhJdWMyaGhjR1VnUFNCT1FTa2dLeUJjYmlBZ2MyTmhiR1ZmZVY5c2IyY3hNQ2dwSUN0Y2JpQWdkR2hsYldWZlkyeGhjM05wWXlncFhHNWNibHh1WEc0Z0lIQWdQQzBnWjJkd2JHOTBLSFJsYlhBdWRHSXNJR0ZsY3loNElEMGdaM0p2ZFhBc0lIa2dQU0J6WTI5eVpTa3BJQ3NnWjJWdmJWOTJhVzlzYVc0b1lXVnpLR1pwYkd3Z1BTQm5jbTkxY0Nrc0lITm9iM2N1YkdWblpXNWtJRDBnUmtGTVUwVXBJQ3NnWEc0Z0lDQWdaMlZ2YlY5aWIzaHdiRzkwS0hkcFpIUm9JRDBnTUM0eExDQnZkWFJzYVdWeUxuTm9ZWEJsSUQwZ1RrRXBJQ3RjYmlBZ0lDQnpkR0YwWDNOMWJXMWhjbmtvWVdWektHZHliM1Z3SUQwZ1ozSnZkWEFwTENCbWRXNGdQU0J0WldGdUxDQm5aVzl0SUQwZ1hGeHdiMmx1ZEZ4Y0xDQnphR0Z3WlNBOUlESXhMQ0J6YVhwbElEMGdNaXdnWm1sc2JDQTlJRnhjY21Wa1hGd3NJR052Ykc5eUlEMGdYRnhpYkdGamExeGNLU0FyWEc0Z0lDQWdkR2hsYldWZlkyeGhjM05wWXlncElDc2dZMjl2Y21SZlkyRnlkR1Z6YVdGdUtIbHNhVzBnUFNCaktIbHRhVzRzSUhsdFlYZ3BLU0FyWEc0Z0lDQWdZVzV1YjNSaGRHVW9YRngwWlhoMFhGd3NJSGdnUFNBeExDQjVJRDBnZVcxcGJpQXJJREVzSUd4aFltVnNJRDBnY0dGemRHVXdLRnhjY0RFeU9pQmNYQ3dnWTI5dWRsQjJZV3gxWlNod01USXBMQ0JjWEZ4Y2JseGNMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1hGeHdNVFU2SUZ4Y0xDQmpiMjUyVUhaaGJIVmxLSEF4TlNrc0lGeGNYRnh1WEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JjWEhBeE9Eb2dYRndzSUdOdmJuWlFkbUZzZFdVb2NERTRLU3dnWEZ4Y1hHNWNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGeGNjREkxT2lCY1hDd2dZMjl1ZGxCMllXeDFaU2h3TWpVcExDQmNYRnhjYmx4Y0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWEZ4d01qZzZJRnhjTENCamIyNTJVSFpoYkhWbEtIQXlPQ2tzSUZ4Y1hGeHVYRndzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmNYSEExT0RvZ1hGd3NZMjl1ZGxCMllXeDFaU2dnY0RVNEtTd2dYRnhjWEc1Y1hDa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3c0lHaHFkWE4wSUQwZ01Dd2djMmw2WlNBOUlETXBYRzRnSUZ4dUlDQmNiaUFnWm1sc1pVNWhiV1VnUEMwZ2NHRnpkR1V3S0Z4Y2FXNXpkV3hoZEdsdmJsOXpZMjl5WlY5Y1hDd2dibTkwWlNsY2JpQWdhR1ZwWjJoMElEd3RJRE5jYmlBZ2QybGtkR2dnUEMwZ00xeHVJQ0J3Ym1jb2FHVnlaU2htYVdkRWFYSXNJSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYRnd1Y0c1blhGd3BLU3dnY21WeklEMGdOakF3TENCMWJtbDBJRDBnWEZ4cGJseGNMQ0JvWldsbmFIUWdQU0JvWldsbmFIUXNJSGRwWkhSb0lEMGdkMmxrZEdncFhHNGdJSEJ5YVc1MEtIQXBYRzRnSUdSbGRpNXZabVlvS1Z4dUlDQnpkbWRzYVhSbEtHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRnhjTG5OMloxeGNLU2tzSUNCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzRnSUhCeWFXNTBLSEFwWEc0Z0lHUmxkaTV2Wm1Zb0tWeHVZR0JnWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5gYGByXG4jIyBJbXBvcnRpbmcgZ3JvdXBzXG5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMS50c3ZcXCkpJGdlbmVcbmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAyLnRzdlxcKSkkZ2VuZVxuZ3JvdXA1IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDUudHN2XFwpKSRnZW5lXG5ncm91cDggPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwOC50c3ZcXCkpJGdlbmVcblxuIyMgSW1wb3J0aW5nIFJOQS1zZXEgVFBNIGZvciBETVNPXG50cG0uc2VsZWN0ZWQgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxccmVhZENvdW50LmZpbHRlcmVkLlRQTS5hbGwudHN2XFwpKSAlPiUgZHBseXI6OnNlbGVjdCgxLCAzLCA0LCA1KVxuY29sbmFtZXModHBtLnNlbGVjdGVkKSA8LSBjKFxcZW5zZW1ibFxcLCBcXHJlcDFcXCwgXFxyZXAyXFwsIFxccmVwM1xcKVxuXG50cG0uc2VsZWN0ZWQgPC0gdHBtLnNlbGVjdGVkICU+JSBkcGx5cjo6cm93d2lzZSgpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXAxLCBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMiwgXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA1LCBcXGdyb3VwNVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShlbnNlbWJsICVpbiUgZ3JvdXA4LCBcXGdyb3VwOFxcLCBOQSkpKSkpICU+JSBcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKSAlPiVcbiAgZHBseXI6Om11dGF0ZShhdmdUUE0gPSBtZWFuKHJlcDEsIHJlcDIsIHJlcDMpKVxuXG5cbmdncGxvdCh0cG0uc2VsZWN0ZWQsIGFlcyh4ID0gZ3JvdXAsIHkgPSBhdmdUUE0pKSArXG4gIGdlb21fdmlvbGluKGFlcyhmaWxsID0gZ3JvdXApLCBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArIFxuICBzY2FsZV95X2xvZzEwKCkgK1xuICB0aGVtZV9jbGFzc2ljKClcblxuXG5cbiAgcCA8LSBnZ3Bsb3QodGVtcC50YiwgYWVzKHggPSBncm91cCwgeSA9IHNjb3JlKSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgK1xuICAgIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICB0aGVtZV9jbGFzc2ljKCkgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoeW1pbiwgeW1heCkpICtcbiAgICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSB5bWluICsgMSwgbGFiZWwgPSBwYXN0ZTAoXFxwMTI6IFxcLCBjb252UHZhbHVlKHAxMiksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxNTogXFwsIGNvbnZQdmFsdWUocDE1KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDE4OiBcXCwgY29udlB2YWx1ZShwMTgpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjU6IFxcLCBjb252UHZhbHVlKHAyNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAyODogXFwsIGNvbnZQdmFsdWUocDI4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDU4OiBcXCxjb252UHZhbHVlKCBwNTgpLCBcXFxcblxcKSxcbiAgICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMylcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxpbnN1bGF0aW9uX3Njb3JlX1xcLCBub3RlKVxuICBoZWlnaHQgPC0gM1xuICB3aWR0aCA8LSAzXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMgSW1wb3J0aW5nIGdyb3Vwc1xuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcXCkpJGdlbmVcbmdyb3VwNSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA1LnRzdlxcKSkkZ2VuZVxuZ3JvdXA4IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9ncm91cDgudHN2XFwpKSRnZW5lXG5cbiMjIEltcG9ydGluZyBSTkEtc2VxIFRQTSBmb3IgRE1TT1xudHBtLnNlbGVjdGVkIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXHJlYWRDb3VudC5maWx0ZXJlZC5UUE0uYWxsLnRzdlxcKSkgJT4lIGRwbHlyOjpzZWxlY3QoMSwgMywgNCwgNSlcbmNvbG5hbWVzKHRwbS5zZWxlY3RlZCkgPC0gYyhcXGVuc2VtYmxcXCwgXFxyZXAxXFwsIFxccmVwMlxcLCBcXHJlcDNcXClcblxudHBtLnNlbGVjdGVkIDwtIHRwbS5zZWxlY3RlZCAlPiUgZHBseXI6OnJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgZ3JvdXAgPSBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwMSwgXFxncm91cDFcXCxcbiAgICAgICAgICAgICAgICAgaWZlbHNlKGVuc2VtYmwgJWluJSBncm91cDIsIFxcZ3JvdXAyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwNSwgXFxncm91cDVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZW5zZW1ibCAlaW4lIGdyb3VwOCwgXFxncm91cDhcXCwgTkEpKSkpKSAlPiUgXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoYXZnVFBNID0gbWVhbihyZXAxLCByZXAyLCByZXAzKSlcblxuXG5nZ3Bsb3QodHBtLnNlbGVjdGVkLCBhZXMoeCA9IGdyb3VwLCB5ID0gYXZnVFBNKSkgK1xuICBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjEsIG91dGxpZXIuc2hhcGUgPSBOQSkgKyBcbiAgc2NhbGVfeV9sb2cxMCgpICtcbiAgdGhlbWVfY2xhc3NpYygpXG5cblxuXG4gIHAgPC0gZ2dwbG90KHRlbXAudGIsIGFlcyh4ID0gZ3JvdXAsIHkgPSBzY29yZSkpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBncm91cCksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgdGhlbWVfY2xhc3NpYygpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHltaW4sIHltYXgpKSArXG4gICAgYW5ub3RhdGUoXFx0ZXh0XFwsIHggPSAxLCB5ID0geW1pbiArIDEsIGxhYmVsID0gcGFzdGUwKFxccDEyOiBcXCwgY29udlB2YWx1ZShwMTIpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMTU6IFxcLCBjb252UHZhbHVlKHAxNSksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHAxODogXFwsIGNvbnZQdmFsdWUocDE4KSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccDI1OiBcXCwgY29udlB2YWx1ZShwMjUpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwMjg6IFxcLCBjb252UHZhbHVlKHAyOCksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHA1ODogXFwsY29udlB2YWx1ZSggcDU4KSwgXFxcXG5cXCksXG4gICAgICAgICAgICAgY29sb3IgPSBcXGJsYWNrXFwsIGhqdXN0ID0gMCwgc2l6ZSA9IDMpXG4gIFxuICBcbiAgZmlsZU5hbWUgPC0gcGFzdGUwKFxcaW5zdWxhdGlvbl9zY29yZV9cXCwgbm90ZSlcbiAgaGVpZ2h0IDwtIDNcbiAgd2lkdGggPC0gM1xuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuICBzdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG4gIHByaW50KHApXG4gIGRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
## Importing groups
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene

## Importing RNA-seq TPM for DMSO
tpm.selected <- fread(here(refDir, \readCount.filtered.TPM.all.tsv\)) %>% dplyr::select(1, 3, 4, 5)
colnames(tpm.selected) <- c(\ensembl\, \rep1\, \rep2\, \rep3\)

tpm.selected <- tpm.selected %>% dplyr::rowwise() %>%
  dplyr::mutate(
  group = ifelse(ensembl %in% group1, \group1\,
                 ifelse(ensembl %in% group2, \group2\,
                        ifelse(ensembl %in% group5, \group5\,
                               ifelse(ensembl %in% group8, \group8\, NA))))) %>% 
  dplyr::filter(!is.na(group)) %>%
  dplyr::mutate(avgTPM = mean(rep1, rep2, rep3))


ggplot(tpm.selected, aes(x = group, y = avgTPM)) +
  geom_violin(aes(fill = group), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + 
  scale_y_log10() +
  theme_classic()



  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate(\text\, x = 1, y = ymin + 1, label = paste0(\p12: \, convPvalue(p12), \\n\,
                                                         \p15: \, convPvalue(p15), \\n\,
                                                         \p18: \, convPvalue(p18), \\n\,
                                                         \p25: \, convPvalue(p25), \\n\,
                                                         \p28: \, convPvalue(p28), \\n\,
                                                         \p58: \,convPvalue( p58), \\n\),
             color = \black\, hjust = 0, size = 3)
  
  
  fileName <- paste0(\insulation_score_\, note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n## Importing groups\ngroup1 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\"))$gene\ngroup2 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\"))$gene\ngroup5 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\"))$gene\ngroup8 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\"))$gene\n\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \"bobbie_gene_classification.csv\")) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\"gene\", \"ensembl_transcript_id\", \"cluster\")\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\"ensembl_transcript_id\", \"ensembl_gene_id\"),\n                 filters = \"ensembl_transcript_id\",\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\"ensembl_transcript_id\"))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \"Early\")\n  n2 <- countGene(geneCluster, groupName, \"Middle\")\n  n3 <-countGene(geneCluster, groupName, \"Late\")\n  n4 <- countGene(geneCluster, groupName, \"Transient\")\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\"group1\", 4), rep(\"group2\", 4), rep(\"group3\", 4), rep(\"group4\", 4))\ncluster <- rep(c(\"Early\", \"Middle\", \"Late\", \"Transient\"), 4)\ncluster <- factor(cluster, levels = c(\"Early\", \"Middle\", \"Late\", \"Transient\"))\nvalue <- c(countGeneList(geneCluster, group1),\n           countGeneList(geneCluster, group2),\n           countGeneList(geneCluster, group5),\n           countGeneList(geneCluster, group8))\n\ndata <- data.frame(group, cluster, value)\n\n\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\"fill\", stat=\"identity\") + theme_classic()\n\n\n# Statistical analysis \n# Similar to the Chi-Square test, Fisher’s Exact Test is used when you have smaller sample sizes or when the expected frequency in any cell of the contingency table is below 5.\ntemp <- data %>% dplyr::filter(group %in% c(\"group1\", \"group2\"))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\"group1\", \"group3\"))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\"group1\", \"group4\"))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n\n### P-N\nresultDir <- here(\"../../result\")\ntemp2 <- readRDS(here(resultDir, \"gene_loop_link.rds\"))\n\npnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene\npnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene\npnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene\npnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene\npnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene\n\ngroup <- c(rep(\"pnOver8\", 4), rep(\"pnOver6\", 4), rep(\"pnOver4\", 4), rep(\"pnOver2\", 4), rep(\"pnOver0\", 4))\ncluster <- rep(c(\"Early\", \"Middle\", \"Late\", \"Transient\"), 5)\ncluster <- factor(cluster, levels = c(\"Early\", \"Middle\", \"Late\", \"Transient\"))\nvalue <- c(countGeneList(geneCluster, pnOver8),\n           countGeneList(geneCluster, pnOver6),\n           countGeneList(geneCluster, pnOver4),\n           countGeneList(geneCluster, pnOver2),\n           countGeneList(geneCluster, pnOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\"fill\", stat=\"identity\") + theme_classic()\n\ntemp <- data %>% dplyr::filter(group %in% c(\"pnOver2\", \"pnOver8\"))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n### P-S\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\ngroup <- c(rep(\"psOver4\", 4), rep(\"psOver3\", 4), rep(\"psOver2\", 4), rep(\"psOver1\", 4), rep(\"psOver0\", 4))\ncluster <- rep(c(\"Early\", \"Middle\", \"Late\", \"Transient\"), 5)\ncluster <- factor(cluster, levels = c(\"Early\", \"Middle\", \"Late\", \"Transient\"))\nvalue <- c(countGeneList(geneCluster, psOver4),\n           countGeneList(geneCluster, psOver3),\n           countGeneList(geneCluster, psOver2),\n           countGeneList(geneCluster, psOver1),\n           countGeneList(geneCluster, psOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\"fill\", stat=\"identity\") + theme_classic()\ntemp <- data %>% dplyr::filter(group %in% c(\"psOver2\", \"psOver4\"))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n### P-E\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\ngroup <- c(rep(\"peOver4\", 4), rep(\"peOver3\", 4), rep(\"peOver2\", 4), rep(\"peOver1\", 4), rep(\"peOver0\", 4))\ncluster <- rep(c(\"Early\", \"Middle\", \"Late\", \"Transient\"), 5)\ncluster <- factor(cluster, levels = c(\"Early\", \"Middle\", \"Late\", \"Transient\"))\nvalue <- c(countGeneList(geneCluster, peOver4),\n           countGeneList(geneCluster, peOver3),\n           countGeneList(geneCluster, peOver2),\n           countGeneList(geneCluster, peOver1),\n           countGeneList(geneCluster, peOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\"fill\", stat=\"identity\") + theme_classic()\n\n### P-P\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\ngroup <- c(rep(\"ppOver4\", 4), rep(\"ppOver3\", 4), rep(\"ppOver2\", 4), rep(\"ppOver1\", 4), rep(\"ppOver0\", 4))\ncluster <- rep(c(\"Early\", \"Middle\", \"Late\", \"Transient\"), 5)\ncluster <- factor(cluster, levels = c(\"Early\", \"Middle\", \"Late\", \"Transient\"))\nvalue <- c(countGeneList(geneCluster, ppOver4),\n           countGeneList(geneCluster, ppOver3),\n           countGeneList(geneCluster, ppOver2),\n           countGeneList(geneCluster, ppOver1),\n           countGeneList(geneCluster, ppOver0))\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\"fill\", stat=\"identity\") + theme_classic()\n\n```"} -->\n\n```r\n## Importing groups\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\))$gene\n\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \\bobbie_gene_classification.csv\\)) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\\gene\\, \\ensembl_transcript_id\\, \\cluster\\)\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\\ensembl_transcript_id\\, \\ensembl_gene_id\\),\n                 filters = \\ensembl_transcript_id\\,\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\\ensembl_transcript_id\\))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \\Early\\)\n  n2 <- countGene(geneCluster, groupName, \\Middle\\)\n  n3 <-countGene(geneCluster, groupName, \\Late\\)\n  n4 <- countGene(geneCluster, groupName, \\Transient\\)\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\\group1\\, 4), rep(\\group2\\, 4), rep(\\group3\\, 4), rep(\\group4\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 4)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, group1),\n           countGeneList(geneCluster, group2),\n           countGeneList(geneCluster, group5),\n           countGeneList(geneCluster, group8))\n\ndata <- data.frame(group, cluster, value)\n\n\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n\n# Statistical analysis \n# Similar to the Chi-Square test, Fisher’s Exact Test is used when you have smaller sample sizes or when the expected frequency in any cell of the contingency table is below 5.\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group2\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group3\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group4\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n\n### P-N\nresultDir <- here(\\../../result\\)\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene\npnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene\npnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene\npnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene\npnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene\n\ngroup <- c(rep(\\pnOver8\\, 4), rep(\\pnOver6\\, 4), rep(\\pnOver4\\, 4), rep(\\pnOver2\\, 4), rep(\\pnOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, pnOver8),\n           countGeneList(geneCluster, pnOver6),\n           countGeneList(geneCluster, pnOver4),\n           countGeneList(geneCluster, pnOver2),\n           countGeneList(geneCluster, pnOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\ntemp <- data %>% dplyr::filter(group %in% c(\\pnOver2\\, \\pnOver8\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n### P-S\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\ngroup <- c(rep(\\psOver4\\, 4), rep(\\psOver3\\, 4), rep(\\psOver2\\, 4), rep(\\psOver1\\, 4), rep(\\psOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, psOver4),\n           countGeneList(geneCluster, psOver3),\n           countGeneList(geneCluster, psOver2),\n           countGeneList(geneCluster, psOver1),\n           countGeneList(geneCluster, psOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\ntemp <- data %>% dplyr::filter(group %in% c(\\psOver2\\, \\psOver4\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n### P-E\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\ngroup <- c(rep(\\peOver4\\, 4), rep(\\peOver3\\, 4), rep(\\peOver2\\, 4), rep(\\peOver1\\, 4), rep(\\peOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, peOver4),\n           countGeneList(geneCluster, peOver3),\n           countGeneList(geneCluster, peOver2),\n           countGeneList(geneCluster, peOver1),\n           countGeneList(geneCluster, peOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n### P-P\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\ngroup <- c(rep(\\ppOver4\\, 4), rep(\\ppOver3\\, 4), rep(\\ppOver2\\, 4), rep(\\ppOver1\\, 4), rep(\\ppOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, ppOver4),\n           countGeneList(geneCluster, ppOver3),\n           countGeneList(geneCluster, ppOver2),\n           countGeneList(geneCluster, ppOver1),\n           countGeneList(geneCluster, ppOver0))\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n```\n\n<!-- rnb-source-end -->\n"} -->
## Importing groups
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene


## Importing Bobbie gene classification
geneCluster <- fread(here(refDir, \bobbie_gene_classification.csv\)) %>%
  dplyr::select(gene, enst, Cluster)
colnames(geneCluster) <- c(\gene\, \ensembl_transcript_id\, \cluster\)


## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c(\ensembl_transcript_id\, \ensembl_gene_id\),
                 filters = \ensembl_transcript_id\,
                 values = geneCluster$ensembl_transcript,
                 mart = ensembl.v102)
geneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\ensembl_transcript_id\))

# Making data for stacked barplot
countGene <- function(geneCluster, groupName, clusterName){
  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,
                                            cluster %in% clusterName))
  return(num)
}
countGeneList <- function(geneCluster, groupName){
  n1 <- countGene(geneCluster, groupName, \Early\)
  n2 <- countGene(geneCluster, groupName, \Middle\)
  n3 <-countGene(geneCluster, groupName, \Late\)
  n4 <- countGene(geneCluster, groupName, \Transient\)
  return(c(n1, n2, n3, n4))
}

group <- c(rep(\group1\, 4), rep(\group2\, 4), rep(\group3\, 4), rep(\group4\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 4)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, group1),
           countGeneList(geneCluster, group2),
           countGeneList(geneCluster, group5),
           countGeneList(geneCluster, group8))

data <- data.frame(group, cluster, value)


# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()


# Statistical analysis 
# Similar to the Chi-Square test, Fisher’s Exact Test is used when you have smaller sample sizes or when the expected frequency in any cell of the contingency table is below 5.
temp <- data %>% dplyr::filter(group %in% c(\group1\, \group2\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

temp <- data %>% dplyr::filter(group %in% c(\group1\, \group3\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

temp <- data %>% dplyr::filter(group %in% c(\group1\, \group4\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result


### P-N
resultDir <- here(\../../result\)
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

pnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene
pnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene
pnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene
pnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene
pnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene

group <- c(rep(\pnOver8\, 4), rep(\pnOver6\, 4), rep(\pnOver4\, 4), rep(\pnOver2\, 4), rep(\pnOver0\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 5)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, pnOver8),
           countGeneList(geneCluster, pnOver6),
           countGeneList(geneCluster, pnOver4),
           countGeneList(geneCluster, pnOver2),
           countGeneList(geneCluster, pnOver0))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()

temp <- data %>% dplyr::filter(group %in% c(\pnOver2\, \pnOver8\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

### P-S
psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene

group <- c(rep(\psOver4\, 4), rep(\psOver3\, 4), rep(\psOver2\, 4), rep(\psOver1\, 4), rep(\psOver0\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 5)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, psOver4),
           countGeneList(geneCluster, psOver3),
           countGeneList(geneCluster, psOver2),
           countGeneList(geneCluster, psOver1),
           countGeneList(geneCluster, psOver0))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()
temp <- data %>% dplyr::filter(group %in% c(\psOver2\, \psOver4\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

### P-E
peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene

group <- c(rep(\peOver4\, 4), rep(\peOver3\, 4), rep(\peOver2\, 4), rep(\peOver1\, 4), rep(\peOver0\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 5)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, peOver4),
           countGeneList(geneCluster, peOver3),
           countGeneList(geneCluster, peOver2),
           countGeneList(geneCluster, peOver1),
           countGeneList(geneCluster, peOver0))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()

### P-P
ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene

group <- c(rep(\ppOver4\, 4), rep(\ppOver3\, 4), rep(\ppOver2\, 4), rep(\ppOver1\, 4), rep(\ppOver0\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 5)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, ppOver4),
           countGeneList(geneCluster, ppOver3),
           countGeneList(geneCluster, ppOver2),
           countGeneList(geneCluster, ppOver1),
           countGeneList(geneCluster, ppOver0))
data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n## Importing groups\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\))$gene\n\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \\bobbie_gene_classification.csv\\)) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\\gene\\, \\ensembl_transcript_id\\, \\cluster\\)\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\\ensembl_transcript_id\\, \\ensembl_gene_id\\),\n                 filters = \\ensembl_transcript_id\\,\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\\ensembl_transcript_id\\))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \\Early\\)\n  n2 <- countGene(geneCluster, groupName, \\Middle\\)\n  n3 <-countGene(geneCluster, groupName, \\Late\\)\n  n4 <- countGene(geneCluster, groupName, \\Transient\\)\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\\group1\\, 4), rep(\\group2\\, 4), rep(\\group3\\, 4), rep(\\group4\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 4)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, group1),\n           countGeneList(geneCluster, group2),\n           countGeneList(geneCluster, group5),\n           countGeneList(geneCluster, group8))\n\ndata <- data.frame(group, cluster, value)\n\n\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n\n# Statistical analysis \n# Similar to the Chi-Square test, Fisher’s Exact Test is used when you have smaller sample sizes or when the expected frequency in any cell of the contingency table is below 5.\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group2\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group3\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group4\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n\n### P-N\nresultDir <- here(\\../../result\\)\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene\npnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene\npnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene\npnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene\npnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene\n\ngroup <- c(rep(\\pnOver8\\, 4), rep(\\pnOver6\\, 4), rep(\\pnOver4\\, 4), rep(\\pnOver2\\, 4), rep(\\pnOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, pnOver8),\n           countGeneList(geneCluster, pnOver6),\n           countGeneList(geneCluster, pnOver4),\n           countGeneList(geneCluster, pnOver2),\n           countGeneList(geneCluster, pnOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\ntemp <- data %>% dplyr::filter(group %in% c(\\pnOver2\\, \\pnOver8\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n### P-S\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\ngroup <- c(rep(\\psOver4\\, 4), rep(\\psOver3\\, 4), rep(\\psOver2\\, 4), rep(\\psOver1\\, 4), rep(\\psOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, psOver4),\n           countGeneList(geneCluster, psOver3),\n           countGeneList(geneCluster, psOver2),\n           countGeneList(geneCluster, psOver1),\n           countGeneList(geneCluster, psOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\ntemp <- data %>% dplyr::filter(group %in% c(\\psOver2\\, \\psOver4\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n### P-E\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\ngroup <- c(rep(\\peOver4\\, 4), rep(\\peOver3\\, 4), rep(\\peOver2\\, 4), rep(\\peOver1\\, 4), rep(\\peOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, peOver4),\n           countGeneList(geneCluster, peOver3),\n           countGeneList(geneCluster, peOver2),\n           countGeneList(geneCluster, peOver1),\n           countGeneList(geneCluster, peOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n### P-P\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\ngroup <- c(rep(\\ppOver4\\, 4), rep(\\ppOver3\\, 4), rep(\\ppOver2\\, 4), rep(\\ppOver1\\, 4), rep(\\ppOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, ppOver4),\n           countGeneList(geneCluster, ppOver3),\n           countGeneList(geneCluster, ppOver2),\n           countGeneList(geneCluster, ppOver1),\n           countGeneList(geneCluster, ppOver0))\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n```\n```"} -->\n\n```r\n```r\n## Importing groups\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\))$gene\n\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \\bobbie_gene_classification.csv\\)) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\\gene\\, \\ensembl_transcript_id\\, \\cluster\\)\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\\ensembl_transcript_id\\, \\ensembl_gene_id\\),\n                 filters = \\ensembl_transcript_id\\,\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\\ensembl_transcript_id\\))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \\Early\\)\n  n2 <- countGene(geneCluster, groupName, \\Middle\\)\n  n3 <-countGene(geneCluster, groupName, \\Late\\)\n  n4 <- countGene(geneCluster, groupName, \\Transient\\)\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\\group1\\, 4), rep(\\group2\\, 4), rep(\\group3\\, 4), rep(\\group4\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 4)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, group1),\n           countGeneList(geneCluster, group2),\n           countGeneList(geneCluster, group5),\n           countGeneList(geneCluster, group8))\n\ndata <- data.frame(group, cluster, value)\n\n\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n\n# Statistical analysis \n# Similar to the Chi-Square test, Fisher’s Exact Test is used when you have smaller sample sizes or when the expected frequency in any cell of the contingency table is below 5.\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group2\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group3\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group4\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n\n### P-N\nresultDir <- here(\\../../result\\)\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene\npnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene\npnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene\npnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene\npnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene\n\ngroup <- c(rep(\\pnOver8\\, 4), rep(\\pnOver6\\, 4), rep(\\pnOver4\\, 4), rep(\\pnOver2\\, 4), rep(\\pnOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, pnOver8),\n           countGeneList(geneCluster, pnOver6),\n           countGeneList(geneCluster, pnOver4),\n           countGeneList(geneCluster, pnOver2),\n           countGeneList(geneCluster, pnOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\ntemp <- data %>% dplyr::filter(group %in% c(\\pnOver2\\, \\pnOver8\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n### P-S\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\ngroup <- c(rep(\\psOver4\\, 4), rep(\\psOver3\\, 4), rep(\\psOver2\\, 4), rep(\\psOver1\\, 4), rep(\\psOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, psOver4),\n           countGeneList(geneCluster, psOver3),\n           countGeneList(geneCluster, psOver2),\n           countGeneList(geneCluster, psOver1),\n           countGeneList(geneCluster, psOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\ntemp <- data %>% dplyr::filter(group %in% c(\\psOver2\\, \\psOver4\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n### P-E\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\ngroup <- c(rep(\\peOver4\\, 4), rep(\\peOver3\\, 4), rep(\\peOver2\\, 4), rep(\\peOver1\\, 4), rep(\\peOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, peOver4),\n           countGeneList(geneCluster, peOver3),\n           countGeneList(geneCluster, peOver2),\n           countGeneList(geneCluster, peOver1),\n           countGeneList(geneCluster, peOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n### P-P\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\ngroup <- c(rep(\\ppOver4\\, 4), rep(\\ppOver3\\, 4), rep(\\ppOver2\\, 4), rep(\\ppOver1\\, 4), rep(\\ppOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, ppOver4),\n           countGeneList(geneCluster, ppOver3),\n           countGeneList(geneCluster, ppOver2),\n           countGeneList(geneCluster, ppOver1),\n           countGeneList(geneCluster, ppOver0))\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n## Importing groups\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\\))$gene\n\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \\bobbie_gene_classification.csv\\)) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\\gene\\, \\ensembl_transcript_id\\, \\cluster\\)\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\\ensembl_transcript_id\\, \\ensembl_gene_id\\),\n                 filters = \\ensembl_transcript_id\\,\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\\ensembl_transcript_id\\))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \\Early\\)\n  n2 <- countGene(geneCluster, groupName, \\Middle\\)\n  n3 <-countGene(geneCluster, groupName, \\Late\\)\n  n4 <- countGene(geneCluster, groupName, \\Transient\\)\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\\group1\\, 4), rep(\\group2\\, 4), rep(\\group3\\, 4), rep(\\group4\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 4)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, group1),\n           countGeneList(geneCluster, group2),\n           countGeneList(geneCluster, group5),\n           countGeneList(geneCluster, group8))\n\ndata <- data.frame(group, cluster, value)\n\n\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n\n# Statistical analysis \n# Similar to the Chi-Square test, Fisher’s Exact Test is used when you have smaller sample sizes or when the expected frequency in any cell of the contingency table is below 5.\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group2\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group3\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group4\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n\n### P-N\nresultDir <- here(\\../../result\\)\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene\npnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene\npnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene\npnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene\npnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene\n\ngroup <- c(rep(\\pnOver8\\, 4), rep(\\pnOver6\\, 4), rep(\\pnOver4\\, 4), rep(\\pnOver2\\, 4), rep(\\pnOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, pnOver8),\n           countGeneList(geneCluster, pnOver6),\n           countGeneList(geneCluster, pnOver4),\n           countGeneList(geneCluster, pnOver2),\n           countGeneList(geneCluster, pnOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\ntemp <- data %>% dplyr::filter(group %in% c(\\pnOver2\\, \\pnOver8\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n### P-S\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\ngroup <- c(rep(\\psOver4\\, 4), rep(\\psOver3\\, 4), rep(\\psOver2\\, 4), rep(\\psOver1\\, 4), rep(\\psOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, psOver4),\n           countGeneList(geneCluster, psOver3),\n           countGeneList(geneCluster, psOver2),\n           countGeneList(geneCluster, psOver1),\n           countGeneList(geneCluster, psOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\ntemp <- data %>% dplyr::filter(group %in% c(\\psOver2\\, \\psOver4\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n### P-E\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\ngroup <- c(rep(\\peOver4\\, 4), rep(\\peOver3\\, 4), rep(\\peOver2\\, 4), rep(\\peOver1\\, 4), rep(\\peOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, peOver4),\n           countGeneList(geneCluster, peOver3),\n           countGeneList(geneCluster, peOver2),\n           countGeneList(geneCluster, peOver1),\n           countGeneList(geneCluster, peOver0))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n### P-P\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\ngroup <- c(rep(\\ppOver4\\, 4), rep(\\ppOver3\\, 4), rep(\\ppOver2\\, 4), rep(\\ppOver1\\, 4), rep(\\ppOver0\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 5)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, ppOver4),\n           countGeneList(geneCluster, ppOver3),\n           countGeneList(geneCluster, ppOver2),\n           countGeneList(geneCluster, ppOver1),\n           countGeneList(geneCluster, ppOver0))\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n```\n```"} -->

```r
```r
## Importing groups
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv\))$gene
group5 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv\))$gene
group8 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv\))$gene


## Importing Bobbie gene classification
geneCluster <- fread(here(refDir, \bobbie_gene_classification.csv\)) %>%
  dplyr::select(gene, enst, Cluster)
colnames(geneCluster) <- c(\gene\, \ensembl_transcript_id\, \cluster\)


## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c(\ensembl_transcript_id\, \ensembl_gene_id\),
                 filters = \ensembl_transcript_id\,
                 values = geneCluster$ensembl_transcript,
                 mart = ensembl.v102)
geneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\ensembl_transcript_id\))

# Making data for stacked barplot
countGene <- function(geneCluster, groupName, clusterName){
  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,
                                            cluster %in% clusterName))
  return(num)
}
countGeneList <- function(geneCluster, groupName){
  n1 <- countGene(geneCluster, groupName, \Early\)
  n2 <- countGene(geneCluster, groupName, \Middle\)
  n3 <-countGene(geneCluster, groupName, \Late\)
  n4 <- countGene(geneCluster, groupName, \Transient\)
  return(c(n1, n2, n3, n4))
}

group <- c(rep(\group1\, 4), rep(\group2\, 4), rep(\group3\, 4), rep(\group4\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 4)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, group1),
           countGeneList(geneCluster, group2),
           countGeneList(geneCluster, group5),
           countGeneList(geneCluster, group8))

data <- data.frame(group, cluster, value)


# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()


# Statistical analysis 
# Similar to the Chi-Square test, Fisher’s Exact Test is used when you have smaller sample sizes or when the expected frequency in any cell of the contingency table is below 5.
temp <- data %>% dplyr::filter(group %in% c(\group1\, \group2\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

temp <- data %>% dplyr::filter(group %in% c(\group1\, \group3\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

temp <- data %>% dplyr::filter(group %in% c(\group1\, \group4\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result


### P-N
resultDir <- here(\../../result\)
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

pnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene
pnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene
pnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene
pnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene
pnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene

group <- c(rep(\pnOver8\, 4), rep(\pnOver6\, 4), rep(\pnOver4\, 4), rep(\pnOver2\, 4), rep(\pnOver0\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 5)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, pnOver8),
           countGeneList(geneCluster, pnOver6),
           countGeneList(geneCluster, pnOver4),
           countGeneList(geneCluster, pnOver2),
           countGeneList(geneCluster, pnOver0))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()

temp <- data %>% dplyr::filter(group %in% c(\pnOver2\, \pnOver8\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

### P-S
psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene

group <- c(rep(\psOver4\, 4), rep(\psOver3\, 4), rep(\psOver2\, 4), rep(\psOver1\, 4), rep(\psOver0\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 5)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, psOver4),
           countGeneList(geneCluster, psOver3),
           countGeneList(geneCluster, psOver2),
           countGeneList(geneCluster, psOver1),
           countGeneList(geneCluster, psOver0))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()
temp <- data %>% dplyr::filter(group %in% c(\psOver2\, \psOver4\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

### P-E
peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene

group <- c(rep(\peOver4\, 4), rep(\peOver3\, 4), rep(\peOver2\, 4), rep(\peOver1\, 4), rep(\peOver0\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 5)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, peOver4),
           countGeneList(geneCluster, peOver3),
           countGeneList(geneCluster, peOver2),
           countGeneList(geneCluster, peOver1),
           countGeneList(geneCluster, peOver0))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()

### P-P
ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene

group <- c(rep(\ppOver4\, 4), rep(\ppOver3\, 4), rep(\ppOver2\, 4), rep(\ppOver1\, 4), rep(\ppOver0\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 5)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, ppOver4),
           countGeneList(geneCluster, ppOver3),
           countGeneList(geneCluster, ppOver2),
           countGeneList(geneCluster, ppOver1),
           countGeneList(geneCluster, ppOver0))
data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



## [2.22] Comparing absolute RNA expression level across group
The aim is to see if there is a trend in RNA expression level among group 1, 2, 3, 4.
It would be making comparison among genes. For this, TPM should be used.

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyMgSW1wb3J0aW5nIGdyb3Vwc1xuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XCIpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcIikpJGdlbmVcbmdyb3VwMyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAzLnRzdlwiKSkkZ2VuZVxuZ3JvdXA0IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDQudHN2XCIpKSRnZW5lXG5ncm91cDUgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwNS50c3ZcIikpJGdlbmVcbmdyb3VwNiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA2LnRzdlwiKSkkZ2VuZVxuZ3JvdXA3IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDcudHN2XCIpKSRnZW5lXG5ncm91cDggPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwOC50c3ZcIikpJGdlbmVcbmdyb3VwOSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA5LnRzdlwiKSkkZ2VuZVxuXG5cbiMjIEltcG9ydGluZyBCb2JiaWUgZ2VuZSBjbGFzc2lmaWNhdGlvblxuZ2VuZUNsdXN0ZXIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiYm9iYmllX2dlbmVfY2xhc3NpZmljYXRpb24uY3N2XCIpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChnZW5lLCBlbnN0LCBDbHVzdGVyKVxuY29sbmFtZXMoZ2VuZUNsdXN0ZXIpIDwtIGMoXCJnZW5lXCIsIFwiZW5zZW1ibF90cmFuc2NyaXB0X2lkXCIsIFwiY2x1c3RlclwiKVxuXG5cbiMjIENvbnZlcnRpbmcgdHJhbnNjcmlwdCBJRCB0byBnZW5lIElEXG5pZFBhaXJfdGcgPC0gZ2V0Qk0oYXR0cmlidXRlcyA9IGMoXCJlbnNlbWJsX3RyYW5zY3JpcHRfaWRcIiwgXCJlbnNlbWJsX2dlbmVfaWRcIiksXG4gICAgICAgICAgICAgICAgIGZpbHRlcnMgPSBcImVuc2VtYmxfdHJhbnNjcmlwdF9pZFwiLFxuICAgICAgICAgICAgICAgICB2YWx1ZXMgPSBnZW5lQ2x1c3RlciRlbnNlbWJsX3RyYW5zY3JpcHQsXG4gICAgICAgICAgICAgICAgIG1hcnQgPSBlbnNlbWJsLnYxMDIpXG5nZW5lQ2x1c3RlciA8LSBnZW5lQ2x1c3RlciAlPiUgZHBseXI6OmxlZnRfam9pbihpZFBhaXJfdGcsIGJ5ID0gYyhcImVuc2VtYmxfdHJhbnNjcmlwdF9pZFwiKSlcblxuIyBNYWtpbmcgZGF0YSBmb3Igc3RhY2tlZCBiYXJwbG90XG5jb3VudEdlbmUgPC0gZnVuY3Rpb24oZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSwgY2x1c3Rlck5hbWUpe1xuICBudW0gPC0gbnJvdyhnZW5lQ2x1c3RlciAlPiUgZHBseXI6OmZpbHRlcihlbnNlbWJsX2dlbmVfaWQgJWluJSBncm91cE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNsdXN0ZXIgJWluJSBjbHVzdGVyTmFtZSkpXG4gIHJldHVybihudW0pXG59XG5jb3VudEdlbmVMaXN0IDwtIGZ1bmN0aW9uKGdlbmVDbHVzdGVyLCBncm91cE5hbWUpe1xuICBuMSA8LSBjb3VudEdlbmUoZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSwgXCJFYXJseVwiKVxuICBuMiA8LSBjb3VudEdlbmUoZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSwgXCJNaWRkbGVcIilcbiAgbjMgPC1jb3VudEdlbmUoZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSwgXCJMYXRlXCIpXG4gIG40IDwtIGNvdW50R2VuZShnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBcIlRyYW5zaWVudFwiKVxuICByZXR1cm4oYyhuMSwgbjIsIG4zLCBuNCkpXG59XG5cbmdyb3VwIDwtIGMocmVwKFwiZ3JvdXAxXCIsIDQpLCByZXAoXCJncm91cDJcIiwgNCksIHJlcChcImdyb3VwM1wiLCA0KSxcbiAgICAgICAgICAgcmVwKFwiZ3JvdXA0XCIsIDQpLCByZXAoXCJncm91cDVcIiwgNCksIHJlcChcImdyb3VwNlwiLCA0KSxcbiAgICAgICAgICAgcmVwKFwiZ3JvdXA3XCIsIDQpLCByZXAoXCJncm91cDhcIiwgNCksIHJlcChcImdyb3VwOVwiLCA0KSlcbmNsdXN0ZXIgPC0gcmVwKGMoXCJFYXJseVwiLCBcIk1pZGRsZVwiLCBcIkxhdGVcIiwgXCJUcmFuc2llbnRcIiksIDkpXG5jbHVzdGVyIDwtIGZhY3RvcihjbHVzdGVyLCBsZXZlbHMgPSBjKFwiRWFybHlcIiwgXCJNaWRkbGVcIiwgXCJMYXRlXCIsIFwiVHJhbnNpZW50XCIpKVxudmFsdWUgPC0gYyhjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDEpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDIpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDMpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDQpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDUpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDYpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDcpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDgpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDkpKVxuXG5kYXRhIDwtIGRhdGEuZnJhbWUoZ3JvdXAsIGNsdXN0ZXIsIHZhbHVlKVxuXG5cbiMgUGxvdHRpbmdcbmdncGxvdChkYXRhLCBhZXMoZmlsbD1jbHVzdGVyLCB5PXZhbHVlLCB4PWdyb3VwKSkgKyBcbiAgICBnZW9tX2Jhcihwb3NpdGlvbj1cImZpbGxcIiwgc3RhdD1cImlkZW50aXR5XCIpICsgdGhlbWVfY2xhc3NpYygpXG5cblxuIyBTdGF0aXN0aWNhbCBhbmFseXNpcyBcbiMgU2ltaWxhciB0byB0aGUgQ2hpLVNxdWFyZSB0ZXN0LCBGaXNoZXLigJlzIEV4YWN0IFRlc3QgaXMgdXNlZCB3aGVuIHlvdSBoYXZlIHNtYWxsZXIgc2FtcGxlIHNpemVzIG9yIHdoZW4gdGhlIGV4cGVjdGVkIGZyZXF1ZW5jeSBpbiBhbnkgY2VsbCBvZiB0aGUgY29udGluZ2VuY3kgdGFibGUgaXMgYmVsb3cgNS5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCAlaW4lIGMoXCJncm91cDFcIiwgXCJncm91cDJcIikpXG5jb250aW5nZW5jeV90YWJsZSA8LSB4dGFicyh2YWx1ZSB+IGdyb3VwICsgY2x1c3RlciwgZGF0YSA9IHRlbXApXG5maXNoZXJfcmVzdWx0IDwtIGZpc2hlci50ZXN0KGNvbnRpbmdlbmN5X3RhYmxlLCBzaW11bGF0ZS5wLnZhbHVlID0gVFJVRSwgQiA9IDEwMDAwMClcbmZpc2hlcl9yZXN1bHRcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwICVpbiUgYyhcImdyb3VwMVwiLCBcImdyb3VwM1wiKSlcbmNvbnRpbmdlbmN5X3RhYmxlIDwtIHh0YWJzKHZhbHVlIH4gZ3JvdXAgKyBjbHVzdGVyLCBkYXRhID0gdGVtcClcbmZpc2hlcl9yZXN1bHQgPC0gZmlzaGVyLnRlc3QoY29udGluZ2VuY3lfdGFibGUsIHNpbXVsYXRlLnAudmFsdWUgPSBUUlVFLCBCID0gMTAwMDAwKVxuZmlzaGVyX3Jlc3VsdFxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgJWluJSBjKFwiZ3JvdXAxXCIsIFwiZ3JvdXA0XCIpKVxuY29udGluZ2VuY3lfdGFibGUgPC0geHRhYnModmFsdWUgfiBncm91cCArIGNsdXN0ZXIsIGRhdGEgPSB0ZW1wKVxuZmlzaGVyX3Jlc3VsdCA8LSBmaXNoZXIudGVzdChjb250aW5nZW5jeV90YWJsZSwgc2ltdWxhdGUucC52YWx1ZSA9IFRSVUUsIEIgPSAxMDAwMDApXG5maXNoZXJfcmVzdWx0XG5cblxuYGBgIn0= -->\n\n```r\n## Importing groups\ngroup1 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup3 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group3.tsv\\))$gene\ngroup4 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group4.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup6 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group6.tsv\\))$gene\ngroup7 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group7.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group8.tsv\\))$gene\ngroup9 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group9.tsv\\))$gene\n\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \\bobbie_gene_classification.csv\\)) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\\gene\\, \\ensembl_transcript_id\\, \\cluster\\)\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\\ensembl_transcript_id\\, \\ensembl_gene_id\\),\n                 filters = \\ensembl_transcript_id\\,\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\\ensembl_transcript_id\\))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \\Early\\)\n  n2 <- countGene(geneCluster, groupName, \\Middle\\)\n  n3 <-countGene(geneCluster, groupName, \\Late\\)\n  n4 <- countGene(geneCluster, groupName, \\Transient\\)\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\\group1\\, 4), rep(\\group2\\, 4), rep(\\group3\\, 4),\n           rep(\\group4\\, 4), rep(\\group5\\, 4), rep(\\group6\\, 4),\n           rep(\\group7\\, 4), rep(\\group8\\, 4), rep(\\group9\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 9)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, group1),\n           countGeneList(geneCluster, group2),\n           countGeneList(geneCluster, group3),\n           countGeneList(geneCluster, group4),\n           countGeneList(geneCluster, group5),\n           countGeneList(geneCluster, group6),\n           countGeneList(geneCluster, group7),\n           countGeneList(geneCluster, group8),\n           countGeneList(geneCluster, group9))\n\ndata <- data.frame(group, cluster, value)\n\n\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n\n# Statistical analysis \n# Similar to the Chi-Square test, Fisher’s Exact Test is used when you have smaller sample sizes or when the expected frequency in any cell of the contingency table is below 5.\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group2\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group3\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group4\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
## Importing groups
group1 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group2.tsv\))$gene
group3 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group3.tsv\))$gene
group4 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group4.tsv\))$gene
group5 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group5.tsv\))$gene
group6 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group6.tsv\))$gene
group7 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group7.tsv\))$gene
group8 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group8.tsv\))$gene
group9 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group9.tsv\))$gene


## Importing Bobbie gene classification
geneCluster <- fread(here(refDir, \bobbie_gene_classification.csv\)) %>%
  dplyr::select(gene, enst, Cluster)
colnames(geneCluster) <- c(\gene\, \ensembl_transcript_id\, \cluster\)


## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c(\ensembl_transcript_id\, \ensembl_gene_id\),
                 filters = \ensembl_transcript_id\,
                 values = geneCluster$ensembl_transcript,
                 mart = ensembl.v102)
geneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\ensembl_transcript_id\))

# Making data for stacked barplot
countGene <- function(geneCluster, groupName, clusterName){
  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,
                                            cluster %in% clusterName))
  return(num)
}
countGeneList <- function(geneCluster, groupName){
  n1 <- countGene(geneCluster, groupName, \Early\)
  n2 <- countGene(geneCluster, groupName, \Middle\)
  n3 <-countGene(geneCluster, groupName, \Late\)
  n4 <- countGene(geneCluster, groupName, \Transient\)
  return(c(n1, n2, n3, n4))
}

group <- c(rep(\group1\, 4), rep(\group2\, 4), rep(\group3\, 4),
           rep(\group4\, 4), rep(\group5\, 4), rep(\group6\, 4),
           rep(\group7\, 4), rep(\group8\, 4), rep(\group9\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 9)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, group1),
           countGeneList(geneCluster, group2),
           countGeneList(geneCluster, group3),
           countGeneList(geneCluster, group4),
           countGeneList(geneCluster, group5),
           countGeneList(geneCluster, group6),
           countGeneList(geneCluster, group7),
           countGeneList(geneCluster, group8),
           countGeneList(geneCluster, group9))

data <- data.frame(group, cluster, value)


# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()


# Statistical analysis 
# Similar to the Chi-Square test, Fisher’s Exact Test is used when you have smaller sample sizes or when the expected frequency in any cell of the contingency table is below 5.
temp <- data %>% dplyr::filter(group %in% c(\group1\, \group2\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

temp <- data %>% dplyr::filter(group %in% c(\group1\, \group3\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

temp <- data %>% dplyr::filter(group %in% c(\group1\, \group4\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMgSW1wb3J0aW5nIGdyb3Vwc1xuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcXCkpJGdlbmVcbmdyb3VwMyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAzLnRzdlxcKSkkZ2VuZVxuZ3JvdXA0IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDQudHN2XFwpKSRnZW5lXG5ncm91cDUgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwNS50c3ZcXCkpJGdlbmVcbmdyb3VwNiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA2LnRzdlxcKSkkZ2VuZVxuZ3JvdXA3IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDcudHN2XFwpKSRnZW5lXG5ncm91cDggPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwOC50c3ZcXCkpJGdlbmVcbmdyb3VwOSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA5LnRzdlxcKSkkZ2VuZVxuXG5cbiMjIEltcG9ydGluZyBCb2JiaWUgZ2VuZSBjbGFzc2lmaWNhdGlvblxuZ2VuZUNsdXN0ZXIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcYm9iYmllX2dlbmVfY2xhc3NpZmljYXRpb24uY3N2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChnZW5lLCBlbnN0LCBDbHVzdGVyKVxuY29sbmFtZXMoZ2VuZUNsdXN0ZXIpIDwtIGMoXFxnZW5lXFwsIFxcZW5zZW1ibF90cmFuc2NyaXB0X2lkXFwsIFxcY2x1c3RlclxcKVxuXG5cbiMjIENvbnZlcnRpbmcgdHJhbnNjcmlwdCBJRCB0byBnZW5lIElEXG5pZFBhaXJfdGcgPC0gZ2V0Qk0oYXR0cmlidXRlcyA9IGMoXFxlbnNlbWJsX3RyYW5zY3JpcHRfaWRcXCwgXFxlbnNlbWJsX2dlbmVfaWRcXCksXG4gICAgICAgICAgICAgICAgIGZpbHRlcnMgPSBcXGVuc2VtYmxfdHJhbnNjcmlwdF9pZFxcLFxuICAgICAgICAgICAgICAgICB2YWx1ZXMgPSBnZW5lQ2x1c3RlciRlbnNlbWJsX3RyYW5zY3JpcHQsXG4gICAgICAgICAgICAgICAgIG1hcnQgPSBlbnNlbWJsLnYxMDIpXG5nZW5lQ2x1c3RlciA8LSBnZW5lQ2x1c3RlciAlPiUgZHBseXI6OmxlZnRfam9pbihpZFBhaXJfdGcsIGJ5ID0gYyhcXGVuc2VtYmxfdHJhbnNjcmlwdF9pZFxcKSlcblxuIyBNYWtpbmcgZGF0YSBmb3Igc3RhY2tlZCBiYXJwbG90XG5jb3VudEdlbmUgPC0gZnVuY3Rpb24oZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSwgY2x1c3Rlck5hbWUpe1xuICBudW0gPC0gbnJvdyhnZW5lQ2x1c3RlciAlPiUgZHBseXI6OmZpbHRlcihlbnNlbWJsX2dlbmVfaWQgJWluJSBncm91cE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNsdXN0ZXIgJWluJSBjbHVzdGVyTmFtZSkpXG4gIHJldHVybihudW0pXG59XG5jb3VudEdlbmVMaXN0IDwtIGZ1bmN0aW9uKGdlbmVDbHVzdGVyLCBncm91cE5hbWUpe1xuICBuMSA8LSBjb3VudEdlbmUoZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSwgXFxFYXJseVxcKVxuICBuMiA8LSBjb3VudEdlbmUoZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSwgXFxNaWRkbGVcXClcbiAgbjMgPC1jb3VudEdlbmUoZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSwgXFxMYXRlXFwpXG4gIG40IDwtIGNvdW50R2VuZShnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBcXFRyYW5zaWVudFxcKVxuICByZXR1cm4oYyhuMSwgbjIsIG4zLCBuNCkpXG59XG5cbmdyb3VwIDwtIGMocmVwKFxcZ3JvdXAxXFwsIDQpLCByZXAoXFxncm91cDJcXCwgNCksIHJlcChcXGdyb3VwM1xcLCA0KSxcbiAgICAgICAgICAgcmVwKFxcZ3JvdXA0XFwsIDQpLCByZXAoXFxncm91cDVcXCwgNCksIHJlcChcXGdyb3VwNlxcLCA0KSxcbiAgICAgICAgICAgcmVwKFxcZ3JvdXA3XFwsIDQpLCByZXAoXFxncm91cDhcXCwgNCksIHJlcChcXGdyb3VwOVxcLCA0KSlcbmNsdXN0ZXIgPC0gcmVwKGMoXFxFYXJseVxcLCBcXE1pZGRsZVxcLCBcXExhdGVcXCwgXFxUcmFuc2llbnRcXCksIDkpXG5jbHVzdGVyIDwtIGZhY3RvcihjbHVzdGVyLCBsZXZlbHMgPSBjKFxcRWFybHlcXCwgXFxNaWRkbGVcXCwgXFxMYXRlXFwsIFxcVHJhbnNpZW50XFwpKVxudmFsdWUgPC0gYyhjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDEpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDIpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDMpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDQpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDUpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDYpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDcpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDgpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDkpKVxuXG5kYXRhIDwtIGRhdGEuZnJhbWUoZ3JvdXAsIGNsdXN0ZXIsIHZhbHVlKVxuXG5cbiMgUGxvdHRpbmdcbmdncGxvdChkYXRhLCBhZXMoZmlsbD1jbHVzdGVyLCB5PXZhbHVlLCB4PWdyb3VwKSkgKyBcbiAgICBnZW9tX2Jhcihwb3NpdGlvbj1cXGZpbGxcXCwgc3RhdD1cXGlkZW50aXR5XFwpICsgdGhlbWVfY2xhc3NpYygpXG5cblxuIyBTdGF0aXN0aWNhbCBhbmFseXNpcyBcbiMgU2ltaWxhciB0byB0aGUgQ2hpLVNxdWFyZSB0ZXN0LCBGaXNoZXLigJlzIEV4YWN0IFRlc3QgaXMgdXNlZCB3aGVuIHlvdSBoYXZlIHNtYWxsZXIgc2FtcGxlIHNpemVzIG9yIHdoZW4gdGhlIGV4cGVjdGVkIGZyZXF1ZW5jeSBpbiBhbnkgY2VsbCBvZiB0aGUgY29udGluZ2VuY3kgdGFibGUgaXMgYmVsb3cgNS5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCAlaW4lIGMoXFxncm91cDFcXCwgXFxncm91cDJcXCkpXG5jb250aW5nZW5jeV90YWJsZSA8LSB4dGFicyh2YWx1ZSB+IGdyb3VwICsgY2x1c3RlciwgZGF0YSA9IHRlbXApXG5maXNoZXJfcmVzdWx0IDwtIGZpc2hlci50ZXN0KGNvbnRpbmdlbmN5X3RhYmxlLCBzaW11bGF0ZS5wLnZhbHVlID0gVFJVRSwgQiA9IDEwMDAwMClcbmZpc2hlcl9yZXN1bHRcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwICVpbiUgYyhcXGdyb3VwMVxcLCBcXGdyb3VwM1xcKSlcbmNvbnRpbmdlbmN5X3RhYmxlIDwtIHh0YWJzKHZhbHVlIH4gZ3JvdXAgKyBjbHVzdGVyLCBkYXRhID0gdGVtcClcbmZpc2hlcl9yZXN1bHQgPC0gZmlzaGVyLnRlc3QoY29udGluZ2VuY3lfdGFibGUsIHNpbXVsYXRlLnAudmFsdWUgPSBUUlVFLCBCID0gMTAwMDAwKVxuZmlzaGVyX3Jlc3VsdFxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgJWluJSBjKFxcZ3JvdXAxXFwsIFxcZ3JvdXA0XFwpKVxuY29udGluZ2VuY3lfdGFibGUgPC0geHRhYnModmFsdWUgfiBncm91cCArIGNsdXN0ZXIsIGRhdGEgPSB0ZW1wKVxuZmlzaGVyX3Jlc3VsdCA8LSBmaXNoZXIudGVzdChjb250aW5nZW5jeV90YWJsZSwgc2ltdWxhdGUucC52YWx1ZSA9IFRSVUUsIEIgPSAxMDAwMDApXG5maXNoZXJfcmVzdWx0XG5cblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n## Importing groups\ngroup1 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group2.tsv\\))$gene\ngroup3 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group3.tsv\\))$gene\ngroup4 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group4.tsv\\))$gene\ngroup5 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group5.tsv\\))$gene\ngroup6 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group6.tsv\\))$gene\ngroup7 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group7.tsv\\))$gene\ngroup8 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group8.tsv\\))$gene\ngroup9 <- fread(here(refDir, \\geneList_A485_vs_DMSO_RNA_loop_group9.tsv\\))$gene\n\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \\bobbie_gene_classification.csv\\)) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\\gene\\, \\ensembl_transcript_id\\, \\cluster\\)\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\\ensembl_transcript_id\\, \\ensembl_gene_id\\),\n                 filters = \\ensembl_transcript_id\\,\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\\ensembl_transcript_id\\))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \\Early\\)\n  n2 <- countGene(geneCluster, groupName, \\Middle\\)\n  n3 <-countGene(geneCluster, groupName, \\Late\\)\n  n4 <- countGene(geneCluster, groupName, \\Transient\\)\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\\group1\\, 4), rep(\\group2\\, 4), rep(\\group3\\, 4),\n           rep(\\group4\\, 4), rep(\\group5\\, 4), rep(\\group6\\, 4),\n           rep(\\group7\\, 4), rep(\\group8\\, 4), rep(\\group9\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 9)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, group1),\n           countGeneList(geneCluster, group2),\n           countGeneList(geneCluster, group3),\n           countGeneList(geneCluster, group4),\n           countGeneList(geneCluster, group5),\n           countGeneList(geneCluster, group6),\n           countGeneList(geneCluster, group7),\n           countGeneList(geneCluster, group8),\n           countGeneList(geneCluster, group9))\n\ndata <- data.frame(group, cluster, value)\n\n\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n\n# Statistical analysis \n# Similar to the Chi-Square test, Fisher’s Exact Test is used when you have smaller sample sizes or when the expected frequency in any cell of the contingency table is below 5.\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group2\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group3\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\ntemp <- data %>% dplyr::filter(group %in% c(\\group1\\, \\group4\\))\ncontingency_table <- xtabs(value ~ group + cluster, data = temp)\nfisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)\nfisher_result\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMgSW1wb3J0aW5nIGdyb3Vwc1xuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwMi50c3ZcXCkpJGdlbmVcbmdyb3VwMyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXAzLnRzdlxcKSkkZ2VuZVxuZ3JvdXA0IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDQudHN2XFwpKSRnZW5lXG5ncm91cDUgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwNS50c3ZcXCkpJGdlbmVcbmdyb3VwNiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA2LnRzdlxcKSkkZ2VuZVxuZ3JvdXA3IDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X0E0ODVfdnNfRE1TT19STkFfbG9vcF9ncm91cDcudHN2XFwpKSRnZW5lXG5ncm91cDggPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfQTQ4NV92c19ETVNPX1JOQV9sb29wX2dyb3VwOC50c3ZcXCkpJGdlbmVcbmdyb3VwOSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9BNDg1X3ZzX0RNU09fUk5BX2xvb3BfZ3JvdXA5LnRzdlxcKSkkZ2VuZVxuXG5cbiMjIEltcG9ydGluZyBCb2JiaWUgZ2VuZSBjbGFzc2lmaWNhdGlvblxuZ2VuZUNsdXN0ZXIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcYm9iYmllX2dlbmVfY2xhc3NpZmljYXRpb24uY3N2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChnZW5lLCBlbnN0LCBDbHVzdGVyKVxuY29sbmFtZXMoZ2VuZUNsdXN0ZXIpIDwtIGMoXFxnZW5lXFwsIFxcZW5zZW1ibF90cmFuc2NyaXB0X2lkXFwsIFxcY2x1c3RlclxcKVxuXG5cbiMjIENvbnZlcnRpbmcgdHJhbnNjcmlwdCBJRCB0byBnZW5lIElEXG5pZFBhaXJfdGcgPC0gZ2V0Qk0oYXR0cmlidXRlcyA9IGMoXFxlbnNlbWJsX3RyYW5zY3JpcHRfaWRcXCwgXFxlbnNlbWJsX2dlbmVfaWRcXCksXG4gICAgICAgICAgICAgICAgIGZpbHRlcnMgPSBcXGVuc2VtYmxfdHJhbnNjcmlwdF9pZFxcLFxuICAgICAgICAgICAgICAgICB2YWx1ZXMgPSBnZW5lQ2x1c3RlciRlbnNlbWJsX3RyYW5zY3JpcHQsXG4gICAgICAgICAgICAgICAgIG1hcnQgPSBlbnNlbWJsLnYxMDIpXG5nZW5lQ2x1c3RlciA8LSBnZW5lQ2x1c3RlciAlPiUgZHBseXI6OmxlZnRfam9pbihpZFBhaXJfdGcsIGJ5ID0gYyhcXGVuc2VtYmxfdHJhbnNjcmlwdF9pZFxcKSlcblxuIyBNYWtpbmcgZGF0YSBmb3Igc3RhY2tlZCBiYXJwbG90XG5jb3VudEdlbmUgPC0gZnVuY3Rpb24oZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSwgY2x1c3Rlck5hbWUpe1xuICBudW0gPC0gbnJvdyhnZW5lQ2x1c3RlciAlPiUgZHBseXI6OmZpbHRlcihlbnNlbWJsX2dlbmVfaWQgJWluJSBncm91cE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNsdXN0ZXIgJWluJSBjbHVzdGVyTmFtZSkpXG4gIHJldHVybihudW0pXG59XG5jb3VudEdlbmVMaXN0IDwtIGZ1bmN0aW9uKGdlbmVDbHVzdGVyLCBncm91cE5hbWUpe1xuICBuMSA8LSBjb3VudEdlbmUoZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSwgXFxFYXJseVxcKVxuICBuMiA8LSBjb3VudEdlbmUoZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSwgXFxNaWRkbGVcXClcbiAgbjMgPC1jb3VudEdlbmUoZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSwgXFxMYXRlXFwpXG4gIG40IDwtIGNvdW50R2VuZShnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBcXFRyYW5zaWVudFxcKVxuICByZXR1cm4oYyhuMSwgbjIsIG4zLCBuNCkpXG59XG5cbmdyb3VwIDwtIGMocmVwKFxcZ3JvdXAxXFwsIDQpLCByZXAoXFxncm91cDJcXCwgNCksIHJlcChcXGdyb3VwM1xcLCA0KSxcbiAgICAgICAgICAgcmVwKFxcZ3JvdXA0XFwsIDQpLCByZXAoXFxncm91cDVcXCwgNCksIHJlcChcXGdyb3VwNlxcLCA0KSxcbiAgICAgICAgICAgcmVwKFxcZ3JvdXA3XFwsIDQpLCByZXAoXFxncm91cDhcXCwgNCksIHJlcChcXGdyb3VwOVxcLCA0KSlcbmNsdXN0ZXIgPC0gcmVwKGMoXFxFYXJseVxcLCBcXE1pZGRsZVxcLCBcXExhdGVcXCwgXFxUcmFuc2llbnRcXCksIDkpXG5jbHVzdGVyIDwtIGZhY3RvcihjbHVzdGVyLCBsZXZlbHMgPSBjKFxcRWFybHlcXCwgXFxNaWRkbGVcXCwgXFxMYXRlXFwsIFxcVHJhbnNpZW50XFwpKVxudmFsdWUgPC0gYyhjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDEpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDIpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDMpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDQpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDUpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDYpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDcpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDgpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBncm91cDkpKVxuXG5kYXRhIDwtIGRhdGEuZnJhbWUoZ3JvdXAsIGNsdXN0ZXIsIHZhbHVlKVxuXG5cbiMgUGxvdHRpbmdcbmdncGxvdChkYXRhLCBhZXMoZmlsbD1jbHVzdGVyLCB5PXZhbHVlLCB4PWdyb3VwKSkgKyBcbiAgICBnZW9tX2Jhcihwb3NpdGlvbj1cXGZpbGxcXCwgc3RhdD1cXGlkZW50aXR5XFwpICsgdGhlbWVfY2xhc3NpYygpXG5cblxuIyBTdGF0aXN0aWNhbCBhbmFseXNpcyBcbiMgU2ltaWxhciB0byB0aGUgQ2hpLVNxdWFyZSB0ZXN0LCBGaXNoZXLigJlzIEV4YWN0IFRlc3QgaXMgdXNlZCB3aGVuIHlvdSBoYXZlIHNtYWxsZXIgc2FtcGxlIHNpemVzIG9yIHdoZW4gdGhlIGV4cGVjdGVkIGZyZXF1ZW5jeSBpbiBhbnkgY2VsbCBvZiB0aGUgY29udGluZ2VuY3kgdGFibGUgaXMgYmVsb3cgNS5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCAlaW4lIGMoXFxncm91cDFcXCwgXFxncm91cDJcXCkpXG5jb250aW5nZW5jeV90YWJsZSA8LSB4dGFicyh2YWx1ZSB+IGdyb3VwICsgY2x1c3RlciwgZGF0YSA9IHRlbXApXG5maXNoZXJfcmVzdWx0IDwtIGZpc2hlci50ZXN0KGNvbnRpbmdlbmN5X3RhYmxlLCBzaW11bGF0ZS5wLnZhbHVlID0gVFJVRSwgQiA9IDEwMDAwMClcbmZpc2hlcl9yZXN1bHRcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwICVpbiUgYyhcXGdyb3VwMVxcLCBcXGdyb3VwM1xcKSlcbmNvbnRpbmdlbmN5X3RhYmxlIDwtIHh0YWJzKHZhbHVlIH4gZ3JvdXAgKyBjbHVzdGVyLCBkYXRhID0gdGVtcClcbmZpc2hlcl9yZXN1bHQgPC0gZmlzaGVyLnRlc3QoY29udGluZ2VuY3lfdGFibGUsIHNpbXVsYXRlLnAudmFsdWUgPSBUUlVFLCBCID0gMTAwMDAwKVxuZmlzaGVyX3Jlc3VsdFxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgJWluJSBjKFxcZ3JvdXAxXFwsIFxcZ3JvdXA0XFwpKVxuY29udGluZ2VuY3lfdGFibGUgPC0geHRhYnModmFsdWUgfiBncm91cCArIGNsdXN0ZXIsIGRhdGEgPSB0ZW1wKVxuZmlzaGVyX3Jlc3VsdCA8LSBmaXNoZXIudGVzdChjb250aW5nZW5jeV90YWJsZSwgc2ltdWxhdGUucC52YWx1ZSA9IFRSVUUsIEIgPSAxMDAwMDApXG5maXNoZXJfcmVzdWx0XG5cblxuYGBgXG5gYGAifQ== -->

```r
```r
## Importing groups
group1 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group2.tsv\))$gene
group3 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group3.tsv\))$gene
group4 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group4.tsv\))$gene
group5 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group5.tsv\))$gene
group6 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group6.tsv\))$gene
group7 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group7.tsv\))$gene
group8 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group8.tsv\))$gene
group9 <- fread(here(refDir, \geneList_A485_vs_DMSO_RNA_loop_group9.tsv\))$gene


## Importing Bobbie gene classification
geneCluster <- fread(here(refDir, \bobbie_gene_classification.csv\)) %>%
  dplyr::select(gene, enst, Cluster)
colnames(geneCluster) <- c(\gene\, \ensembl_transcript_id\, \cluster\)


## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c(\ensembl_transcript_id\, \ensembl_gene_id\),
                 filters = \ensembl_transcript_id\,
                 values = geneCluster$ensembl_transcript,
                 mart = ensembl.v102)
geneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\ensembl_transcript_id\))

# Making data for stacked barplot
countGene <- function(geneCluster, groupName, clusterName){
  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,
                                            cluster %in% clusterName))
  return(num)
}
countGeneList <- function(geneCluster, groupName){
  n1 <- countGene(geneCluster, groupName, \Early\)
  n2 <- countGene(geneCluster, groupName, \Middle\)
  n3 <-countGene(geneCluster, groupName, \Late\)
  n4 <- countGene(geneCluster, groupName, \Transient\)
  return(c(n1, n2, n3, n4))
}

group <- c(rep(\group1\, 4), rep(\group2\, 4), rep(\group3\, 4),
           rep(\group4\, 4), rep(\group5\, 4), rep(\group6\, 4),
           rep(\group7\, 4), rep(\group8\, 4), rep(\group9\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 9)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, group1),
           countGeneList(geneCluster, group2),
           countGeneList(geneCluster, group3),
           countGeneList(geneCluster, group4),
           countGeneList(geneCluster, group5),
           countGeneList(geneCluster, group6),
           countGeneList(geneCluster, group7),
           countGeneList(geneCluster, group8),
           countGeneList(geneCluster, group9))

data <- data.frame(group, cluster, value)


# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()


# Statistical analysis 
# Similar to the Chi-Square test, Fisher’s Exact Test is used when you have smaller sample sizes or when the expected frequency in any cell of the contingency table is below 5.
temp <- data %>% dplyr::filter(group %in% c(\group1\, \group2\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

temp <- data %>% dplyr::filter(group %in% c(\group1\, \group3\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

temp <- data %>% dplyr::filter(group %in% c(\group1\, \group4\))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


## [2.23] Checking Early gene from Bobbie
#### dTAG

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\nextractAnchor <- function(loop){\n  anchor1 <- loop %>% dplyr::select(c(1, 2, 3))\n  colnames(anchor1) <- c(\"chr\", \"start\", \"end\")\n  anchor2 <- loop %>% dplyr::select(c(4, 5, 6))\n  colnames(anchor2) <- c(\"chr\", \"start\", \"end\")\n  anchors <- reduce(makeGRangesFromDataFrame(bind_rows(anchor1, anchor2)))\n    return(anchors)\n}\n\nrunFisherExact <- function(interest.gr, background.gr, query.gr){\n  overlaps_interest <- countOverlaps(interest.gr, query.gr)\n  a <- sum(overlaps_interest > 0)\n  total_interest <- length(interest.gr)\n  c <- total_interest - a\n  \n  overlaps_background <- countOverlaps(background.gr, query.gr)\n  b <- sum(overlaps_background > 0)\n  total_background <- length(background.gr)\n  d <- total_background - b\n  \n  # Construct contingency table\n  contingency_table <- matrix(c(a, c, b, d), nrow=2, byrow=TRUE,\n                              dimnames=list(\"Region\" = c(\"interest.gr\", \"background.gr\"),\n                                            \"Overlap\" = c(\"Yes\", \"No\")))\n  \n  # Perform Fisher's exact test\n  fisher_result <- fisher.test(contingency_table)\n  \n  return(fisher_result)\n}\n\nrunFisherExactCombination <- function(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \"_UP\"),\n                      target = paste0(targetName, \"_retained\"),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \"_NO\"),\n            target = paste0(targetName, \"_retained\"),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \"_DOWN\"),\n            target = paste0(targetName, \"_retained\"),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.up.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \"_UP\"),\n            target = paste0(targetName, \"_lost\"),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \"_NO\"),\n            target = paste0(targetName, \"_lost\"),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \"_DOWN\"),\n            target = paste0(targetName, \"_lost\"),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  return(result.tb)\n}\n\nrunFisherExactCombinationBinary <- function(interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.upno.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \"_UP/NO\"),\n                      target = paste0(targetName, \"_retained\"),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n\n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \"_DOWN\"),\n            target = paste0(targetName, \"_retained\"),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.upno.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \"_UP/NO\"),\n            target = paste0(targetName, \"_lost\"),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \"_DOWN\"),\n            target = paste0(targetName, \"_lost\"),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  return(result.tb)\n}\n\nrunFisherExactCombinationRetained <- function(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \"_UP\"),\n                      target = paste0(targetName, \"_retained\"),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \"_NO\"),\n            target = paste0(targetName, \"_retained\"),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \"_DOWN\"),\n            target = paste0(targetName, \"_retained\"),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n\n  return(result.tb)\n}\n\nrunFisherExactCombinationTarget <- function(targetName, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \"TF_bookmarking\", targetName, \"am_a.bed\")) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\"chr\", \"start\", \"end\")\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  lost <- fread(here(refDir, \"TF_bookmarking\", targetName, \"oa.bed\")) %>% dplyr::select(c(1, 2, 3))\n  colnames(lost) <- c(\"chr\", \"start\", \"end\")\n  lost.gr <- makeGRangesFromDataFrame(lost)\n  \n  result <- runFisherExactCombination(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr)\n  \n  return(result)\n}\n\nrunFisherExactCombinationTargetBinary <- function(targetName, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \"TF_bookmarking\", targetName, \"am_a.bed\")) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\"chr\", \"start\", \"end\")\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  lost <- fread(here(refDir, \"TF_bookmarking\", targetName, \"oa.bed\")) %>% dplyr::select(c(1, 2, 3))\n  colnames(lost) <- c(\"chr\", \"start\", \"end\")\n  lost.gr <- makeGRangesFromDataFrame(lost)\n  \n  result <- runFisherExactCombinationBinary(interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr)\n  \n  return(result)\n}\n\nrunFisherExactCombinationTargetRetained <- function(targetName, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \"TF_bookmarking\", targetName, \"am_a.bed\")) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\"chr\", \"start\", \"end\")\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  result <- runFisherExactCombinationRetained(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr)\n  \n  return(result)\n}\n```"} -->\n\n```r\nextractAnchor <- function(loop){\n  anchor1 <- loop %>% dplyr::select(c(1, 2, 3))\n  colnames(anchor1) <- c(\\chr\\, \\start\\, \\end\\)\n  anchor2 <- loop %>% dplyr::select(c(4, 5, 6))\n  colnames(anchor2) <- c(\\chr\\, \\start\\, \\end\\)\n  anchors <- reduce(makeGRangesFromDataFrame(bind_rows(anchor1, anchor2)))\n    return(anchors)\n}\n\nrunFisherExact <- function(interest.gr, background.gr, query.gr){\n  overlaps_interest <- countOverlaps(interest.gr, query.gr)\n  a <- sum(overlaps_interest > 0)\n  total_interest <- length(interest.gr)\n  c <- total_interest - a\n  \n  overlaps_background <- countOverlaps(background.gr, query.gr)\n  b <- sum(overlaps_background > 0)\n  total_background <- length(background.gr)\n  d <- total_background - b\n  \n  # Construct contingency table\n  contingency_table <- matrix(c(a, c, b, d), nrow=2, byrow=TRUE,\n                              dimnames=list(\\Region\\ = c(\\interest.gr\\, \\background.gr\\),\n                                            \\Overlap\\ = c(\\Yes\\, \\No\\)))\n  \n  # Perform Fisher's exact test\n  fisher_result <- fisher.test(contingency_table)\n  \n  return(fisher_result)\n}\n\nrunFisherExactCombination <- function(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \\_UP\\),\n                      target = paste0(targetName, \\_retained\\),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_NO\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.up.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_UP\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_NO\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  return(result.tb)\n}\n\nrunFisherExactCombinationBinary <- function(interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.upno.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \\_UP/NO\\),\n                      target = paste0(targetName, \\_retained\\),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n\n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.upno.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_UP/NO\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  return(result.tb)\n}\n\nrunFisherExactCombinationRetained <- function(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \\_UP\\),\n                      target = paste0(targetName, \\_retained\\),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_NO\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n\n  return(result.tb)\n}\n\nrunFisherExactCombinationTarget <- function(targetName, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  lost <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\oa.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(lost) <- c(\\chr\\, \\start\\, \\end\\)\n  lost.gr <- makeGRangesFromDataFrame(lost)\n  \n  result <- runFisherExactCombination(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr)\n  \n  return(result)\n}\n\nrunFisherExactCombinationTargetBinary <- function(targetName, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  lost <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\oa.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(lost) <- c(\\chr\\, \\start\\, \\end\\)\n  lost.gr <- makeGRangesFromDataFrame(lost)\n  \n  result <- runFisherExactCombinationBinary(interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr)\n  \n  return(result)\n}\n\nrunFisherExactCombinationTargetRetained <- function(targetName, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  result <- runFisherExactCombinationRetained(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr)\n  \n  return(result)\n}\n```\n\n<!-- rnb-source-end -->\n"} -->
extractAnchor <- function(loop){
  anchor1 <- loop %>% dplyr::select(c(1, 2, 3))
  colnames(anchor1) <- c(\chr\, \start\, \end\)
  anchor2 <- loop %>% dplyr::select(c(4, 5, 6))
  colnames(anchor2) <- c(\chr\, \start\, \end\)
  anchors <- reduce(makeGRangesFromDataFrame(bind_rows(anchor1, anchor2)))
    return(anchors)
}

runFisherExact <- function(interest.gr, background.gr, query.gr){
  overlaps_interest <- countOverlaps(interest.gr, query.gr)
  a <- sum(overlaps_interest > 0)
  total_interest <- length(interest.gr)
  c <- total_interest - a
  
  overlaps_background <- countOverlaps(background.gr, query.gr)
  b <- sum(overlaps_background > 0)
  total_background <- length(background.gr)
  d <- total_background - b
  
  # Construct contingency table
  contingency_table <- matrix(c(a, c, b, d), nrow=2, byrow=TRUE,
                              dimnames=list(\Region\ = c(\interest.gr\, \background.gr\),
                                            \Overlap\ = c(\Yes\, \No\)))
  
  # Perform Fisher's exact test
  fisher_result <- fisher.test(contingency_table)
  
  return(fisher_result)
}

runFisherExactCombination <- function(interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr, lost.gr){
  # SEEDING
  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)
  result.tb <- tibble(interest = paste0(interestName, \_UP\),
                      target = paste0(targetName, \_retained\),
                      pvalue = temp$p.value,
                      oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_NO\),
            target = paste0(targetName, \_retained\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_DOWN\),
            target = paste0(targetName, \_retained\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.up.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_UP\),
            target = paste0(targetName, \_lost\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.no.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_NO\),
            target = paste0(targetName, \_lost\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_DOWN\),
            target = paste0(targetName, \_lost\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  return(result.tb)
}

runFisherExactCombinationBinary <- function(interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr, lost.gr){
  # SEEDING
  temp <- runFisherExact(loop.upno.gr, background.gr, retained.gr)
  result.tb <- tibble(interest = paste0(interestName, \_UP/NO\),
                      target = paste0(targetName, \_retained\),
                      pvalue = temp$p.value,
                      oddsRatio = temp$estimate)
  

  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_DOWN\),
            target = paste0(targetName, \_retained\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.upno.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_UP/NO\),
            target = paste0(targetName, \_lost\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)

  
  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_DOWN\),
            target = paste0(targetName, \_lost\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  return(result.tb)
}

runFisherExactCombinationRetained <- function(interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr){
  # SEEDING
  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)
  result.tb <- tibble(interest = paste0(interestName, \_UP\),
                      target = paste0(targetName, \_retained\),
                      pvalue = temp$p.value,
                      oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_NO\),
            target = paste0(targetName, \_retained\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_DOWN\),
            target = paste0(targetName, \_retained\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  

  return(result.tb)
}

runFisherExactCombinationTarget <- function(targetName, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr){
  # RETAINED loop
  retained <- fread(here(refDir, \TF_bookmarking\, targetName, \am_a.bed\)) %>% dplyr::select(c(1, 2, 3))
  colnames(retained) <- c(\chr\, \start\, \end\)
  retained.gr <- makeGRangesFromDataFrame(retained)
  # LOST loop
  lost <- fread(here(refDir, \TF_bookmarking\, targetName, \oa.bed\)) %>% dplyr::select(c(1, 2, 3))
  colnames(lost) <- c(\chr\, \start\, \end\)
  lost.gr <- makeGRangesFromDataFrame(lost)
  
  result <- runFisherExactCombination(interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr, lost.gr)
  
  return(result)
}

runFisherExactCombinationTargetBinary <- function(targetName, interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr){
  # RETAINED loop
  retained <- fread(here(refDir, \TF_bookmarking\, targetName, \am_a.bed\)) %>% dplyr::select(c(1, 2, 3))
  colnames(retained) <- c(\chr\, \start\, \end\)
  retained.gr <- makeGRangesFromDataFrame(retained)
  # LOST loop
  lost <- fread(here(refDir, \TF_bookmarking\, targetName, \oa.bed\)) %>% dplyr::select(c(1, 2, 3))
  colnames(lost) <- c(\chr\, \start\, \end\)
  lost.gr <- makeGRangesFromDataFrame(lost)
  
  result <- runFisherExactCombinationBinary(interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr, lost.gr)
  
  return(result)
}

runFisherExactCombinationTargetRetained <- function(targetName, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr){
  # RETAINED loop
  retained <- fread(here(refDir, \TF_bookmarking\, targetName, \am_a.bed\)) %>% dplyr::select(c(1, 2, 3))
  colnames(retained) <- c(\chr\, \start\, \end\)
  retained.gr <- makeGRangesFromDataFrame(retained)
  # LOST loop
  result <- runFisherExactCombinationRetained(interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr)
  
  return(result)
}



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\nextractAnchor <- function(loop){\n  anchor1 <- loop %>% dplyr::select(c(1, 2, 3))\n  colnames(anchor1) <- c(\\chr\\, \\start\\, \\end\\)\n  anchor2 <- loop %>% dplyr::select(c(4, 5, 6))\n  colnames(anchor2) <- c(\\chr\\, \\start\\, \\end\\)\n  anchors <- reduce(makeGRangesFromDataFrame(bind_rows(anchor1, anchor2)))\n    return(anchors)\n}\n\nrunFisherExact <- function(interest.gr, background.gr, query.gr){\n  overlaps_interest <- countOverlaps(interest.gr, query.gr)\n  a <- sum(overlaps_interest > 0)\n  total_interest <- length(interest.gr)\n  c <- total_interest - a\n  \n  overlaps_background <- countOverlaps(background.gr, query.gr)\n  b <- sum(overlaps_background > 0)\n  total_background <- length(background.gr)\n  d <- total_background - b\n  \n  # Construct contingency table\n  contingency_table <- matrix(c(a, c, b, d), nrow=2, byrow=TRUE,\n                              dimnames=list(\\Region\\ = c(\\interest.gr\\, \\background.gr\\),\n                                            \\Overlap\\ = c(\\Yes\\, \\No\\)))\n  \n  # Perform Fisher's exact test\n  fisher_result <- fisher.test(contingency_table)\n  \n  return(fisher_result)\n}\n\nrunFisherExactCombination <- function(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \\_UP\\),\n                      target = paste0(targetName, \\_retained\\),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_NO\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.up.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_UP\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_NO\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  return(result.tb)\n}\n\nrunFisherExactCombinationBinary <- function(interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.upno.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \\_UP/NO\\),\n                      target = paste0(targetName, \\_retained\\),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n\n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.upno.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_UP/NO\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  return(result.tb)\n}\n\nrunFisherExactCombinationRetained <- function(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \\_UP\\),\n                      target = paste0(targetName, \\_retained\\),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_NO\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n\n  return(result.tb)\n}\n\nrunFisherExactCombinationTarget <- function(targetName, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  lost <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\oa.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(lost) <- c(\\chr\\, \\start\\, \\end\\)\n  lost.gr <- makeGRangesFromDataFrame(lost)\n  \n  result <- runFisherExactCombination(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr)\n  \n  return(result)\n}\n\nrunFisherExactCombinationTargetBinary <- function(targetName, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  lost <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\oa.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(lost) <- c(\\chr\\, \\start\\, \\end\\)\n  lost.gr <- makeGRangesFromDataFrame(lost)\n  \n  result <- runFisherExactCombinationBinary(interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr)\n  \n  return(result)\n}\n\nrunFisherExactCombinationTargetRetained <- function(targetName, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  result <- runFisherExactCombinationRetained(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr)\n  \n  return(result)\n}\n```\n```"} -->\n\n```r\n```r\nextractAnchor <- function(loop){\n  anchor1 <- loop %>% dplyr::select(c(1, 2, 3))\n  colnames(anchor1) <- c(\\chr\\, \\start\\, \\end\\)\n  anchor2 <- loop %>% dplyr::select(c(4, 5, 6))\n  colnames(anchor2) <- c(\\chr\\, \\start\\, \\end\\)\n  anchors <- reduce(makeGRangesFromDataFrame(bind_rows(anchor1, anchor2)))\n    return(anchors)\n}\n\nrunFisherExact <- function(interest.gr, background.gr, query.gr){\n  overlaps_interest <- countOverlaps(interest.gr, query.gr)\n  a <- sum(overlaps_interest > 0)\n  total_interest <- length(interest.gr)\n  c <- total_interest - a\n  \n  overlaps_background <- countOverlaps(background.gr, query.gr)\n  b <- sum(overlaps_background > 0)\n  total_background <- length(background.gr)\n  d <- total_background - b\n  \n  # Construct contingency table\n  contingency_table <- matrix(c(a, c, b, d), nrow=2, byrow=TRUE,\n                              dimnames=list(\\Region\\ = c(\\interest.gr\\, \\background.gr\\),\n                                            \\Overlap\\ = c(\\Yes\\, \\No\\)))\n  \n  # Perform Fisher's exact test\n  fisher_result <- fisher.test(contingency_table)\n  \n  return(fisher_result)\n}\n\nrunFisherExactCombination <- function(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \\_UP\\),\n                      target = paste0(targetName, \\_retained\\),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_NO\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.up.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_UP\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_NO\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  return(result.tb)\n}\n\nrunFisherExactCombinationBinary <- function(interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.upno.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \\_UP/NO\\),\n                      target = paste0(targetName, \\_retained\\),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n\n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.upno.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_UP/NO\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  return(result.tb)\n}\n\nrunFisherExactCombinationRetained <- function(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \\_UP\\),\n                      target = paste0(targetName, \\_retained\\),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_NO\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n\n  return(result.tb)\n}\n\nrunFisherExactCombinationTarget <- function(targetName, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  lost <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\oa.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(lost) <- c(\\chr\\, \\start\\, \\end\\)\n  lost.gr <- makeGRangesFromDataFrame(lost)\n  \n  result <- runFisherExactCombination(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr)\n  \n  return(result)\n}\n\nrunFisherExactCombinationTargetBinary <- function(targetName, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  lost <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\oa.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(lost) <- c(\\chr\\, \\start\\, \\end\\)\n  lost.gr <- makeGRangesFromDataFrame(lost)\n  \n  result <- runFisherExactCombinationBinary(interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr)\n  \n  return(result)\n}\n\nrunFisherExactCombinationTargetRetained <- function(targetName, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  result <- runFisherExactCombinationRetained(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr)\n  \n  return(result)\n}\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\nextractAnchor <- function(loop){\n  anchor1 <- loop %>% dplyr::select(c(1, 2, 3))\n  colnames(anchor1) <- c(\\chr\\, \\start\\, \\end\\)\n  anchor2 <- loop %>% dplyr::select(c(4, 5, 6))\n  colnames(anchor2) <- c(\\chr\\, \\start\\, \\end\\)\n  anchors <- reduce(makeGRangesFromDataFrame(bind_rows(anchor1, anchor2)))\n    return(anchors)\n}\n\nrunFisherExact <- function(interest.gr, background.gr, query.gr){\n  overlaps_interest <- countOverlaps(interest.gr, query.gr)\n  a <- sum(overlaps_interest > 0)\n  total_interest <- length(interest.gr)\n  c <- total_interest - a\n  \n  overlaps_background <- countOverlaps(background.gr, query.gr)\n  b <- sum(overlaps_background > 0)\n  total_background <- length(background.gr)\n  d <- total_background - b\n  \n  # Construct contingency table\n  contingency_table <- matrix(c(a, c, b, d), nrow=2, byrow=TRUE,\n                              dimnames=list(\\Region\\ = c(\\interest.gr\\, \\background.gr\\),\n                                            \\Overlap\\ = c(\\Yes\\, \\No\\)))\n  \n  # Perform Fisher's exact test\n  fisher_result <- fisher.test(contingency_table)\n  \n  return(fisher_result)\n}\n\nrunFisherExactCombination <- function(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \\_UP\\),\n                      target = paste0(targetName, \\_retained\\),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_NO\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.up.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_UP\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_NO\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  return(result.tb)\n}\n\nrunFisherExactCombinationBinary <- function(interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.upno.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \\_UP/NO\\),\n                      target = paste0(targetName, \\_retained\\),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n\n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.upno.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_UP/NO\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_lost\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  return(result.tb)\n}\n\nrunFisherExactCombinationRetained <- function(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr){\n  # SEEDING\n  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)\n  result.tb <- tibble(interest = paste0(interestName, \\_UP\\),\n                      target = paste0(targetName, \\_retained\\),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_NO\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  # ADDING ROWS\n  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\n  result.tb <- result.tb %>% \n    add_row(interest = paste0(interestName, \\_DOWN\\),\n            target = paste0(targetName, \\_retained\\),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n\n  return(result.tb)\n}\n\nrunFisherExactCombinationTarget <- function(targetName, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  lost <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\oa.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(lost) <- c(\\chr\\, \\start\\, \\end\\)\n  lost.gr <- makeGRangesFromDataFrame(lost)\n  \n  result <- runFisherExactCombination(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr)\n  \n  return(result)\n}\n\nrunFisherExactCombinationTargetBinary <- function(targetName, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  lost <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\oa.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(lost) <- c(\\chr\\, \\start\\, \\end\\)\n  lost.gr <- makeGRangesFromDataFrame(lost)\n  \n  result <- runFisherExactCombinationBinary(interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr, lost.gr)\n  \n  return(result)\n}\n\nrunFisherExactCombinationTargetRetained <- function(targetName, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr){\n  # RETAINED loop\n  retained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\n  colnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\n  retained.gr <- makeGRangesFromDataFrame(retained)\n  # LOST loop\n  result <- runFisherExactCombinationRetained(interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr,\n                                      targetName,\n                                      retained.gr)\n  \n  return(result)\n}\n```\n```"} -->

```r
```r
extractAnchor <- function(loop){
  anchor1 <- loop %>% dplyr::select(c(1, 2, 3))
  colnames(anchor1) <- c(\chr\, \start\, \end\)
  anchor2 <- loop %>% dplyr::select(c(4, 5, 6))
  colnames(anchor2) <- c(\chr\, \start\, \end\)
  anchors <- reduce(makeGRangesFromDataFrame(bind_rows(anchor1, anchor2)))
    return(anchors)
}

runFisherExact <- function(interest.gr, background.gr, query.gr){
  overlaps_interest <- countOverlaps(interest.gr, query.gr)
  a <- sum(overlaps_interest > 0)
  total_interest <- length(interest.gr)
  c <- total_interest - a
  
  overlaps_background <- countOverlaps(background.gr, query.gr)
  b <- sum(overlaps_background > 0)
  total_background <- length(background.gr)
  d <- total_background - b
  
  # Construct contingency table
  contingency_table <- matrix(c(a, c, b, d), nrow=2, byrow=TRUE,
                              dimnames=list(\Region\ = c(\interest.gr\, \background.gr\),
                                            \Overlap\ = c(\Yes\, \No\)))
  
  # Perform Fisher's exact test
  fisher_result <- fisher.test(contingency_table)
  
  return(fisher_result)
}

runFisherExactCombination <- function(interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr, lost.gr){
  # SEEDING
  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)
  result.tb <- tibble(interest = paste0(interestName, \_UP\),
                      target = paste0(targetName, \_retained\),
                      pvalue = temp$p.value,
                      oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_NO\),
            target = paste0(targetName, \_retained\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_DOWN\),
            target = paste0(targetName, \_retained\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.up.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_UP\),
            target = paste0(targetName, \_lost\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.no.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_NO\),
            target = paste0(targetName, \_lost\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_DOWN\),
            target = paste0(targetName, \_lost\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  return(result.tb)
}

runFisherExactCombinationBinary <- function(interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr, lost.gr){
  # SEEDING
  temp <- runFisherExact(loop.upno.gr, background.gr, retained.gr)
  result.tb <- tibble(interest = paste0(interestName, \_UP/NO\),
                      target = paste0(targetName, \_retained\),
                      pvalue = temp$p.value,
                      oddsRatio = temp$estimate)
  

  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_DOWN\),
            target = paste0(targetName, \_retained\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.upno.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_UP/NO\),
            target = paste0(targetName, \_lost\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)

  
  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_DOWN\),
            target = paste0(targetName, \_lost\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  return(result.tb)
}

runFisherExactCombinationRetained <- function(interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr){
  # SEEDING
  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)
  result.tb <- tibble(interest = paste0(interestName, \_UP\),
                      target = paste0(targetName, \_retained\),
                      pvalue = temp$p.value,
                      oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_NO\),
            target = paste0(targetName, \_retained\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, \_DOWN\),
            target = paste0(targetName, \_retained\),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  

  return(result.tb)
}

runFisherExactCombinationTarget <- function(targetName, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr){
  # RETAINED loop
  retained <- fread(here(refDir, \TF_bookmarking\, targetName, \am_a.bed\)) %>% dplyr::select(c(1, 2, 3))
  colnames(retained) <- c(\chr\, \start\, \end\)
  retained.gr <- makeGRangesFromDataFrame(retained)
  # LOST loop
  lost <- fread(here(refDir, \TF_bookmarking\, targetName, \oa.bed\)) %>% dplyr::select(c(1, 2, 3))
  colnames(lost) <- c(\chr\, \start\, \end\)
  lost.gr <- makeGRangesFromDataFrame(lost)
  
  result <- runFisherExactCombination(interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr, lost.gr)
  
  return(result)
}

runFisherExactCombinationTargetBinary <- function(targetName, interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr){
  # RETAINED loop
  retained <- fread(here(refDir, \TF_bookmarking\, targetName, \am_a.bed\)) %>% dplyr::select(c(1, 2, 3))
  colnames(retained) <- c(\chr\, \start\, \end\)
  retained.gr <- makeGRangesFromDataFrame(retained)
  # LOST loop
  lost <- fread(here(refDir, \TF_bookmarking\, targetName, \oa.bed\)) %>% dplyr::select(c(1, 2, 3))
  colnames(lost) <- c(\chr\, \start\, \end\)
  lost.gr <- makeGRangesFromDataFrame(lost)
  
  result <- runFisherExactCombinationBinary(interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr, lost.gr)
  
  return(result)
}

runFisherExactCombinationTargetRetained <- function(targetName, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr){
  # RETAINED loop
  retained <- fread(here(refDir, \TF_bookmarking\, targetName, \am_a.bed\)) %>% dplyr::select(c(1, 2, 3))
  colnames(retained) <- c(\chr\, \start\, \end\)
  retained.gr <- makeGRangesFromDataFrame(retained)
  # LOST loop
  result <- runFisherExactCombinationRetained(interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr)
  
  return(result)
}
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### A485

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgaW50ZXJlc3RcbmludGVyZXN0TmFtZSA8LSBcImFsbExvb3BcIlxuIyBCQUNLR1JPVU5EIGxvb3BcbmJhY2tncm91bmQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGwuYmVkcGVcIikpXG5iYWNrZ3JvdW5kLmdyIDwtIChleHRyYWN0QW5jaG9yKGJhY2tncm91bmQpKVxuIyBVUCBsb29wXG5sb29wLnVwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX2RUQUd2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVwiKSlcbmxvb3AudXAuZ3IgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG4jIE5PIGxvb3Bcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXCIpKVxubG9vcC5uby5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbiMgRE9XTiBsb29wXG5sb29wTnVtIDwtIG5yb3cobG9vcC5ubylcbmxvb3AuYWxsIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHkudHN2XCIpKVxubG9vcC5kb3duIDwtIGxvb3AuYWxsICU+JSBkcGx5cjo6ZmlsdGVyKGRpZmZfZFRBR19ETVNPIDwgLTAuMikgJT4lIGRwbHlyOjphcnJhbmdlKGRpZmZfZFRBR19ETVNPKSAlPiUgc2xpY2VfaGVhZChuID0gbG9vcE51bSlcbmxvb3AuZG93bi5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxuXG4jIyMjIEltcG9ydGluZyBsb29wcyBvZiB0YXJnZXRcbnRlbXAxIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJBVEFDX2VmZmllXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDIgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIkNUQ0ZcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiRVNSUkJfZHNnXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDQgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIkVTUlJCX05DQlwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJFU1JSQl9wZmFcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiSDNLMjdhY19lZmZpZVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJLTEY0X2VmZmllXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDggPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIk5BTk9HX2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA5IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJOQU5PR19wZmFcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTAgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIk9DVDRfZWZmaWVcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIk9DVDRfZHNnXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDEyIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJPQ1Q0X3BmYVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiU01DMVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiU09YMl9lZmZpZVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxNSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiU09YMl9kc2dcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIlNPWDJfcGZhXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDE3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJUQlBcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG5cblxuXG5cbmRhdGEgPC0gYmluZF9yb3dzKHRlbXAxLCB0ZW1wMiwgdGVtcDMsIHRlbXA0LCB0ZW1wNSxcbiAgICAgICAgIHRlbXA2LCB0ZW1wNywgdGVtcDgsIHRlbXA5LCB0ZW1wMTAsXG4gICAgICAgICB0ZW1wMTEsIHRlbXAxMiwgdGVtcDEzLCB0ZW1wMTQsIHRlbXAxNSwgdGVtcDE2ICx0ZW1wMTcpXG5cbiMgVmlzdWFsaXphdGlvblxubGlicmFyeShjaXJjbGl6ZSlcblxuaGVhdG1hcF9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgb2Rkc1JhdGlvKSAlPiVcbnBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBpbnRlcmVzdCwgdmFsdWVzX2Zyb20gPSBvZGRzUmF0aW8pICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXCJ0YXJnZXRcIilcblxucHZhbHVlX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGludGVyZXN0LCBwdmFsdWUpICU+JVxuICBwaXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gcHZhbHVlKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFwidGFyZ2V0XCIpXG5cbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEsIDUpLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFwiYmx1ZVwiLCBcIndoaXRlXCIsIFwicmVkXCIpKVxuXG5IZWF0bWFwKGFzLm1hdHJpeChoZWF0bWFwX2RhdGEpLFxuICAgICAgICBuYW1lID0gXCJPZGRzIFJhdGlvXCIsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4sXG4gICAgICAgICMgQWRkIGFubm90YXRpb24gZm9yIHAtdmFsdWVzXG4gICAgICAgIGNlbGxfZnVuID0gZnVuY3Rpb24oaiwgaSwgeCwgeSwgd2lkdGgsIGhlaWdodCwgZmlsbCkge1xuICAgICAgICAgIHB2YWwgPC0gcHZhbHVlX2RhdGFbaSwgal1cbiAgICAgICAgICBsYWJlbCA8LSBpZmVsc2UocHZhbCA+IDAuMDUsIFwibi5zLlwiLCBzcHJpbnRmKFwiJS4yZVwiLCBwdmFsKSlcbiAgICAgICAgICBncmlkLnRleHQobGFiZWwsIHgsIHksIGdwID0gZ3Bhcihmb250c2l6ZSA9IDEwKSlcbiAgICAgICAgfSxcbiAgICAgICAgIyBDdXN0b21pemUgdGhlIGhlYXRtYXAgbGF5b3V0XG4gICAgICAgIGNsdXN0ZXJfcm93cyA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY29sdW1uX3RpdGxlID0gXCJJbnRlcmVzdFwiLFxuICAgICAgICByb3dfdGl0bGUgPSBcIlRhcmdldFwiLFxuICAgICAgICBoZWF0bWFwX2xlZ2VuZF9wYXJhbSA9IGxpc3QoYXQgPSBjKDAsIDEsIDIsIDMsIDQsIDUpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxhYmVscyA9IGMoXCIwXCIsIFwiMVwiLCBcIjJcIiwgXCIzXCIsIFwiNFwiLCBcIjVcIikpKVxuYGBgIn0= -->\n\n```r\n#### Importing loops of interest\ninterestName <- \\allLoop\\\n# BACKGROUND loop\nbackground <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all.bedpe\\))\nbackground.gr <- (extractAnchor(background))\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.up.gr <- (extractAnchor(loop.up))\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nloop.no.gr <- (extractAnchor(loop.no))\n# DOWN loop\nloopNum <- nrow(loop.no)\nloop.all <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\))\nloop.down <- loop.all %>% dplyr::filter(diff_dTAG_DMSO < -0.2) %>% dplyr::arrange(diff_dTAG_DMSO) %>% slice_head(n = loopNum)\nloop.down.gr <- (extractAnchor(loop.down))\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTarget(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTarget(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTarget(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTarget(\\ESRRB_NCB\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTarget(\\ESRRB_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTarget(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTarget(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTarget(\\NANOG_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTarget(\\OCT4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp11 <- runFisherExactCombinationTarget(\\OCT4_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp12 <- runFisherExactCombinationTarget(\\OCT4_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp13 <- runFisherExactCombinationTarget(\\SMC1\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp14 <- runFisherExactCombinationTarget(\\SOX2_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp15 <- runFisherExactCombinationTarget(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp16 <- runFisherExactCombinationTarget(\\SOX2_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp17 <- runFisherExactCombinationTarget(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10,\n         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 5), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\, \\4\\, \\5\\)))\n```\n\n<!-- rnb-source-end -->\n"} -->
#### Importing loops of interest
interestName <- \allLoop\
# BACKGROUND loop
background <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all.bedpe\))
background.gr <- (extractAnchor(background))
# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.up.gr <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\))
loop.no.gr <- (extractAnchor(loop.no))
# DOWN loop
loopNum <- nrow(loop.no)
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\))
loop.down <- loop.all %>% dplyr::filter(diff_dTAG_DMSO < -0.2) %>% dplyr::arrange(diff_dTAG_DMSO) %>% slice_head(n = loopNum)
loop.down.gr <- (extractAnchor(loop.down))

#### Importing loops of target
temp1 <- runFisherExactCombinationTarget(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget(\ESRRB_NCB\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget(\ESRRB_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget(\NANOG_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget(\OCT4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp11 <- runFisherExactCombinationTarget(\OCT4_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp12 <- runFisherExactCombinationTarget(\OCT4_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp13 <- runFisherExactCombinationTarget(\SMC1\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp14 <- runFisherExactCombinationTarget(\SOX2_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp15 <- runFisherExactCombinationTarget(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp16 <- runFisherExactCombinationTarget(\SOX2_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp17 <- runFisherExactCombinationTarget(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10,
         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 5), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), 
                                    labels = c(\0\, \1\, \2\, \3\, \4\, \5\)))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgaW50ZXJlc3RcbmludGVyZXN0TmFtZSA8LSBcXGFsbExvb3BcXFxuIyBCQUNLR1JPVU5EIGxvb3BcbmJhY2tncm91bmQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGwuYmVkcGVcXCkpXG5iYWNrZ3JvdW5kLmdyIDwtIChleHRyYWN0QW5jaG9yKGJhY2tncm91bmQpKVxuIyBVUCBsb29wXG5sb29wLnVwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX2RUQUd2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSlcbmxvb3AudXAuZ3IgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG4jIE5PIGxvb3Bcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5uby5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbiMgRE9XTiBsb29wXG5sb29wTnVtIDwtIG5yb3cobG9vcC5ubylcbmxvb3AuYWxsIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHkudHN2XFwpKVxubG9vcC5kb3duIDwtIGxvb3AuYWxsICU+JSBkcGx5cjo6ZmlsdGVyKGRpZmZfZFRBR19ETVNPIDwgLTAuMikgJT4lIGRwbHlyOjphcnJhbmdlKGRpZmZfZFRBR19ETVNPKSAlPiUgc2xpY2VfaGVhZChuID0gbG9vcE51bSlcbmxvb3AuZG93bi5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxuXG4jIyMjIEltcG9ydGluZyBsb29wcyBvZiB0YXJnZXRcbnRlbXAxIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxBVEFDX2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDIgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXENUQ0ZcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcRVNSUkJfZHNnXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDQgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEVTUlJCX05DQlxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxFU1JSQl9wZmFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcSDNLMjdhY19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxLTEY0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDggPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE5BTk9HX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA5IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxOQU5PR19wZmFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTAgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE9DVDRfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE9DVDRfZHNnXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDEyIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X3BmYVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcU01DMVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcU09YMl9lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxNSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcU09YMl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFNPWDJfcGZhXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDE3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxUQlBcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG5cblxuXG5cbmRhdGEgPC0gYmluZF9yb3dzKHRlbXAxLCB0ZW1wMiwgdGVtcDMsIHRlbXA0LCB0ZW1wNSxcbiAgICAgICAgIHRlbXA2LCB0ZW1wNywgdGVtcDgsIHRlbXA5LCB0ZW1wMTAsXG4gICAgICAgICB0ZW1wMTEsIHRlbXAxMiwgdGVtcDEzLCB0ZW1wMTQsIHRlbXAxNSwgdGVtcDE2ICx0ZW1wMTcpXG5cbiMgVmlzdWFsaXphdGlvblxubGlicmFyeShjaXJjbGl6ZSlcblxuaGVhdG1hcF9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgb2Rkc1JhdGlvKSAlPiVcbnBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBpbnRlcmVzdCwgdmFsdWVzX2Zyb20gPSBvZGRzUmF0aW8pICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFx0YXJnZXRcXClcblxucHZhbHVlX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGludGVyZXN0LCBwdmFsdWUpICU+JVxuICBwaXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gcHZhbHVlKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEsIDUpLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFxcYmx1ZVxcLCBcXHdoaXRlXFwsIFxccmVkXFwpKVxuXG5IZWF0bWFwKGFzLm1hdHJpeChoZWF0bWFwX2RhdGEpLFxuICAgICAgICBuYW1lID0gXFxPZGRzIFJhdGlvXFwsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4sXG4gICAgICAgICMgQWRkIGFubm90YXRpb24gZm9yIHAtdmFsdWVzXG4gICAgICAgIGNlbGxfZnVuID0gZnVuY3Rpb24oaiwgaSwgeCwgeSwgd2lkdGgsIGhlaWdodCwgZmlsbCkge1xuICAgICAgICAgIHB2YWwgPC0gcHZhbHVlX2RhdGFbaSwgal1cbiAgICAgICAgICBsYWJlbCA8LSBpZmVsc2UocHZhbCA+IDAuMDUsIFxcbi5zLlxcLCBzcHJpbnRmKFxcJS4yZVxcLCBwdmFsKSlcbiAgICAgICAgICBncmlkLnRleHQobGFiZWwsIHgsIHksIGdwID0gZ3Bhcihmb250c2l6ZSA9IDEwKSlcbiAgICAgICAgfSxcbiAgICAgICAgIyBDdXN0b21pemUgdGhlIGhlYXRtYXAgbGF5b3V0XG4gICAgICAgIGNsdXN0ZXJfcm93cyA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY29sdW1uX3RpdGxlID0gXFxJbnRlcmVzdFxcLFxuICAgICAgICByb3dfdGl0bGUgPSBcXFRhcmdldFxcLFxuICAgICAgICBoZWF0bWFwX2xlZ2VuZF9wYXJhbSA9IGxpc3QoYXQgPSBjKDAsIDEsIDIsIDMsIDQsIDUpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxhYmVscyA9IGMoXFwwXFwsIFxcMVxcLCBcXDJcXCwgXFwzXFwsIFxcNFxcLCBcXDVcXCkpKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n#### Importing loops of interest\ninterestName <- \\allLoop\\\n# BACKGROUND loop\nbackground <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all.bedpe\\))\nbackground.gr <- (extractAnchor(background))\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.up.gr <- (extractAnchor(loop.up))\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nloop.no.gr <- (extractAnchor(loop.no))\n# DOWN loop\nloopNum <- nrow(loop.no)\nloop.all <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\))\nloop.down <- loop.all %>% dplyr::filter(diff_dTAG_DMSO < -0.2) %>% dplyr::arrange(diff_dTAG_DMSO) %>% slice_head(n = loopNum)\nloop.down.gr <- (extractAnchor(loop.down))\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTarget(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTarget(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTarget(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTarget(\\ESRRB_NCB\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTarget(\\ESRRB_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTarget(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTarget(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTarget(\\NANOG_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTarget(\\OCT4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp11 <- runFisherExactCombinationTarget(\\OCT4_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp12 <- runFisherExactCombinationTarget(\\OCT4_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp13 <- runFisherExactCombinationTarget(\\SMC1\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp14 <- runFisherExactCombinationTarget(\\SOX2_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp15 <- runFisherExactCombinationTarget(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp16 <- runFisherExactCombinationTarget(\\SOX2_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp17 <- runFisherExactCombinationTarget(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10,\n         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 5), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\, \\4\\, \\5\\)))\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgaW50ZXJlc3RcbmludGVyZXN0TmFtZSA8LSBcXGFsbExvb3BcXFxuIyBCQUNLR1JPVU5EIGxvb3BcbmJhY2tncm91bmQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGwuYmVkcGVcXCkpXG5iYWNrZ3JvdW5kLmdyIDwtIChleHRyYWN0QW5jaG9yKGJhY2tncm91bmQpKVxuIyBVUCBsb29wXG5sb29wLnVwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX2RUQUd2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSlcbmxvb3AudXAuZ3IgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG4jIE5PIGxvb3Bcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5uby5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbiMgRE9XTiBsb29wXG5sb29wTnVtIDwtIG5yb3cobG9vcC5ubylcbmxvb3AuYWxsIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHkudHN2XFwpKVxubG9vcC5kb3duIDwtIGxvb3AuYWxsICU+JSBkcGx5cjo6ZmlsdGVyKGRpZmZfZFRBR19ETVNPIDwgLTAuMikgJT4lIGRwbHlyOjphcnJhbmdlKGRpZmZfZFRBR19ETVNPKSAlPiUgc2xpY2VfaGVhZChuID0gbG9vcE51bSlcbmxvb3AuZG93bi5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxuXG4jIyMjIEltcG9ydGluZyBsb29wcyBvZiB0YXJnZXRcbnRlbXAxIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxBVEFDX2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDIgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXENUQ0ZcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcRVNSUkJfZHNnXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDQgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEVTUlJCX05DQlxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxFU1JSQl9wZmFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcSDNLMjdhY19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxLTEY0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDggPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE5BTk9HX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA5IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxOQU5PR19wZmFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTAgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE9DVDRfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE9DVDRfZHNnXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDEyIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X3BmYVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcU01DMVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcU09YMl9lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxNSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcU09YMl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFNPWDJfcGZhXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDE3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxUQlBcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG5cblxuXG5cbmRhdGEgPC0gYmluZF9yb3dzKHRlbXAxLCB0ZW1wMiwgdGVtcDMsIHRlbXA0LCB0ZW1wNSxcbiAgICAgICAgIHRlbXA2LCB0ZW1wNywgdGVtcDgsIHRlbXA5LCB0ZW1wMTAsXG4gICAgICAgICB0ZW1wMTEsIHRlbXAxMiwgdGVtcDEzLCB0ZW1wMTQsIHRlbXAxNSwgdGVtcDE2ICx0ZW1wMTcpXG5cbiMgVmlzdWFsaXphdGlvblxubGlicmFyeShjaXJjbGl6ZSlcblxuaGVhdG1hcF9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgb2Rkc1JhdGlvKSAlPiVcbnBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBpbnRlcmVzdCwgdmFsdWVzX2Zyb20gPSBvZGRzUmF0aW8pICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFx0YXJnZXRcXClcblxucHZhbHVlX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGludGVyZXN0LCBwdmFsdWUpICU+JVxuICBwaXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gcHZhbHVlKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEsIDUpLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFxcYmx1ZVxcLCBcXHdoaXRlXFwsIFxccmVkXFwpKVxuXG5IZWF0bWFwKGFzLm1hdHJpeChoZWF0bWFwX2RhdGEpLFxuICAgICAgICBuYW1lID0gXFxPZGRzIFJhdGlvXFwsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4sXG4gICAgICAgICMgQWRkIGFubm90YXRpb24gZm9yIHAtdmFsdWVzXG4gICAgICAgIGNlbGxfZnVuID0gZnVuY3Rpb24oaiwgaSwgeCwgeSwgd2lkdGgsIGhlaWdodCwgZmlsbCkge1xuICAgICAgICAgIHB2YWwgPC0gcHZhbHVlX2RhdGFbaSwgal1cbiAgICAgICAgICBsYWJlbCA8LSBpZmVsc2UocHZhbCA+IDAuMDUsIFxcbi5zLlxcLCBzcHJpbnRmKFxcJS4yZVxcLCBwdmFsKSlcbiAgICAgICAgICBncmlkLnRleHQobGFiZWwsIHgsIHksIGdwID0gZ3Bhcihmb250c2l6ZSA9IDEwKSlcbiAgICAgICAgfSxcbiAgICAgICAgIyBDdXN0b21pemUgdGhlIGhlYXRtYXAgbGF5b3V0XG4gICAgICAgIGNsdXN0ZXJfcm93cyA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY29sdW1uX3RpdGxlID0gXFxJbnRlcmVzdFxcLFxuICAgICAgICByb3dfdGl0bGUgPSBcXFRhcmdldFxcLFxuICAgICAgICBoZWF0bWFwX2xlZ2VuZF9wYXJhbSA9IGxpc3QoYXQgPSBjKDAsIDEsIDIsIDMsIDQsIDUpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxhYmVscyA9IGMoXFwwXFwsIFxcMVxcLCBcXDJcXCwgXFwzXFwsIFxcNFxcLCBcXDVcXCkpKVxuYGBgXG5gYGAifQ== -->

```r
```r
#### Importing loops of interest
interestName <- \allLoop\
# BACKGROUND loop
background <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all.bedpe\))
background.gr <- (extractAnchor(background))
# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.up.gr <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\))
loop.no.gr <- (extractAnchor(loop.no))
# DOWN loop
loopNum <- nrow(loop.no)
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\))
loop.down <- loop.all %>% dplyr::filter(diff_dTAG_DMSO < -0.2) %>% dplyr::arrange(diff_dTAG_DMSO) %>% slice_head(n = loopNum)
loop.down.gr <- (extractAnchor(loop.down))

#### Importing loops of target
temp1 <- runFisherExactCombinationTarget(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget(\ESRRB_NCB\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget(\ESRRB_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget(\NANOG_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget(\OCT4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp11 <- runFisherExactCombinationTarget(\OCT4_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp12 <- runFisherExactCombinationTarget(\OCT4_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp13 <- runFisherExactCombinationTarget(\SMC1\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp14 <- runFisherExactCombinationTarget(\SOX2_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp15 <- runFisherExactCombinationTarget(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp16 <- runFisherExactCombinationTarget(\SOX2_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp17 <- runFisherExactCombinationTarget(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10,
         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 5), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), 
                                    labels = c(\0\, \1\, \2\, \3\, \4\, \5\)))
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


## [2.24] Checking bookmarking
(1) Checking whether subset of regulatory loop have bookmarking
(2) Checking whether loops related to genes have bookmarking
H3K27ac_effie
ATAC_effie
TBP
Oct4_effie, Oct4_dsg
Sox2_effie, Sox2_dsg
Esrrb_dsg
Klf4_effie
CTCF
##### Functions

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIkFUQUNfZWZmaWVcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiQ1RDRlwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAzIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJFU1JSQl9kc2dcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiSDNLMjdhY19lZmZpZVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJLTEY0X2VmZmllXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIk5BTk9HX2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJPQ1Q0X2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA4IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJTTUMxXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiU09YMl9kc2dcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTAgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIlRCUFwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcblxuXG5cblxuZGF0YSA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyLCB0ZW1wMywgdGVtcDQsIHRlbXA1LFxuICAgICAgICAgdGVtcDYsIHRlbXA3LCB0ZW1wOCwgdGVtcDksIHRlbXAxMClcblxuIyBWaXN1YWxpemF0aW9uXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5oZWF0bWFwX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGludGVyZXN0LCBvZGRzUmF0aW8pICU+JVxucGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IG9kZHNSYXRpbykgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcInRhcmdldFwiKVxuXG5wdmFsdWVfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIHB2YWx1ZSkgJT4lXG4gIHBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBpbnRlcmVzdCwgdmFsdWVzX2Zyb20gPSBwdmFsdWUpICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXCJ0YXJnZXRcIilcblxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoMCwgMSwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgIGMoXCJibHVlXCIsIFwid2hpdGVcIiwgXCJyZWRcIikpXG5cbkhlYXRtYXAoYXMubWF0cml4KGhlYXRtYXBfZGF0YSksXG4gICAgICAgIG5hbWUgPSBcIk9kZHMgUmF0aW9cIixcbiAgICAgICAgY29sID0gY29sX2Z1bixcbiAgICAgICAgIyBBZGQgYW5ub3RhdGlvbiBmb3IgcC12YWx1ZXNcbiAgICAgICAgY2VsbF9mdW4gPSBmdW5jdGlvbihqLCBpLCB4LCB5LCB3aWR0aCwgaGVpZ2h0LCBmaWxsKSB7XG4gICAgICAgICAgcHZhbCA8LSBwdmFsdWVfZGF0YVtpLCBqXVxuICAgICAgICAgIGxhYmVsIDwtIGlmZWxzZShwdmFsID4gMC4wNSwgXCJuLnMuXCIsIHNwcmludGYoXCIlLjJlXCIsIHB2YWwpKVxuICAgICAgICAgIGdyaWQudGV4dChsYWJlbCwgeCwgeSwgZ3AgPSBncGFyKGZvbnRzaXplID0gMTApKVxuICAgICAgICB9LFxuICAgICAgICAjIEN1c3RvbWl6ZSB0aGUgaGVhdG1hcCBsYXlvdXRcbiAgICAgICAgY2x1c3Rlcl9yb3dzID0gVFJVRSxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY29sdW1uX3RpdGxlID0gXCJJbnRlcmVzdFwiLFxuICAgICAgICByb3dfdGl0bGUgPSBcIlRhcmdldFwiLFxuICAgICAgICBoZWF0bWFwX2xlZ2VuZF9wYXJhbSA9IGxpc3QoYXQgPSBjKDAsIDEsIDIsIDMpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxhYmVscyA9IGMoXCIwXCIsIFwiMVwiLCBcIjJcIiwgXCIzXCIpKSlcblxuYGBgIn0= -->\n\n```r\n\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTarget(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTarget(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTarget(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTarget(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTarget(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTarget(\\OCT4_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTarget(\\SMC1\\, interestName,\n                                     loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTarget(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTarget(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 3), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\)))\n\n```\n\n<!-- rnb-source-end -->\n"} -->


#### Importing loops of target
temp1 <- runFisherExactCombinationTarget(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget(\OCT4_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget(\SMC1\, interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 3), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c(\0\, \1\, \2\, \3\)))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEFUQUNfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcQ1RDRlxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAzIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxFU1JSQl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcSDNLMjdhY19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxLTEY0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE5BTk9HX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA4IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxTTUMxXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcU09YMl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTAgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFRCUFxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcblxuXG5cblxuZGF0YSA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyLCB0ZW1wMywgdGVtcDQsIHRlbXA1LFxuICAgICAgICAgdGVtcDYsIHRlbXA3LCB0ZW1wOCwgdGVtcDksIHRlbXAxMClcblxuIyBWaXN1YWxpemF0aW9uXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5oZWF0bWFwX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGludGVyZXN0LCBvZGRzUmF0aW8pICU+JVxucGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IG9kZHNSYXRpbykgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5wdmFsdWVfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIHB2YWx1ZSkgJT4lXG4gIHBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBpbnRlcmVzdCwgdmFsdWVzX2Zyb20gPSBwdmFsdWUpICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFx0YXJnZXRcXClcblxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoMCwgMSwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgIGMoXFxibHVlXFwsIFxcd2hpdGVcXCwgXFxyZWRcXCkpXG5cbkhlYXRtYXAoYXMubWF0cml4KGhlYXRtYXBfZGF0YSksXG4gICAgICAgIG5hbWUgPSBcXE9kZHMgUmF0aW9cXCxcbiAgICAgICAgY29sID0gY29sX2Z1bixcbiAgICAgICAgIyBBZGQgYW5ub3RhdGlvbiBmb3IgcC12YWx1ZXNcbiAgICAgICAgY2VsbF9mdW4gPSBmdW5jdGlvbihqLCBpLCB4LCB5LCB3aWR0aCwgaGVpZ2h0LCBmaWxsKSB7XG4gICAgICAgICAgcHZhbCA8LSBwdmFsdWVfZGF0YVtpLCBqXVxuICAgICAgICAgIGxhYmVsIDwtIGlmZWxzZShwdmFsID4gMC4wNSwgXFxuLnMuXFwsIHNwcmludGYoXFwlLjJlXFwsIHB2YWwpKVxuICAgICAgICAgIGdyaWQudGV4dChsYWJlbCwgeCwgeSwgZ3AgPSBncGFyKGZvbnRzaXplID0gMTApKVxuICAgICAgICB9LFxuICAgICAgICAjIEN1c3RvbWl6ZSB0aGUgaGVhdG1hcCBsYXlvdXRcbiAgICAgICAgY2x1c3Rlcl9yb3dzID0gVFJVRSxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY29sdW1uX3RpdGxlID0gXFxJbnRlcmVzdFxcLFxuICAgICAgICByb3dfdGl0bGUgPSBcXFRhcmdldFxcLFxuICAgICAgICBoZWF0bWFwX2xlZ2VuZF9wYXJhbSA9IGxpc3QoYXQgPSBjKDAsIDEsIDIsIDMpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxhYmVscyA9IGMoXFwwXFwsIFxcMVxcLCBcXDJcXCwgXFwzXFwpKSlcblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTarget(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTarget(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTarget(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTarget(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTarget(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTarget(\\OCT4_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTarget(\\SMC1\\, interestName,\n                                     loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTarget(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTarget(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 3), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\)))\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEFUQUNfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcQ1RDRlxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAzIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxFU1JSQl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcSDNLMjdhY19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxLTEY0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE5BTk9HX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA4IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxTTUMxXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcU09YMl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTAgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFRCUFxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcblxuXG5cblxuZGF0YSA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyLCB0ZW1wMywgdGVtcDQsIHRlbXA1LFxuICAgICAgICAgdGVtcDYsIHRlbXA3LCB0ZW1wOCwgdGVtcDksIHRlbXAxMClcblxuIyBWaXN1YWxpemF0aW9uXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5oZWF0bWFwX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGludGVyZXN0LCBvZGRzUmF0aW8pICU+JVxucGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IG9kZHNSYXRpbykgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5wdmFsdWVfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIHB2YWx1ZSkgJT4lXG4gIHBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBpbnRlcmVzdCwgdmFsdWVzX2Zyb20gPSBwdmFsdWUpICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFx0YXJnZXRcXClcblxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoMCwgMSwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgIGMoXFxibHVlXFwsIFxcd2hpdGVcXCwgXFxyZWRcXCkpXG5cbkhlYXRtYXAoYXMubWF0cml4KGhlYXRtYXBfZGF0YSksXG4gICAgICAgIG5hbWUgPSBcXE9kZHMgUmF0aW9cXCxcbiAgICAgICAgY29sID0gY29sX2Z1bixcbiAgICAgICAgIyBBZGQgYW5ub3RhdGlvbiBmb3IgcC12YWx1ZXNcbiAgICAgICAgY2VsbF9mdW4gPSBmdW5jdGlvbihqLCBpLCB4LCB5LCB3aWR0aCwgaGVpZ2h0LCBmaWxsKSB7XG4gICAgICAgICAgcHZhbCA8LSBwdmFsdWVfZGF0YVtpLCBqXVxuICAgICAgICAgIGxhYmVsIDwtIGlmZWxzZShwdmFsID4gMC4wNSwgXFxuLnMuXFwsIHNwcmludGYoXFwlLjJlXFwsIHB2YWwpKVxuICAgICAgICAgIGdyaWQudGV4dChsYWJlbCwgeCwgeSwgZ3AgPSBncGFyKGZvbnRzaXplID0gMTApKVxuICAgICAgICB9LFxuICAgICAgICAjIEN1c3RvbWl6ZSB0aGUgaGVhdG1hcCBsYXlvdXRcbiAgICAgICAgY2x1c3Rlcl9yb3dzID0gVFJVRSxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY29sdW1uX3RpdGxlID0gXFxJbnRlcmVzdFxcLFxuICAgICAgICByb3dfdGl0bGUgPSBcXFRhcmdldFxcLFxuICAgICAgICBoZWF0bWFwX2xlZ2VuZF9wYXJhbSA9IGxpc3QoYXQgPSBjKDAsIDEsIDIsIDMpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxhYmVscyA9IGMoXFwwXFwsIFxcMVxcLCBcXDJcXCwgXFwzXFwpKSlcblxuYGBgXG5gYGAifQ== -->

```r
```r


#### Importing loops of target
temp1 <- runFisherExactCombinationTarget(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget(\OCT4_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget(\SMC1\, interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 3), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c(\0\, \1\, \2\, \3\)))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### All loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlCSmJYQnZjblJwYm1jZ2JHOXZjSE1nYjJZZ2FXNTBaWEpsYzNSY2JtbHVkR1Z5WlhOMFRtRnRaU0E4TFNCY0luSmxaMHh2YjNCY0lseHVJeUJDUVVOTFIxSlBWVTVFSUd4dmIzQmNibUpoWTJ0bmNtOTFibVFnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5d1pTMXdaUzVpWldSd1pWd2lLU2xjYm1KaFkydG5jbTkxYm1RdVozSWdQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9ZbUZqYTJkeWIzVnVaQ2twWEc0aklGVlFJR3h2YjNCY2JteHZiM0F1ZFhBZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGd2lZMmh5YjIxdlgyTnZibk5mWVc1dWIwaHBaWEpoY21Ob2VWOXdaUzF3WlY5a1ZFRkhkbk5FVFZOUFgxVlFYMlJwWm1Zd0xqSXVZbVZrY0dWY0lpa3BYRzVzYjI5d0xuVndMbWR5SUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0d4dmIzQXVkWEFwS1Z4dUl5Qk9UeUJzYjI5d1hHNXNiMjl3TG01dklEd3RJR1p5WldGa0tHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQmNJbU5vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGZjR1V0Y0dWZlpGUkJSM1p6UkUxVFQxOU9UMTlrYVdabU1DNHlMbUpsWkhCbFhDSXBLVnh1Ykc5dmNDNXVieTVuY2lBOExTQW9aWGgwY21GamRFRnVZMmh2Y2loc2IyOXdMbTV2S1NsY2JpTWdWVkJPVHlCc2IyOXdYRzVzYjI5d0xuVndibThnUEMwZ1ltbHVaRjl5YjNkektHeHZiM0F1ZFhBc0lHeHZiM0F1Ym04cFhHNXNiMjl3TG5Wd2JtOHVaM0lnUEMwZ1pYaDBjbUZqZEVGdVkyaHZjaWhzYjI5d0xuVndibThwWEc0aklFUlBWMDRnYkc5dmNGeHViRzl2Y0M1a2IzZHVJRHd0SUdaeVpXRmtLR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0JjSW1Ob2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxmY0dVdGNHVmZaRlJCUjNaelJFMVRUMTlFVDFkT1gyUnBabVl3TGpJdVltVmtjR1ZjSWlrcFhHNXNiMjl3TG1SdmQyNHVaM0lnUEMwZ0tHVjRkSEpoWTNSQmJtTm9iM0lvYkc5dmNDNWtiM2R1S1NsY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG4jIyMjIEltcG9ydGluZyBsb29wcyBvZiBpbnRlcmVzdFxuaW50ZXJlc3ROYW1lIDwtIFxccmVnTG9vcFxcXG4jIEJBQ0tHUk9VTkQgbG9vcFxuYmFja2dyb3VuZCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlLmJlZHBlXFwpKVxuYmFja2dyb3VuZC5nciA8LSAoZXh0cmFjdEFuY2hvcihiYWNrZ3JvdW5kKSlcbiMgVVAgbG9vcFxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX2RUQUd2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSlcbmxvb3AudXAuZ3IgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG4jIE5PIGxvb3Bcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLm5vLmdyIDwtIChleHRyYWN0QW5jaG9yKGxvb3Aubm8pKVxuIyBVUE5PIGxvb3Bcbmxvb3AudXBubyA8LSBiaW5kX3Jvd3MobG9vcC51cCwgbG9vcC5ubylcbmxvb3AudXBuby5nciA8LSBleHRyYWN0QW5jaG9yKGxvb3AudXBubylcbiMgRE9XTiBsb29wXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVxcKSlcbmxvb3AuZG93bi5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
#### Importing loops of interest
interestName <- \regLoop\
# BACKGROUND loop
background <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\))
background.gr <- (extractAnchor(background))
# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.up.gr <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
loop.no.gr <- (extractAnchor(loop.no))
# UPNO loop
loop.upno <- bind_rows(loop.up, loop.no)
loop.upno.gr <- extractAnchor(loop.upno)
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
loop.down.gr <- (extractAnchor(loop.down))



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeUJKYlhCdmNuUnBibWNnYkc5dmNITWdiMllnYVc1MFpYSmxjM1JjYm1sdWRHVnlaWE4wVG1GdFpTQThMU0JjWEhKbFoweHZiM0JjWEZ4dUl5QkNRVU5MUjFKUFZVNUVJR3h2YjNCY2JtSmhZMnRuY205MWJtUWdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lVjl3WlMxd1pTNWlaV1J3WlZ4Y0tTbGNibUpoWTJ0bmNtOTFibVF1WjNJZ1BDMGdLR1Y0ZEhKaFkzUkJibU5vYjNJb1ltRmphMmR5YjNWdVpDa3BYRzRqSUZWUUlHeHZiM0JjYm14dmIzQXVkWEFnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ4Y1kyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5d1pTMXdaVjlrVkVGSGRuTkVUVk5QWDFWUVgyUnBabVl3TGpJdVltVmtjR1ZjWENrcFhHNXNiMjl3TG5Wd0xtZHlJRHd0SUNobGVIUnlZV04wUVc1amFHOXlLR3h2YjNBdWRYQXBLVnh1SXlCT1R5QnNiMjl3WEc1c2IyOXdMbTV2SUR3dElHWnlaV0ZrS0dobGNtVW9ZMjl1YzJWdWMzVnpSR2x5TENCY1hHTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsZmNHVXRjR1ZmWkZSQlIzWnpSRTFUVDE5T1QxOWthV1ptTUM0eUxtSmxaSEJsWEZ3cEtWeHViRzl2Y0M1dWJ5NW5jaUE4TFNBb1pYaDBjbUZqZEVGdVkyaHZjaWhzYjI5d0xtNXZLU2xjYmlNZ1ZWQk9UeUJzYjI5d1hHNXNiMjl3TG5Wd2JtOGdQQzBnWW1sdVpGOXliM2R6S0d4dmIzQXVkWEFzSUd4dmIzQXVibThwWEc1c2IyOXdMblZ3Ym04dVozSWdQQzBnWlhoMGNtRmpkRUZ1WTJodmNpaHNiMjl3TG5Wd2JtOHBYRzRqSUVSUFYwNGdiRzl2Y0Z4dWJHOXZjQzVrYjNkdUlEd3RJR1p5WldGa0tHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQmNYR05vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGZjR1V0Y0dWZlpGUkJSM1p6UkUxVFQxOUVUMWRPWDJScFptWXdMakl1WW1Wa2NHVmNYQ2twWEc1c2IyOXdMbVJ2ZDI0dVozSWdQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1a2IzZHVLU2xjYm1CZ1lGeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgaW50ZXJlc3RcbmludGVyZXN0TmFtZSA8LSBcXHJlZ0xvb3BcXFxuIyBCQUNLR1JPVU5EIGxvb3BcbmJhY2tncm91bmQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZS5iZWRwZVxcKSlcbmJhY2tncm91bmQuZ3IgPC0gKGV4dHJhY3RBbmNob3IoYmFja2dyb3VuZCkpXG4jIFVQIGxvb3Bcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLnVwLmdyIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXApKVxuIyBOTyBsb29wXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5uby5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbiMgVVBOTyBsb29wXG5sb29wLnVwbm8gPC0gYmluZF9yb3dzKGxvb3AudXAsIGxvb3Aubm8pXG5sb29wLnVwbm8uZ3IgPC0gZXh0cmFjdEFuY2hvcihsb29wLnVwbm8pXG4jIERPV04gbG9vcFxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLmRvd24uZ3IgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5kb3duKSlcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgaW50ZXJlc3RcbmludGVyZXN0TmFtZSA8LSBcXHJlZ0xvb3BcXFxuIyBCQUNLR1JPVU5EIGxvb3BcbmJhY2tncm91bmQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZS5iZWRwZVxcKSlcbmJhY2tncm91bmQuZ3IgPC0gKGV4dHJhY3RBbmNob3IoYmFja2dyb3VuZCkpXG4jIFVQIGxvb3Bcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLnVwLmdyIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXApKVxuIyBOTyBsb29wXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5uby5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbiMgVVBOTyBsb29wXG5sb29wLnVwbm8gPC0gYmluZF9yb3dzKGxvb3AudXAsIGxvb3Aubm8pXG5sb29wLnVwbm8uZ3IgPC0gZXh0cmFjdEFuY2hvcihsb29wLnVwbm8pXG4jIERPV04gbG9vcFxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLmRvd24uZ3IgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5kb3duKSlcbmBgYFxuYGBgIn0= -->

```r
```r
#### Importing loops of interest
interestName <- \regLoop\
# BACKGROUND loop
background <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\))
background.gr <- (extractAnchor(background))
# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.up.gr <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
loop.no.gr <- (extractAnchor(loop.no))
# UPNO loop
loop.upno <- bind_rows(loop.up, loop.no)
loop.upno.gr <- extractAnchor(loop.upno)
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
loop.down.gr <- (extractAnchor(loop.down))
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### All loops refined

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxudGFyZ2V0TmFtZSA8LSBcIkgzSzI3YWNfZWZmaWVcIlxuIyBSRVRBSU5FRCBsb29wXG5yZXRhaW5lZCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJURl9ib29rbWFya2luZ1wiLCB0YXJnZXROYW1lLCBcImFtX2EuYmVkXCIpKSAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuY29sbmFtZXMocmV0YWluZWQpIDwtIGMoXCJjaHJcIiwgXCJzdGFydFwiLCBcImVuZFwiKVxucmV0YWluZWQuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHJldGFpbmVkKVxuIyBMT1NUIGxvb3Bcbmxvc3QgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiVEZfYm9va21hcmtpbmdcIiwgdGFyZ2V0TmFtZSwgXCJvYS5iZWRcIikpICU+JSBkcGx5cjo6c2VsZWN0KGMoMSwgMiwgMykpXG5jb2xuYW1lcyhsb3N0KSA8LSBjKFwiY2hyXCIsIFwic3RhcnRcIiwgXCJlbmRcIilcbmxvc3QuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGxvc3QpXG5cblxuIyBTRUVESU5HXG50ZW1wIDwtIHJ1bkZpc2hlckV4YWN0KGxvb3AudXBuby5nciwgYmFja2dyb3VuZC5nciwgcmV0YWluZWQuZ3IpXG5yZXN1bHQudGIgPC0gdGliYmxlKGludGVyZXN0ID0gcGFzdGUwKGludGVyZXN0TmFtZSwgXCJfVVAvTk9cIiksXG4gICAgICAgICAgICAgICAgICAgIHRhcmdldCA9IHBhc3RlMCh0YXJnZXROYW1lLCBcIl9yZXRhaW5lZFwiKSxcbiAgICAgICAgICAgICAgICAgICAgcHZhbHVlID0gdGVtcCRwLnZhbHVlLFxuICAgICAgICAgICAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuXG4jIEFERElORyBST1dTXG50ZW1wIDwtIHJ1bkZpc2hlckV4YWN0KGxvb3AuZG93bi5nciwgYmFja2dyb3VuZC5nciwgcmV0YWluZWQuZ3IpXG5yZXN1bHQudGIgPC0gcmVzdWx0LnRiICU+JSBcbiAgYWRkX3JvdyhpbnRlcmVzdCA9IHBhc3RlMChpbnRlcmVzdE5hbWUsIFwiX0RPV05cIiksXG4gICAgICAgICAgdGFyZ2V0ID0gcGFzdGUwKHRhcmdldE5hbWUsIFwiX3JldGFpbmVkXCIpLFxuICAgICAgICAgIHB2YWx1ZSA9IHRlbXAkcC52YWx1ZSxcbiAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuXG4jIEFERElORyBST1dTXG50ZW1wIDwtIHJ1bkZpc2hlckV4YWN0KGxvb3AudXBuby5nciwgYmFja2dyb3VuZC5nciwgbG9zdC5ncilcbnJlc3VsdC50YiA8LSByZXN1bHQudGIgJT4lIFxuICBhZGRfcm93KGludGVyZXN0ID0gcGFzdGUwKGludGVyZXN0TmFtZSwgXCJfVVAvTk9cIiksXG4gICAgICAgICAgdGFyZ2V0ID0gcGFzdGUwKHRhcmdldE5hbWUsIFwiX2xvc3RcIiksXG4gICAgICAgICAgcHZhbHVlID0gdGVtcCRwLnZhbHVlLFxuICAgICAgICAgIG9kZHNSYXRpbyA9IHRlbXAkZXN0aW1hdGUpXG5cbiMgQURESU5HIFJPV1NcbnRlbXAgPC0gcnVuRmlzaGVyRXhhY3QobG9vcC5kb3duLmdyLCBiYWNrZ3JvdW5kLmdyLCBsb3N0LmdyKVxucmVzdWx0LnRiIDwtIHJlc3VsdC50YiAlPiUgXG4gIGFkZF9yb3coaW50ZXJlc3QgPSBwYXN0ZTAoaW50ZXJlc3ROYW1lLCBcIl9ET1dOXCIpLFxuICAgICAgICAgIHRhcmdldCA9IHBhc3RlMCh0YXJnZXROYW1lLCBcIl9sb3N0XCIpLFxuICAgICAgICAgIHB2YWx1ZSA9IHRlbXAkcC52YWx1ZSxcbiAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuXG5cbnJlc3VsdC50YiA8LSByZXN1bHQudGIgJT4lXG4gIG11dGF0ZShpbnRlcmVzdCA9IHJlY29kZShpbnRlcmVzdCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICBcInJlZ0xvb3BfVVAvTk9cIiA9IFwiVVAvTk9cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicmVnTG9vcF9ET1dOXCIgPSBcIkRPV05cIiksXG4gICAgICAgICB0YXJnZXQgPSByZWNvZGUodGFyZ2V0LFxuICAgICAgICAgICAgICAgICAgICAgICAgIFwiSDNLMjdhY19lZmZpZV9yZXRhaW5lZFwiID0gXCJSZXRhaW5lZFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgIFwiSDNLMjdhY19lZmZpZV9sb3N0XCIgPSBcIkxvc3RcIikpXG5cbnJlc3VsdC50YiRpbnRlcmVzdCA8LSBmYWN0b3IocmVzdWx0LnRiJGludGVyZXN0LCBsZXZlbHMgPSBjKFwiVVAvTk9cIiwgXCJET1dOXCIpKVxuXG5wIDwtIGdncGxvdChyZXN1bHQudGIsIGFlcyh4ID0gaW50ZXJlc3QsIHkgPSB0YXJnZXQsIHNpemUgPSAtbG9nMTAocHZhbHVlKSwgZmlsbCA9IG9kZHNSYXRpbykpICtcbiAgZ2VvbV9wb2ludChzaGFwZSA9IDIxLCAgICAgICAgIyBFbnN1cmVzIGEgcG9pbnQgd2l0aCBhbiBvdXRsaW5lXG4gICAgICAgICAgICAgc3Ryb2tlID0gMC41KnB0VG9NTSAgICAgICMgTGluZSB3aWR0aCBmb3IgdGhlIGJvcmRlclxuICApICsgdGhlbWVfYncoKSArIFxuICBzY2FsZV9zaXplX2NvbnRpbnVvdXMocmFuZ2UgPSBjKDEsIDMpKSArICAjIFNldCBtaW4gYW5kIG1heCBwb2ludCBzaXplcyBoZXJlXG4gIHNjYWxlX2ZpbGxfZ3JhZGllbnRuKGNvbG9ycyA9IGMoXCIjNDg1MkEwXCIsIFwid2hpdGVcIiwgXCIjQ0IzMzNBXCIpLCAgIyBEZWZpbmUgZ3JhZGllbnQgY29sb3JzXG4gICAgICAgICAgICAgICAgICAgICAgdmFsdWVzID0gc2NhbGVzOjpyZXNjYWxlKGMoMC41LCAxLCAxLjUpKSwgbGltaXRzID0gYygwLjUsIDEuNSksIFxuICAgICAgICAgICAgICAgICAgICAgICNsb3cgPSBcIndoaXRlXCIsIGhpZ2ggPSBcIiNDQjMzM0FcIixcbiAgICAgICAgICAgICAgICAgICAgICAjICAgICAgICAgICAgICAgICAgbGltaXRzID0gYygxLCAzKSxcbiAgICAgICAgICAgICAgICAgICAgICBvb2IgPSBzY2FsZXM6OnNxdWlzaCwgIyBEZWZpbmUgZ3JhZGllbnQgY29sb3JzXG4gICAgICAgICAgICAgICAgICAgICAgZ3VpZGUgPSBndWlkZV9jb2xvcmJhcihcbiAgICAgICAgICAgICAgICAgICAgICAgIGJhcndpZHRoID0gMS41LzUuMDgsICAjIEFkanVzdCB3aWR0aCBvZiB0aGUgY29sb3IgYmFyXG4gICAgICAgICAgICAgICAgICAgICAgICBiYXJoZWlnaHQgPSAxNS81LjA4ICAgIyBBZGp1c3QgaGVpZ2h0IG9mIHRoZSBjb2xvciBiYXJcbiAgICAgICAgICAgICAgICAgICAgICApXG4gICkgK1xuICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgYW5nbGUgPSA0NSwgICAgICAjIFJvdGF0ZSB4LWF4aXMgbGFiZWxzIDQ1IGRlZ3JlZXNcbiAgICAgIGhqdXN0ID0gMSwgICAgICAgIyBBZGp1c3QgaG9yaXpvbnRhbCBqdXN0aWZpY2F0aW9uXG4gICAgICB2anVzdCA9IDEgICAgICAgICMgQWRqdXN0IHZlcnRpY2FsIGp1c3RpZmljYXRpb25cbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCIsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcInNxdWFyZVwiXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFwidHJhbnNwYXJlbnRcIiksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKVxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgXCJoZWF0bWFwX0gzSzI3YWNfYm9va21hcmtpbmdfcmVnX2RvdHBsb3RcIilcbndpZHRoIDwtIHBhbmVsU2l6ZSgxLjcpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuMSkqbW1Ub0luY2hcbiMgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuIyBwcmludChwKVxuIyBkZXYub2ZmKClcbnN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIiksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5cbiAgXG5gYGAifQ== -->\n\n```r\ntargetName <- \\H3K27ac_effie\\\n# RETAINED loop\nretained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\ncolnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\nretained.gr <- makeGRangesFromDataFrame(retained)\n# LOST loop\nlost <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\oa.bed\\)) %>% dplyr::select(c(1, 2, 3))\ncolnames(lost) <- c(\\chr\\, \\start\\, \\end\\)\nlost.gr <- makeGRangesFromDataFrame(lost)\n\n\n# SEEDING\ntemp <- runFisherExact(loop.upno.gr, background.gr, retained.gr)\nresult.tb <- tibble(interest = paste0(interestName, \\_UP/NO\\),\n                    target = paste0(targetName, \\_retained\\),\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\n\n# ADDING ROWS\ntemp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\nresult.tb <- result.tb %>% \n  add_row(interest = paste0(interestName, \\_DOWN\\),\n          target = paste0(targetName, \\_retained\\),\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n# ADDING ROWS\ntemp <- runFisherExact(loop.upno.gr, background.gr, lost.gr)\nresult.tb <- result.tb %>% \n  add_row(interest = paste0(interestName, \\_UP/NO\\),\n          target = paste0(targetName, \\_lost\\),\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n# ADDING ROWS\ntemp <- runFisherExact(loop.down.gr, background.gr, lost.gr)\nresult.tb <- result.tb %>% \n  add_row(interest = paste0(interestName, \\_DOWN\\),\n          target = paste0(targetName, \\_lost\\),\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\nresult.tb <- result.tb %>%\n  mutate(interest = recode(interest, \n                           \\regLoop_UP/NO\\ = \\UP/NO\\,\n                           \\regLoop_DOWN\\ = \\DOWN\\),\n         target = recode(target,\n                         \\H3K27ac_effie_retained\\ = \\Retained\\,\n                         \\H3K27ac_effie_lost\\ = \\Lost\\))\n\nresult.tb$interest <- factor(result.tb$interest, levels = c(\\UP/NO\\, \\DOWN\\))\n\np <- ggplot(result.tb, aes(x = interest, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 0.5*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\\#4852A0\\, \\white\\, \\#CB333A\\),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \\white\\, high = \\#CB333A\\,\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) +\n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\heatmap_H3K27ac_bookmarking_reg_dotplot\\)\nwidth <- panelSize(1.7)*mmToInch\nheight <- panelSize(1.1)*mmToInch\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\nsvglite(paste0(fileName, \\.svg\\),  height = height, width = width)\nprint(p)\ndev.off()\n\n  \n```\n\n<!-- rnb-source-end -->\n"} -->
targetName <- \H3K27ac_effie\
# RETAINED loop
retained <- fread(here(refDir, \TF_bookmarking\, targetName, \am_a.bed\)) %>% dplyr::select(c(1, 2, 3))
colnames(retained) <- c(\chr\, \start\, \end\)
retained.gr <- makeGRangesFromDataFrame(retained)
# LOST loop
lost <- fread(here(refDir, \TF_bookmarking\, targetName, \oa.bed\)) %>% dplyr::select(c(1, 2, 3))
colnames(lost) <- c(\chr\, \start\, \end\)
lost.gr <- makeGRangesFromDataFrame(lost)


# SEEDING
temp <- runFisherExact(loop.upno.gr, background.gr, retained.gr)
result.tb <- tibble(interest = paste0(interestName, \_UP/NO\),
                    target = paste0(targetName, \_retained\),
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)

# ADDING ROWS
temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)
result.tb <- result.tb %>% 
  add_row(interest = paste0(interestName, \_DOWN\),
          target = paste0(targetName, \_retained\),
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

# ADDING ROWS
temp <- runFisherExact(loop.upno.gr, background.gr, lost.gr)
result.tb <- result.tb %>% 
  add_row(interest = paste0(interestName, \_UP/NO\),
          target = paste0(targetName, \_lost\),
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

# ADDING ROWS
temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)
result.tb <- result.tb %>% 
  add_row(interest = paste0(interestName, \_DOWN\),
          target = paste0(targetName, \_lost\),
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)


result.tb <- result.tb %>%
  mutate(interest = recode(interest, 
                           \regLoop_UP/NO\ = \UP/NO\,
                           \regLoop_DOWN\ = \DOWN\),
         target = recode(target,
                         \H3K27ac_effie_retained\ = \Retained\,
                         \H3K27ac_effie_lost\ = \Lost\))

result.tb$interest <- factor(result.tb$interest, levels = c(\UP/NO\, \DOWN\))

p <- ggplot(result.tb, aes(x = interest, y = target, size = -log10(pvalue), fill = oddsRatio)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 0.5*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
  scale_fill_gradientn(colors = c(\#4852A0\, \white\, \#CB333A\),  # Define gradient colors
                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), 
                      #low = \white\, high = \#CB333A\,
                      #                  limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) +
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, \heatmap_H3K27ac_bookmarking_reg_dotplot\)
width <- panelSize(1.7)*mmToInch
height <- panelSize(1.1)*mmToInch
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
svglite(paste0(fileName, \.svg\),  height = height, width = width)
print(p)
dev.off()

  



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudGFyZ2V0TmFtZSA8LSBcXEgzSzI3YWNfZWZmaWVcXFxuIyBSRVRBSU5FRCBsb29wXG5yZXRhaW5lZCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxURl9ib29rbWFya2luZ1xcLCB0YXJnZXROYW1lLCBcXGFtX2EuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuY29sbmFtZXMocmV0YWluZWQpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxucmV0YWluZWQuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHJldGFpbmVkKVxuIyBMT1NUIGxvb3Bcbmxvc3QgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcVEZfYm9va21hcmtpbmdcXCwgdGFyZ2V0TmFtZSwgXFxvYS5iZWRcXCkpICU+JSBkcGx5cjo6c2VsZWN0KGMoMSwgMiwgMykpXG5jb2xuYW1lcyhsb3N0KSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbmxvc3QuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGxvc3QpXG5cblxuIyBTRUVESU5HXG50ZW1wIDwtIHJ1bkZpc2hlckV4YWN0KGxvb3AudXBuby5nciwgYmFja2dyb3VuZC5nciwgcmV0YWluZWQuZ3IpXG5yZXN1bHQudGIgPC0gdGliYmxlKGludGVyZXN0ID0gcGFzdGUwKGludGVyZXN0TmFtZSwgXFxfVVAvTk9cXCksXG4gICAgICAgICAgICAgICAgICAgIHRhcmdldCA9IHBhc3RlMCh0YXJnZXROYW1lLCBcXF9yZXRhaW5lZFxcKSxcbiAgICAgICAgICAgICAgICAgICAgcHZhbHVlID0gdGVtcCRwLnZhbHVlLFxuICAgICAgICAgICAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuXG4jIEFERElORyBST1dTXG50ZW1wIDwtIHJ1bkZpc2hlckV4YWN0KGxvb3AuZG93bi5nciwgYmFja2dyb3VuZC5nciwgcmV0YWluZWQuZ3IpXG5yZXN1bHQudGIgPC0gcmVzdWx0LnRiICU+JSBcbiAgYWRkX3JvdyhpbnRlcmVzdCA9IHBhc3RlMChpbnRlcmVzdE5hbWUsIFxcX0RPV05cXCksXG4gICAgICAgICAgdGFyZ2V0ID0gcGFzdGUwKHRhcmdldE5hbWUsIFxcX3JldGFpbmVkXFwpLFxuICAgICAgICAgIHB2YWx1ZSA9IHRlbXAkcC52YWx1ZSxcbiAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuXG4jIEFERElORyBST1dTXG50ZW1wIDwtIHJ1bkZpc2hlckV4YWN0KGxvb3AudXBuby5nciwgYmFja2dyb3VuZC5nciwgbG9zdC5ncilcbnJlc3VsdC50YiA8LSByZXN1bHQudGIgJT4lIFxuICBhZGRfcm93KGludGVyZXN0ID0gcGFzdGUwKGludGVyZXN0TmFtZSwgXFxfVVAvTk9cXCksXG4gICAgICAgICAgdGFyZ2V0ID0gcGFzdGUwKHRhcmdldE5hbWUsIFxcX2xvc3RcXCksXG4gICAgICAgICAgcHZhbHVlID0gdGVtcCRwLnZhbHVlLFxuICAgICAgICAgIG9kZHNSYXRpbyA9IHRlbXAkZXN0aW1hdGUpXG5cbiMgQURESU5HIFJPV1NcbnRlbXAgPC0gcnVuRmlzaGVyRXhhY3QobG9vcC5kb3duLmdyLCBiYWNrZ3JvdW5kLmdyLCBsb3N0LmdyKVxucmVzdWx0LnRiIDwtIHJlc3VsdC50YiAlPiUgXG4gIGFkZF9yb3coaW50ZXJlc3QgPSBwYXN0ZTAoaW50ZXJlc3ROYW1lLCBcXF9ET1dOXFwpLFxuICAgICAgICAgIHRhcmdldCA9IHBhc3RlMCh0YXJnZXROYW1lLCBcXF9sb3N0XFwpLFxuICAgICAgICAgIHB2YWx1ZSA9IHRlbXAkcC52YWx1ZSxcbiAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuXG5cbnJlc3VsdC50YiA8LSByZXN1bHQudGIgJT4lXG4gIG11dGF0ZShpbnRlcmVzdCA9IHJlY29kZShpbnRlcmVzdCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICBcXHJlZ0xvb3BfVVAvTk9cXCA9IFxcVVAvTk9cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccmVnTG9vcF9ET1dOXFwgPSBcXERPV05cXCksXG4gICAgICAgICB0YXJnZXQgPSByZWNvZGUodGFyZ2V0LFxuICAgICAgICAgICAgICAgICAgICAgICAgIFxcSDNLMjdhY19lZmZpZV9yZXRhaW5lZFxcID0gXFxSZXRhaW5lZFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIFxcSDNLMjdhY19lZmZpZV9sb3N0XFwgPSBcXExvc3RcXCkpXG5cbnJlc3VsdC50YiRpbnRlcmVzdCA8LSBmYWN0b3IocmVzdWx0LnRiJGludGVyZXN0LCBsZXZlbHMgPSBjKFxcVVAvTk9cXCwgXFxET1dOXFwpKVxuXG5wIDwtIGdncGxvdChyZXN1bHQudGIsIGFlcyh4ID0gaW50ZXJlc3QsIHkgPSB0YXJnZXQsIHNpemUgPSAtbG9nMTAocHZhbHVlKSwgZmlsbCA9IG9kZHNSYXRpbykpICtcbiAgZ2VvbV9wb2ludChzaGFwZSA9IDIxLCAgICAgICAgIyBFbnN1cmVzIGEgcG9pbnQgd2l0aCBhbiBvdXRsaW5lXG4gICAgICAgICAgICAgc3Ryb2tlID0gMC41KnB0VG9NTSAgICAgICMgTGluZSB3aWR0aCBmb3IgdGhlIGJvcmRlclxuICApICsgdGhlbWVfYncoKSArIFxuICBzY2FsZV9zaXplX2NvbnRpbnVvdXMocmFuZ2UgPSBjKDEsIDMpKSArICAjIFNldCBtaW4gYW5kIG1heCBwb2ludCBzaXplcyBoZXJlXG4gIHNjYWxlX2ZpbGxfZ3JhZGllbnRuKGNvbG9ycyA9IGMoXFwjNDg1MkEwXFwsIFxcd2hpdGVcXCwgXFwjQ0IzMzNBXFwpLCAgIyBEZWZpbmUgZ3JhZGllbnQgY29sb3JzXG4gICAgICAgICAgICAgICAgICAgICAgdmFsdWVzID0gc2NhbGVzOjpyZXNjYWxlKGMoMC41LCAxLCAxLjUpKSwgbGltaXRzID0gYygwLjUsIDEuNSksIFxuICAgICAgICAgICAgICAgICAgICAgICNsb3cgPSBcXHdoaXRlXFwsIGhpZ2ggPSBcXCNDQjMzM0FcXCxcbiAgICAgICAgICAgICAgICAgICAgICAjICAgICAgICAgICAgICAgICAgbGltaXRzID0gYygxLCAzKSxcbiAgICAgICAgICAgICAgICAgICAgICBvb2IgPSBzY2FsZXM6OnNxdWlzaCwgIyBEZWZpbmUgZ3JhZGllbnQgY29sb3JzXG4gICAgICAgICAgICAgICAgICAgICAgZ3VpZGUgPSBndWlkZV9jb2xvcmJhcihcbiAgICAgICAgICAgICAgICAgICAgICAgIGJhcndpZHRoID0gMS41LzUuMDgsICAjIEFkanVzdCB3aWR0aCBvZiB0aGUgY29sb3IgYmFyXG4gICAgICAgICAgICAgICAgICAgICAgICBiYXJoZWlnaHQgPSAxNS81LjA4ICAgIyBBZGp1c3QgaGVpZ2h0IG9mIHRoZSBjb2xvciBiYXJcbiAgICAgICAgICAgICAgICAgICAgICApXG4gICkgK1xuICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgYW5nbGUgPSA0NSwgICAgICAjIFJvdGF0ZSB4LWF4aXMgbGFiZWxzIDQ1IGRlZ3JlZXNcbiAgICAgIGhqdXN0ID0gMSwgICAgICAgIyBBZGp1c3QgaG9yaXpvbnRhbCBqdXN0aWZpY2F0aW9uXG4gICAgICB2anVzdCA9IDEgICAgICAgICMgQWRqdXN0IHZlcnRpY2FsIGp1c3RpZmljYXRpb25cbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKVxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgXFxoZWF0bWFwX0gzSzI3YWNfYm9va21hcmtpbmdfcmVnX2RvdHBsb3RcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSgxLjcpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuMSkqbW1Ub0luY2hcbiMgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuIyBwcmludChwKVxuIyBkZXYub2ZmKClcbnN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5cbiAgXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\ntargetName <- \\H3K27ac_effie\\\n# RETAINED loop\nretained <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\am_a.bed\\)) %>% dplyr::select(c(1, 2, 3))\ncolnames(retained) <- c(\\chr\\, \\start\\, \\end\\)\nretained.gr <- makeGRangesFromDataFrame(retained)\n# LOST loop\nlost <- fread(here(refDir, \\TF_bookmarking\\, targetName, \\oa.bed\\)) %>% dplyr::select(c(1, 2, 3))\ncolnames(lost) <- c(\\chr\\, \\start\\, \\end\\)\nlost.gr <- makeGRangesFromDataFrame(lost)\n\n\n# SEEDING\ntemp <- runFisherExact(loop.upno.gr, background.gr, retained.gr)\nresult.tb <- tibble(interest = paste0(interestName, \\_UP/NO\\),\n                    target = paste0(targetName, \\_retained\\),\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\n\n# ADDING ROWS\ntemp <- runFisherExact(loop.down.gr, background.gr, retained.gr)\nresult.tb <- result.tb %>% \n  add_row(interest = paste0(interestName, \\_DOWN\\),\n          target = paste0(targetName, \\_retained\\),\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n# ADDING ROWS\ntemp <- runFisherExact(loop.upno.gr, background.gr, lost.gr)\nresult.tb <- result.tb %>% \n  add_row(interest = paste0(interestName, \\_UP/NO\\),\n          target = paste0(targetName, \\_lost\\),\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n# ADDING ROWS\ntemp <- runFisherExact(loop.down.gr, background.gr, lost.gr)\nresult.tb <- result.tb %>% \n  add_row(interest = paste0(interestName, \\_DOWN\\),\n          target = paste0(targetName, \\_lost\\),\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\nresult.tb <- result.tb %>%\n  mutate(interest = recode(interest, \n                           \\regLoop_UP/NO\\ = \\UP/NO\\,\n                           \\regLoop_DOWN\\ = \\DOWN\\),\n         target = recode(target,\n                         \\H3K27ac_effie_retained\\ = \\Retained\\,\n                         \\H3K27ac_effie_lost\\ = \\Lost\\))\n\nresult.tb$interest <- factor(result.tb$interest, levels = c(\\UP/NO\\, \\DOWN\\))\n\np <- ggplot(result.tb, aes(x = interest, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 0.5*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\\#4852A0\\, \\white\\, \\#CB333A\\),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \\white\\, high = \\#CB333A\\,\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) +\n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\heatmap_H3K27ac_bookmarking_reg_dotplot\\)\nwidth <- panelSize(1.7)*mmToInch\nheight <- panelSize(1.1)*mmToInch\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\nsvglite(paste0(fileName, \\.svg\\),  height = height, width = width)\nprint(p)\ndev.off()\n\n  \n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudGFyZ2V0TmFtZSA8LSBcXEgzSzI3YWNfZWZmaWVcXFxuIyBSRVRBSU5FRCBsb29wXG5yZXRhaW5lZCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxURl9ib29rbWFya2luZ1xcLCB0YXJnZXROYW1lLCBcXGFtX2EuYmVkXFwpKSAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuY29sbmFtZXMocmV0YWluZWQpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxucmV0YWluZWQuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHJldGFpbmVkKVxuIyBMT1NUIGxvb3Bcbmxvc3QgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcVEZfYm9va21hcmtpbmdcXCwgdGFyZ2V0TmFtZSwgXFxvYS5iZWRcXCkpICU+JSBkcGx5cjo6c2VsZWN0KGMoMSwgMiwgMykpXG5jb2xuYW1lcyhsb3N0KSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbmxvc3QuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGxvc3QpXG5cblxuIyBTRUVESU5HXG50ZW1wIDwtIHJ1bkZpc2hlckV4YWN0KGxvb3AudXBuby5nciwgYmFja2dyb3VuZC5nciwgcmV0YWluZWQuZ3IpXG5yZXN1bHQudGIgPC0gdGliYmxlKGludGVyZXN0ID0gcGFzdGUwKGludGVyZXN0TmFtZSwgXFxfVVAvTk9cXCksXG4gICAgICAgICAgICAgICAgICAgIHRhcmdldCA9IHBhc3RlMCh0YXJnZXROYW1lLCBcXF9yZXRhaW5lZFxcKSxcbiAgICAgICAgICAgICAgICAgICAgcHZhbHVlID0gdGVtcCRwLnZhbHVlLFxuICAgICAgICAgICAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuXG4jIEFERElORyBST1dTXG50ZW1wIDwtIHJ1bkZpc2hlckV4YWN0KGxvb3AuZG93bi5nciwgYmFja2dyb3VuZC5nciwgcmV0YWluZWQuZ3IpXG5yZXN1bHQudGIgPC0gcmVzdWx0LnRiICU+JSBcbiAgYWRkX3JvdyhpbnRlcmVzdCA9IHBhc3RlMChpbnRlcmVzdE5hbWUsIFxcX0RPV05cXCksXG4gICAgICAgICAgdGFyZ2V0ID0gcGFzdGUwKHRhcmdldE5hbWUsIFxcX3JldGFpbmVkXFwpLFxuICAgICAgICAgIHB2YWx1ZSA9IHRlbXAkcC52YWx1ZSxcbiAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuXG4jIEFERElORyBST1dTXG50ZW1wIDwtIHJ1bkZpc2hlckV4YWN0KGxvb3AudXBuby5nciwgYmFja2dyb3VuZC5nciwgbG9zdC5ncilcbnJlc3VsdC50YiA8LSByZXN1bHQudGIgJT4lIFxuICBhZGRfcm93KGludGVyZXN0ID0gcGFzdGUwKGludGVyZXN0TmFtZSwgXFxfVVAvTk9cXCksXG4gICAgICAgICAgdGFyZ2V0ID0gcGFzdGUwKHRhcmdldE5hbWUsIFxcX2xvc3RcXCksXG4gICAgICAgICAgcHZhbHVlID0gdGVtcCRwLnZhbHVlLFxuICAgICAgICAgIG9kZHNSYXRpbyA9IHRlbXAkZXN0aW1hdGUpXG5cbiMgQURESU5HIFJPV1NcbnRlbXAgPC0gcnVuRmlzaGVyRXhhY3QobG9vcC5kb3duLmdyLCBiYWNrZ3JvdW5kLmdyLCBsb3N0LmdyKVxucmVzdWx0LnRiIDwtIHJlc3VsdC50YiAlPiUgXG4gIGFkZF9yb3coaW50ZXJlc3QgPSBwYXN0ZTAoaW50ZXJlc3ROYW1lLCBcXF9ET1dOXFwpLFxuICAgICAgICAgIHRhcmdldCA9IHBhc3RlMCh0YXJnZXROYW1lLCBcXF9sb3N0XFwpLFxuICAgICAgICAgIHB2YWx1ZSA9IHRlbXAkcC52YWx1ZSxcbiAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuXG5cbnJlc3VsdC50YiA8LSByZXN1bHQudGIgJT4lXG4gIG11dGF0ZShpbnRlcmVzdCA9IHJlY29kZShpbnRlcmVzdCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICBcXHJlZ0xvb3BfVVAvTk9cXCA9IFxcVVAvTk9cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccmVnTG9vcF9ET1dOXFwgPSBcXERPV05cXCksXG4gICAgICAgICB0YXJnZXQgPSByZWNvZGUodGFyZ2V0LFxuICAgICAgICAgICAgICAgICAgICAgICAgIFxcSDNLMjdhY19lZmZpZV9yZXRhaW5lZFxcID0gXFxSZXRhaW5lZFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIFxcSDNLMjdhY19lZmZpZV9sb3N0XFwgPSBcXExvc3RcXCkpXG5cbnJlc3VsdC50YiRpbnRlcmVzdCA8LSBmYWN0b3IocmVzdWx0LnRiJGludGVyZXN0LCBsZXZlbHMgPSBjKFxcVVAvTk9cXCwgXFxET1dOXFwpKVxuXG5wIDwtIGdncGxvdChyZXN1bHQudGIsIGFlcyh4ID0gaW50ZXJlc3QsIHkgPSB0YXJnZXQsIHNpemUgPSAtbG9nMTAocHZhbHVlKSwgZmlsbCA9IG9kZHNSYXRpbykpICtcbiAgZ2VvbV9wb2ludChzaGFwZSA9IDIxLCAgICAgICAgIyBFbnN1cmVzIGEgcG9pbnQgd2l0aCBhbiBvdXRsaW5lXG4gICAgICAgICAgICAgc3Ryb2tlID0gMC41KnB0VG9NTSAgICAgICMgTGluZSB3aWR0aCBmb3IgdGhlIGJvcmRlclxuICApICsgdGhlbWVfYncoKSArIFxuICBzY2FsZV9zaXplX2NvbnRpbnVvdXMocmFuZ2UgPSBjKDEsIDMpKSArICAjIFNldCBtaW4gYW5kIG1heCBwb2ludCBzaXplcyBoZXJlXG4gIHNjYWxlX2ZpbGxfZ3JhZGllbnRuKGNvbG9ycyA9IGMoXFwjNDg1MkEwXFwsIFxcd2hpdGVcXCwgXFwjQ0IzMzNBXFwpLCAgIyBEZWZpbmUgZ3JhZGllbnQgY29sb3JzXG4gICAgICAgICAgICAgICAgICAgICAgdmFsdWVzID0gc2NhbGVzOjpyZXNjYWxlKGMoMC41LCAxLCAxLjUpKSwgbGltaXRzID0gYygwLjUsIDEuNSksIFxuICAgICAgICAgICAgICAgICAgICAgICNsb3cgPSBcXHdoaXRlXFwsIGhpZ2ggPSBcXCNDQjMzM0FcXCxcbiAgICAgICAgICAgICAgICAgICAgICAjICAgICAgICAgICAgICAgICAgbGltaXRzID0gYygxLCAzKSxcbiAgICAgICAgICAgICAgICAgICAgICBvb2IgPSBzY2FsZXM6OnNxdWlzaCwgIyBEZWZpbmUgZ3JhZGllbnQgY29sb3JzXG4gICAgICAgICAgICAgICAgICAgICAgZ3VpZGUgPSBndWlkZV9jb2xvcmJhcihcbiAgICAgICAgICAgICAgICAgICAgICAgIGJhcndpZHRoID0gMS41LzUuMDgsICAjIEFkanVzdCB3aWR0aCBvZiB0aGUgY29sb3IgYmFyXG4gICAgICAgICAgICAgICAgICAgICAgICBiYXJoZWlnaHQgPSAxNS81LjA4ICAgIyBBZGp1c3QgaGVpZ2h0IG9mIHRoZSBjb2xvciBiYXJcbiAgICAgICAgICAgICAgICAgICAgICApXG4gICkgK1xuICBsYWJzKHggPSBOVUxMLCB5ID0gTlVMTCkgICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KFxuICAgICAgYW5nbGUgPSA0NSwgICAgICAjIFJvdGF0ZSB4LWF4aXMgbGFiZWxzIDQ1IGRlZ3JlZXNcbiAgICAgIGhqdXN0ID0gMSwgICAgICAgIyBBZGp1c3QgaG9yaXpvbnRhbCBqdXN0aWZpY2F0aW9uXG4gICAgICB2anVzdCA9IDEgICAgICAgICMgQWRqdXN0IHZlcnRpY2FsIGp1c3RpZmljYXRpb25cbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKVxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgXFxoZWF0bWFwX0gzSzI3YWNfYm9va21hcmtpbmdfcmVnX2RvdHBsb3RcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSgxLjcpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuMSkqbW1Ub0luY2hcbiMgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuIyBwcmludChwKVxuIyBkZXYub2ZmKClcbnN2Z2xpdGUocGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5cbiAgXG5gYGBcbmBgYCJ9 -->

```r
```r
targetName <- \H3K27ac_effie\
# RETAINED loop
retained <- fread(here(refDir, \TF_bookmarking\, targetName, \am_a.bed\)) %>% dplyr::select(c(1, 2, 3))
colnames(retained) <- c(\chr\, \start\, \end\)
retained.gr <- makeGRangesFromDataFrame(retained)
# LOST loop
lost <- fread(here(refDir, \TF_bookmarking\, targetName, \oa.bed\)) %>% dplyr::select(c(1, 2, 3))
colnames(lost) <- c(\chr\, \start\, \end\)
lost.gr <- makeGRangesFromDataFrame(lost)


# SEEDING
temp <- runFisherExact(loop.upno.gr, background.gr, retained.gr)
result.tb <- tibble(interest = paste0(interestName, \_UP/NO\),
                    target = paste0(targetName, \_retained\),
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)

# ADDING ROWS
temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)
result.tb <- result.tb %>% 
  add_row(interest = paste0(interestName, \_DOWN\),
          target = paste0(targetName, \_retained\),
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

# ADDING ROWS
temp <- runFisherExact(loop.upno.gr, background.gr, lost.gr)
result.tb <- result.tb %>% 
  add_row(interest = paste0(interestName, \_UP/NO\),
          target = paste0(targetName, \_lost\),
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

# ADDING ROWS
temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)
result.tb <- result.tb %>% 
  add_row(interest = paste0(interestName, \_DOWN\),
          target = paste0(targetName, \_lost\),
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)


result.tb <- result.tb %>%
  mutate(interest = recode(interest, 
                           \regLoop_UP/NO\ = \UP/NO\,
                           \regLoop_DOWN\ = \DOWN\),
         target = recode(target,
                         \H3K27ac_effie_retained\ = \Retained\,
                         \H3K27ac_effie_lost\ = \Lost\))

result.tb$interest <- factor(result.tb$interest, levels = c(\UP/NO\, \DOWN\))

p <- ggplot(result.tb, aes(x = interest, y = target, size = -log10(pvalue), fill = oddsRatio)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 0.5*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
  scale_fill_gradientn(colors = c(\#4852A0\, \white\, \#CB333A\),  # Define gradient colors
                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), 
                      #low = \white\, high = \#CB333A\,
                      #                  limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) +
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, \heatmap_H3K27ac_bookmarking_reg_dotplot\)
width <- panelSize(1.7)*mmToInch
height <- panelSize(1.1)*mmToInch
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
svglite(paste0(fileName, \.svg\),  height = height, width = width)
print(p)
dev.off()

  
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



##### Reg loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgdGFyZ2V0XG5cbnRlbXAxIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRCaW5hcnkoXCJFU1JSQl9kc2dcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwbm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAyIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRCaW5hcnkoXCJIM0syN2FjX2VmZmllXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cG5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0QmluYXJ5KFwiS0xGNF9lZmZpZVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXBuby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDQgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldEJpbmFyeShcIk9DVDRfZWZmaWVcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwbm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRCaW5hcnkoXCJTT1gyX2VmZmllXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cG5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG5cblxuZGF0YSA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyLCB0ZW1wMywgdGVtcDQsIHRlbXA1KVxuXG5cblxucmVzdWx0LnRiIDwtIGRhdGEgJT4lXG4gIG11dGF0ZShpbnRlcmVzdCA9IHJlY29kZShpbnRlcmVzdCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICBcInJlZ0xvb3BfVVAvTk9cIiA9IFwiVVAvTk9cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicmVnTG9vcF9ET1dOXCIgPSBcIkRPV05cIiksXG4gICAgICAgICB0YXJnZXQgPSByZWNvZGUodGFyZ2V0LFxuICAgICAgICAgICAgICAgICAgICAgICAgIFwiSDNLMjdhY19lZmZpZV9yZXRhaW5lZFwiID0gXCJIM0syN2FjX3JldGFpbmVkXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgXCJIM0syN2FjX2VmZmllX2xvc3RcIiA9IFwiSDNLMjdhY19sb3N0XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgXCJFU1JSQl9kc2dfcmV0YWluZWRcIiA9IFwiRVNSUkJfcmV0YWluZWRcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICBcIkVTUlJCX2RzZ19sb3N0XCIgPSBcIkVTUlJCX2xvc3RcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICBcIktMRjRfZWZmaWVfcmV0YWluZWRcIiA9IFwiS0xGNF9yZXRhaW5lZFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgIFwiS0xGNF9lZmZpZV9sb3N0XCIgPSBcIktMRjRfbG9zdFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgIFwiT0NUNF9lZmZpZV9yZXRhaW5lZFwiID0gXCJPQ1Q0X3JldGFpbmVkXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgXCJPQ1Q0X2VmZmllX2xvc3RcIiA9IFwiT0NUNF9sb3N0XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgXCJTT1gyX2VmZmllX3JldGFpbmVkXCIgPSBcIlNPWDJfcmV0YWluZWRcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICBcIlNPWDJfZWZmaWVfbG9zdFwiID0gXCJTT1gyX2xvc3RcIikpXG5cbnJlc3VsdC50YiRpbnRlcmVzdCA8LSBmYWN0b3IocmVzdWx0LnRiJGludGVyZXN0LCBsZXZlbHMgPSBjKFwiVVAvTk9cIiwgXCJET1dOXCIpKVxucmVzdWx0LnRiJHRhcmdldCA8LSBmYWN0b3IocmVzdWx0LnRiJHRhcmdldCwgbGV2ZWxzID0gcmV2KGMoXCJIM0syN2FjX3JldGFpbmVkXCIsIFwiSDNLMjdhY19sb3N0XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiRVNSUkJfcmV0YWluZWRcIiwgXCJFU1JSQl9sb3N0XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiS0xGNF9yZXRhaW5lZFwiLCBcIktMRjRfbG9zdFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIk9DVDRfcmV0YWluZWRcIiwgXCJPQ1Q0X2xvc3RcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJTT1gyX3JldGFpbmVkXCIsXCJTT1gyX2xvc3RcIikpKVxuXG5wIDwtIGdncGxvdChyZXN1bHQudGIsIGFlcyh4ID0gaW50ZXJlc3QsIHkgPSB0YXJnZXQsIHNpemUgPSAtbG9nMTAocHZhbHVlKSwgZmlsbCA9IG9kZHNSYXRpbykpICtcbiAgZ2VvbV9wb2ludChzaGFwZSA9IDIxLCAgICAgICAgIyBFbnN1cmVzIGEgcG9pbnQgd2l0aCBhbiBvdXRsaW5lXG4gICAgICAgICAgICAgc3Ryb2tlID0gMSpwdFRvTU0gICAgICAjIExpbmUgd2lkdGggZm9yIHRoZSBib3JkZXJcbiAgKSArIHRoZW1lX2J3KCkgKyBcbiAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygxLCAzKSkgKyAgIyBTZXQgbWluIGFuZCBtYXggcG9pbnQgc2l6ZXMgaGVyZVxuICBzY2FsZV9maWxsX2dyYWRpZW50bihjb2xvcnMgPSBjKFwiIzQ4NTJBMFwiLCBcIndoaXRlXCIsIFwiI0NCMzMzQVwiKSwgICMgRGVmaW5lIGdyYWRpZW50IGNvbG9yc1xuICAgICAgICAgICAgICAgICAgICAgIHZhbHVlcyA9IHNjYWxlczo6cmVzY2FsZShjKDAuNSwgMSwgMS41KSksIGxpbWl0cyA9IGMoMC41LCAxLjUpLCBcbiAgICAgICAgICAgICAgICAgICAgICAjbG93ID0gXCJ3aGl0ZVwiLCBoaWdoID0gXCIjQ0IzMzNBXCIsXG4gICAgICAgICAgICAgICAgICAgICAgIyAgICAgICAgICAgICAgICAgIGxpbWl0cyA9IGMoMSwgMyksXG4gICAgICAgICAgICAgICAgICAgICAgb29iID0gc2NhbGVzOjpzcXVpc2gsICMgRGVmaW5lIGdyYWRpZW50IGNvbG9yc1xuICAgICAgICAgICAgICAgICAgICAgIGd1aWRlID0gZ3VpZGVfY29sb3JiYXIoXG4gICAgICAgICAgICAgICAgICAgICAgICBiYXJ3aWR0aCA9IDEuNS81LjA4LCAgIyBBZGp1c3Qgd2lkdGggb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyaGVpZ2h0ID0gMTUvNS4wOCAgICMgQWRqdXN0IGhlaWdodCBvZiB0aGUgY29sb3IgYmFyXG4gICAgICAgICAgICAgICAgICAgICAgKVxuICApICtcbiAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICArXG4gIHRoZW1lKFxuICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiXG4gICAgKSxcbiAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIGFuZ2xlID0gNDUsICAgICAgIyBSb3RhdGUgeC1heGlzIGxhYmVscyA0NSBkZWdyZWVzXG4gICAgICBoanVzdCA9IDEsICAgICAgICMgQWRqdXN0IGhvcml6b250YWwganVzdGlmaWNhdGlvblxuICAgICAgdmp1c3QgPSAxICAgICAgICAjIEFkanVzdCB2ZXJ0aWNhbCBqdXN0aWZpY2F0aW9uXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCIsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcInNxdWFyZVwiXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcInRyYW5zcGFyZW50XCIpLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gIClcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFwiaGVhdG1hcF9hbGx0YXJnZXRfYm9va21hcmtpbmdfcmVnX2RvdHBsb3RcIilcbndpZHRoIDwtIHBhbmVsU2l6ZSgyLjIpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDIpKm1tVG9JbmNoXG4jIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5zdmdsaXRlKHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cblxuXG5cblxuXG5cbmBgYCJ9 -->\n\n```r\n#### Importing loops of target\n\ntemp1 <- runFisherExactCombinationTargetBinary(\\ESRRB_dsg\\, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTargetBinary(\\H3K27ac_effie\\, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTargetBinary(\\KLF4_effie\\, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTargetBinary(\\OCT4_effie\\, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTargetBinary(\\SOX2_effie\\, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr)\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5)\n\n\n\nresult.tb <- data %>%\n  mutate(interest = recode(interest, \n                           \\regLoop_UP/NO\\ = \\UP/NO\\,\n                           \\regLoop_DOWN\\ = \\DOWN\\),\n         target = recode(target,\n                         \\H3K27ac_effie_retained\\ = \\H3K27ac_retained\\,\n                         \\H3K27ac_effie_lost\\ = \\H3K27ac_lost\\,\n                         \\ESRRB_dsg_retained\\ = \\ESRRB_retained\\,\n                         \\ESRRB_dsg_lost\\ = \\ESRRB_lost\\,\n                         \\KLF4_effie_retained\\ = \\KLF4_retained\\,\n                         \\KLF4_effie_lost\\ = \\KLF4_lost\\,\n                         \\OCT4_effie_retained\\ = \\OCT4_retained\\,\n                         \\OCT4_effie_lost\\ = \\OCT4_lost\\,\n                         \\SOX2_effie_retained\\ = \\SOX2_retained\\,\n                         \\SOX2_effie_lost\\ = \\SOX2_lost\\))\n\nresult.tb$interest <- factor(result.tb$interest, levels = c(\\UP/NO\\, \\DOWN\\))\nresult.tb$target <- factor(result.tb$target, levels = rev(c(\\H3K27ac_retained\\, \\H3K27ac_lost\\,\n                                                        \\ESRRB_retained\\, \\ESRRB_lost\\,\n                                                        \\KLF4_retained\\, \\KLF4_lost\\,\n                                                        \\OCT4_retained\\, \\OCT4_lost\\,\n                                                        \\SOX2_retained\\,\\SOX2_lost\\)))\n\np <- ggplot(result.tb, aes(x = interest, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\\#4852A0\\, \\white\\, \\#CB333A\\),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \\white\\, high = \\#CB333A\\,\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) +\n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\heatmap_alltarget_bookmarking_reg_dotplot\\)\nwidth <- panelSize(2.2)*mmToInch\nheight <- panelSize(2)*mmToInch\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\nsvglite(paste0(fileName, \\.svg\\),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
#### Importing loops of target

temp1 <- runFisherExactCombinationTargetBinary(\ESRRB_dsg\, interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTargetBinary(\H3K27ac_effie\, interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTargetBinary(\KLF4_effie\, interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTargetBinary(\OCT4_effie\, interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTargetBinary(\SOX2_effie\, interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)


data <- bind_rows(temp1, temp2, temp3, temp4, temp5)



result.tb <- data %>%
  mutate(interest = recode(interest, 
                           \regLoop_UP/NO\ = \UP/NO\,
                           \regLoop_DOWN\ = \DOWN\),
         target = recode(target,
                         \H3K27ac_effie_retained\ = \H3K27ac_retained\,
                         \H3K27ac_effie_lost\ = \H3K27ac_lost\,
                         \ESRRB_dsg_retained\ = \ESRRB_retained\,
                         \ESRRB_dsg_lost\ = \ESRRB_lost\,
                         \KLF4_effie_retained\ = \KLF4_retained\,
                         \KLF4_effie_lost\ = \KLF4_lost\,
                         \OCT4_effie_retained\ = \OCT4_retained\,
                         \OCT4_effie_lost\ = \OCT4_lost\,
                         \SOX2_effie_retained\ = \SOX2_retained\,
                         \SOX2_effie_lost\ = \SOX2_lost\))

result.tb$interest <- factor(result.tb$interest, levels = c(\UP/NO\, \DOWN\))
result.tb$target <- factor(result.tb$target, levels = rev(c(\H3K27ac_retained\, \H3K27ac_lost\,
                                                        \ESRRB_retained\, \ESRRB_lost\,
                                                        \KLF4_retained\, \KLF4_lost\,
                                                        \OCT4_retained\, \OCT4_lost\,
                                                        \SOX2_retained\,\SOX2_lost\)))

p <- ggplot(result.tb, aes(x = interest, y = target, size = -log10(pvalue), fill = oddsRatio)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
  scale_fill_gradientn(colors = c(\#4852A0\, \white\, \#CB333A\),  # Define gradient colors
                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), 
                      #low = \white\, high = \#CB333A\,
                      #                  limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) +
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, \heatmap_alltarget_bookmarking_reg_dotplot\)
width <- panelSize(2.2)*mmToInch
height <- panelSize(2)*mmToInch
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
svglite(paste0(fileName, \.svg\),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgdGFyZ2V0XG5cbnRlbXAxIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRCaW5hcnkoXFxFU1JSQl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwbm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAyIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRCaW5hcnkoXFxIM0syN2FjX2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cG5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0QmluYXJ5KFxcS0xGNF9lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXBuby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDQgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldEJpbmFyeShcXE9DVDRfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwbm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRCaW5hcnkoXFxTT1gyX2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cG5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG5cblxuZGF0YSA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyLCB0ZW1wMywgdGVtcDQsIHRlbXA1KVxuXG5cblxucmVzdWx0LnRiIDwtIGRhdGEgJT4lXG4gIG11dGF0ZShpbnRlcmVzdCA9IHJlY29kZShpbnRlcmVzdCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICBcXHJlZ0xvb3BfVVAvTk9cXCA9IFxcVVAvTk9cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccmVnTG9vcF9ET1dOXFwgPSBcXERPV05cXCksXG4gICAgICAgICB0YXJnZXQgPSByZWNvZGUodGFyZ2V0LFxuICAgICAgICAgICAgICAgICAgICAgICAgIFxcSDNLMjdhY19lZmZpZV9yZXRhaW5lZFxcID0gXFxIM0syN2FjX3JldGFpbmVkXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgXFxIM0syN2FjX2VmZmllX2xvc3RcXCA9IFxcSDNLMjdhY19sb3N0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgXFxFU1JSQl9kc2dfcmV0YWluZWRcXCA9IFxcRVNSUkJfcmV0YWluZWRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICBcXEVTUlJCX2RzZ19sb3N0XFwgPSBcXEVTUlJCX2xvc3RcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICBcXEtMRjRfZWZmaWVfcmV0YWluZWRcXCA9IFxcS0xGNF9yZXRhaW5lZFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIFxcS0xGNF9lZmZpZV9sb3N0XFwgPSBcXEtMRjRfbG9zdFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIFxcT0NUNF9lZmZpZV9yZXRhaW5lZFxcID0gXFxPQ1Q0X3JldGFpbmVkXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgXFxPQ1Q0X2VmZmllX2xvc3RcXCA9IFxcT0NUNF9sb3N0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgXFxTT1gyX2VmZmllX3JldGFpbmVkXFwgPSBcXFNPWDJfcmV0YWluZWRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICBcXFNPWDJfZWZmaWVfbG9zdFxcID0gXFxTT1gyX2xvc3RcXCkpXG5cbnJlc3VsdC50YiRpbnRlcmVzdCA8LSBmYWN0b3IocmVzdWx0LnRiJGludGVyZXN0LCBsZXZlbHMgPSBjKFxcVVAvTk9cXCwgXFxET1dOXFwpKVxucmVzdWx0LnRiJHRhcmdldCA8LSBmYWN0b3IocmVzdWx0LnRiJHRhcmdldCwgbGV2ZWxzID0gcmV2KGMoXFxIM0syN2FjX3JldGFpbmVkXFwsIFxcSDNLMjdhY19sb3N0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcRVNSUkJfcmV0YWluZWRcXCwgXFxFU1JSQl9sb3N0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcS0xGNF9yZXRhaW5lZFxcLCBcXEtMRjRfbG9zdFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXE9DVDRfcmV0YWluZWRcXCwgXFxPQ1Q0X2xvc3RcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxTT1gyX3JldGFpbmVkXFwsXFxTT1gyX2xvc3RcXCkpKVxuXG5wIDwtIGdncGxvdChyZXN1bHQudGIsIGFlcyh4ID0gaW50ZXJlc3QsIHkgPSB0YXJnZXQsIHNpemUgPSAtbG9nMTAocHZhbHVlKSwgZmlsbCA9IG9kZHNSYXRpbykpICtcbiAgZ2VvbV9wb2ludChzaGFwZSA9IDIxLCAgICAgICAgIyBFbnN1cmVzIGEgcG9pbnQgd2l0aCBhbiBvdXRsaW5lXG4gICAgICAgICAgICAgc3Ryb2tlID0gMSpwdFRvTU0gICAgICAjIExpbmUgd2lkdGggZm9yIHRoZSBib3JkZXJcbiAgKSArIHRoZW1lX2J3KCkgKyBcbiAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygxLCAzKSkgKyAgIyBTZXQgbWluIGFuZCBtYXggcG9pbnQgc2l6ZXMgaGVyZVxuICBzY2FsZV9maWxsX2dyYWRpZW50bihjb2xvcnMgPSBjKFxcIzQ4NTJBMFxcLCBcXHdoaXRlXFwsIFxcI0NCMzMzQVxcKSwgICMgRGVmaW5lIGdyYWRpZW50IGNvbG9yc1xuICAgICAgICAgICAgICAgICAgICAgIHZhbHVlcyA9IHNjYWxlczo6cmVzY2FsZShjKDAuNSwgMSwgMS41KSksIGxpbWl0cyA9IGMoMC41LCAxLjUpLCBcbiAgICAgICAgICAgICAgICAgICAgICAjbG93ID0gXFx3aGl0ZVxcLCBoaWdoID0gXFwjQ0IzMzNBXFwsXG4gICAgICAgICAgICAgICAgICAgICAgIyAgICAgICAgICAgICAgICAgIGxpbWl0cyA9IGMoMSwgMyksXG4gICAgICAgICAgICAgICAgICAgICAgb29iID0gc2NhbGVzOjpzcXVpc2gsICMgRGVmaW5lIGdyYWRpZW50IGNvbG9yc1xuICAgICAgICAgICAgICAgICAgICAgIGd1aWRlID0gZ3VpZGVfY29sb3JiYXIoXG4gICAgICAgICAgICAgICAgICAgICAgICBiYXJ3aWR0aCA9IDEuNS81LjA4LCAgIyBBZGp1c3Qgd2lkdGggb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyaGVpZ2h0ID0gMTUvNS4wOCAgICMgQWRqdXN0IGhlaWdodCBvZiB0aGUgY29sb3IgYmFyXG4gICAgICAgICAgICAgICAgICAgICAgKVxuICApICtcbiAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICArXG4gIHRoZW1lKFxuICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIGFuZ2xlID0gNDUsICAgICAgIyBSb3RhdGUgeC1heGlzIGxhYmVscyA0NSBkZWdyZWVzXG4gICAgICBoanVzdCA9IDEsICAgICAgICMgQWRqdXN0IGhvcml6b250YWwganVzdGlmaWNhdGlvblxuICAgICAgdmp1c3QgPSAxICAgICAgICAjIEFkanVzdCB2ZXJ0aWNhbCBqdXN0aWZpY2F0aW9uXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcXHRyYW5zcGFyZW50XFwpLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gIClcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcaGVhdG1hcF9hbGx0YXJnZXRfYm9va21hcmtpbmdfcmVnX2RvdHBsb3RcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSgyLjIpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDIpKm1tVG9JbmNoXG4jIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5zdmdsaXRlKHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cblxuXG5cblxuXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\n#### Importing loops of target\n\ntemp1 <- runFisherExactCombinationTargetBinary(\\ESRRB_dsg\\, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTargetBinary(\\H3K27ac_effie\\, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTargetBinary(\\KLF4_effie\\, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTargetBinary(\\OCT4_effie\\, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTargetBinary(\\SOX2_effie\\, interestName,\n                                      loop.upno.gr, loop.down.gr,\n                                      background.gr)\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5)\n\n\n\nresult.tb <- data %>%\n  mutate(interest = recode(interest, \n                           \\regLoop_UP/NO\\ = \\UP/NO\\,\n                           \\regLoop_DOWN\\ = \\DOWN\\),\n         target = recode(target,\n                         \\H3K27ac_effie_retained\\ = \\H3K27ac_retained\\,\n                         \\H3K27ac_effie_lost\\ = \\H3K27ac_lost\\,\n                         \\ESRRB_dsg_retained\\ = \\ESRRB_retained\\,\n                         \\ESRRB_dsg_lost\\ = \\ESRRB_lost\\,\n                         \\KLF4_effie_retained\\ = \\KLF4_retained\\,\n                         \\KLF4_effie_lost\\ = \\KLF4_lost\\,\n                         \\OCT4_effie_retained\\ = \\OCT4_retained\\,\n                         \\OCT4_effie_lost\\ = \\OCT4_lost\\,\n                         \\SOX2_effie_retained\\ = \\SOX2_retained\\,\n                         \\SOX2_effie_lost\\ = \\SOX2_lost\\))\n\nresult.tb$interest <- factor(result.tb$interest, levels = c(\\UP/NO\\, \\DOWN\\))\nresult.tb$target <- factor(result.tb$target, levels = rev(c(\\H3K27ac_retained\\, \\H3K27ac_lost\\,\n                                                        \\ESRRB_retained\\, \\ESRRB_lost\\,\n                                                        \\KLF4_retained\\, \\KLF4_lost\\,\n                                                        \\OCT4_retained\\, \\OCT4_lost\\,\n                                                        \\SOX2_retained\\,\\SOX2_lost\\)))\n\np <- ggplot(result.tb, aes(x = interest, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\\#4852A0\\, \\white\\, \\#CB333A\\),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \\white\\, high = \\#CB333A\\,\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) +\n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\heatmap_alltarget_bookmarking_reg_dotplot\\)\nwidth <- panelSize(2.2)*mmToInch\nheight <- panelSize(2)*mmToInch\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\nsvglite(paste0(fileName, \\.svg\\),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n\n\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgdGFyZ2V0XG5cbnRlbXAxIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRCaW5hcnkoXFxFU1JSQl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwbm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAyIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRCaW5hcnkoXFxIM0syN2FjX2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cG5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0QmluYXJ5KFxcS0xGNF9lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXBuby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDQgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldEJpbmFyeShcXE9DVDRfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwbm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRCaW5hcnkoXFxTT1gyX2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cG5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG5cblxuZGF0YSA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyLCB0ZW1wMywgdGVtcDQsIHRlbXA1KVxuXG5cblxucmVzdWx0LnRiIDwtIGRhdGEgJT4lXG4gIG11dGF0ZShpbnRlcmVzdCA9IHJlY29kZShpbnRlcmVzdCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICBcXHJlZ0xvb3BfVVAvTk9cXCA9IFxcVVAvTk9cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccmVnTG9vcF9ET1dOXFwgPSBcXERPV05cXCksXG4gICAgICAgICB0YXJnZXQgPSByZWNvZGUodGFyZ2V0LFxuICAgICAgICAgICAgICAgICAgICAgICAgIFxcSDNLMjdhY19lZmZpZV9yZXRhaW5lZFxcID0gXFxIM0syN2FjX3JldGFpbmVkXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgXFxIM0syN2FjX2VmZmllX2xvc3RcXCA9IFxcSDNLMjdhY19sb3N0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgXFxFU1JSQl9kc2dfcmV0YWluZWRcXCA9IFxcRVNSUkJfcmV0YWluZWRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICBcXEVTUlJCX2RzZ19sb3N0XFwgPSBcXEVTUlJCX2xvc3RcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICBcXEtMRjRfZWZmaWVfcmV0YWluZWRcXCA9IFxcS0xGNF9yZXRhaW5lZFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIFxcS0xGNF9lZmZpZV9sb3N0XFwgPSBcXEtMRjRfbG9zdFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgIFxcT0NUNF9lZmZpZV9yZXRhaW5lZFxcID0gXFxPQ1Q0X3JldGFpbmVkXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgXFxPQ1Q0X2VmZmllX2xvc3RcXCA9IFxcT0NUNF9sb3N0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgXFxTT1gyX2VmZmllX3JldGFpbmVkXFwgPSBcXFNPWDJfcmV0YWluZWRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICBcXFNPWDJfZWZmaWVfbG9zdFxcID0gXFxTT1gyX2xvc3RcXCkpXG5cbnJlc3VsdC50YiRpbnRlcmVzdCA8LSBmYWN0b3IocmVzdWx0LnRiJGludGVyZXN0LCBsZXZlbHMgPSBjKFxcVVAvTk9cXCwgXFxET1dOXFwpKVxucmVzdWx0LnRiJHRhcmdldCA8LSBmYWN0b3IocmVzdWx0LnRiJHRhcmdldCwgbGV2ZWxzID0gcmV2KGMoXFxIM0syN2FjX3JldGFpbmVkXFwsIFxcSDNLMjdhY19sb3N0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcRVNSUkJfcmV0YWluZWRcXCwgXFxFU1JSQl9sb3N0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcS0xGNF9yZXRhaW5lZFxcLCBcXEtMRjRfbG9zdFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXE9DVDRfcmV0YWluZWRcXCwgXFxPQ1Q0X2xvc3RcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxTT1gyX3JldGFpbmVkXFwsXFxTT1gyX2xvc3RcXCkpKVxuXG5wIDwtIGdncGxvdChyZXN1bHQudGIsIGFlcyh4ID0gaW50ZXJlc3QsIHkgPSB0YXJnZXQsIHNpemUgPSAtbG9nMTAocHZhbHVlKSwgZmlsbCA9IG9kZHNSYXRpbykpICtcbiAgZ2VvbV9wb2ludChzaGFwZSA9IDIxLCAgICAgICAgIyBFbnN1cmVzIGEgcG9pbnQgd2l0aCBhbiBvdXRsaW5lXG4gICAgICAgICAgICAgc3Ryb2tlID0gMSpwdFRvTU0gICAgICAjIExpbmUgd2lkdGggZm9yIHRoZSBib3JkZXJcbiAgKSArIHRoZW1lX2J3KCkgKyBcbiAgc2NhbGVfc2l6ZV9jb250aW51b3VzKHJhbmdlID0gYygxLCAzKSkgKyAgIyBTZXQgbWluIGFuZCBtYXggcG9pbnQgc2l6ZXMgaGVyZVxuICBzY2FsZV9maWxsX2dyYWRpZW50bihjb2xvcnMgPSBjKFxcIzQ4NTJBMFxcLCBcXHdoaXRlXFwsIFxcI0NCMzMzQVxcKSwgICMgRGVmaW5lIGdyYWRpZW50IGNvbG9yc1xuICAgICAgICAgICAgICAgICAgICAgIHZhbHVlcyA9IHNjYWxlczo6cmVzY2FsZShjKDAuNSwgMSwgMS41KSksIGxpbWl0cyA9IGMoMC41LCAxLjUpLCBcbiAgICAgICAgICAgICAgICAgICAgICAjbG93ID0gXFx3aGl0ZVxcLCBoaWdoID0gXFwjQ0IzMzNBXFwsXG4gICAgICAgICAgICAgICAgICAgICAgIyAgICAgICAgICAgICAgICAgIGxpbWl0cyA9IGMoMSwgMyksXG4gICAgICAgICAgICAgICAgICAgICAgb29iID0gc2NhbGVzOjpzcXVpc2gsICMgRGVmaW5lIGdyYWRpZW50IGNvbG9yc1xuICAgICAgICAgICAgICAgICAgICAgIGd1aWRlID0gZ3VpZGVfY29sb3JiYXIoXG4gICAgICAgICAgICAgICAgICAgICAgICBiYXJ3aWR0aCA9IDEuNS81LjA4LCAgIyBBZGp1c3Qgd2lkdGggb2YgdGhlIGNvbG9yIGJhclxuICAgICAgICAgICAgICAgICAgICAgICAgYmFyaGVpZ2h0ID0gMTUvNS4wOCAgICMgQWRqdXN0IGhlaWdodCBvZiB0aGUgY29sb3IgYmFyXG4gICAgICAgICAgICAgICAgICAgICAgKVxuICApICtcbiAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICArXG4gIHRoZW1lKFxuICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIGFuZ2xlID0gNDUsICAgICAgIyBSb3RhdGUgeC1heGlzIGxhYmVscyA0NSBkZWdyZWVzXG4gICAgICBoanVzdCA9IDEsICAgICAgICMgQWRqdXN0IGhvcml6b250YWwganVzdGlmaWNhdGlvblxuICAgICAgdmp1c3QgPSAxICAgICAgICAjIEFkanVzdCB2ZXJ0aWNhbCBqdXN0aWZpY2F0aW9uXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcXHRyYW5zcGFyZW50XFwpLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gIClcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxcaGVhdG1hcF9hbGx0YXJnZXRfYm9va21hcmtpbmdfcmVnX2RvdHBsb3RcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSgyLjIpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDIpKm1tVG9JbmNoXG4jIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiMgcHJpbnQocClcbiMgZGV2Lm9mZigpXG5zdmdsaXRlKHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5cblxuXG5cblxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
#### Importing loops of target

temp1 <- runFisherExactCombinationTargetBinary(\ESRRB_dsg\, interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTargetBinary(\H3K27ac_effie\, interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTargetBinary(\KLF4_effie\, interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTargetBinary(\OCT4_effie\, interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTargetBinary(\SOX2_effie\, interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)


data <- bind_rows(temp1, temp2, temp3, temp4, temp5)



result.tb <- data %>%
  mutate(interest = recode(interest, 
                           \regLoop_UP/NO\ = \UP/NO\,
                           \regLoop_DOWN\ = \DOWN\),
         target = recode(target,
                         \H3K27ac_effie_retained\ = \H3K27ac_retained\,
                         \H3K27ac_effie_lost\ = \H3K27ac_lost\,
                         \ESRRB_dsg_retained\ = \ESRRB_retained\,
                         \ESRRB_dsg_lost\ = \ESRRB_lost\,
                         \KLF4_effie_retained\ = \KLF4_retained\,
                         \KLF4_effie_lost\ = \KLF4_lost\,
                         \OCT4_effie_retained\ = \OCT4_retained\,
                         \OCT4_effie_lost\ = \OCT4_lost\,
                         \SOX2_effie_retained\ = \SOX2_retained\,
                         \SOX2_effie_lost\ = \SOX2_lost\))

result.tb$interest <- factor(result.tb$interest, levels = c(\UP/NO\, \DOWN\))
result.tb$target <- factor(result.tb$target, levels = rev(c(\H3K27ac_retained\, \H3K27ac_lost\,
                                                        \ESRRB_retained\, \ESRRB_lost\,
                                                        \KLF4_retained\, \KLF4_lost\,
                                                        \OCT4_retained\, \OCT4_lost\,
                                                        \SOX2_retained\,\SOX2_lost\)))

p <- ggplot(result.tb, aes(x = interest, y = target, size = -log10(pvalue), fill = oddsRatio)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
  scale_fill_gradientn(colors = c(\#4852A0\, \white\, \#CB333A\),  # Define gradient colors
                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), 
                      #low = \white\, high = \#CB333A\,
                      #                  limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) +
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, \heatmap_alltarget_bookmarking_reg_dotplot\)
width <- panelSize(2.2)*mmToInch
height <- panelSize(2)*mmToInch
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
svglite(paste0(fileName, \.svg\),  height = height, width = width)
print(p)
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

###### Figure - H3K27ac only

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgdGFyZ2V0XG50ZW1wMSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiQVRBQ19lZmZpZVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAyIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJDVENGXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDMgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIkVTUlJCX2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA0IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJFU1JSQl9OQ0JcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiRVNSUkJfcGZhXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIkgzSzI3YWNfZWZmaWVcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiS0xGNF9lZmZpZVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA4IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJOQU5PR19kc2dcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiTkFOT0dfcGZhXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDEwIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJPQ1Q0X2VmZmllXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDExIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJPQ1Q0X2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiT0NUNF9wZmFcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTMgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIlNNQzFcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTQgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIlNPWDJfZWZmaWVcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTUgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIlNPWDJfZHNnXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDE2IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJTT1gyX3BmYVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxNyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiVEJQXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxuXG5cblxuXG5kYXRhIDwtIGJpbmRfcm93cyh0ZW1wMSwgdGVtcDIsIHRlbXAzLCB0ZW1wNCwgdGVtcDUsXG4gICAgICAgICB0ZW1wNiwgdGVtcDcsIHRlbXA4LCB0ZW1wOSwgdGVtcDEwLFxuICAgICAgICAgdGVtcDExLCB0ZW1wMTIsIHRlbXAxMywgdGVtcDE0LCB0ZW1wMTUsIHRlbXAxNiAsdGVtcDE3KVxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFwidGFyZ2V0XCIpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcInRhcmdldFwiKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCA1KSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcImJsdWVcIiwgXCJ3aGl0ZVwiLCBcInJlZFwiKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFwiT2RkcyBSYXRpb1wiLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcIm4ucy5cIiwgc3ByaW50ZihcIiUuMmVcIiwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcIkludGVyZXN0XCIsXG4gICAgICAgIHJvd190aXRsZSA9IFwiVGFyZ2V0XCIsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiwgMywgNCwgNSksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcIjBcIiwgXCIxXCIsIFwiMlwiLCBcIjNcIiwgXCI0XCIsIFwiNVwiKSkpXG5cbmBgYCJ9 -->\n\n```r\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTarget(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTarget(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTarget(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTarget(\\ESRRB_NCB\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTarget(\\ESRRB_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTarget(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTarget(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTarget(\\NANOG_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTarget(\\OCT4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp11 <- runFisherExactCombinationTarget(\\OCT4_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp12 <- runFisherExactCombinationTarget(\\OCT4_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp13 <- runFisherExactCombinationTarget(\\SMC1\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp14 <- runFisherExactCombinationTarget(\\SOX2_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp15 <- runFisherExactCombinationTarget(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp16 <- runFisherExactCombinationTarget(\\SOX2_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp17 <- runFisherExactCombinationTarget(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10,\n         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 5), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\, \\4\\, \\5\\)))\n\n```\n\n<!-- rnb-source-end -->\n"} -->
#### Importing loops of target
temp1 <- runFisherExactCombinationTarget(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget(\ESRRB_NCB\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget(\ESRRB_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget(\NANOG_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget(\OCT4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp11 <- runFisherExactCombinationTarget(\OCT4_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp12 <- runFisherExactCombinationTarget(\OCT4_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp13 <- runFisherExactCombinationTarget(\SMC1\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp14 <- runFisherExactCombinationTarget(\SOX2_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp15 <- runFisherExactCombinationTarget(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp16 <- runFisherExactCombinationTarget(\SOX2_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp17 <- runFisherExactCombinationTarget(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10,
         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 5), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), 
                                    labels = c(\0\, \1\, \2\, \3\, \4\, \5\)))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgdGFyZ2V0XG50ZW1wMSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcQVRBQ19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAyIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxDVENGXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDMgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEVTUlJCX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA0IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxFU1JSQl9OQ0JcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcRVNSUkJfcGZhXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEgzSzI3YWNfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcS0xGNF9lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA4IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxOQU5PR19kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcTkFOT0dfcGZhXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDEwIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDExIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcT0NUNF9wZmFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTMgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFNNQzFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTQgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFNPWDJfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTUgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFNPWDJfZHNnXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDE2IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxTT1gyX3BmYVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxNyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcVEJQXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxuXG5cblxuXG5kYXRhIDwtIGJpbmRfcm93cyh0ZW1wMSwgdGVtcDIsIHRlbXAzLCB0ZW1wNCwgdGVtcDUsXG4gICAgICAgICB0ZW1wNiwgdGVtcDcsIHRlbXA4LCB0ZW1wOSwgdGVtcDEwLFxuICAgICAgICAgdGVtcDExLCB0ZW1wMTIsIHRlbXAxMywgdGVtcDE0LCB0ZW1wMTUsIHRlbXAxNiAsdGVtcDE3KVxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCA1KSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFxcT2RkcyBSYXRpb1xcLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcXG4ucy5cXCwgc3ByaW50ZihcXCUuMmVcXCwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcXEludGVyZXN0XFwsXG4gICAgICAgIHJvd190aXRsZSA9IFxcVGFyZ2V0XFwsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiwgMywgNCwgNSksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcXDBcXCwgXFwxXFwsIFxcMlxcLCBcXDNcXCwgXFw0XFwsIFxcNVxcKSkpXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTarget(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTarget(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTarget(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTarget(\\ESRRB_NCB\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTarget(\\ESRRB_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTarget(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTarget(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTarget(\\NANOG_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTarget(\\OCT4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp11 <- runFisherExactCombinationTarget(\\OCT4_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp12 <- runFisherExactCombinationTarget(\\OCT4_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp13 <- runFisherExactCombinationTarget(\\SMC1\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp14 <- runFisherExactCombinationTarget(\\SOX2_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp15 <- runFisherExactCombinationTarget(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp16 <- runFisherExactCombinationTarget(\\SOX2_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp17 <- runFisherExactCombinationTarget(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10,\n         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 5), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\, \\4\\, \\5\\)))\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgdGFyZ2V0XG50ZW1wMSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcQVRBQ19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAyIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxDVENGXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDMgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEVTUlJCX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA0IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxFU1JSQl9OQ0JcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcRVNSUkJfcGZhXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEgzSzI3YWNfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcS0xGNF9lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA4IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxOQU5PR19kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcTkFOT0dfcGZhXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDEwIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDExIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcT0NUNF9wZmFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTMgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFNNQzFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTQgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFNPWDJfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTUgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFNPWDJfZHNnXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDE2IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxTT1gyX3BmYVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxNyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcVEJQXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxuXG5cblxuXG5kYXRhIDwtIGJpbmRfcm93cyh0ZW1wMSwgdGVtcDIsIHRlbXAzLCB0ZW1wNCwgdGVtcDUsXG4gICAgICAgICB0ZW1wNiwgdGVtcDcsIHRlbXA4LCB0ZW1wOSwgdGVtcDEwLFxuICAgICAgICAgdGVtcDExLCB0ZW1wMTIsIHRlbXAxMywgdGVtcDE0LCB0ZW1wMTUsIHRlbXAxNiAsdGVtcDE3KVxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCA1KSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFxcT2RkcyBSYXRpb1xcLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcXG4ucy5cXCwgc3ByaW50ZihcXCUuMmVcXCwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcXEludGVyZXN0XFwsXG4gICAgICAgIHJvd190aXRsZSA9IFxcVGFyZ2V0XFwsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiwgMywgNCwgNSksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcXDBcXCwgXFwxXFwsIFxcMlxcLCBcXDNcXCwgXFw0XFwsIFxcNVxcKSkpXG5cbmBgYFxuYGBgIn0= -->

```r
```r
#### Importing loops of target
temp1 <- runFisherExactCombinationTarget(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget(\ESRRB_NCB\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget(\ESRRB_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget(\NANOG_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget(\OCT4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp11 <- runFisherExactCombinationTarget(\OCT4_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp12 <- runFisherExactCombinationTarget(\OCT4_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp13 <- runFisherExactCombinationTarget(\SMC1\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp14 <- runFisherExactCombinationTarget(\SOX2_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp15 <- runFisherExactCombinationTarget(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp16 <- runFisherExactCombinationTarget(\SOX2_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp17 <- runFisherExactCombinationTarget(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10,
         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 5), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), 
                                    labels = c(\0\, \1\, \2\, \3\, \4\, \5\)))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

###### Figure - all targets

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG4jIyMjIEltcG9ydGluZyBsb29wcyBvZiB0YXJnZXRcbnRlbXAxIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcIkFUQUNfZWZmaWVcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXCJDVENGXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDMgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFwiRVNSUkJfZHNnXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDQgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFwiRVNSUkJfTkNCXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDUgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFwiRVNSUkJfcGZhXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFwiSDNLMjdhY19lZmZpZVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcIktMRjRfZWZmaWVcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXCJOQU5PR19kc2dcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXCJOQU5PR19wZmFcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTAgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFwiT0NUNF9lZmZpZVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXCJPQ1Q0X2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXCJPQ1Q0X3BmYVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXCJTTUMxXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDE0IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcIlNPWDJfZWZmaWVcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTUgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFwiU09YMl9kc2dcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFwiU09YMl9wZmFcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTcgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFwiVEJQXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxuXG5cblxuXG5kYXRhIDwtIGJpbmRfcm93cyh0ZW1wMSwgdGVtcDIsIHRlbXAzLCB0ZW1wNCwgdGVtcDUsXG4gICAgICAgICB0ZW1wNiwgdGVtcDcsIHRlbXA4LCB0ZW1wOSwgdGVtcDEwLFxuICAgICAgICAgdGVtcDExLCB0ZW1wMTIsIHRlbXAxMywgdGVtcDE0LCB0ZW1wMTUsIHRlbXAxNiAsdGVtcDE3KVxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFwidGFyZ2V0XCIpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcInRhcmdldFwiKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAzKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcImJsdWVcIiwgXCJ3aGl0ZVwiLCBcInJlZFwiKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFwiT2RkcyBSYXRpb1wiLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcIm4ucy5cIiwgc3ByaW50ZihcIiUuMmVcIiwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcIkludGVyZXN0XCIsXG4gICAgICAgIHJvd190aXRsZSA9IFwiVGFyZ2V0XCIsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcIjBcIiwgXCIxXCIsIFwiMlwiLCBcIjNcIikpKVxuXG5gYGAifQ== -->\n\n```r\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTargetRetained(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTargetRetained(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTargetRetained(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTargetRetained(\\ESRRB_NCB\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTargetRetained(\\ESRRB_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTargetRetained(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTargetRetained(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTargetRetained(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTargetRetained(\\NANOG_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTargetRetained(\\OCT4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp11 <- runFisherExactCombinationTargetRetained(\\OCT4_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp12 <- runFisherExactCombinationTargetRetained(\\OCT4_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp13 <- runFisherExactCombinationTargetRetained(\\SMC1\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp14 <- runFisherExactCombinationTargetRetained(\\SOX2_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp15 <- runFisherExactCombinationTargetRetained(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp16 <- runFisherExactCombinationTargetRetained(\\SOX2_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp17 <- runFisherExactCombinationTargetRetained(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10,\n         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 3), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\)))\n\n```\n\n<!-- rnb-source-end -->\n"} -->

#### Importing loops of target
temp1 <- runFisherExactCombinationTargetRetained(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTargetRetained(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTargetRetained(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTargetRetained(\ESRRB_NCB\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTargetRetained(\ESRRB_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTargetRetained(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTargetRetained(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTargetRetained(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTargetRetained(\NANOG_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTargetRetained(\OCT4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp11 <- runFisherExactCombinationTargetRetained(\OCT4_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp12 <- runFisherExactCombinationTargetRetained(\OCT4_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp13 <- runFisherExactCombinationTargetRetained(\SMC1\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp14 <- runFisherExactCombinationTargetRetained(\SOX2_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp15 <- runFisherExactCombinationTargetRetained(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp16 <- runFisherExactCombinationTargetRetained(\SOX2_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp17 <- runFisherExactCombinationTargetRetained(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10,
         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 3), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c(\0\, \1\, \2\, \3\)))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG4jIyMjIEltcG9ydGluZyBsb29wcyBvZiB0YXJnZXRcbnRlbXAxIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcXEFUQUNfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxDVENGXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDMgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcRVNSUkJfZHNnXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDQgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcRVNSUkJfTkNCXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDUgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcRVNSUkJfcGZhXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcSDNLMjdhY19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcXEtMRjRfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxOQU5PR19kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxOQU5PR19wZmFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTAgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcT0NUNF9lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxPQ1Q0X2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxPQ1Q0X3BmYVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxTTUMxXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDE0IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcXFNPWDJfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTUgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcU09YMl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcU09YMl9wZmFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTcgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcVEJQXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxuXG5cblxuXG5kYXRhIDwtIGJpbmRfcm93cyh0ZW1wMSwgdGVtcDIsIHRlbXAzLCB0ZW1wNCwgdGVtcDUsXG4gICAgICAgICB0ZW1wNiwgdGVtcDcsIHRlbXA4LCB0ZW1wOSwgdGVtcDEwLFxuICAgICAgICAgdGVtcDExLCB0ZW1wMTIsIHRlbXAxMywgdGVtcDE0LCB0ZW1wMTUsIHRlbXAxNiAsdGVtcDE3KVxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAzKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFxcT2RkcyBSYXRpb1xcLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcXG4ucy5cXCwgc3ByaW50ZihcXCUuMmVcXCwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcXEludGVyZXN0XFwsXG4gICAgICAgIHJvd190aXRsZSA9IFxcVGFyZ2V0XFwsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcXDBcXCwgXFwxXFwsIFxcMlxcLCBcXDNcXCkpKVxuXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTargetRetained(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTargetRetained(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTargetRetained(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTargetRetained(\\ESRRB_NCB\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTargetRetained(\\ESRRB_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTargetRetained(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTargetRetained(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTargetRetained(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTargetRetained(\\NANOG_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTargetRetained(\\OCT4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp11 <- runFisherExactCombinationTargetRetained(\\OCT4_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp12 <- runFisherExactCombinationTargetRetained(\\OCT4_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp13 <- runFisherExactCombinationTargetRetained(\\SMC1\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp14 <- runFisherExactCombinationTargetRetained(\\SOX2_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp15 <- runFisherExactCombinationTargetRetained(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp16 <- runFisherExactCombinationTargetRetained(\\SOX2_pfa\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp17 <- runFisherExactCombinationTargetRetained(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10,\n         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 3), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\)))\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG4jIyMjIEltcG9ydGluZyBsb29wcyBvZiB0YXJnZXRcbnRlbXAxIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcXEFUQUNfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxDVENGXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDMgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcRVNSUkJfZHNnXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDQgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcRVNSUkJfTkNCXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDUgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcRVNSUkJfcGZhXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcSDNLMjdhY19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcXEtMRjRfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxOQU5PR19kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxOQU5PR19wZmFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTAgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcT0NUNF9lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxPQ1Q0X2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxPQ1Q0X3BmYVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxTTUMxXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDE0IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcXFNPWDJfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTUgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcU09YMl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcU09YMl9wZmFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTcgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcVEJQXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxuXG5cblxuXG5kYXRhIDwtIGJpbmRfcm93cyh0ZW1wMSwgdGVtcDIsIHRlbXAzLCB0ZW1wNCwgdGVtcDUsXG4gICAgICAgICB0ZW1wNiwgdGVtcDcsIHRlbXA4LCB0ZW1wOSwgdGVtcDEwLFxuICAgICAgICAgdGVtcDExLCB0ZW1wMTIsIHRlbXAxMywgdGVtcDE0LCB0ZW1wMTUsIHRlbXAxNiAsdGVtcDE3KVxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAzKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFxcT2RkcyBSYXRpb1xcLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcXG4ucy5cXCwgc3ByaW50ZihcXCUuMmVcXCwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcXEludGVyZXN0XFwsXG4gICAgICAgIHJvd190aXRsZSA9IFxcVGFyZ2V0XFwsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcXDBcXCwgXFwxXFwsIFxcMlxcLCBcXDNcXCkpKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r

#### Importing loops of target
temp1 <- runFisherExactCombinationTargetRetained(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTargetRetained(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTargetRetained(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTargetRetained(\ESRRB_NCB\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTargetRetained(\ESRRB_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTargetRetained(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTargetRetained(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTargetRetained(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTargetRetained(\NANOG_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTargetRetained(\OCT4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp11 <- runFisherExactCombinationTargetRetained(\OCT4_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp12 <- runFisherExactCombinationTargetRetained(\OCT4_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp13 <- runFisherExactCombinationTargetRetained(\SMC1\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp14 <- runFisherExactCombinationTargetRetained(\SOX2_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp15 <- runFisherExactCombinationTargetRetained(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp16 <- runFisherExactCombinationTargetRetained(\SOX2_pfa\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp17 <- runFisherExactCombinationTargetRetained(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10,
         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 3), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c(\0\, \1\, \2\, \3\)))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

###### Retained & Lost

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIkFUQUNfZWZmaWVcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiQ1RDRlwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAzIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJFU1JSQl9kc2dcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiSDNLMjdhY19lZmZpZVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJLTEY0X2VmZmllXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIk5BTk9HX2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJPQ1Q0X2VmZmllXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDggPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIlNNQzFcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA5IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJTT1gyX2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiVEJQXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxuXG5cblxuXG5kYXRhIDwtIGJpbmRfcm93cyh0ZW1wMSwgdGVtcDIsIHRlbXAzLCB0ZW1wNCwgdGVtcDUsXG4gICAgICAgICB0ZW1wNiwgdGVtcDcsIHRlbXA4LCB0ZW1wOSwgdGVtcDEwKVxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFwidGFyZ2V0XCIpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcInRhcmdldFwiKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAzKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcImJsdWVcIiwgXCJ3aGl0ZVwiLCBcInJlZFwiKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFwiT2RkcyBSYXRpb1wiLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcIm4ucy5cIiwgc3ByaW50ZihcIiUuMmVcIiwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcIkludGVyZXN0XCIsXG4gICAgICAgIHJvd190aXRsZSA9IFwiVGFyZ2V0XCIsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcIjBcIiwgXCIxXCIsIFwiMlwiLCBcIjNcIikpKVxuXG5cblxuYGBgIn0= -->\n\n```r\n\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTarget(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTarget(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTarget(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTarget(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTarget(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTarget(\\OCT4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTarget(\\SMC1\\, interestName,\n                                     loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTarget(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTarget(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 3), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\)))\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->


#### Importing loops of target
temp1 <- runFisherExactCombinationTarget(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget(\OCT4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget(\SMC1\, interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 3), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c(\0\, \1\, \2\, \3\)))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEFUQUNfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcQ1RDRlxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAzIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxFU1JSQl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcSDNLMjdhY19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxLTEY0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE5BTk9HX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDggPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFNNQzFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA5IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxTT1gyX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcVEJQXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxuXG5cblxuXG5kYXRhIDwtIGJpbmRfcm93cyh0ZW1wMSwgdGVtcDIsIHRlbXAzLCB0ZW1wNCwgdGVtcDUsXG4gICAgICAgICB0ZW1wNiwgdGVtcDcsIHRlbXA4LCB0ZW1wOSwgdGVtcDEwKVxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAzKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFxcT2RkcyBSYXRpb1xcLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcXG4ucy5cXCwgc3ByaW50ZihcXCUuMmVcXCwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcXEludGVyZXN0XFwsXG4gICAgICAgIHJvd190aXRsZSA9IFxcVGFyZ2V0XFwsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcXDBcXCwgXFwxXFwsIFxcMlxcLCBcXDNcXCkpKVxuXG5cblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTarget(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTarget(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTarget(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTarget(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTarget(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTarget(\\OCT4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTarget(\\SMC1\\, interestName,\n                                     loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTarget(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTarget(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 3), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\)))\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEFUQUNfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcQ1RDRlxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAzIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxFU1JSQl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcSDNLMjdhY19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxLTEY0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE5BTk9HX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDggPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFNNQzFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA5IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxTT1gyX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcVEJQXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxuXG5cblxuXG5kYXRhIDwtIGJpbmRfcm93cyh0ZW1wMSwgdGVtcDIsIHRlbXAzLCB0ZW1wNCwgdGVtcDUsXG4gICAgICAgICB0ZW1wNiwgdGVtcDcsIHRlbXA4LCB0ZW1wOSwgdGVtcDEwKVxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAzKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFxcT2RkcyBSYXRpb1xcLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcXG4ucy5cXCwgc3ByaW50ZihcXCUuMmVcXCwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcXEludGVyZXN0XFwsXG4gICAgICAgIHJvd190aXRsZSA9IFxcVGFyZ2V0XFwsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcXDBcXCwgXFwxXFwsIFxcMlxcLCBcXDNcXCkpKVxuXG5cblxuYGBgXG5gYGAifQ== -->

```r
```r


#### Importing loops of target
temp1 <- runFisherExactCombinationTarget(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget(\OCT4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget(\SMC1\, interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 3), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c(\0\, \1\, \2\, \3\)))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

######  Retained

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFwiQVRBQ19lZmZpZVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAyIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcIkNUQ0ZcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXCJFU1JSQl9kc2dcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXCJIM0syN2FjX2VmZmllXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDUgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFwiS0xGNF9lZmZpZVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA2IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcIk5BTk9HX2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcIk9DVDRfZWZmaWVcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXCJTTUMxXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXCJTT1gyX2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXCJUQlBcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG5cblxuXG5cbmRhdGEgPC0gYmluZF9yb3dzKHRlbXAxLCB0ZW1wMiwgdGVtcDMsIHRlbXA0LCB0ZW1wNSxcbiAgICAgICAgIHRlbXA2LCB0ZW1wNywgdGVtcDgsIHRlbXA5LCB0ZW1wMTApXG5cbiMgVmlzdWFsaXphdGlvblxubGlicmFyeShjaXJjbGl6ZSlcblxuaGVhdG1hcF9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgb2Rkc1JhdGlvKSAlPiVcbnBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBpbnRlcmVzdCwgdmFsdWVzX2Zyb20gPSBvZGRzUmF0aW8pICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXCJ0YXJnZXRcIilcblxucHZhbHVlX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGludGVyZXN0LCBwdmFsdWUpICU+JVxuICBwaXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gcHZhbHVlKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFwidGFyZ2V0XCIpXG5cbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEsIDMpLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFwiYmx1ZVwiLCBcIndoaXRlXCIsIFwicmVkXCIpKVxuXG5IZWF0bWFwKGFzLm1hdHJpeChoZWF0bWFwX2RhdGEpLFxuICAgICAgICBuYW1lID0gXCJPZGRzIFJhdGlvXCIsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4sXG4gICAgICAgICMgQWRkIGFubm90YXRpb24gZm9yIHAtdmFsdWVzXG4gICAgICAgIGNlbGxfZnVuID0gZnVuY3Rpb24oaiwgaSwgeCwgeSwgd2lkdGgsIGhlaWdodCwgZmlsbCkge1xuICAgICAgICAgIHB2YWwgPC0gcHZhbHVlX2RhdGFbaSwgal1cbiAgICAgICAgICBsYWJlbCA8LSBpZmVsc2UocHZhbCA+IDAuMDUsIFwibi5zLlwiLCBzcHJpbnRmKFwiJS4yZVwiLCBwdmFsKSlcbiAgICAgICAgICBncmlkLnRleHQobGFiZWwsIHgsIHksIGdwID0gZ3Bhcihmb250c2l6ZSA9IDEwKSlcbiAgICAgICAgfSxcbiAgICAgICAgIyBDdXN0b21pemUgdGhlIGhlYXRtYXAgbGF5b3V0XG4gICAgICAgIGNsdXN0ZXJfcm93cyA9IFRSVUUsXG4gICAgICAgIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgICAgICAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsXG4gICAgICAgIGNvbHVtbl90aXRsZSA9IFwiSW50ZXJlc3RcIixcbiAgICAgICAgcm93X3RpdGxlID0gXCJUYXJnZXRcIixcbiAgICAgICAgaGVhdG1hcF9sZWdlbmRfcGFyYW0gPSBsaXN0KGF0ID0gYygwLCAxLCAyLCAzKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsYWJlbHMgPSBjKFwiMFwiLCBcIjFcIiwgXCIyXCIsIFwiM1wiKSkpXG5cblxuXG5gYGAifQ== -->\n\n```r\n\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTargetRetained(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTargetRetained(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTargetRetained(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTargetRetained(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTargetRetained(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTargetRetained(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTargetRetained(\\OCT4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTargetRetained(\\SMC1\\, interestName,\n                                     loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTargetRetained(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTargetRetained(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 3), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\)))\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->


#### Importing loops of target
temp1 <- runFisherExactCombinationTargetRetained(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTargetRetained(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTargetRetained(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTargetRetained(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTargetRetained(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTargetRetained(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTargetRetained(\OCT4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTargetRetained(\SMC1\, interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTargetRetained(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTargetRetained(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 3), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c(\0\, \1\, \2\, \3\)))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcQVRBQ19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAyIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcXENUQ0ZcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxFU1JSQl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxIM0syN2FjX2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDUgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcS0xGNF9lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA2IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcXE5BTk9HX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcXE9DVDRfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxTTUMxXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxTT1gyX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxUQlBcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG5cblxuXG5cbmRhdGEgPC0gYmluZF9yb3dzKHRlbXAxLCB0ZW1wMiwgdGVtcDMsIHRlbXA0LCB0ZW1wNSxcbiAgICAgICAgIHRlbXA2LCB0ZW1wNywgdGVtcDgsIHRlbXA5LCB0ZW1wMTApXG5cbiMgVmlzdWFsaXphdGlvblxubGlicmFyeShjaXJjbGl6ZSlcblxuaGVhdG1hcF9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgb2Rkc1JhdGlvKSAlPiVcbnBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBpbnRlcmVzdCwgdmFsdWVzX2Zyb20gPSBvZGRzUmF0aW8pICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFx0YXJnZXRcXClcblxucHZhbHVlX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGludGVyZXN0LCBwdmFsdWUpICU+JVxuICBwaXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gcHZhbHVlKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEsIDMpLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFxcYmx1ZVxcLCBcXHdoaXRlXFwsIFxccmVkXFwpKVxuXG5IZWF0bWFwKGFzLm1hdHJpeChoZWF0bWFwX2RhdGEpLFxuICAgICAgICBuYW1lID0gXFxPZGRzIFJhdGlvXFwsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4sXG4gICAgICAgICMgQWRkIGFubm90YXRpb24gZm9yIHAtdmFsdWVzXG4gICAgICAgIGNlbGxfZnVuID0gZnVuY3Rpb24oaiwgaSwgeCwgeSwgd2lkdGgsIGhlaWdodCwgZmlsbCkge1xuICAgICAgICAgIHB2YWwgPC0gcHZhbHVlX2RhdGFbaSwgal1cbiAgICAgICAgICBsYWJlbCA8LSBpZmVsc2UocHZhbCA+IDAuMDUsIFxcbi5zLlxcLCBzcHJpbnRmKFxcJS4yZVxcLCBwdmFsKSlcbiAgICAgICAgICBncmlkLnRleHQobGFiZWwsIHgsIHksIGdwID0gZ3Bhcihmb250c2l6ZSA9IDEwKSlcbiAgICAgICAgfSxcbiAgICAgICAgIyBDdXN0b21pemUgdGhlIGhlYXRtYXAgbGF5b3V0XG4gICAgICAgIGNsdXN0ZXJfcm93cyA9IFRSVUUsXG4gICAgICAgIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgICAgICAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsXG4gICAgICAgIGNvbHVtbl90aXRsZSA9IFxcSW50ZXJlc3RcXCxcbiAgICAgICAgcm93X3RpdGxlID0gXFxUYXJnZXRcXCxcbiAgICAgICAgaGVhdG1hcF9sZWdlbmRfcGFyYW0gPSBsaXN0KGF0ID0gYygwLCAxLCAyLCAzKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsYWJlbHMgPSBjKFxcMFxcLCBcXDFcXCwgXFwyXFwsIFxcM1xcKSkpXG5cblxuXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\n\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTargetRetained(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTargetRetained(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTargetRetained(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTargetRetained(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTargetRetained(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTargetRetained(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTargetRetained(\\OCT4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTargetRetained(\\SMC1\\, interestName,\n                                     loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTargetRetained(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTargetRetained(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 3), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\)))\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcQVRBQ19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAyIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcXENUQ0ZcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMyA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxFU1JSQl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxIM0syN2FjX2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDUgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldFJldGFpbmVkKFxcS0xGNF9lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA2IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcXE5BTk9HX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXRSZXRhaW5lZChcXE9DVDRfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxTTUMxXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxTT1gyX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0UmV0YWluZWQoXFxUQlBcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG5cblxuXG5cbmRhdGEgPC0gYmluZF9yb3dzKHRlbXAxLCB0ZW1wMiwgdGVtcDMsIHRlbXA0LCB0ZW1wNSxcbiAgICAgICAgIHRlbXA2LCB0ZW1wNywgdGVtcDgsIHRlbXA5LCB0ZW1wMTApXG5cbiMgVmlzdWFsaXphdGlvblxubGlicmFyeShjaXJjbGl6ZSlcblxuaGVhdG1hcF9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgb2Rkc1JhdGlvKSAlPiVcbnBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBpbnRlcmVzdCwgdmFsdWVzX2Zyb20gPSBvZGRzUmF0aW8pICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFx0YXJnZXRcXClcblxucHZhbHVlX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGludGVyZXN0LCBwdmFsdWUpICU+JVxuICBwaXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gcHZhbHVlKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEsIDMpLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFxcYmx1ZVxcLCBcXHdoaXRlXFwsIFxccmVkXFwpKVxuXG5IZWF0bWFwKGFzLm1hdHJpeChoZWF0bWFwX2RhdGEpLFxuICAgICAgICBuYW1lID0gXFxPZGRzIFJhdGlvXFwsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4sXG4gICAgICAgICMgQWRkIGFubm90YXRpb24gZm9yIHAtdmFsdWVzXG4gICAgICAgIGNlbGxfZnVuID0gZnVuY3Rpb24oaiwgaSwgeCwgeSwgd2lkdGgsIGhlaWdodCwgZmlsbCkge1xuICAgICAgICAgIHB2YWwgPC0gcHZhbHVlX2RhdGFbaSwgal1cbiAgICAgICAgICBsYWJlbCA8LSBpZmVsc2UocHZhbCA+IDAuMDUsIFxcbi5zLlxcLCBzcHJpbnRmKFxcJS4yZVxcLCBwdmFsKSlcbiAgICAgICAgICBncmlkLnRleHQobGFiZWwsIHgsIHksIGdwID0gZ3Bhcihmb250c2l6ZSA9IDEwKSlcbiAgICAgICAgfSxcbiAgICAgICAgIyBDdXN0b21pemUgdGhlIGhlYXRtYXAgbGF5b3V0XG4gICAgICAgIGNsdXN0ZXJfcm93cyA9IFRSVUUsXG4gICAgICAgIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgICAgICAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsXG4gICAgICAgIGNvbHVtbl90aXRsZSA9IFxcSW50ZXJlc3RcXCxcbiAgICAgICAgcm93X3RpdGxlID0gXFxUYXJnZXRcXCxcbiAgICAgICAgaGVhdG1hcF9sZWdlbmRfcGFyYW0gPSBsaXN0KGF0ID0gYygwLCAxLCAyLCAzKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsYWJlbHMgPSBjKFxcMFxcLCBcXDFcXCwgXFwyXFwsIFxcM1xcKSkpXG5cblxuXG5gYGBcbmBgYCJ9 -->

```r
```r


#### Importing loops of target
temp1 <- runFisherExactCombinationTargetRetained(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTargetRetained(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTargetRetained(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTargetRetained(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTargetRetained(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTargetRetained(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTargetRetained(\OCT4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTargetRetained(\SMC1\, interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTargetRetained(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTargetRetained(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 3), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c(\0\, \1\, \2\, \3\)))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Reg refined
###### Retained & Lost

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlCSmJYQnZjblJwYm1jZ2JHOXZjSE1nYjJZZ2FXNTBaWEpsYzNSY2JtbHVkR1Z5WlhOMFRtRnRaU0E4TFNCY0ltRnNiRXh2YjNCY0lseHVJeUJDUVVOTFIxSlBWVTVFSUd4dmIzQmNibUpoWTJ0bmNtOTFibVFnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5aGJHd3VZbVZrY0dWY0lpa3BYRzVpWVdOclozSnZkVzVrTG1keUlEd3RJQ2hsZUhSeVlXTjBRVzVqYUc5eUtHSmhZMnRuY205MWJtUXBLVnh1SXlCVlVDQnNiMjl3WEc1c2IyOXdMblZ3SUR3dElHWnlaV0ZrS0dobGNtVW9ZMjl1YzJWdWMzVnpSR2x5TENCY0ltTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsZllXeHNYMEUwT0RWMmMwUk5VMDlmVlZCZlpHbG1aakF1TWk1aVpXUndaVndpS1NsY2JteHZiM0F1ZFhBdVozSWdQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1MWNDa3BYRzRqSUU1UElHeHZiM0JjYm14dmIzQXVibThnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5aGJHeGZRVFE0TlhaelJFMVRUMTlPVDE5a2FXWm1NQzR5TG1KbFpIQmxYQ0lwS1Z4dWJHOXZjQzV1Ynk1bmNpQThMU0FvWlhoMGNtRmpkRUZ1WTJodmNpaHNiMjl3TG01dktTbGNiaU1nUkU5WFRpQnNiMjl3WEc1c2IyOXdMbVJ2ZDI0Z1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGd2lZMmh5YjIxdlgyTnZibk5mWVc1dWIwaHBaWEpoY21Ob2VWOWhiR3hmUVRRNE5YWnpSRTFUVDE5RVQxZE9YMlJwWm1Zd0xqSXVZbVZrY0dWY0lpa3BYRzVzYjI5d0xtUnZkMjR1WjNJZ1BDMGdLR1Y0ZEhKaFkzUkJibU5vYjNJb2JHOXZjQzVrYjNkdUtTbGNibUJnWUNKOSAtLT5cblxuYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgaW50ZXJlc3RcbmludGVyZXN0TmFtZSA8LSBcXGFsbExvb3BcXFxuIyBCQUNLR1JPVU5EIGxvb3BcbmJhY2tncm91bmQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGwuYmVkcGVcXCkpXG5iYWNrZ3JvdW5kLmdyIDwtIChleHRyYWN0QW5jaG9yKGJhY2tncm91bmQpKVxuIyBVUCBsb29wXG5sb29wLnVwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX0E0ODV2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSlcbmxvb3AudXAuZ3IgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG4jIE5PIGxvb3Bcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5uby5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbiMgRE9XTiBsb29wXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLmRvd24uZ3IgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5kb3duKSlcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
#### Importing loops of interest
interestName <- \allLoop\
# BACKGROUND loop
background <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all.bedpe\))
background.gr <- (extractAnchor(background))
# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe\))
loop.up.gr <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_NO_diff0.2.bedpe\))
loop.no.gr <- (extractAnchor(loop.no))
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe\))
loop.down.gr <- (extractAnchor(loop.down))



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeUJKYlhCdmNuUnBibWNnYkc5dmNITWdiMllnYVc1MFpYSmxjM1JjYm1sdWRHVnlaWE4wVG1GdFpTQThMU0JjWEdGc2JFeHZiM0JjWEZ4dUl5QkNRVU5MUjFKUFZVNUVJR3h2YjNCY2JtSmhZMnRuY205MWJtUWdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lVjloYkd3dVltVmtjR1ZjWENrcFhHNWlZV05yWjNKdmRXNWtMbWR5SUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0dKaFkydG5jbTkxYm1RcEtWeHVJeUJWVUNCc2IyOXdYRzVzYjI5d0xuVndJRHd0SUdaeVpXRmtLR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0JjWEdOb2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxmWVd4c1gwRTBPRFYyYzBSTlUwOWZWVkJmWkdsbVpqQXVNaTVpWldSd1pWeGNLU2xjYm14dmIzQXVkWEF1WjNJZ1BDMGdLR1Y0ZEhKaFkzUkJibU5vYjNJb2JHOXZjQzUxY0NrcFhHNGpJRTVQSUd4dmIzQmNibXh2YjNBdWJtOGdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lVjloYkd4ZlFUUTROWFp6UkUxVFQxOU9UMTlrYVdabU1DNHlMbUpsWkhCbFhGd3BLVnh1Ykc5dmNDNXVieTVuY2lBOExTQW9aWGgwY21GamRFRnVZMmh2Y2loc2IyOXdMbTV2S1NsY2JpTWdSRTlYVGlCc2IyOXdYRzVzYjI5d0xtUnZkMjRnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ4Y1kyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5aGJHeGZRVFE0TlhaelJFMVRUMTlFVDFkT1gyUnBabVl3TGpJdVltVmtjR1ZjWENrcFhHNXNiMjl3TG1SdmQyNHVaM0lnUEMwZ0tHVjRkSEpoWTNSQmJtTm9iM0lvYkc5dmNDNWtiM2R1S1NsY2JtQmdZRnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbmBgYHJcbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIGludGVyZXN0XG5pbnRlcmVzdE5hbWUgPC0gXFxhbGxMb29wXFxcbiMgQkFDS0dST1VORCBsb29wXG5iYWNrZ3JvdW5kIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsLmJlZHBlXFwpKVxuYmFja2dyb3VuZC5nciA8LSAoZXh0cmFjdEFuY2hvcihiYWNrZ3JvdW5kKSlcbiMgVVAgbG9vcFxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9BNDg1dnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLnVwLmdyIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXApKVxuIyBOTyBsb29wXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX0E0ODV2c0RNU09fTk9fZGlmZjAuMi5iZWRwZVxcKSlcbmxvb3Aubm8uZ3IgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5ubykpXG4jIERPV04gbG9vcFxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX0E0ODV2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5kb3duLmdyIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuZG93bikpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgaW50ZXJlc3RcbmludGVyZXN0TmFtZSA8LSBcXGFsbExvb3BcXFxuIyBCQUNLR1JPVU5EIGxvb3BcbmJhY2tncm91bmQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGwuYmVkcGVcXCkpXG5iYWNrZ3JvdW5kLmdyIDwtIChleHRyYWN0QW5jaG9yKGJhY2tncm91bmQpKVxuIyBVUCBsb29wXG5sb29wLnVwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX0E0ODV2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSlcbmxvb3AudXAuZ3IgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG4jIE5PIGxvb3Bcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5uby5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbiMgRE9XTiBsb29wXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLmRvd24uZ3IgPC0gKGV4dHJhY3RBbmNob3IobG9vcC5kb3duKSlcbmBgYFxuYGBgIn0= -->

```r
```r
#### Importing loops of interest
interestName <- \allLoop\
# BACKGROUND loop
background <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all.bedpe\))
background.gr <- (extractAnchor(background))
# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe\))
loop.up.gr <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_NO_diff0.2.bedpe\))
loop.no.gr <- (extractAnchor(loop.no))
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe\))
loop.down.gr <- (extractAnchor(loop.down))
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

###### Retained

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIkFUQUNfZWZmaWVcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiQ1RDRlwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAzIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJFU1JSQl9kc2dcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiSDNLMjdhY19lZmZpZVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJLTEY0X2VmZmllXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIk5BTk9HX2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJPQ1Q0X2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA4IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJTTUMxXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiU09YMl9kc2dcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTAgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIlRCUFwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcblxuXG5cblxuZGF0YSA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyLCB0ZW1wMywgdGVtcDQsIHRlbXA1LFxuICAgICAgICAgdGVtcDYsIHRlbXA3LCB0ZW1wOCwgdGVtcDksIHRlbXAxMClcblxuIyBWaXN1YWxpemF0aW9uXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5oZWF0bWFwX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGludGVyZXN0LCBvZGRzUmF0aW8pICU+JVxucGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IG9kZHNSYXRpbykgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcInRhcmdldFwiKVxuXG5wdmFsdWVfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIHB2YWx1ZSkgJT4lXG4gIHBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBpbnRlcmVzdCwgdmFsdWVzX2Zyb20gPSBwdmFsdWUpICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXCJ0YXJnZXRcIilcblxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoMCwgMSwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgIGMoXCJibHVlXCIsIFwid2hpdGVcIiwgXCJyZWRcIikpXG5cbkhlYXRtYXAoYXMubWF0cml4KGhlYXRtYXBfZGF0YSksXG4gICAgICAgIG5hbWUgPSBcIk9kZHMgUmF0aW9cIixcbiAgICAgICAgY29sID0gY29sX2Z1bixcbiAgICAgICAgIyBBZGQgYW5ub3RhdGlvbiBmb3IgcC12YWx1ZXNcbiAgICAgICAgY2VsbF9mdW4gPSBmdW5jdGlvbihqLCBpLCB4LCB5LCB3aWR0aCwgaGVpZ2h0LCBmaWxsKSB7XG4gICAgICAgICAgcHZhbCA8LSBwdmFsdWVfZGF0YVtpLCBqXVxuICAgICAgICAgIGxhYmVsIDwtIGlmZWxzZShwdmFsID4gMC4wNSwgXCJuLnMuXCIsIHNwcmludGYoXCIlLjJlXCIsIHB2YWwpKVxuICAgICAgICAgIGdyaWQudGV4dChsYWJlbCwgeCwgeSwgZ3AgPSBncGFyKGZvbnRzaXplID0gMTApKVxuICAgICAgICB9LFxuICAgICAgICAjIEN1c3RvbWl6ZSB0aGUgaGVhdG1hcCBsYXlvdXRcbiAgICAgICAgY2x1c3Rlcl9yb3dzID0gVFJVRSxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY29sdW1uX3RpdGxlID0gXCJJbnRlcmVzdFwiLFxuICAgICAgICByb3dfdGl0bGUgPSBcIlRhcmdldFwiLFxuICAgICAgICBoZWF0bWFwX2xlZ2VuZF9wYXJhbSA9IGxpc3QoYXQgPSBjKDAsIDEsIDIsIDMpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxhYmVscyA9IGMoXCIwXCIsIFwiMVwiLCBcIjJcIiwgXCIzXCIpKSlcblxuYGBgIn0= -->\n\n```r\n\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTarget(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTarget(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTarget(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTarget(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTarget(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTarget(\\OCT4_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTarget(\\SMC1\\, interestName,\n                                     loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTarget(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTarget(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 3), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\)))\n\n```\n\n<!-- rnb-source-end -->\n"} -->


#### Importing loops of target
temp1 <- runFisherExactCombinationTarget(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget(\OCT4_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget(\SMC1\, interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 3), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c(\0\, \1\, \2\, \3\)))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEFUQUNfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcQ1RDRlxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAzIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxFU1JSQl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcSDNLMjdhY19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxLTEY0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE5BTk9HX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA4IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxTTUMxXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcU09YMl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTAgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFRCUFxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcblxuXG5cblxuZGF0YSA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyLCB0ZW1wMywgdGVtcDQsIHRlbXA1LFxuICAgICAgICAgdGVtcDYsIHRlbXA3LCB0ZW1wOCwgdGVtcDksIHRlbXAxMClcblxuIyBWaXN1YWxpemF0aW9uXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5oZWF0bWFwX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGludGVyZXN0LCBvZGRzUmF0aW8pICU+JVxucGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IG9kZHNSYXRpbykgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5wdmFsdWVfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIHB2YWx1ZSkgJT4lXG4gIHBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBpbnRlcmVzdCwgdmFsdWVzX2Zyb20gPSBwdmFsdWUpICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFx0YXJnZXRcXClcblxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoMCwgMSwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgIGMoXFxibHVlXFwsIFxcd2hpdGVcXCwgXFxyZWRcXCkpXG5cbkhlYXRtYXAoYXMubWF0cml4KGhlYXRtYXBfZGF0YSksXG4gICAgICAgIG5hbWUgPSBcXE9kZHMgUmF0aW9cXCxcbiAgICAgICAgY29sID0gY29sX2Z1bixcbiAgICAgICAgIyBBZGQgYW5ub3RhdGlvbiBmb3IgcC12YWx1ZXNcbiAgICAgICAgY2VsbF9mdW4gPSBmdW5jdGlvbihqLCBpLCB4LCB5LCB3aWR0aCwgaGVpZ2h0LCBmaWxsKSB7XG4gICAgICAgICAgcHZhbCA8LSBwdmFsdWVfZGF0YVtpLCBqXVxuICAgICAgICAgIGxhYmVsIDwtIGlmZWxzZShwdmFsID4gMC4wNSwgXFxuLnMuXFwsIHNwcmludGYoXFwlLjJlXFwsIHB2YWwpKVxuICAgICAgICAgIGdyaWQudGV4dChsYWJlbCwgeCwgeSwgZ3AgPSBncGFyKGZvbnRzaXplID0gMTApKVxuICAgICAgICB9LFxuICAgICAgICAjIEN1c3RvbWl6ZSB0aGUgaGVhdG1hcCBsYXlvdXRcbiAgICAgICAgY2x1c3Rlcl9yb3dzID0gVFJVRSxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY29sdW1uX3RpdGxlID0gXFxJbnRlcmVzdFxcLFxuICAgICAgICByb3dfdGl0bGUgPSBcXFRhcmdldFxcLFxuICAgICAgICBoZWF0bWFwX2xlZ2VuZF9wYXJhbSA9IGxpc3QoYXQgPSBjKDAsIDEsIDIsIDMpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxhYmVscyA9IGMoXFwwXFwsIFxcMVxcLCBcXDJcXCwgXFwzXFwpKSlcblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTarget(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTarget(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTarget(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTarget(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTarget(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTarget(\\OCT4_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTarget(\\SMC1\\, interestName,\n                                     loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTarget(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTarget(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 3), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\)))\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEFUQUNfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcQ1RDRlxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAzIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxFU1JSQl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcSDNLMjdhY19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxLTEY0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE5BTk9HX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA4IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxTTUMxXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wOSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcU09YMl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMTAgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFRCUFxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcblxuXG5cblxuZGF0YSA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyLCB0ZW1wMywgdGVtcDQsIHRlbXA1LFxuICAgICAgICAgdGVtcDYsIHRlbXA3LCB0ZW1wOCwgdGVtcDksIHRlbXAxMClcblxuIyBWaXN1YWxpemF0aW9uXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5oZWF0bWFwX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGludGVyZXN0LCBvZGRzUmF0aW8pICU+JVxucGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IG9kZHNSYXRpbykgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5wdmFsdWVfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIHB2YWx1ZSkgJT4lXG4gIHBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBpbnRlcmVzdCwgdmFsdWVzX2Zyb20gPSBwdmFsdWUpICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFx0YXJnZXRcXClcblxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoMCwgMSwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgIGMoXFxibHVlXFwsIFxcd2hpdGVcXCwgXFxyZWRcXCkpXG5cbkhlYXRtYXAoYXMubWF0cml4KGhlYXRtYXBfZGF0YSksXG4gICAgICAgIG5hbWUgPSBcXE9kZHMgUmF0aW9cXCxcbiAgICAgICAgY29sID0gY29sX2Z1bixcbiAgICAgICAgIyBBZGQgYW5ub3RhdGlvbiBmb3IgcC12YWx1ZXNcbiAgICAgICAgY2VsbF9mdW4gPSBmdW5jdGlvbihqLCBpLCB4LCB5LCB3aWR0aCwgaGVpZ2h0LCBmaWxsKSB7XG4gICAgICAgICAgcHZhbCA8LSBwdmFsdWVfZGF0YVtpLCBqXVxuICAgICAgICAgIGxhYmVsIDwtIGlmZWxzZShwdmFsID4gMC4wNSwgXFxuLnMuXFwsIHNwcmludGYoXFwlLjJlXFwsIHB2YWwpKVxuICAgICAgICAgIGdyaWQudGV4dChsYWJlbCwgeCwgeSwgZ3AgPSBncGFyKGZvbnRzaXplID0gMTApKVxuICAgICAgICB9LFxuICAgICAgICAjIEN1c3RvbWl6ZSB0aGUgaGVhdG1hcCBsYXlvdXRcbiAgICAgICAgY2x1c3Rlcl9yb3dzID0gVFJVRSxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY29sdW1uX3RpdGxlID0gXFxJbnRlcmVzdFxcLFxuICAgICAgICByb3dfdGl0bGUgPSBcXFRhcmdldFxcLFxuICAgICAgICBoZWF0bWFwX2xlZ2VuZF9wYXJhbSA9IGxpc3QoYXQgPSBjKDAsIDEsIDIsIDMpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxhYmVscyA9IGMoXFwwXFwsIFxcMVxcLCBcXDJcXCwgXFwzXFwpKSlcblxuYGBgXG5gYGAifQ== -->

```r
```r


#### Importing loops of target
temp1 <- runFisherExactCombinationTarget(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget(\OCT4_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget(\SMC1\, interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 3), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c(\0\, \1\, \2\, \3\)))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

## [2.24.2] Checking bookmarking - A485
#### All loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeU1qSXlCSmJYQnZjblJwYm1jZ2JHOXZjSE1nYjJZZ2FXNTBaWEpsYzNSY2JtbHVkR1Z5WlhOMFRtRnRaU0E4TFNCY0luSmxaMHh2YjNCY0lseHVJeUJDUVVOTFIxSlBWVTVFSUd4dmIzQmNibUpoWTJ0bmNtOTFibVFnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5d1pTMXdaUzVpWldSd1pWd2lLU2xjYm1KaFkydG5jbTkxYm1RdVozSWdQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9ZbUZqYTJkeWIzVnVaQ2twWEc0aklGVlFJR3h2YjNCY2JteHZiM0F1ZFhBZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGd2lZMmh5YjIxdlgyTnZibk5mWVc1dWIwaHBaWEpoY21Ob2VWOXdaUzF3WlY5Qk5EZzFkbk5FVFZOUFgxVlFYMlJwWm1Zd0xqSXVZbVZrY0dWY0lpa3BYRzVzYjI5d0xuVndMbWR5SUR3dElDaGxlSFJ5WVdOMFFXNWphRzl5S0d4dmIzQXVkWEFwS1Z4dUl5Qk9UeUJzYjI5d1hHNXNiMjl3TG01dklEd3RJR1p5WldGa0tHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQmNJbU5vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGZjR1V0Y0dWZlFUUTROWFp6UkUxVFQxOU9UMTlrYVdabU1DNHlMbUpsWkhCbFhDSXBLVnh1Ykc5dmNDNXVieTVuY2lBOExTQW9aWGgwY21GamRFRnVZMmh2Y2loc2IyOXdMbTV2S1NsY2JpTWdSRTlYVGlCc2IyOXdYRzVzYjI5d0xtUnZkMjRnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ3aVkyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5d1pTMXdaVjlCTkRnMWRuTkVUVk5QWDBSUFYwNWZaR2xtWmpBdU1pNWlaV1J3WlZ3aUtTbGNibXh2YjNBdVpHOTNiaTVuY2lBOExTQW9aWGgwY21GamRFRnVZMmh2Y2loc2IyOXdMbVJ2ZDI0cEtWeHVYRzVtZDNKcGRHVW9ZWE5mZEdsaVlteGxLR3h2YjNBdWRYQXVaM0lwSUNVK0pTQmtjR3g1Y2pvNmMyVnNaV04wS0hObGNXNWhiV1Z6TENCemRHRnlkQ3dnWlc1a0tTd2dhR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRndpWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lVjl3WlMxd1pWOUJORGcxZG5ORVRWTlBYMVZRWDJScFptWXdMakl1WVc1amFHOXlMbUpsWkZ3aUtTd2dZMjlzTG01aGJXVnpJRDBnUmtGTVUwVXNJSE5sY0NBOUlGd2lYRngwWENJcFhHNW1kM0pwZEdVb1lYTmZkR2xpWW14bEtHeHZiM0F1Ym04dVozSXBJQ1UrSlNCa2NHeDVjam82YzJWc1pXTjBLSE5sY1c1aGJXVnpMQ0J6ZEdGeWRDd2daVzVrS1N3Z2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGd2lZMmh5YjIxdlgyTnZibk5mWVc1dWIwaHBaWEpoY21Ob2VWOXdaUzF3WlY5Qk5EZzFkbk5FVFZOUFgwNVBYMlJwWm1Zd0xqSXVZVzVqYUc5eUxtSmxaRndpS1N3Z1kyOXNMbTVoYldWeklEMGdSa0ZNVTBVc0lITmxjQ0E5SUZ3aVhGeDBYQ0lwWEc1bWQzSnBkR1VvWVhOZmRHbGlZbXhsS0d4dmIzQXVaRzkzYmk1bmNpa2dKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9jMlZ4Ym1GdFpYTXNJSE4wWVhKMExDQmxibVFwTENCb1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z1hDSmphSEp2Ylc5ZlkyOXVjMTloYm01dlNHbGxjbUZ5WTJoNVgzQmxMWEJsWDBFME9EVjJjMFJOVTA5ZlJFOVhUbDlrYVdabU1DNHlMbUZ1WTJodmNpNWlaV1JjSWlrc0lHTnZiQzV1WVcxbGN5QTlJRVpCVEZORkxDQnpaWEFnUFNCY0lseGNkRndpS1Z4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG4jIyMjIEltcG9ydGluZyBsb29wcyBvZiBpbnRlcmVzdFxuaW50ZXJlc3ROYW1lIDwtIFxccmVnTG9vcFxcXG4jIEJBQ0tHUk9VTkQgbG9vcFxuYmFja2dyb3VuZCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlLmJlZHBlXFwpKVxuYmFja2dyb3VuZC5nciA8LSAoZXh0cmFjdEFuY2hvcihiYWNrZ3JvdW5kKSlcbiMgVVAgbG9vcFxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSlcbmxvb3AudXAuZ3IgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG4jIE5PIGxvb3Bcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLm5vLmdyIDwtIChleHRyYWN0QW5jaG9yKGxvb3Aubm8pKVxuIyBET1dOIGxvb3Bcbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5kb3duLmdyIDwtIChleHRyYWN0QW5jaG9yKGxvb3AuZG93bikpXG5cbmZ3cml0ZShhc190aWJibGUobG9vcC51cC5ncikgJT4lIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQpLCBoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fVVBfZGlmZjAuMi5hbmNob3IuYmVkXFwpLCBjb2wubmFtZXMgPSBGQUxTRSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZShhc190aWJibGUobG9vcC5uby5ncikgJT4lIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQpLCBoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fTk9fZGlmZjAuMi5hbmNob3IuYmVkXFwpLCBjb2wubmFtZXMgPSBGQUxTRSwgc2VwID0gXFxcXHRcXClcbmZ3cml0ZShhc190aWJibGUobG9vcC5kb3duLmdyKSAlPiUgZHBseXI6OnNlbGVjdChzZXFuYW1lcywgc3RhcnQsIGVuZCksIGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19ET1dOX2RpZmYwLjIuYW5jaG9yLmJlZFxcKSwgY29sLm5hbWVzID0gRkFMU0UsIHNlcCA9IFxcXFx0XFwpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
#### Importing loops of interest
interestName <- \regLoop\
# BACKGROUND loop
background <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\))
background.gr <- (extractAnchor(background))
# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\))
loop.up.gr <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\))
loop.no.gr <- (extractAnchor(loop.no))
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\))
loop.down.gr <- (extractAnchor(loop.down))

fwrite(as_tibble(loop.up.gr) %>% dplyr::select(seqnames, start, end), here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.anchor.bed\), col.names = FALSE, sep = \\t\)
fwrite(as_tibble(loop.no.gr) %>% dplyr::select(seqnames, start, end), here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.anchor.bed\), col.names = FALSE, sep = \\t\)
fwrite(as_tibble(loop.down.gr) %>% dplyr::select(seqnames, start, end), here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.anchor.bed\), col.names = FALSE, sep = \\t\)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5TWpJeUJKYlhCdmNuUnBibWNnYkc5dmNITWdiMllnYVc1MFpYSmxjM1JjYm1sdWRHVnlaWE4wVG1GdFpTQThMU0JjWEhKbFoweHZiM0JjWEZ4dUl5QkNRVU5MUjFKUFZVNUVJR3h2YjNCY2JtSmhZMnRuY205MWJtUWdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lVjl3WlMxd1pTNWlaV1J3WlZ4Y0tTbGNibUpoWTJ0bmNtOTFibVF1WjNJZ1BDMGdLR1Y0ZEhKaFkzUkJibU5vYjNJb1ltRmphMmR5YjNWdVpDa3BYRzRqSUZWUUlHeHZiM0JjYm14dmIzQXVkWEFnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ4Y1kyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5d1pTMXdaVjlCTkRnMWRuTkVUVk5QWDFWUVgyUnBabVl3TGpJdVltVmtjR1ZjWENrcFhHNXNiMjl3TG5Wd0xtZHlJRHd0SUNobGVIUnlZV04wUVc1amFHOXlLR3h2YjNBdWRYQXBLVnh1SXlCT1R5QnNiMjl3WEc1c2IyOXdMbTV2SUR3dElHWnlaV0ZrS0dobGNtVW9ZMjl1YzJWdWMzVnpSR2x5TENCY1hHTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsZmNHVXRjR1ZmUVRRNE5YWnpSRTFUVDE5T1QxOWthV1ptTUM0eUxtSmxaSEJsWEZ3cEtWeHViRzl2Y0M1dWJ5NW5jaUE4TFNBb1pYaDBjbUZqZEVGdVkyaHZjaWhzYjI5d0xtNXZLU2xjYmlNZ1JFOVhUaUJzYjI5d1hHNXNiMjl3TG1SdmQyNGdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRnhjWTJoeWIyMXZYMk52Ym5OZllXNXViMGhwWlhKaGNtTm9lVjl3WlMxd1pWOUJORGcxZG5ORVRWTlBYMFJQVjA1ZlpHbG1aakF1TWk1aVpXUndaVnhjS1NsY2JteHZiM0F1Wkc5M2JpNW5jaUE4TFNBb1pYaDBjbUZqZEVGdVkyaHZjaWhzYjI5d0xtUnZkMjRwS1Z4dVhHNW1kM0pwZEdVb1lYTmZkR2xpWW14bEtHeHZiM0F1ZFhBdVozSXBJQ1UrSlNCa2NHeDVjam82YzJWc1pXTjBLSE5sY1c1aGJXVnpMQ0J6ZEdGeWRDd2daVzVrS1N3Z2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGeGNZMmh5YjIxdlgyTnZibk5mWVc1dWIwaHBaWEpoY21Ob2VWOXdaUzF3WlY5Qk5EZzFkbk5FVFZOUFgxVlFYMlJwWm1Zd0xqSXVZVzVqYUc5eUxtSmxaRnhjS1N3Z1kyOXNMbTVoYldWeklEMGdSa0ZNVTBVc0lITmxjQ0E5SUZ4Y1hGeDBYRndwWEc1bWQzSnBkR1VvWVhOZmRHbGlZbXhsS0d4dmIzQXVibTh1WjNJcElDVStKU0JrY0d4NWNqbzZjMlZzWldOMEtITmxjVzVoYldWekxDQnpkR0Z5ZEN3Z1pXNWtLU3dnYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ4Y1kyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5d1pTMXdaVjlCTkRnMWRuTkVUVk5QWDA1UFgyUnBabVl3TGpJdVlXNWphRzl5TG1KbFpGeGNLU3dnWTI5c0xtNWhiV1Z6SUQwZ1JrRk1VMFVzSUhObGNDQTlJRnhjWEZ4MFhGd3BYRzVtZDNKcGRHVW9ZWE5mZEdsaVlteGxLR3h2YjNBdVpHOTNiaTVuY2lrZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb2MyVnhibUZ0WlhNc0lITjBZWEowTENCbGJtUXBMQ0JvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnWEZ4amFISnZiVzlmWTI5dWMxOWhibTV2U0dsbGNtRnlZMmg1WDNCbExYQmxYMEUwT0RWMmMwUk5VMDlmUkU5WFRsOWthV1ptTUM0eUxtRnVZMmh2Y2k1aVpXUmNYQ2tzSUdOdmJDNXVZVzFsY3lBOUlFWkJURk5GTENCelpYQWdQU0JjWEZ4Y2RGeGNLVnh1WUdCZ1hHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgaW50ZXJlc3RcbmludGVyZXN0TmFtZSA8LSBcXHJlZ0xvb3BcXFxuIyBCQUNLR1JPVU5EIGxvb3BcbmJhY2tncm91bmQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZS5iZWRwZVxcKSlcbmJhY2tncm91bmQuZ3IgPC0gKGV4dHJhY3RBbmNob3IoYmFja2dyb3VuZCkpXG4jIFVQIGxvb3Bcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLnVwLmdyIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXApKVxuIyBOTyBsb29wXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5uby5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbiMgRE9XTiBsb29wXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVxcKSlcbmxvb3AuZG93bi5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxuXG5md3JpdGUoYXNfdGliYmxlKGxvb3AudXAuZ3IpICU+JSBkcGx5cjo6c2VsZWN0KHNlcW5hbWVzLCBzdGFydCwgZW5kKSwgaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX1VQX2RpZmYwLjIuYW5jaG9yLmJlZFxcKSwgY29sLm5hbWVzID0gRkFMU0UsIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoYXNfdGliYmxlKGxvb3Aubm8uZ3IpICU+JSBkcGx5cjo6c2VsZWN0KHNlcW5hbWVzLCBzdGFydCwgZW5kKSwgaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX05PX2RpZmYwLjIuYW5jaG9yLmJlZFxcKSwgY29sLm5hbWVzID0gRkFMU0UsIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoYXNfdGliYmxlKGxvb3AuZG93bi5ncikgJT4lIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQpLCBoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fRE9XTl9kaWZmMC4yLmFuY2hvci5iZWRcXCksIGNvbC5uYW1lcyA9IEZBTFNFLCBzZXAgPSBcXFxcdFxcKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIyBJbXBvcnRpbmcgbG9vcHMgb2YgaW50ZXJlc3RcbmludGVyZXN0TmFtZSA8LSBcXHJlZ0xvb3BcXFxuIyBCQUNLR1JPVU5EIGxvb3BcbmJhY2tncm91bmQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZS5iZWRwZVxcKSlcbmJhY2tncm91bmQuZ3IgPC0gKGV4dHJhY3RBbmNob3IoYmFja2dyb3VuZCkpXG4jIFVQIGxvb3Bcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLnVwLmdyIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXApKVxuIyBOTyBsb29wXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5uby5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbiMgRE9XTiBsb29wXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVxcKSlcbmxvb3AuZG93bi5nciA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxuXG5md3JpdGUoYXNfdGliYmxlKGxvb3AudXAuZ3IpICU+JSBkcGx5cjo6c2VsZWN0KHNlcW5hbWVzLCBzdGFydCwgZW5kKSwgaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX1VQX2RpZmYwLjIuYW5jaG9yLmJlZFxcKSwgY29sLm5hbWVzID0gRkFMU0UsIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoYXNfdGliYmxlKGxvb3Aubm8uZ3IpICU+JSBkcGx5cjo6c2VsZWN0KHNlcW5hbWVzLCBzdGFydCwgZW5kKSwgaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX05PX2RpZmYwLjIuYW5jaG9yLmJlZFxcKSwgY29sLm5hbWVzID0gRkFMU0UsIHNlcCA9IFxcXFx0XFwpXG5md3JpdGUoYXNfdGliYmxlKGxvb3AuZG93bi5ncikgJT4lIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQpLCBoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fRE9XTl9kaWZmMC4yLmFuY2hvci5iZWRcXCksIGNvbC5uYW1lcyA9IEZBTFNFLCBzZXAgPSBcXFxcdFxcKVxuYGBgXG5gYGAifQ== -->

```r
```r
#### Importing loops of interest
interestName <- \regLoop\
# BACKGROUND loop
background <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\))
background.gr <- (extractAnchor(background))
# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\))
loop.up.gr <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\))
loop.no.gr <- (extractAnchor(loop.no))
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\))
loop.down.gr <- (extractAnchor(loop.down))

fwrite(as_tibble(loop.up.gr) %>% dplyr::select(seqnames, start, end), here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.anchor.bed\), col.names = FALSE, sep = \\t\)
fwrite(as_tibble(loop.no.gr) %>% dplyr::select(seqnames, start, end), here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.anchor.bed\), col.names = FALSE, sep = \\t\)
fwrite(as_tibble(loop.down.gr) %>% dplyr::select(seqnames, start, end), here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.anchor.bed\), col.names = FALSE, sep = \\t\)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### All loops refined

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIkFUQUNfZWZmaWVcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiQ1RDRlwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAzIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJFU1JSQl9kc2dcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiSDNLMjdhY19lZmZpZVwiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJLTEY0X2VmZmllXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIk5BTk9HX2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJPQ1Q0X2VmZmllXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDggPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcIlNNQzFcIiwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA5IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXCJTT1gyX2RzZ1wiLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiVEJQXCIsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxuXG5cblxuXG5kYXRhIDwtIGJpbmRfcm93cyh0ZW1wMSwgdGVtcDIsIHRlbXAzLCB0ZW1wNCwgdGVtcDUsXG4gICAgICAgICB0ZW1wNiwgdGVtcDcsIHRlbXA4LCB0ZW1wOSwgdGVtcDEwKVxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFwidGFyZ2V0XCIpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcInRhcmdldFwiKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAzKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcImJsdWVcIiwgXCJ3aGl0ZVwiLCBcInJlZFwiKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFwiT2RkcyBSYXRpb1wiLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcIm4ucy5cIiwgc3ByaW50ZihcIiUuMmVcIiwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcIkludGVyZXN0XCIsXG4gICAgICAgIHJvd190aXRsZSA9IFwiVGFyZ2V0XCIsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcIjBcIiwgXCIxXCIsIFwiMlwiLCBcIjNcIikpKVxuXG5cblxuYGBgIn0= -->\n\n```r\n\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTarget(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTarget(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTarget(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTarget(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTarget(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTarget(\\OCT4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTarget(\\SMC1\\, interestName,\n                                     loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTarget(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTarget(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 3), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\)))\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->


#### Importing loops of target
temp1 <- runFisherExactCombinationTarget(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget(\OCT4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget(\SMC1\, interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 3), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c(\0\, \1\, \2\, \3\)))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEFUQUNfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcQ1RDRlxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAzIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxFU1JSQl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcSDNLMjdhY19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxLTEY0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE5BTk9HX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDggPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFNNQzFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA5IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxTT1gyX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcVEJQXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxuXG5cblxuXG5kYXRhIDwtIGJpbmRfcm93cyh0ZW1wMSwgdGVtcDIsIHRlbXAzLCB0ZW1wNCwgdGVtcDUsXG4gICAgICAgICB0ZW1wNiwgdGVtcDcsIHRlbXA4LCB0ZW1wOSwgdGVtcDEwKVxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAzKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFxcT2RkcyBSYXRpb1xcLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcXG4ucy5cXCwgc3ByaW50ZihcXCUuMmVcXCwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcXEludGVyZXN0XFwsXG4gICAgICAgIHJvd190aXRsZSA9IFxcVGFyZ2V0XFwsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcXDBcXCwgXFwxXFwsIFxcMlxcLCBcXDNcXCkpKVxuXG5cblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n\n\n#### Importing loops of target\ntemp1 <- runFisherExactCombinationTarget(\\ATAC_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp2 <- runFisherExactCombinationTarget(\\CTCF\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp3 <- runFisherExactCombinationTarget(\\ESRRB_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp4 <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp5 <- runFisherExactCombinationTarget(\\KLF4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp6 <- runFisherExactCombinationTarget(\\NANOG_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp7 <- runFisherExactCombinationTarget(\\OCT4_effie\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp8 <- runFisherExactCombinationTarget(\\SMC1\\, interestName,\n                                     loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp9 <- runFisherExactCombinationTarget(\\SOX2_dsg\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\ntemp10 <- runFisherExactCombinationTarget(\\TBP\\, interestName,\n                                      loop.up.gr, loop.no.gr, loop.down.gr,\n                                      background.gr)\n\n\n\n\ndata <- bind_rows(temp1, temp2, temp3, temp4, temp5,\n         temp6, temp7, temp8, temp9, temp10)\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 3), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\)))\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5cbiMjIyMgSW1wb3J0aW5nIGxvb3BzIG9mIHRhcmdldFxudGVtcDEgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXEFUQUNfZWZmaWVcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wMiA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcQ1RDRlxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAzIDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxFU1JSQl9kc2dcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wLnVwLmdyLCBsb29wLm5vLmdyLCBsb29wLmRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQuZ3IpXG50ZW1wNCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcSDNLMjdhY19lZmZpZVxcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA1IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxLTEY0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDYgPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXE5BTk9HX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA3IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxPQ1Q0X2VmZmllXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxudGVtcDggPC0gcnVuRmlzaGVyRXhhY3RDb21iaW5hdGlvblRhcmdldChcXFNNQzFcXCwgaW50ZXJlc3ROYW1lLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXA5IDwtIHJ1bkZpc2hlckV4YWN0Q29tYmluYXRpb25UYXJnZXQoXFxTT1gyX2RzZ1xcLCBpbnRlcmVzdE5hbWUsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3AudXAuZ3IsIGxvb3Aubm8uZ3IsIGxvb3AuZG93bi5ncixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZC5ncilcbnRlbXAxMCA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcVEJQXFwsIGludGVyZXN0TmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9vcC51cC5nciwgbG9vcC5uby5nciwgbG9vcC5kb3duLmdyLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kLmdyKVxuXG5cblxuXG5kYXRhIDwtIGJpbmRfcm93cyh0ZW1wMSwgdGVtcDIsIHRlbXAzLCB0ZW1wNCwgdGVtcDUsXG4gICAgICAgICB0ZW1wNiwgdGVtcDcsIHRlbXA4LCB0ZW1wOSwgdGVtcDEwKVxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAzKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFxcT2RkcyBSYXRpb1xcLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcXG4ucy5cXCwgc3ByaW50ZihcXCUuMmVcXCwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcXEludGVyZXN0XFwsXG4gICAgICAgIHJvd190aXRsZSA9IFxcVGFyZ2V0XFwsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiwgMyksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcXDBcXCwgXFwxXFwsIFxcMlxcLCBcXDNcXCkpKVxuXG5cblxuYGBgXG5gYGAifQ== -->

```r
```r


#### Importing loops of target
temp1 <- runFisherExactCombinationTarget(\ATAC_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget(\CTCF\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget(\ESRRB_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget(\H3K27ac_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget(\KLF4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget(\NANOG_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget(\OCT4_effie\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget(\SMC1\, interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget(\SOX2_dsg\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget(\TBP\, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 3), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c(\0\, \1\, \2\, \3\)))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Reg loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ngene.tb <- fread(here(refDir, \"mm10_GRCm38.p6_gene_sorted.bed\")) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \"+\", V2, V3)) %>%\n  dplyr::select(V1, TSS, V6)\ncolnames(gene.tb) <- c(\"chr\", \"TSS\", \"ensembl\")\n\ndiff.RNA <- fread(here(refDir, \"diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\"ensembl_gene_id\" = \"ensembl\")) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \"UP\",\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \"DOWN\",\n                                                        TRUE ~ \"NO\"))\n\n\ntemp <- diff.RNA %>% dplyr::mutate(start = TSS - 2500,\n                           end = TSS + 2500) %>%\n  dplyr::select(chr, start, end, ensembl_gene_id, diff)\n\n\ndown.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \"DOWN\"))\nup.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \"UP\"))\nno.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \"NO\"))\nall.gr <- makeGRangesFromDataFrame(temp)\n\ndata <- runFisherExactCombinationTarget(\"H3K27ac_effie\", \"TSS\",\n                                      up.gr, no.gr, down.gr,\n                                      all.gr)\n\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \"target\")\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \"target\")\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\"blue\", \"white\", \"red\"))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \"Odds Ratio\",\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \"n.s.\", sprintf(\"%.2e\", pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \"Interest\",\n        row_title = \"Target\",\n        heatmap_legend_param = list(at = c(0, 1, 2), \n                                    labels = c(\"0\", \"1\", \"2\")))\n\n\n## GO TEST\ndiff.RNA <- fread(here(refDir, \"diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\"ensembl_gene_id\" = \"ensembl\")) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \"UP\",\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \"DOWN\",\n                                                        TRUE ~ \"NO\"))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \"DOWN\"))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\")\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\n\ndownStemGene <- unique(unlist((as.data.frame(GO) %>% dplyr::slice(c(4, 5, 14, 66)) %>% dplyr::mutate(geneID = strsplit(geneID, \"/\")))$geneID))\ndownStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(ensembl_gene_id %in% downStemGene))\n\nprint(dotplot(GO, showCategory = 15, title = \"\") + \n        scale_color_continuous(limits = c(0, 0.05), low = \"red\", high = \"black\"))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \"UP\"))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\")\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \"\") + \n        scale_color_continuous(limits = c(0, 0.05), low = \"red\", high = \"black\"))\n\n\ndownNONStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \"DOWN\",\n                                                               !(ensembl_gene_id %in% downStemGene)))\n\nprint(dotplot(GO, showCategory = 15, title = \"\") + \n        scale_color_continuous(limits = c(0, 0.05), low = \"red\", high = \"black\"))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \"UP\"))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\")\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \"\") + \n        scale_color_continuous(limits = c(0, 0.05), low = \"red\", high = \"black\"))\n\n\n\n### Checking bookmarking only in stem gene\n\ndata <- runFisherExactCombinationTarget(\"H3K27ac_effie\", \"TSS\",\n                                      down.gr, downNONStem.gr, downStem.gr,\n                                      all.gr)\n\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \"target\")\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \"target\")\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\"blue\", \"white\", \"red\"))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \"Odds Ratio\",\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \"n.s.\", sprintf(\"%.2e\", pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \"Interest\",\n        row_title = \"Target\",\n        heatmap_legend_param = list(at = c(0, 1, 2), \n                                    labels = c(\"0\", \"1\", \"2\")))\n```"} -->\n\n```r\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V1, TSS, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\TSS\\, \\ensembl\\)\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\n\n\ntemp <- diff.RNA %>% dplyr::mutate(start = TSS - 2500,\n                           end = TSS + 2500) %>%\n  dplyr::select(chr, start, end, ensembl_gene_id, diff)\n\n\ndown.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\DOWN\\))\nup.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\UP\\))\nno.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\NO\\))\nall.gr <- makeGRangesFromDataFrame(temp)\n\ndata <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, \\TSS\\,\n                                      up.gr, no.gr, down.gr,\n                                      all.gr)\n\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2), \n                                    labels = c(\\0\\, \\1\\, \\2\\)))\n\n\n## GO TEST\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\DOWN\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\n\ndownStemGene <- unique(unlist((as.data.frame(GO) %>% dplyr::slice(c(4, 5, 14, 66)) %>% dplyr::mutate(geneID = strsplit(geneID, \\/\\)))$geneID))\ndownStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(ensembl_gene_id %in% downStemGene))\n\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\UP\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\n\n\ndownNONStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\DOWN\\,\n                                                               !(ensembl_gene_id %in% downStemGene)))\n\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\UP\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\n\n\n\n### Checking bookmarking only in stem gene\n\ndata <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, \\TSS\\,\n                                      down.gr, downNONStem.gr, downStem.gr,\n                                      all.gr)\n\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2), \n                                    labels = c(\\0\\, \\1\\, \\2\\)))\n```\n\n<!-- rnb-source-end -->\n"} -->
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V1, TSS, V6)
colnames(gene.tb) <- c(\chr\, \TSS\, \ensembl\)

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\ensembl_gene_id\ = \ensembl\)) %>%
  dplyr::filter(!is.na(TSS))
alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                                        TRUE ~ \NO\))


temp <- diff.RNA %>% dplyr::mutate(start = TSS - 2500,
                           end = TSS + 2500) %>%
  dplyr::select(chr, start, end, ensembl_gene_id, diff)


down.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \DOWN\))
up.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \UP\))
no.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \NO\))
all.gr <- makeGRangesFromDataFrame(temp)

data <- runFisherExactCombinationTarget(\H3K27ac_effie\, \TSS\,
                                      up.gr, no.gr, down.gr,
                                      all.gr)


# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 2), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2), 
                                    labels = c(\0\, \1\, \2\)))


## GO TEST
diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\ensembl_gene_id\ = \ensembl\)) %>%
  dplyr::filter(!is.na(TSS))
alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                                        TRUE ~ \NO\))
geneList <- (diff.RNA %>% dplyr::filter(diff == \DOWN\))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)

downStemGene <- unique(unlist((as.data.frame(GO) %>% dplyr::slice(c(4, 5, 14, 66)) %>% dplyr::mutate(geneID = strsplit(geneID, \/\)))$geneID))
downStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(ensembl_gene_id %in% downStemGene))

print(dotplot(GO, showCategory = 15, title = \\) + 
        scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))
geneList <- (diff.RNA %>% dplyr::filter(diff == \UP\))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
print(dotplot(GO, showCategory = 15, title = \\) + 
        scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))


downNONStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \DOWN\,
                                                               !(ensembl_gene_id %in% downStemGene)))

print(dotplot(GO, showCategory = 15, title = \\) + 
        scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))
geneList <- (diff.RNA %>% dplyr::filter(diff == \UP\))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
print(dotplot(GO, showCategory = 15, title = \\) + 
        scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))



### Checking bookmarking only in stem gene

data <- runFisherExactCombinationTarget(\H3K27ac_effie\, \TSS\,
                                      down.gr, downNONStem.gr, downStem.gr,
                                      all.gr)


# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 2), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2), 
                                    labels = c(\0\, \1\, \2\)))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V1, TSS, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\TSS\\, \\ensembl\\)\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\n\n\ntemp <- diff.RNA %>% dplyr::mutate(start = TSS - 2500,\n                           end = TSS + 2500) %>%\n  dplyr::select(chr, start, end, ensembl_gene_id, diff)\n\n\ndown.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\DOWN\\))\nup.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\UP\\))\nno.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\NO\\))\nall.gr <- makeGRangesFromDataFrame(temp)\n\ndata <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, \\TSS\\,\n                                      up.gr, no.gr, down.gr,\n                                      all.gr)\n\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2), \n                                    labels = c(\\0\\, \\1\\, \\2\\)))\n\n\n## GO TEST\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\DOWN\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\n\ndownStemGene <- unique(unlist((as.data.frame(GO) %>% dplyr::slice(c(4, 5, 14, 66)) %>% dplyr::mutate(geneID = strsplit(geneID, \\/\\)))$geneID))\ndownStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(ensembl_gene_id %in% downStemGene))\n\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\UP\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\n\n\ndownNONStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\DOWN\\,\n                                                               !(ensembl_gene_id %in% downStemGene)))\n\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\UP\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\n\n\n\n### Checking bookmarking only in stem gene\n\ndata <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, \\TSS\\,\n                                      down.gr, downNONStem.gr, downStem.gr,\n                                      all.gr)\n\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2), \n                                    labels = c(\\0\\, \\1\\, \\2\\)))\n```\n```"} -->\n\n```r\n```r\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V1, TSS, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\TSS\\, \\ensembl\\)\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\n\n\ntemp <- diff.RNA %>% dplyr::mutate(start = TSS - 2500,\n                           end = TSS + 2500) %>%\n  dplyr::select(chr, start, end, ensembl_gene_id, diff)\n\n\ndown.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\DOWN\\))\nup.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\UP\\))\nno.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\NO\\))\nall.gr <- makeGRangesFromDataFrame(temp)\n\ndata <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, \\TSS\\,\n                                      up.gr, no.gr, down.gr,\n                                      all.gr)\n\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2), \n                                    labels = c(\\0\\, \\1\\, \\2\\)))\n\n\n## GO TEST\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\DOWN\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\n\ndownStemGene <- unique(unlist((as.data.frame(GO) %>% dplyr::slice(c(4, 5, 14, 66)) %>% dplyr::mutate(geneID = strsplit(geneID, \\/\\)))$geneID))\ndownStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(ensembl_gene_id %in% downStemGene))\n\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\UP\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\n\n\ndownNONStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\DOWN\\,\n                                                               !(ensembl_gene_id %in% downStemGene)))\n\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\UP\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\n\n\n\n### Checking bookmarking only in stem gene\n\ndata <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, \\TSS\\,\n                                      down.gr, downNONStem.gr, downStem.gr,\n                                      all.gr)\n\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2), \n                                    labels = c(\\0\\, \\1\\, \\2\\)))\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V1, TSS, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\TSS\\, \\ensembl\\)\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\n\n\ntemp <- diff.RNA %>% dplyr::mutate(start = TSS - 2500,\n                           end = TSS + 2500) %>%\n  dplyr::select(chr, start, end, ensembl_gene_id, diff)\n\n\ndown.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\DOWN\\))\nup.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\UP\\))\nno.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\NO\\))\nall.gr <- makeGRangesFromDataFrame(temp)\n\ndata <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, \\TSS\\,\n                                      up.gr, no.gr, down.gr,\n                                      all.gr)\n\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2), \n                                    labels = c(\\0\\, \\1\\, \\2\\)))\n\n\n## GO TEST\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\DOWN\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\n\ndownStemGene <- unique(unlist((as.data.frame(GO) %>% dplyr::slice(c(4, 5, 14, 66)) %>% dplyr::mutate(geneID = strsplit(geneID, \\/\\)))$geneID))\ndownStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(ensembl_gene_id %in% downStemGene))\n\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\UP\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\n\n\ndownNONStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\DOWN\\,\n                                                               !(ensembl_gene_id %in% downStemGene)))\n\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\UP\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\n\n\n\n### Checking bookmarking only in stem gene\n\ndata <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, \\TSS\\,\n                                      down.gr, downNONStem.gr, downStem.gr,\n                                      all.gr)\n\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2), \n                                    labels = c(\\0\\, \\1\\, \\2\\)))\n```\n```"} -->

```r
```r
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V1, TSS, V6)
colnames(gene.tb) <- c(\chr\, \TSS\, \ensembl\)

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\ensembl_gene_id\ = \ensembl\)) %>%
  dplyr::filter(!is.na(TSS))
alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                                        TRUE ~ \NO\))


temp <- diff.RNA %>% dplyr::mutate(start = TSS - 2500,
                           end = TSS + 2500) %>%
  dplyr::select(chr, start, end, ensembl_gene_id, diff)


down.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \DOWN\))
up.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \UP\))
no.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \NO\))
all.gr <- makeGRangesFromDataFrame(temp)

data <- runFisherExactCombinationTarget(\H3K27ac_effie\, \TSS\,
                                      up.gr, no.gr, down.gr,
                                      all.gr)


# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 2), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2), 
                                    labels = c(\0\, \1\, \2\)))


## GO TEST
diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\ensembl_gene_id\ = \ensembl\)) %>%
  dplyr::filter(!is.na(TSS))
alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                                        TRUE ~ \NO\))
geneList <- (diff.RNA %>% dplyr::filter(diff == \DOWN\))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)

downStemGene <- unique(unlist((as.data.frame(GO) %>% dplyr::slice(c(4, 5, 14, 66)) %>% dplyr::mutate(geneID = strsplit(geneID, \/\)))$geneID))
downStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(ensembl_gene_id %in% downStemGene))

print(dotplot(GO, showCategory = 15, title = \\) + 
        scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))
geneList <- (diff.RNA %>% dplyr::filter(diff == \UP\))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
print(dotplot(GO, showCategory = 15, title = \\) + 
        scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))


downNONStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \DOWN\,
                                                               !(ensembl_gene_id %in% downStemGene)))

print(dotplot(GO, showCategory = 15, title = \\) + 
        scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))
geneList <- (diff.RNA %>% dplyr::filter(diff == \UP\))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
print(dotplot(GO, showCategory = 15, title = \\) + 
        scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))



### Checking bookmarking only in stem gene

data <- runFisherExactCombinationTarget(\H3K27ac_effie\, \TSS\,
                                      down.gr, downNONStem.gr, downStem.gr,
                                      all.gr)


# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 2), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2), 
                                    labels = c(\0\, \1\, \2\)))
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### Retained & Lost

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcIitcIiwgVjIsIFYzKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTUywgVjYpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFwiY2hyXCIsIFwiVFNTXCIsIFwiZW5zZW1ibFwiKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJkaWZmX0cxLkE0ODUuc2VsZWN0ZWQyX0cxLkVwaS5BNDg1X3ZzX0cxLkVwaS5ETVNPLnRzdlwiKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibF9nZW5lX2lkLCBsb2cyRm9sZENoYW5nZSwgc2hyaW5rZWRfbG9nMkZDLCBwYWRqLCBleHRlcm5hbF9nZW5lX25hbWUpXG5kaWZmLlJOQSA8LSBkaWZmLlJOQSAlPiUgZHBseXI6OmxlZnRfam9pbihnZW5lLnRiLCBieSA9IGMoXCJlbnNlbWJsX2dlbmVfaWRcIiA9IFwiZW5zZW1ibFwiKSkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKFRTUykpXG5hbHBoYSA8LSAwLjA1XG5mY0N1dG9mZiA8LSAwLjVcblxuZGlmZi5STkEgPC0gZGlmZi5STkEgJT4lIGRwbHlyOjptdXRhdGUoZGlmZiA9IGNhc2Vfd2hlbihwYWRqIDwgYWxwaGEgJiBzaHJpbmtlZF9sb2cyRkMgPiBmY0N1dG9mZiB+IFwiVVBcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkaiA8IGFscGhhICYgc2hyaW5rZWRfbG9nMkZDIDwgLWZjQ3V0b2ZmIH4gXCJET1dOXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBcIk5PXCIpKVxuXG5cbnRlbXAgPC0gZGlmZi5STkEgJT4lIGRwbHlyOjptdXRhdGUoc3RhcnQgPSBUU1MgLSAyNTAwLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgZW5kID0gVFNTICsgMjUwMCkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoY2hyLCBzdGFydCwgZW5kLCBlbnNlbWJsX2dlbmVfaWQsIGRpZmYpXG5cblxuZG93bi5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcCAlPiUgZHBseXI6OmZpbHRlcihkaWZmID09IFwiRE9XTlwiKSlcbnVwLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGRpZmYgPT0gXCJVUFwiKSlcbm5vLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGRpZmYgPT0gXCJOT1wiKSlcbmFsbC5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcblxuZGF0YSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFwiSDNLMjdhY19lZmZpZVwiLCBcIlRTU1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB1cC5nciwgbm8uZ3IsIGRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFsbC5ncilcblxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFwidGFyZ2V0XCIpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcInRhcmdldFwiKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAyKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcImJsdWVcIiwgXCJ3aGl0ZVwiLCBcInJlZFwiKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFwiT2RkcyBSYXRpb1wiLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcIm4ucy5cIiwgc3ByaW50ZihcIiUuMmVcIiwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcIkludGVyZXN0XCIsXG4gICAgICAgIHJvd190aXRsZSA9IFwiVGFyZ2V0XCIsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcIjBcIiwgXCIxXCIsIFwiMlwiKSkpXG5cblxuIyMgR09cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImRpZmZfRzEuQTQ4NS5zZWxlY3RlZDJfRzEuRXBpLkE0ODVfdnNfRzEuRXBpLkRNU08udHN2XCIpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcbmRpZmYuUk5BIDwtIGRpZmYuUk5BICU+JSBkcGx5cjo6bGVmdF9qb2luKGdlbmUudGIsIGJ5ID0gYyhcImVuc2VtYmxfZ2VuZV9pZFwiID0gXCJlbnNlbWJsXCIpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoVFNTKSlcbmFscGhhIDwtIDAuMDVcbmZjQ3V0b2ZmIDwtIDAuNVxuXG5kaWZmLlJOQSA8LSBkaWZmLlJOQSAlPiUgZHBseXI6Om11dGF0ZShkaWZmID0gY2FzZV93aGVuKHBhZGogPCBhbHBoYSAmIHNocmlua2VkX2xvZzJGQyA+IGZjQ3V0b2ZmIH4gXCJVUFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBwYWRqIDwgYWxwaGEgJiBzaHJpbmtlZF9sb2cyRkMgPCAtZmNDdXRvZmYgfiBcIkRPV05cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IFwiTk9cIikpXG5cbmdlbmVMaXN0IDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihkaWZmID09IFwiRE9XTlwiKSkkZW5zZW1ibF9nZW5lX2lkXG5HTyA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIilcbkdPLnJlYWRhYmxlIDwtIHNldFJlYWRhYmxlKEdPLCBPcmdEYiA9IG9yZy5NbS5lZy5kYilcbnByaW50KGRvdHBsb3QoR08sIHNob3dDYXRlZ29yeSA9IDE1LCB0aXRsZSA9IFwiXCIpICsgXG4gICAgICAgIHNjYWxlX2NvbG9yX2NvbnRpbnVvdXMobGltaXRzID0gYygwLCAwLjA1KSwgbG93ID0gXCJyZWRcIiwgaGlnaCA9IFwiYmxhY2tcIikpXG5nZW5lTGlzdCA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoZGlmZiA9PSBcIlVQXCIpKSRlbnNlbWJsX2dlbmVfaWRcbkdPIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuR08ucmVhZGFibGUgPC0gc2V0UmVhZGFibGUoR08sIE9yZ0RiID0gb3JnLk1tLmVnLmRiKVxucHJpbnQoZG90cGxvdChHTywgc2hvd0NhdGVnb3J5ID0gMTUsIHRpdGxlID0gXCJcIikgKyBcbiAgICAgICAgc2NhbGVfY29sb3JfY29udGludW91cyhsaW1pdHMgPSBjKDAsIDAuMDUpLCBsb3cgPSBcInJlZFwiLCBoaWdoID0gXCJibGFja1wiKSlcblxuYGBgIn0= -->\n\n```r\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V1, TSS, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\TSS\\, \\ensembl\\)\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.Epi.A485_vs_G1.Epi.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\n\n\ntemp <- diff.RNA %>% dplyr::mutate(start = TSS - 2500,\n                           end = TSS + 2500) %>%\n  dplyr::select(chr, start, end, ensembl_gene_id, diff)\n\n\ndown.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\DOWN\\))\nup.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\UP\\))\nno.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\NO\\))\nall.gr <- makeGRangesFromDataFrame(temp)\n\ndata <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, \\TSS\\,\n                                      up.gr, no.gr, down.gr,\n                                      all.gr)\n\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2), \n                                    labels = c(\\0\\, \\1\\, \\2\\)))\n\n\n## GO\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.Epi.A485_vs_G1.Epi.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\n\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\DOWN\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\UP\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\n\n```\n\n<!-- rnb-source-end -->\n"} -->
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V1, TSS, V6)
colnames(gene.tb) <- c(\chr\, \TSS\, \ensembl\)

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.Epi.A485_vs_G1.Epi.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\ensembl_gene_id\ = \ensembl\)) %>%
  dplyr::filter(!is.na(TSS))
alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                                        TRUE ~ \NO\))


temp <- diff.RNA %>% dplyr::mutate(start = TSS - 2500,
                           end = TSS + 2500) %>%
  dplyr::select(chr, start, end, ensembl_gene_id, diff)


down.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \DOWN\))
up.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \UP\))
no.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \NO\))
all.gr <- makeGRangesFromDataFrame(temp)

data <- runFisherExactCombinationTarget(\H3K27ac_effie\, \TSS\,
                                      up.gr, no.gr, down.gr,
                                      all.gr)


# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 2), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2), 
                                    labels = c(\0\, \1\, \2\)))


## GO
diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.Epi.A485_vs_G1.Epi.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\ensembl_gene_id\ = \ensembl\)) %>%
  dplyr::filter(!is.na(TSS))
alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                                        TRUE ~ \NO\))

geneList <- (diff.RNA %>% dplyr::filter(diff == \DOWN\))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
print(dotplot(GO, showCategory = 15, title = \\) + 
        scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))
geneList <- (diff.RNA %>% dplyr::filter(diff == \UP\))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
print(dotplot(GO, showCategory = 15, title = \\) + 
        scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTUywgVjYpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFxcY2hyXFwsIFxcVFNTXFwsIFxcZW5zZW1ibFxcKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLkE0ODUuc2VsZWN0ZWQyX0cxLkVwaS5BNDg1X3ZzX0cxLkVwaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibF9nZW5lX2lkLCBsb2cyRm9sZENoYW5nZSwgc2hyaW5rZWRfbG9nMkZDLCBwYWRqLCBleHRlcm5hbF9nZW5lX25hbWUpXG5kaWZmLlJOQSA8LSBkaWZmLlJOQSAlPiUgZHBseXI6OmxlZnRfam9pbihnZW5lLnRiLCBieSA9IGMoXFxlbnNlbWJsX2dlbmVfaWRcXCA9IFxcZW5zZW1ibFxcKSkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKFRTUykpXG5hbHBoYSA8LSAwLjA1XG5mY0N1dG9mZiA8LSAwLjVcblxuZGlmZi5STkEgPC0gZGlmZi5STkEgJT4lIGRwbHlyOjptdXRhdGUoZGlmZiA9IGNhc2Vfd2hlbihwYWRqIDwgYWxwaGEgJiBzaHJpbmtlZF9sb2cyRkMgPiBmY0N1dG9mZiB+IFxcVVBcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkaiA8IGFscGhhICYgc2hyaW5rZWRfbG9nMkZDIDwgLWZjQ3V0b2ZmIH4gXFxET1dOXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBcXE5PXFwpKVxuXG5cbnRlbXAgPC0gZGlmZi5STkEgJT4lIGRwbHlyOjptdXRhdGUoc3RhcnQgPSBUU1MgLSAyNTAwLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgZW5kID0gVFNTICsgMjUwMCkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoY2hyLCBzdGFydCwgZW5kLCBlbnNlbWJsX2dlbmVfaWQsIGRpZmYpXG5cblxuZG93bi5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcCAlPiUgZHBseXI6OmZpbHRlcihkaWZmID09IFxcRE9XTlxcKSlcbnVwLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGRpZmYgPT0gXFxVUFxcKSlcbm5vLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGRpZmYgPT0gXFxOT1xcKSlcbmFsbC5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcblxuZGF0YSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcSDNLMjdhY19lZmZpZVxcLCBcXFRTU1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB1cC5nciwgbm8uZ3IsIGRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFsbC5ncilcblxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAyKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFxcT2RkcyBSYXRpb1xcLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcXG4ucy5cXCwgc3ByaW50ZihcXCUuMmVcXCwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcXEludGVyZXN0XFwsXG4gICAgICAgIHJvd190aXRsZSA9IFxcVGFyZ2V0XFwsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcXDBcXCwgXFwxXFwsIFxcMlxcKSkpXG5cblxuIyMgR09cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGRpZmZfRzEuQTQ4NS5zZWxlY3RlZDJfRzEuRXBpLkE0ODVfdnNfRzEuRXBpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcbmRpZmYuUk5BIDwtIGRpZmYuUk5BICU+JSBkcGx5cjo6bGVmdF9qb2luKGdlbmUudGIsIGJ5ID0gYyhcXGVuc2VtYmxfZ2VuZV9pZFxcID0gXFxlbnNlbWJsXFwpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoVFNTKSlcbmFscGhhIDwtIDAuMDVcbmZjQ3V0b2ZmIDwtIDAuNVxuXG5kaWZmLlJOQSA8LSBkaWZmLlJOQSAlPiUgZHBseXI6Om11dGF0ZShkaWZmID0gY2FzZV93aGVuKHBhZGogPCBhbHBoYSAmIHNocmlua2VkX2xvZzJGQyA+IGZjQ3V0b2ZmIH4gXFxVUFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBwYWRqIDwgYWxwaGEgJiBzaHJpbmtlZF9sb2cyRkMgPCAtZmNDdXRvZmYgfiBcXERPV05cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IFxcTk9cXCkpXG5cbmdlbmVMaXN0IDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihkaWZmID09IFxcRE9XTlxcKSkkZW5zZW1ibF9nZW5lX2lkXG5HTyA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbkdPLnJlYWRhYmxlIDwtIHNldFJlYWRhYmxlKEdPLCBPcmdEYiA9IG9yZy5NbS5lZy5kYilcbnByaW50KGRvdHBsb3QoR08sIHNob3dDYXRlZ29yeSA9IDE1LCB0aXRsZSA9IFxcXFwpICsgXG4gICAgICAgIHNjYWxlX2NvbG9yX2NvbnRpbnVvdXMobGltaXRzID0gYygwLCAwLjA1KSwgbG93ID0gXFxyZWRcXCwgaGlnaCA9IFxcYmxhY2tcXCkpXG5nZW5lTGlzdCA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoZGlmZiA9PSBcXFVQXFwpKSRlbnNlbWJsX2dlbmVfaWRcbkdPIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR08ucmVhZGFibGUgPC0gc2V0UmVhZGFibGUoR08sIE9yZ0RiID0gb3JnLk1tLmVnLmRiKVxucHJpbnQoZG90cGxvdChHTywgc2hvd0NhdGVnb3J5ID0gMTUsIHRpdGxlID0gXFxcXCkgKyBcbiAgICAgICAgc2NhbGVfY29sb3JfY29udGludW91cyhsaW1pdHMgPSBjKDAsIDAuMDUpLCBsb3cgPSBcXHJlZFxcLCBoaWdoID0gXFxibGFja1xcKSlcblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V1, TSS, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\TSS\\, \\ensembl\\)\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.Epi.A485_vs_G1.Epi.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\n\n\ntemp <- diff.RNA %>% dplyr::mutate(start = TSS - 2500,\n                           end = TSS + 2500) %>%\n  dplyr::select(chr, start, end, ensembl_gene_id, diff)\n\n\ndown.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\DOWN\\))\nup.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\UP\\))\nno.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \\NO\\))\nall.gr <- makeGRangesFromDataFrame(temp)\n\ndata <- runFisherExactCombinationTarget(\\H3K27ac_effie\\, \\TSS\\,\n                                      up.gr, no.gr, down.gr,\n                                      all.gr)\n\n\n# Visualization\nlibrary(circlize)\n\nheatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%\npivot_wider(names_from = interest, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%\n  pivot_wider(names_from = interest, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2), \n                                    labels = c(\\0\\, \\1\\, \\2\\)))\n\n\n## GO\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.Epi.A485_vs_G1.Epi.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\n\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\DOWN\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\ngeneList <- (diff.RNA %>% dplyr::filter(diff == \\UP\\))$ensembl_gene_id\nGO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\nGO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)\nprint(dotplot(GO, showCategory = 15, title = \\\\) + \n        scale_color_continuous(limits = c(0, 0.05), low = \\red\\, high = \\black\\))\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTUywgVjYpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFxcY2hyXFwsIFxcVFNTXFwsIFxcZW5zZW1ibFxcKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLkE0ODUuc2VsZWN0ZWQyX0cxLkVwaS5BNDg1X3ZzX0cxLkVwaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibF9nZW5lX2lkLCBsb2cyRm9sZENoYW5nZSwgc2hyaW5rZWRfbG9nMkZDLCBwYWRqLCBleHRlcm5hbF9nZW5lX25hbWUpXG5kaWZmLlJOQSA8LSBkaWZmLlJOQSAlPiUgZHBseXI6OmxlZnRfam9pbihnZW5lLnRiLCBieSA9IGMoXFxlbnNlbWJsX2dlbmVfaWRcXCA9IFxcZW5zZW1ibFxcKSkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKFRTUykpXG5hbHBoYSA8LSAwLjA1XG5mY0N1dG9mZiA8LSAwLjVcblxuZGlmZi5STkEgPC0gZGlmZi5STkEgJT4lIGRwbHlyOjptdXRhdGUoZGlmZiA9IGNhc2Vfd2hlbihwYWRqIDwgYWxwaGEgJiBzaHJpbmtlZF9sb2cyRkMgPiBmY0N1dG9mZiB+IFxcVVBcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkaiA8IGFscGhhICYgc2hyaW5rZWRfbG9nMkZDIDwgLWZjQ3V0b2ZmIH4gXFxET1dOXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBcXE5PXFwpKVxuXG5cbnRlbXAgPC0gZGlmZi5STkEgJT4lIGRwbHlyOjptdXRhdGUoc3RhcnQgPSBUU1MgLSAyNTAwLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgZW5kID0gVFNTICsgMjUwMCkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoY2hyLCBzdGFydCwgZW5kLCBlbnNlbWJsX2dlbmVfaWQsIGRpZmYpXG5cblxuZG93bi5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcCAlPiUgZHBseXI6OmZpbHRlcihkaWZmID09IFxcRE9XTlxcKSlcbnVwLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGRpZmYgPT0gXFxVUFxcKSlcbm5vLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGRpZmYgPT0gXFxOT1xcKSlcbmFsbC5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcblxuZGF0YSA8LSBydW5GaXNoZXJFeGFjdENvbWJpbmF0aW9uVGFyZ2V0KFxcSDNLMjdhY19lZmZpZVxcLCBcXFRTU1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB1cC5nciwgbm8uZ3IsIGRvd24uZ3IsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFsbC5ncilcblxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmhlYXRtYXBfZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KHRhcmdldCwgaW50ZXJlc3QsIG9kZHNSYXRpbykgJT4lXG5waXZvdF93aWRlcihuYW1lc19mcm9tID0gaW50ZXJlc3QsIHZhbHVlc19mcm9tID0gb2Rkc1JhdGlvKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbnB2YWx1ZV9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBpbnRlcmVzdCwgcHZhbHVlKSAlPiVcbiAgcGl2b3Rfd2lkZXIobmFtZXNfZnJvbSA9IGludGVyZXN0LCB2YWx1ZXNfZnJvbSA9IHB2YWx1ZSkgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHRhcmdldFxcKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAyKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuSGVhdG1hcChhcy5tYXRyaXgoaGVhdG1hcF9kYXRhKSxcbiAgICAgICAgbmFtZSA9IFxcT2RkcyBSYXRpb1xcLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICAjIEFkZCBhbm5vdGF0aW9uIGZvciBwLXZhbHVlc1xuICAgICAgICBjZWxsX2Z1biA9IGZ1bmN0aW9uKGosIGksIHgsIHksIHdpZHRoLCBoZWlnaHQsIGZpbGwpIHtcbiAgICAgICAgICBwdmFsIDwtIHB2YWx1ZV9kYXRhW2ksIGpdXG4gICAgICAgICAgbGFiZWwgPC0gaWZlbHNlKHB2YWwgPiAwLjA1LCBcXG4ucy5cXCwgc3ByaW50ZihcXCUuMmVcXCwgcHZhbCkpXG4gICAgICAgICAgZ3JpZC50ZXh0KGxhYmVsLCB4LCB5LCBncCA9IGdwYXIoZm9udHNpemUgPSAxMCkpXG4gICAgICAgIH0sXG4gICAgICAgICMgQ3VzdG9taXplIHRoZSBoZWF0bWFwIGxheW91dFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjb2x1bW5fdGl0bGUgPSBcXEludGVyZXN0XFwsXG4gICAgICAgIHJvd190aXRsZSA9IFxcVGFyZ2V0XFwsXG4gICAgICAgIGhlYXRtYXBfbGVnZW5kX3BhcmFtID0gbGlzdChhdCA9IGMoMCwgMSwgMiksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGFiZWxzID0gYyhcXDBcXCwgXFwxXFwsIFxcMlxcKSkpXG5cblxuIyMgR09cbmRpZmYuUk5BIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGRpZmZfRzEuQTQ4NS5zZWxlY3RlZDJfRzEuRXBpLkE0ODVfdnNfRzEuRXBpLkRNU08udHN2XFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsX2dlbmVfaWQsIGxvZzJGb2xkQ2hhbmdlLCBzaHJpbmtlZF9sb2cyRkMsIHBhZGosIGV4dGVybmFsX2dlbmVfbmFtZSlcbmRpZmYuUk5BIDwtIGRpZmYuUk5BICU+JSBkcGx5cjo6bGVmdF9qb2luKGdlbmUudGIsIGJ5ID0gYyhcXGVuc2VtYmxfZ2VuZV9pZFxcID0gXFxlbnNlbWJsXFwpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoVFNTKSlcbmFscGhhIDwtIDAuMDVcbmZjQ3V0b2ZmIDwtIDAuNVxuXG5kaWZmLlJOQSA8LSBkaWZmLlJOQSAlPiUgZHBseXI6Om11dGF0ZShkaWZmID0gY2FzZV93aGVuKHBhZGogPCBhbHBoYSAmIHNocmlua2VkX2xvZzJGQyA+IGZjQ3V0b2ZmIH4gXFxVUFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBwYWRqIDwgYWxwaGEgJiBzaHJpbmtlZF9sb2cyRkMgPCAtZmNDdXRvZmYgfiBcXERPV05cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IFxcTk9cXCkpXG5cbmdlbmVMaXN0IDwtIChkaWZmLlJOQSAlPiUgZHBseXI6OmZpbHRlcihkaWZmID09IFxcRE9XTlxcKSkkZW5zZW1ibF9nZW5lX2lkXG5HTyA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbkdPLnJlYWRhYmxlIDwtIHNldFJlYWRhYmxlKEdPLCBPcmdEYiA9IG9yZy5NbS5lZy5kYilcbnByaW50KGRvdHBsb3QoR08sIHNob3dDYXRlZ29yeSA9IDE1LCB0aXRsZSA9IFxcXFwpICsgXG4gICAgICAgIHNjYWxlX2NvbG9yX2NvbnRpbnVvdXMobGltaXRzID0gYygwLCAwLjA1KSwgbG93ID0gXFxyZWRcXCwgaGlnaCA9IFxcYmxhY2tcXCkpXG5nZW5lTGlzdCA8LSAoZGlmZi5STkEgJT4lIGRwbHlyOjpmaWx0ZXIoZGlmZiA9PSBcXFVQXFwpKSRlbnNlbWJsX2dlbmVfaWRcbkdPIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuR08ucmVhZGFibGUgPC0gc2V0UmVhZGFibGUoR08sIE9yZ0RiID0gb3JnLk1tLmVnLmRiKVxucHJpbnQoZG90cGxvdChHTywgc2hvd0NhdGVnb3J5ID0gMTUsIHRpdGxlID0gXFxcXCkgKyBcbiAgICAgICAgc2NhbGVfY29sb3JfY29udGludW91cyhsaW1pdHMgPSBjKDAsIDAuMDUpLCBsb3cgPSBcXHJlZFxcLCBoaWdoID0gXFxibGFja1xcKSlcblxuYGBgXG5gYGAifQ== -->

```r
```r
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V1, TSS, V6)
colnames(gene.tb) <- c(\chr\, \TSS\, \ensembl\)

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.Epi.A485_vs_G1.Epi.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\ensembl_gene_id\ = \ensembl\)) %>%
  dplyr::filter(!is.na(TSS))
alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                                        TRUE ~ \NO\))


temp <- diff.RNA %>% dplyr::mutate(start = TSS - 2500,
                           end = TSS + 2500) %>%
  dplyr::select(chr, start, end, ensembl_gene_id, diff)


down.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \DOWN\))
up.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \UP\))
no.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == \NO\))
all.gr <- makeGRangesFromDataFrame(temp)

data <- runFisherExactCombinationTarget(\H3K27ac_effie\, \TSS\,
                                      up.gr, no.gr, down.gr,
                                      all.gr)


# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 2), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2), 
                                    labels = c(\0\, \1\, \2\)))


## GO
diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.Epi.A485_vs_G1.Epi.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\ensembl_gene_id\ = \ensembl\)) %>%
  dplyr::filter(!is.na(TSS))
alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                                        TRUE ~ \NO\))

geneList <- (diff.RNA %>% dplyr::filter(diff == \DOWN\))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
print(dotplot(GO, showCategory = 15, title = \\) + 
        scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))
geneList <- (diff.RNA %>% dplyr::filter(diff == \UP\))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
print(dotplot(GO, showCategory = 15, title = \\) + 
        scale_color_continuous(limits = c(0, 0.05), low = \red\, high = \black\))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

### DEGs from RNA-seq
2.5kb from TSS, at least 1 bp overlap
#### 2i

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiX3AtcGVfZW5zZW1ibExpc3QudHN2XCIpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IDAuMilcblxuaWQuRzFTcGVjaWZpY1BlcnQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9HMXZzQXN5bmNfRzFTcGVjaWZpY1BlcnQuYmVkcGVcIikpJFY3XG5pZC5Bc3luY1NwZWNpZmljUGVydCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0cxdnNBc3luY19Bc3luY1NwZWNpZmljUGVydC5iZWRwZVwiKSkkVjdcbmlkLmJvdGhQZXJ0IDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfRzF2c0FzeW5jX2JvdGhQZXJ0LmJlZHBlXCIpKSRWN1xuaWQuYm90aFJldGFpbmVkIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfRzF2c0FzeW5jX2JvdGhSZXRhaW5lZC5iZWRwZVwiKSkkVjdcblxuXG5nZW5lTGlzdC5HMVNwZWNpZmljUGVydCA8LSAoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgaWQuRzFTcGVjaWZpY1BlcnQpICU+JSB1bm5lc3QoZ2VuZSkpJGdlbmVcbmdlbmVMaXN0LkFzeW5jU3BlY2lmaWNQZXJ0IDwtIChnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBpZC5Bc3luY1NwZWNpZmljUGVydCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZVxuZ2VuZUxpc3QuYm90aFBlcnQgPC0gKGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGlkLmJvdGhQZXJ0KSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lXG5nZW5lTGlzdC5ib3RoUmV0YWluZWQgPC0gKGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGlkLmJvdGhSZXRhaW5lZCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZVxuXG5HTy5HMVNwZWNpZmljUGVydC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5HMVNwZWNpZmljUGVydCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKSlcbkdPLkFzeW5jU3BlY2lmaWNQZXIuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QuQXN5bmNTcGVjaWZpY1BlcnQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIikpXG5HTy5ib3RoUGVydC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ib3RoUGVydCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKSlcbkdPLmJvdGhSZXRhaW5lZC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ib3RoUmV0YWluZWQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIikpXG5cbnN1YnNldC5HMVNwZWNpZmljUGVydCA8LSBHTy5HMVNwZWNpZmljUGVydC5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXCJHMVNwZWNpZmljUGVydFwiKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBnciA9IHNhcHBseShHZW5lUmF0aW8sIGZ1bmN0aW9uKHgpIHtcbiAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuICAgICAgcGFydHMgPC0gdW5saXN0KHN0cnNwbGl0KHgsIFwiL1wiKSlcbiAgICAgICMgQ29udmVydCB0byBudW1lcmljIGFuZCBwZXJmb3JtIHRoZSBkaXZpc2lvblxuICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuICAgIH0pXG4gICkgJT4lIGRwbHlyOjphcnJhbmdlKGRlc2MoZ3IpKVxuXG5zdWJzZXQuQXN5bmNTcGVjaWZpY1BlcnQgPC0gR08uQXN5bmNTcGVjaWZpY1Blci5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXCJBc3luY1NwZWNpZmljUGVydFwiKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBnciA9IHNhcHBseShHZW5lUmF0aW8sIGZ1bmN0aW9uKHgpIHtcbiAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcIi9cIlxuICAgICAgcGFydHMgPC0gdW5saXN0KHN0cnNwbGl0KHgsIFwiL1wiKSlcbiAgICAgICMgQ29udmVydCB0byBudW1lcmljIGFuZCBwZXJmb3JtIHRoZSBkaXZpc2lvblxuICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuICAgIH0pXG4gICkgJT4lIGRwbHlyOjphcnJhbmdlKGRlc2MoZ3IpKVxuXG5zdWJzZXQuYm90aFBlcnQgPC0gR08uYm90aFBlcnQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwiYm90aFBlcnRcIikgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXCIvXCJcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcIi9cIikpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcblxuc3Vic2V0LmJvdGhSZXRhaW5lZCA8LSBHTy5ib3RoUmV0YWluZWQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFwiYm90aFJldGFpbmVkXCIpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGdyID0gc2FwcGx5KEdlbmVSYXRpbywgZnVuY3Rpb24oeCkge1xuICAgICAgIyBTcGxpdCB0aGUgc3RyaW5nIGJ5IFwiL1wiXG4gICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXCIvXCIpKVxuICAgICAgIyBDb252ZXJ0IHRvIG51bWVyaWMgYW5kIHBlcmZvcm0gdGhlIGRpdmlzaW9uXG4gICAgICBhcy5udW1lcmljKHBhcnRzWzFdKSAvIGFzLm51bWVyaWMocGFydHNbMl0pXG4gICAgfSlcbiAgKSAlPiUgZHBseXI6OmFycmFuZ2UoZGVzYyhncikpXG5cbmRhdGEgPC0gYmluZF9yb3dzKGJpbmRfcm93cyhzdWJzZXQuRzFTcGVjaWZpY1BlcnQsIHN1YnNldC5ib3RoUGVydCksIHN1YnNldC5ib3RoUmV0YWluZWQpXG5cbnAgPC0gZ2dwbG90KHN1YnNldC5HMVNwZWNpZmljUGVydCwgYWVzKHggPSBncm91cCwgeSA9IERlc2NyaXB0aW9uLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICtcbiAgc2NhbGVfY29sb3JfZ3JhZGllbnQobG93ID0gXCJyZWRcIiwgaGlnaCA9IFwiYmx1ZVwiLCBsaW1pdHMgPSBjKDAsIDAuMDUpKSArXG4gIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICtcbiAgdGhlbWUoYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgICMgU2V0IGF4aXMgdGV4dCBzaXplXG4gICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuICAgICAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICMgU2V0IGxlZ2VuZCB0ZXh0IHNpemVcbiAgICAgICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSkgXG5cbmBgYCJ9 -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-pe_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2)\n\nid.G1SpecificPert <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\\))$V7\nid.AsyncSpecificPert <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\\))$V7\nid.bothPert <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\\))$V7\nid.bothRetained <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\\))$V7\n\n\ngeneList.G1SpecificPert <- (geneAnnoData %>% dplyr::filter(id %in% id.G1SpecificPert) %>% unnest(gene))$gene\ngeneList.AsyncSpecificPert <- (geneAnnoData %>% dplyr::filter(id %in% id.AsyncSpecificPert) %>% unnest(gene))$gene\ngeneList.bothPert <- (geneAnnoData %>% dplyr::filter(id %in% id.bothPert) %>% unnest(gene))$gene\ngeneList.bothRetained <- (geneAnnoData %>% dplyr::filter(id %in% id.bothRetained) %>% unnest(gene))$gene\n\nGO.G1SpecificPert.df <- as.data.frame(enrichGO(gene = geneList.G1SpecificPert, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO.AsyncSpecificPer.df <- as.data.frame(enrichGO(gene = geneList.AsyncSpecificPert, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO.bothPert.df <- as.data.frame(enrichGO(gene = geneList.bothPert, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO.bothRetained.df <- as.data.frame(enrichGO(gene = geneList.bothRetained, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n\nsubset.G1SpecificPert <- GO.G1SpecificPert.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\G1SpecificPert\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\n\nsubset.AsyncSpecificPert <- GO.AsyncSpecificPer.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\AsyncSpecificPert\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\n\nsubset.bothPert <- GO.bothPert.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\bothPert\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\n\nsubset.bothRetained <- GO.bothRetained.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\bothRetained\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\n\ndata <- bind_rows(bind_rows(subset.G1SpecificPert, subset.bothPert), subset.bothRetained)\n\np <- ggplot(subset.G1SpecificPert, aes(x = group, y = Description, color = p.adjust, size = gr)) + \n  geom_point() + theme_bw() +\n  scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n  scale_size_continuous(range = c(0, 3)) +\n  labs(x = NULL, y = NULL) +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-pe_ensemblList.tsv\)),
                                      diffCutoff = 0.2)

id.G1SpecificPert <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\))$V7
id.AsyncSpecificPert <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\))$V7
id.bothPert <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\))$V7
id.bothRetained <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\))$V7


geneList.G1SpecificPert <- (geneAnnoData %>% dplyr::filter(id %in% id.G1SpecificPert) %>% unnest(gene))$gene
geneList.AsyncSpecificPert <- (geneAnnoData %>% dplyr::filter(id %in% id.AsyncSpecificPert) %>% unnest(gene))$gene
geneList.bothPert <- (geneAnnoData %>% dplyr::filter(id %in% id.bothPert) %>% unnest(gene))$gene
geneList.bothRetained <- (geneAnnoData %>% dplyr::filter(id %in% id.bothRetained) %>% unnest(gene))$gene

GO.G1SpecificPert.df <- as.data.frame(enrichGO(gene = geneList.G1SpecificPert, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO.AsyncSpecificPer.df <- as.data.frame(enrichGO(gene = geneList.AsyncSpecificPert, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO.bothPert.df <- as.data.frame(enrichGO(gene = geneList.bothPert, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO.bothRetained.df <- as.data.frame(enrichGO(gene = geneList.bothRetained, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))

subset.G1SpecificPert <- GO.G1SpecificPert.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \G1SpecificPert\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

subset.AsyncSpecificPert <- GO.AsyncSpecificPer.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \AsyncSpecificPert\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

subset.bothPert <- GO.bothPert.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \bothPert\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

subset.bothRetained <- GO.bothRetained.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \bothRetained\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

data <- bind_rows(bind_rows(subset.G1SpecificPert, subset.bothPert), subset.bothRetained)

p <- ggplot(subset.G1SpecificPert, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
  geom_point() + theme_bw() +
  scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
  scale_size_continuous(range = c(0, 3)) +
  labs(x = NULL, y = NULL) +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3AtcGVfZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IDAuMilcblxuaWQuRzFTcGVjaWZpY1BlcnQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9HMXZzQXN5bmNfRzFTcGVjaWZpY1BlcnQuYmVkcGVcXCkpJFY3XG5pZC5Bc3luY1NwZWNpZmljUGVydCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0cxdnNBc3luY19Bc3luY1NwZWNpZmljUGVydC5iZWRwZVxcKSkkVjdcbmlkLmJvdGhQZXJ0IDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfRzF2c0FzeW5jX2JvdGhQZXJ0LmJlZHBlXFwpKSRWN1xuaWQuYm90aFJldGFpbmVkIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfRzF2c0FzeW5jX2JvdGhSZXRhaW5lZC5iZWRwZVxcKSkkVjdcblxuXG5nZW5lTGlzdC5HMVNwZWNpZmljUGVydCA8LSAoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgaWQuRzFTcGVjaWZpY1BlcnQpICU+JSB1bm5lc3QoZ2VuZSkpJGdlbmVcbmdlbmVMaXN0LkFzeW5jU3BlY2lmaWNQZXJ0IDwtIChnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBpZC5Bc3luY1NwZWNpZmljUGVydCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZVxuZ2VuZUxpc3QuYm90aFBlcnQgPC0gKGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGlkLmJvdGhQZXJ0KSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lXG5nZW5lTGlzdC5ib3RoUmV0YWluZWQgPC0gKGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGlkLmJvdGhSZXRhaW5lZCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZVxuXG5HTy5HMVNwZWNpZmljUGVydC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5HMVNwZWNpZmljUGVydCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbkdPLkFzeW5jU3BlY2lmaWNQZXIuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QuQXN5bmNTcGVjaWZpY1BlcnQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG5HTy5ib3RoUGVydC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ib3RoUGVydCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbkdPLmJvdGhSZXRhaW5lZC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ib3RoUmV0YWluZWQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG5cbnN1YnNldC5HMVNwZWNpZmljUGVydCA8LSBHTy5HMVNwZWNpZmljUGVydC5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxHMVNwZWNpZmljUGVydFxcKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBnciA9IHNhcHBseShHZW5lUmF0aW8sIGZ1bmN0aW9uKHgpIHtcbiAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuICAgICAgcGFydHMgPC0gdW5saXN0KHN0cnNwbGl0KHgsIFxcL1xcKSlcbiAgICAgICMgQ29udmVydCB0byBudW1lcmljIGFuZCBwZXJmb3JtIHRoZSBkaXZpc2lvblxuICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuICAgIH0pXG4gICkgJT4lIGRwbHlyOjphcnJhbmdlKGRlc2MoZ3IpKVxuXG5zdWJzZXQuQXN5bmNTcGVjaWZpY1BlcnQgPC0gR08uQXN5bmNTcGVjaWZpY1Blci5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxBc3luY1NwZWNpZmljUGVydFxcKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBnciA9IHNhcHBseShHZW5lUmF0aW8sIGZ1bmN0aW9uKHgpIHtcbiAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuICAgICAgcGFydHMgPC0gdW5saXN0KHN0cnNwbGl0KHgsIFxcL1xcKSlcbiAgICAgICMgQ29udmVydCB0byBudW1lcmljIGFuZCBwZXJmb3JtIHRoZSBkaXZpc2lvblxuICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuICAgIH0pXG4gICkgJT4lIGRwbHlyOjphcnJhbmdlKGRlc2MoZ3IpKVxuXG5zdWJzZXQuYm90aFBlcnQgPC0gR08uYm90aFBlcnQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcYm90aFBlcnRcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcblxuc3Vic2V0LmJvdGhSZXRhaW5lZCA8LSBHTy5ib3RoUmV0YWluZWQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcYm90aFJldGFpbmVkXFwpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGdyID0gc2FwcGx5KEdlbmVSYXRpbywgZnVuY3Rpb24oeCkge1xuICAgICAgIyBTcGxpdCB0aGUgc3RyaW5nIGJ5IFxcL1xcXG4gICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuICAgICAgIyBDb252ZXJ0IHRvIG51bWVyaWMgYW5kIHBlcmZvcm0gdGhlIGRpdmlzaW9uXG4gICAgICBhcy5udW1lcmljKHBhcnRzWzFdKSAvIGFzLm51bWVyaWMocGFydHNbMl0pXG4gICAgfSlcbiAgKSAlPiUgZHBseXI6OmFycmFuZ2UoZGVzYyhncikpXG5cbmRhdGEgPC0gYmluZF9yb3dzKGJpbmRfcm93cyhzdWJzZXQuRzFTcGVjaWZpY1BlcnQsIHN1YnNldC5ib3RoUGVydCksIHN1YnNldC5ib3RoUmV0YWluZWQpXG5cbnAgPC0gZ2dwbG90KHN1YnNldC5HMVNwZWNpZmljUGVydCwgYWVzKHggPSBncm91cCwgeSA9IERlc2NyaXB0aW9uLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICtcbiAgc2NhbGVfY29sb3JfZ3JhZGllbnQobG93ID0gXFxyZWRcXCwgaGlnaCA9IFxcYmx1ZVxcLCBsaW1pdHMgPSBjKDAsIDAuMDUpKSArXG4gIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICtcbiAgdGhlbWUoYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgICMgU2V0IGF4aXMgdGV4dCBzaXplXG4gICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuICAgICAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICMgU2V0IGxlZ2VuZCB0ZXh0IHNpemVcbiAgICAgICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSkgXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-pe_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2)\n\nid.G1SpecificPert <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\\))$V7\nid.AsyncSpecificPert <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\\))$V7\nid.bothPert <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\\))$V7\nid.bothRetained <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\\))$V7\n\n\ngeneList.G1SpecificPert <- (geneAnnoData %>% dplyr::filter(id %in% id.G1SpecificPert) %>% unnest(gene))$gene\ngeneList.AsyncSpecificPert <- (geneAnnoData %>% dplyr::filter(id %in% id.AsyncSpecificPert) %>% unnest(gene))$gene\ngeneList.bothPert <- (geneAnnoData %>% dplyr::filter(id %in% id.bothPert) %>% unnest(gene))$gene\ngeneList.bothRetained <- (geneAnnoData %>% dplyr::filter(id %in% id.bothRetained) %>% unnest(gene))$gene\n\nGO.G1SpecificPert.df <- as.data.frame(enrichGO(gene = geneList.G1SpecificPert, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO.AsyncSpecificPer.df <- as.data.frame(enrichGO(gene = geneList.AsyncSpecificPert, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO.bothPert.df <- as.data.frame(enrichGO(gene = geneList.bothPert, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\nGO.bothRetained.df <- as.data.frame(enrichGO(gene = geneList.bothRetained, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\))\n\nsubset.G1SpecificPert <- GO.G1SpecificPert.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\G1SpecificPert\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\n\nsubset.AsyncSpecificPert <- GO.AsyncSpecificPer.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\AsyncSpecificPert\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\n\nsubset.bothPert <- GO.bothPert.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\bothPert\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\n\nsubset.bothRetained <- GO.bothRetained.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \\bothRetained\\) %>%\n  dplyr::mutate(\n    gr = sapply(GeneRatio, function(x) {\n      # Split the string by \\/\\\n      parts <- unlist(strsplit(x, \\/\\))\n      # Convert to numeric and perform the division\n      as.numeric(parts[1]) / as.numeric(parts[2])\n    })\n  ) %>% dplyr::arrange(desc(gr))\n\ndata <- bind_rows(bind_rows(subset.G1SpecificPert, subset.bothPert), subset.bothRetained)\n\np <- ggplot(subset.G1SpecificPert, aes(x = group, y = Description, color = p.adjust, size = gr)) + \n  geom_point() + theme_bw() +\n  scale_color_gradient(low = \\red\\, high = \\blue\\, limits = c(0, 0.05)) +\n  scale_size_continuous(range = c(0, 3)) +\n  labs(x = NULL, y = NULL) +\n  theme(axis.text = element_text(size = 6),  # Set axis text size\n        axis.title = element_text(size = 6), # Set axis title size (if not removed)\n        legend.text = element_text(size = 6), # Set legend text size\n        legend.title = element_text(size = 6)) \n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3AtcGVfZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IDAuMilcblxuaWQuRzFTcGVjaWZpY1BlcnQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9HMXZzQXN5bmNfRzFTcGVjaWZpY1BlcnQuYmVkcGVcXCkpJFY3XG5pZC5Bc3luY1NwZWNpZmljUGVydCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0cxdnNBc3luY19Bc3luY1NwZWNpZmljUGVydC5iZWRwZVxcKSkkVjdcbmlkLmJvdGhQZXJ0IDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfRzF2c0FzeW5jX2JvdGhQZXJ0LmJlZHBlXFwpKSRWN1xuaWQuYm90aFJldGFpbmVkIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfRzF2c0FzeW5jX2JvdGhSZXRhaW5lZC5iZWRwZVxcKSkkVjdcblxuXG5nZW5lTGlzdC5HMVNwZWNpZmljUGVydCA8LSAoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgaWQuRzFTcGVjaWZpY1BlcnQpICU+JSB1bm5lc3QoZ2VuZSkpJGdlbmVcbmdlbmVMaXN0LkFzeW5jU3BlY2lmaWNQZXJ0IDwtIChnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBpZC5Bc3luY1NwZWNpZmljUGVydCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZVxuZ2VuZUxpc3QuYm90aFBlcnQgPC0gKGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGlkLmJvdGhQZXJ0KSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lXG5nZW5lTGlzdC5ib3RoUmV0YWluZWQgPC0gKGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGlkLmJvdGhSZXRhaW5lZCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZVxuXG5HTy5HMVNwZWNpZmljUGVydC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5HMVNwZWNpZmljUGVydCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbkdPLkFzeW5jU3BlY2lmaWNQZXIuZGYgPC0gYXMuZGF0YS5mcmFtZShlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QuQXN5bmNTcGVjaWZpY1BlcnQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG5HTy5ib3RoUGVydC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ib3RoUGVydCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKSlcbkdPLmJvdGhSZXRhaW5lZC5kZiA8LSBhcy5kYXRhLmZyYW1lKGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ib3RoUmV0YWluZWQsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXCkpXG5cbnN1YnNldC5HMVNwZWNpZmljUGVydCA8LSBHTy5HMVNwZWNpZmljUGVydC5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxHMVNwZWNpZmljUGVydFxcKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBnciA9IHNhcHBseShHZW5lUmF0aW8sIGZ1bmN0aW9uKHgpIHtcbiAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuICAgICAgcGFydHMgPC0gdW5saXN0KHN0cnNwbGl0KHgsIFxcL1xcKSlcbiAgICAgICMgQ29udmVydCB0byBudW1lcmljIGFuZCBwZXJmb3JtIHRoZSBkaXZpc2lvblxuICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuICAgIH0pXG4gICkgJT4lIGRwbHlyOjphcnJhbmdlKGRlc2MoZ3IpKVxuXG5zdWJzZXQuQXN5bmNTcGVjaWZpY1BlcnQgPC0gR08uQXN5bmNTcGVjaWZpY1Blci5kZiAlPiUgZHBseXI6OnNlbGVjdChJRCwgRGVzY3JpcHRpb24sIEdlbmVSYXRpbywgcC5hZGp1c3QpICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gXFxBc3luY1NwZWNpZmljUGVydFxcKSAlPiVcbiAgZHBseXI6Om11dGF0ZShcbiAgICBnciA9IHNhcHBseShHZW5lUmF0aW8sIGZ1bmN0aW9uKHgpIHtcbiAgICAgICMgU3BsaXQgdGhlIHN0cmluZyBieSBcXC9cXFxuICAgICAgcGFydHMgPC0gdW5saXN0KHN0cnNwbGl0KHgsIFxcL1xcKSlcbiAgICAgICMgQ29udmVydCB0byBudW1lcmljIGFuZCBwZXJmb3JtIHRoZSBkaXZpc2lvblxuICAgICAgYXMubnVtZXJpYyhwYXJ0c1sxXSkgLyBhcy5udW1lcmljKHBhcnRzWzJdKVxuICAgIH0pXG4gICkgJT4lIGRwbHlyOjphcnJhbmdlKGRlc2MoZ3IpKVxuXG5zdWJzZXQuYm90aFBlcnQgPC0gR08uYm90aFBlcnQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcYm90aFBlcnRcXCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoXG4gICAgZ3IgPSBzYXBwbHkoR2VuZVJhdGlvLCBmdW5jdGlvbih4KSB7XG4gICAgICAjIFNwbGl0IHRoZSBzdHJpbmcgYnkgXFwvXFxcbiAgICAgIHBhcnRzIDwtIHVubGlzdChzdHJzcGxpdCh4LCBcXC9cXCkpXG4gICAgICAjIENvbnZlcnQgdG8gbnVtZXJpYyBhbmQgcGVyZm9ybSB0aGUgZGl2aXNpb25cbiAgICAgIGFzLm51bWVyaWMocGFydHNbMV0pIC8gYXMubnVtZXJpYyhwYXJ0c1syXSlcbiAgICB9KVxuICApICU+JSBkcGx5cjo6YXJyYW5nZShkZXNjKGdyKSlcblxuc3Vic2V0LmJvdGhSZXRhaW5lZCA8LSBHTy5ib3RoUmV0YWluZWQuZGYgJT4lIGRwbHlyOjpzZWxlY3QoSUQsIERlc2NyaXB0aW9uLCBHZW5lUmF0aW8sIHAuYWRqdXN0KSAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IFxcYm90aFJldGFpbmVkXFwpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGdyID0gc2FwcGx5KEdlbmVSYXRpbywgZnVuY3Rpb24oeCkge1xuICAgICAgIyBTcGxpdCB0aGUgc3RyaW5nIGJ5IFxcL1xcXG4gICAgICBwYXJ0cyA8LSB1bmxpc3Qoc3Ryc3BsaXQoeCwgXFwvXFwpKVxuICAgICAgIyBDb252ZXJ0IHRvIG51bWVyaWMgYW5kIHBlcmZvcm0gdGhlIGRpdmlzaW9uXG4gICAgICBhcy5udW1lcmljKHBhcnRzWzFdKSAvIGFzLm51bWVyaWMocGFydHNbMl0pXG4gICAgfSlcbiAgKSAlPiUgZHBseXI6OmFycmFuZ2UoZGVzYyhncikpXG5cbmRhdGEgPC0gYmluZF9yb3dzKGJpbmRfcm93cyhzdWJzZXQuRzFTcGVjaWZpY1BlcnQsIHN1YnNldC5ib3RoUGVydCksIHN1YnNldC5ib3RoUmV0YWluZWQpXG5cbnAgPC0gZ2dwbG90KHN1YnNldC5HMVNwZWNpZmljUGVydCwgYWVzKHggPSBncm91cCwgeSA9IERlc2NyaXB0aW9uLCBjb2xvciA9IHAuYWRqdXN0LCBzaXplID0gZ3IpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICtcbiAgc2NhbGVfY29sb3JfZ3JhZGllbnQobG93ID0gXFxyZWRcXCwgaGlnaCA9IFxcYmx1ZVxcLCBsaW1pdHMgPSBjKDAsIDAuMDUpKSArXG4gIHNjYWxlX3NpemVfY29udGludW91cyhyYW5nZSA9IGMoMCwgMykpICtcbiAgbGFicyh4ID0gTlVMTCwgeSA9IE5VTEwpICtcbiAgdGhlbWUoYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSwgICMgU2V0IGF4aXMgdGV4dCBzaXplXG4gICAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IDYpLCAjIFNldCBheGlzIHRpdGxlIHNpemUgKGlmIG5vdCByZW1vdmVkKVxuICAgICAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplID0gNiksICMgU2V0IGxlZ2VuZCB0ZXh0IHNpemVcbiAgICAgICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KHNpemUgPSA2KSkgXG5cbmBgYFxuYGBgIn0= -->

```r
```r
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-pe_ensemblList.tsv\)),
                                      diffCutoff = 0.2)

id.G1SpecificPert <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe\))$V7
id.AsyncSpecificPert <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe\))$V7
id.bothPert <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe\))$V7
id.bothRetained <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe\))$V7


geneList.G1SpecificPert <- (geneAnnoData %>% dplyr::filter(id %in% id.G1SpecificPert) %>% unnest(gene))$gene
geneList.AsyncSpecificPert <- (geneAnnoData %>% dplyr::filter(id %in% id.AsyncSpecificPert) %>% unnest(gene))$gene
geneList.bothPert <- (geneAnnoData %>% dplyr::filter(id %in% id.bothPert) %>% unnest(gene))$gene
geneList.bothRetained <- (geneAnnoData %>% dplyr::filter(id %in% id.bothRetained) %>% unnest(gene))$gene

GO.G1SpecificPert.df <- as.data.frame(enrichGO(gene = geneList.G1SpecificPert, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO.AsyncSpecificPer.df <- as.data.frame(enrichGO(gene = geneList.AsyncSpecificPert, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO.bothPert.df <- as.data.frame(enrichGO(gene = geneList.bothPert, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))
GO.bothRetained.df <- as.data.frame(enrichGO(gene = geneList.bothRetained, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\))

subset.G1SpecificPert <- GO.G1SpecificPert.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \G1SpecificPert\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

subset.AsyncSpecificPert <- GO.AsyncSpecificPer.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \AsyncSpecificPert\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

subset.bothPert <- GO.bothPert.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \bothPert\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

subset.bothRetained <- GO.bothRetained.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = \bothRetained\) %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by \/\
      parts <- unlist(strsplit(x, \/\))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

data <- bind_rows(bind_rows(subset.G1SpecificPert, subset.bothPert), subset.bothRetained)

p <- ggplot(subset.G1SpecificPert, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
  geom_point() + theme_bw() +
  scale_color_gradient(low = \red\, high = \blue\, limits = c(0, 0.05)) +
  scale_size_continuous(range = c(0, 3)) +
  labs(x = NULL, y = NULL) +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Epi

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiX3AtcGVfZW5zZW1ibExpc3QudHN2XCIpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IDAuMilcblxuZ2VuZUxpc3QudXBMb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9kVEFHX0RNU08gPT0gXCJVUFwiKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3Qubm9Mb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9kVEFHX0RNU08gPT0gXCJOT1wiKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3QuZG93bkxvb3AgPC0gdW5pcXVlKChnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIodXBkb3duX2RUQUdfRE1TTyA9PSBcIkRPV05cIikgJT4lIHVubmVzdChnZW5lKSkkZ2VuZSlcblxuXG5cbiMgQ0hFQ0tJTkcgSE9XIE1BTlkgR0VORVMgT1ZFUkxBUCBBTU9ORyBVUC9OTy9ET1dOXG5zZXRzX2xpc3QgPC0gbGlzdCh1cCA9IGdlbmVMaXN0LnVwTG9vcCxcbiAgICAgICAgICAgICAgICAgIG5vID0gZ2VuZUxpc3Qubm9Mb29wLFxuICAgICAgICAgICAgICAgICAgZG93biA9IGdlbmVMaXN0LmRvd25Mb29wKVxuXG4jIENyZWF0ZSB0aGUgRXVsZXIgcGxvdFxuZXVsZXJfZml0IDwtIGV1bGVyKHNldHNfbGlzdClcbnBsb3QoZXVsZXJfZml0LFxuICAgICBsYWJlbHMgPSBUUlVFLCAgIyBEaXNwbGF5IHNldCBsYWJlbHNcbiAgICAgZmlsbHMgPSBUUlVFLCAgICMgQ29sb3IgZmlsbCB0aGUgcmVnaW9uc1xuICAgICBxdWFudGl0aWVzID0gVFJVRSlcblxuXG4jIEdPXG5HTy51cCA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QudXBMb29wLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFwiRU5TRU1CTFwiLCBvbnQgPSBcIkJQXCIpXG5kb3RwbG90KEdPLnVwKVxuR08ubm8gPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0Lm5vTG9vcCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuZG90cGxvdChHTy5ubylcbkdPLmRvd24gPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0LmRvd25Mb29wLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFwiRU5TRU1CTFwiLCBvbnQgPSBcIkJQXCIpXG5kb3RwbG90KEdPLmRvd24pXG5cbiMgR08gdG8gb25seSBzcGVjaWZpYyBzdWJzZXRcbmdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYyA8LSBzZXRkaWZmKGdlbmVMaXN0LnVwTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC5kb3duTG9vcCkpXG5nZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5ub0xvb3AsIHVuaW9uKGdlbmVMaXN0LnVwTG9vcCwgZ2VuZUxpc3QuZG93bkxvb3ApKVxuZ2VuZUxpc3QuZG93bkxvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5kb3duTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC51cExvb3ApKVxuR08udXAgPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuZG90cGxvdChHTy51cClcbkdPLm5vIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXCJFTlNFTUJMXCIsIG9udCA9IFwiQlBcIilcbmRvdHBsb3QoR08ubm8pXG5HTy5kb3duIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5kb3duTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcIkVOU0VNQkxcIiwgb250ID0gXCJCUFwiKVxuZG90cGxvdChHTy5kb3duKVxuXG5cbiMjIENoZWNraW5nIHBlcmNlbnRhZ2Ugb2YgYm9iYmllIGVhcmx5IGdlbmVcblxuIyMgSW1wb3J0aW5nIEJvYmJpZSBnZW5lIGNsYXNzaWZpY2F0aW9uXG5nZW5lQ2x1c3RlciA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJib2JiaWVfZ2VuZV9jbGFzc2lmaWNhdGlvbi5jc3ZcIikpICU+JVxuICBkcGx5cjo6c2VsZWN0KGdlbmUsIGVuc3QsIENsdXN0ZXIpXG5jb2xuYW1lcyhnZW5lQ2x1c3RlcikgPC0gYyhcImdlbmVcIiwgXCJlbnNlbWJsX3RyYW5zY3JpcHRfaWRcIiwgXCJjbHVzdGVyXCIpXG5cblxuIyMgQ29udmVydGluZyB0cmFuc2NyaXB0IElEIHRvIGdlbmUgSURcbmlkUGFpcl90ZyA8LSBnZXRCTShhdHRyaWJ1dGVzID0gYyhcImVuc2VtYmxfdHJhbnNjcmlwdF9pZFwiLCBcImVuc2VtYmxfZ2VuZV9pZFwiKSxcbiAgICAgICAgICAgICAgICAgZmlsdGVycyA9IFwiZW5zZW1ibF90cmFuc2NyaXB0X2lkXCIsXG4gICAgICAgICAgICAgICAgIHZhbHVlcyA9IGdlbmVDbHVzdGVyJGVuc2VtYmxfdHJhbnNjcmlwdCxcbiAgICAgICAgICAgICAgICAgbWFydCA9IGVuc2VtYmwudjEwMilcbmdlbmVDbHVzdGVyIDwtIGdlbmVDbHVzdGVyICU+JSBkcGx5cjo6bGVmdF9qb2luKGlkUGFpcl90ZywgYnkgPSBjKFwiZW5zZW1ibF90cmFuc2NyaXB0X2lkXCIpKVxuXG4jIE1ha2luZyBkYXRhIGZvciBzdGFja2VkIGJhcnBsb3RcbmNvdW50R2VuZSA8LSBmdW5jdGlvbihnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBjbHVzdGVyTmFtZSl7XG4gIG51bSA8LSBucm93KGdlbmVDbHVzdGVyICU+JSBkcGx5cjo6ZmlsdGVyKGVuc2VtYmxfZ2VuZV9pZCAlaW4lIGdyb3VwTmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2x1c3RlciAlaW4lIGNsdXN0ZXJOYW1lKSlcbiAgcmV0dXJuKG51bSlcbn1cbmNvdW50R2VuZUxpc3QgPC0gZnVuY3Rpb24oZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSl7XG4gIG4xIDwtIGNvdW50R2VuZShnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBcIkVhcmx5XCIpXG4gIG4yIDwtIGNvdW50R2VuZShnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBcIk1pZGRsZVwiKVxuICBuMyA8LWNvdW50R2VuZShnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBcIkxhdGVcIilcbiAgbjQgPC0gY291bnRHZW5lKGdlbmVDbHVzdGVyLCBncm91cE5hbWUsIFwiVHJhbnNpZW50XCIpXG4gIHJldHVybihjKG4xLCBuMiwgbjMsIG40KSlcbn1cblxuZ3JvdXAgPC0gYyhyZXAoXCJ1cFwiLCA0KSwgcmVwKFwibm9cIiwgNCksIHJlcChcImRvd25cIiwgNCkpXG5jbHVzdGVyIDwtIHJlcChjKFwiRWFybHlcIiwgXCJNaWRkbGVcIiwgXCJMYXRlXCIsIFwiVHJhbnNpZW50XCIpLCAzKVxuY2x1c3RlciA8LSBmYWN0b3IoY2x1c3RlciwgbGV2ZWxzID0gYyhcIkVhcmx5XCIsIFwiTWlkZGxlXCIsIFwiTGF0ZVwiLCBcIlRyYW5zaWVudFwiKSlcbnZhbHVlIDwtIGMoY291bnRHZW5lTGlzdChnZW5lQ2x1c3RlciwgZ2VuZUxpc3QudXBMb29wKSxcbiAgICAgICAgICAgY291bnRHZW5lTGlzdChnZW5lQ2x1c3RlciwgZ2VuZUxpc3Qubm9Mb29wKSxcbiAgICAgICAgICAgY291bnRHZW5lTGlzdChnZW5lQ2x1c3RlciwgZ2VuZUxpc3QuZG93bkxvb3ApKVxuXG5kYXRhIDwtIGRhdGEuZnJhbWUoZ3JvdXAsIGNsdXN0ZXIsIHZhbHVlKVxuZ2dwbG90KGRhdGEsIGFlcyhmaWxsPWNsdXN0ZXIsIHk9dmFsdWUsIHg9Z3JvdXApKSArIFxuICAgIGdlb21fYmFyKHBvc2l0aW9uPVwic3RhY2tcIiwgc3RhdCA9IFwiaWRlbnRpdHlcIikgKyB0aGVtZV9jbGFzc2ljKClcbmdncGxvdChkYXRhLCBhZXMoZmlsbD1jbHVzdGVyLCB5PXZhbHVlLCB4PWdyb3VwKSkgKyBcbiAgICBnZW9tX2Jhcihwb3NpdGlvbj1cImZpbGxcIiwgc3RhdCA9IFwiaWRlbnRpdHlcIikgKyB0aGVtZV9jbGFzc2ljKClcblxudmFsdWUgPC0gYyhjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBnZW5lTGlzdC51cExvb3Auc3BlY2lmaWMpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBnZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBnZW5lTGlzdC5kb3duTG9vcC5zcGVjaWZpYykpXG5cbmRhdGEgPC0gZGF0YS5mcmFtZShncm91cCwgY2x1c3RlciwgdmFsdWUpXG4jIFBsb3R0aW5nXG5nZ3Bsb3QoZGF0YSwgYWVzKGZpbGw9Y2x1c3RlciwgeT12YWx1ZSwgeD1ncm91cCkpICsgXG4gICAgZ2VvbV9iYXIocG9zaXRpb249XCJzdGFja1wiLCBzdGF0ID0gXCJpZGVudGl0eVwiKSArIHRoZW1lX2NsYXNzaWMoKVxuZ2dwbG90KGRhdGEsIGFlcyhmaWxsPWNsdXN0ZXIsIHk9dmFsdWUsIHg9Z3JvdXApKSArIFxuICAgIGdlb21fYmFyKHBvc2l0aW9uPVwiZmlsbFwiLCBzdGF0ID0gXCJpZGVudGl0eVwiKSArIHRoZW1lX2NsYXNzaWMoKVxuXG5gYGAifQ== -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-pe_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2)\n\ngeneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\UP\\) %>% unnest(gene))$gene)\ngeneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\NO\\) %>% unnest(gene))$gene)\ngeneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\DOWN\\) %>% unnest(gene))$gene)\n\n\n\n# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN\nsets_list <- list(up = geneList.upLoop,\n                  no = geneList.noLoop,\n                  down = geneList.downLoop)\n\n# Create the Euler plot\neuler_fit <- euler(sets_list)\nplot(euler_fit,\n     labels = TRUE,  # Display set labels\n     fills = TRUE,   # Color fill the regions\n     quantities = TRUE)\n\n\n# GO\nGO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.down)\n\n# GO to only specific subset\ngeneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))\ngeneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))\ngeneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))\nGO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.down)\n\n\n## Checking percentage of bobbie early gene\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \\bobbie_gene_classification.csv\\)) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\\gene\\, \\ensembl_transcript_id\\, \\cluster\\)\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\\ensembl_transcript_id\\, \\ensembl_gene_id\\),\n                 filters = \\ensembl_transcript_id\\,\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\\ensembl_transcript_id\\))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \\Early\\)\n  n2 <- countGene(geneCluster, groupName, \\Middle\\)\n  n3 <-countGene(geneCluster, groupName, \\Late\\)\n  n4 <- countGene(geneCluster, groupName, \\Transient\\)\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\\up\\, 4), rep(\\no\\, 4), rep(\\down\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 3)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, geneList.upLoop),\n           countGeneList(geneCluster, geneList.noLoop),\n           countGeneList(geneCluster, geneList.downLoop))\n\ndata <- data.frame(group, cluster, value)\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\stack\\, stat = \\identity\\) + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat = \\identity\\) + theme_classic()\n\nvalue <- c(countGeneList(geneCluster, geneList.upLoop.specific),\n           countGeneList(geneCluster, geneList.noLoop.specific),\n           countGeneList(geneCluster, geneList.downLoop.specific))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\stack\\, stat = \\identity\\) + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat = \\identity\\) + theme_classic()\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-pe_ensemblList.tsv\)),
                                      diffCutoff = 0.2)

geneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \UP\) %>% unnest(gene))$gene)
geneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \NO\) %>% unnest(gene))$gene)
geneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \DOWN\) %>% unnest(gene))$gene)



# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN
sets_list <- list(up = geneList.upLoop,
                  no = geneList.noLoop,
                  down = geneList.downLoop)

# Create the Euler plot
euler_fit <- euler(sets_list)
plot(euler_fit,
     labels = TRUE,  # Display set labels
     fills = TRUE,   # Color fill the regions
     quantities = TRUE)


# GO
GO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down)

# GO to only specific subset
geneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))
geneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))
geneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))
GO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down)


## Checking percentage of bobbie early gene

## Importing Bobbie gene classification
geneCluster <- fread(here(refDir, \bobbie_gene_classification.csv\)) %>%
  dplyr::select(gene, enst, Cluster)
colnames(geneCluster) <- c(\gene\, \ensembl_transcript_id\, \cluster\)


## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c(\ensembl_transcript_id\, \ensembl_gene_id\),
                 filters = \ensembl_transcript_id\,
                 values = geneCluster$ensembl_transcript,
                 mart = ensembl.v102)
geneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\ensembl_transcript_id\))

# Making data for stacked barplot
countGene <- function(geneCluster, groupName, clusterName){
  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,
                                            cluster %in% clusterName))
  return(num)
}
countGeneList <- function(geneCluster, groupName){
  n1 <- countGene(geneCluster, groupName, \Early\)
  n2 <- countGene(geneCluster, groupName, \Middle\)
  n3 <-countGene(geneCluster, groupName, \Late\)
  n4 <- countGene(geneCluster, groupName, \Transient\)
  return(c(n1, n2, n3, n4))
}

group <- c(rep(\up\, 4), rep(\no\, 4), rep(\down\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 3)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, geneList.upLoop),
           countGeneList(geneCluster, geneList.noLoop),
           countGeneList(geneCluster, geneList.downLoop))

data <- data.frame(group, cluster, value)
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\stack\, stat = \identity\) + theme_classic()
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat = \identity\) + theme_classic()

value <- c(countGeneList(geneCluster, geneList.upLoop.specific),
           countGeneList(geneCluster, geneList.noLoop.specific),
           countGeneList(geneCluster, geneList.downLoop.specific))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\stack\, stat = \identity\) + theme_classic()
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat = \identity\) + theme_classic()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3AtcGVfZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IDAuMilcblxuZ2VuZUxpc3QudXBMb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9kVEFHX0RNU08gPT0gXFxVUFxcKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3Qubm9Mb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9kVEFHX0RNU08gPT0gXFxOT1xcKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3QuZG93bkxvb3AgPC0gdW5pcXVlKChnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIodXBkb3duX2RUQUdfRE1TTyA9PSBcXERPV05cXCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZSlcblxuXG5cbiMgQ0hFQ0tJTkcgSE9XIE1BTlkgR0VORVMgT1ZFUkxBUCBBTU9ORyBVUC9OTy9ET1dOXG5zZXRzX2xpc3QgPC0gbGlzdCh1cCA9IGdlbmVMaXN0LnVwTG9vcCxcbiAgICAgICAgICAgICAgICAgIG5vID0gZ2VuZUxpc3Qubm9Mb29wLFxuICAgICAgICAgICAgICAgICAgZG93biA9IGdlbmVMaXN0LmRvd25Mb29wKVxuXG4jIENyZWF0ZSB0aGUgRXVsZXIgcGxvdFxuZXVsZXJfZml0IDwtIGV1bGVyKHNldHNfbGlzdClcbnBsb3QoZXVsZXJfZml0LFxuICAgICBsYWJlbHMgPSBUUlVFLCAgIyBEaXNwbGF5IHNldCBsYWJlbHNcbiAgICAgZmlsbHMgPSBUUlVFLCAgICMgQ29sb3IgZmlsbCB0aGUgcmVnaW9uc1xuICAgICBxdWFudGl0aWVzID0gVFJVRSlcblxuXG4jIEdPXG5HTy51cCA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QudXBMb29wLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpXG5kb3RwbG90KEdPLnVwKVxuR08ubm8gPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0Lm5vTG9vcCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy5ubylcbkdPLmRvd24gPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0LmRvd25Mb29wLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpXG5kb3RwbG90KEdPLmRvd24pXG5cbiMgR08gdG8gb25seSBzcGVjaWZpYyBzdWJzZXRcbmdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYyA8LSBzZXRkaWZmKGdlbmVMaXN0LnVwTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC5kb3duTG9vcCkpXG5nZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5ub0xvb3AsIHVuaW9uKGdlbmVMaXN0LnVwTG9vcCwgZ2VuZUxpc3QuZG93bkxvb3ApKVxuZ2VuZUxpc3QuZG93bkxvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5kb3duTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC51cExvb3ApKVxuR08udXAgPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy51cClcbkdPLm5vIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08ubm8pXG5HTy5kb3duIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5kb3duTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy5kb3duKVxuXG5cbiMjIENoZWNraW5nIHBlcmNlbnRhZ2Ugb2YgYm9iYmllIGVhcmx5IGdlbmVcblxuIyMgSW1wb3J0aW5nIEJvYmJpZSBnZW5lIGNsYXNzaWZpY2F0aW9uXG5nZW5lQ2x1c3RlciA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxib2JiaWVfZ2VuZV9jbGFzc2lmaWNhdGlvbi5jc3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGdlbmUsIGVuc3QsIENsdXN0ZXIpXG5jb2xuYW1lcyhnZW5lQ2x1c3RlcikgPC0gYyhcXGdlbmVcXCwgXFxlbnNlbWJsX3RyYW5zY3JpcHRfaWRcXCwgXFxjbHVzdGVyXFwpXG5cblxuIyMgQ29udmVydGluZyB0cmFuc2NyaXB0IElEIHRvIGdlbmUgSURcbmlkUGFpcl90ZyA8LSBnZXRCTShhdHRyaWJ1dGVzID0gYyhcXGVuc2VtYmxfdHJhbnNjcmlwdF9pZFxcLCBcXGVuc2VtYmxfZ2VuZV9pZFxcKSxcbiAgICAgICAgICAgICAgICAgZmlsdGVycyA9IFxcZW5zZW1ibF90cmFuc2NyaXB0X2lkXFwsXG4gICAgICAgICAgICAgICAgIHZhbHVlcyA9IGdlbmVDbHVzdGVyJGVuc2VtYmxfdHJhbnNjcmlwdCxcbiAgICAgICAgICAgICAgICAgbWFydCA9IGVuc2VtYmwudjEwMilcbmdlbmVDbHVzdGVyIDwtIGdlbmVDbHVzdGVyICU+JSBkcGx5cjo6bGVmdF9qb2luKGlkUGFpcl90ZywgYnkgPSBjKFxcZW5zZW1ibF90cmFuc2NyaXB0X2lkXFwpKVxuXG4jIE1ha2luZyBkYXRhIGZvciBzdGFja2VkIGJhcnBsb3RcbmNvdW50R2VuZSA8LSBmdW5jdGlvbihnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBjbHVzdGVyTmFtZSl7XG4gIG51bSA8LSBucm93KGdlbmVDbHVzdGVyICU+JSBkcGx5cjo6ZmlsdGVyKGVuc2VtYmxfZ2VuZV9pZCAlaW4lIGdyb3VwTmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2x1c3RlciAlaW4lIGNsdXN0ZXJOYW1lKSlcbiAgcmV0dXJuKG51bSlcbn1cbmNvdW50R2VuZUxpc3QgPC0gZnVuY3Rpb24oZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSl7XG4gIG4xIDwtIGNvdW50R2VuZShnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBcXEVhcmx5XFwpXG4gIG4yIDwtIGNvdW50R2VuZShnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBcXE1pZGRsZVxcKVxuICBuMyA8LWNvdW50R2VuZShnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBcXExhdGVcXClcbiAgbjQgPC0gY291bnRHZW5lKGdlbmVDbHVzdGVyLCBncm91cE5hbWUsIFxcVHJhbnNpZW50XFwpXG4gIHJldHVybihjKG4xLCBuMiwgbjMsIG40KSlcbn1cblxuZ3JvdXAgPC0gYyhyZXAoXFx1cFxcLCA0KSwgcmVwKFxcbm9cXCwgNCksIHJlcChcXGRvd25cXCwgNCkpXG5jbHVzdGVyIDwtIHJlcChjKFxcRWFybHlcXCwgXFxNaWRkbGVcXCwgXFxMYXRlXFwsIFxcVHJhbnNpZW50XFwpLCAzKVxuY2x1c3RlciA8LSBmYWN0b3IoY2x1c3RlciwgbGV2ZWxzID0gYyhcXEVhcmx5XFwsIFxcTWlkZGxlXFwsIFxcTGF0ZVxcLCBcXFRyYW5zaWVudFxcKSlcbnZhbHVlIDwtIGMoY291bnRHZW5lTGlzdChnZW5lQ2x1c3RlciwgZ2VuZUxpc3QudXBMb29wKSxcbiAgICAgICAgICAgY291bnRHZW5lTGlzdChnZW5lQ2x1c3RlciwgZ2VuZUxpc3Qubm9Mb29wKSxcbiAgICAgICAgICAgY291bnRHZW5lTGlzdChnZW5lQ2x1c3RlciwgZ2VuZUxpc3QuZG93bkxvb3ApKVxuXG5kYXRhIDwtIGRhdGEuZnJhbWUoZ3JvdXAsIGNsdXN0ZXIsIHZhbHVlKVxuZ2dwbG90KGRhdGEsIGFlcyhmaWxsPWNsdXN0ZXIsIHk9dmFsdWUsIHg9Z3JvdXApKSArIFxuICAgIGdlb21fYmFyKHBvc2l0aW9uPVxcc3RhY2tcXCwgc3RhdCA9IFxcaWRlbnRpdHlcXCkgKyB0aGVtZV9jbGFzc2ljKClcbmdncGxvdChkYXRhLCBhZXMoZmlsbD1jbHVzdGVyLCB5PXZhbHVlLCB4PWdyb3VwKSkgKyBcbiAgICBnZW9tX2Jhcihwb3NpdGlvbj1cXGZpbGxcXCwgc3RhdCA9IFxcaWRlbnRpdHlcXCkgKyB0aGVtZV9jbGFzc2ljKClcblxudmFsdWUgPC0gYyhjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBnZW5lTGlzdC51cExvb3Auc3BlY2lmaWMpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBnZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBnZW5lTGlzdC5kb3duTG9vcC5zcGVjaWZpYykpXG5cbmRhdGEgPC0gZGF0YS5mcmFtZShncm91cCwgY2x1c3RlciwgdmFsdWUpXG4jIFBsb3R0aW5nXG5nZ3Bsb3QoZGF0YSwgYWVzKGZpbGw9Y2x1c3RlciwgeT12YWx1ZSwgeD1ncm91cCkpICsgXG4gICAgZ2VvbV9iYXIocG9zaXRpb249XFxzdGFja1xcLCBzdGF0ID0gXFxpZGVudGl0eVxcKSArIHRoZW1lX2NsYXNzaWMoKVxuZ2dwbG90KGRhdGEsIGFlcyhmaWxsPWNsdXN0ZXIsIHk9dmFsdWUsIHg9Z3JvdXApKSArIFxuICAgIGdlb21fYmFyKHBvc2l0aW9uPVxcZmlsbFxcLCBzdGF0ID0gXFxpZGVudGl0eVxcKSArIHRoZW1lX2NsYXNzaWMoKVxuXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-pe_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2)\n\ngeneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\UP\\) %>% unnest(gene))$gene)\ngeneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\NO\\) %>% unnest(gene))$gene)\ngeneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\DOWN\\) %>% unnest(gene))$gene)\n\n\n\n# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN\nsets_list <- list(up = geneList.upLoop,\n                  no = geneList.noLoop,\n                  down = geneList.downLoop)\n\n# Create the Euler plot\neuler_fit <- euler(sets_list)\nplot(euler_fit,\n     labels = TRUE,  # Display set labels\n     fills = TRUE,   # Color fill the regions\n     quantities = TRUE)\n\n\n# GO\nGO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.down)\n\n# GO to only specific subset\ngeneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))\ngeneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))\ngeneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))\nGO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.down)\n\n\n## Checking percentage of bobbie early gene\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \\bobbie_gene_classification.csv\\)) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\\gene\\, \\ensembl_transcript_id\\, \\cluster\\)\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\\ensembl_transcript_id\\, \\ensembl_gene_id\\),\n                 filters = \\ensembl_transcript_id\\,\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\\ensembl_transcript_id\\))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \\Early\\)\n  n2 <- countGene(geneCluster, groupName, \\Middle\\)\n  n3 <-countGene(geneCluster, groupName, \\Late\\)\n  n4 <- countGene(geneCluster, groupName, \\Transient\\)\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\\up\\, 4), rep(\\no\\, 4), rep(\\down\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 3)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, geneList.upLoop),\n           countGeneList(geneCluster, geneList.noLoop),\n           countGeneList(geneCluster, geneList.downLoop))\n\ndata <- data.frame(group, cluster, value)\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\stack\\, stat = \\identity\\) + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat = \\identity\\) + theme_classic()\n\nvalue <- c(countGeneList(geneCluster, geneList.upLoop.specific),\n           countGeneList(geneCluster, geneList.noLoop.specific),\n           countGeneList(geneCluster, geneList.downLoop.specific))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\stack\\, stat = \\identity\\) + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat = \\identity\\) + theme_classic()\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3AtcGVfZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IDAuMilcblxuZ2VuZUxpc3QudXBMb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9kVEFHX0RNU08gPT0gXFxVUFxcKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3Qubm9Mb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9kVEFHX0RNU08gPT0gXFxOT1xcKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3QuZG93bkxvb3AgPC0gdW5pcXVlKChnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIodXBkb3duX2RUQUdfRE1TTyA9PSBcXERPV05cXCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZSlcblxuXG5cbiMgQ0hFQ0tJTkcgSE9XIE1BTlkgR0VORVMgT1ZFUkxBUCBBTU9ORyBVUC9OTy9ET1dOXG5zZXRzX2xpc3QgPC0gbGlzdCh1cCA9IGdlbmVMaXN0LnVwTG9vcCxcbiAgICAgICAgICAgICAgICAgIG5vID0gZ2VuZUxpc3Qubm9Mb29wLFxuICAgICAgICAgICAgICAgICAgZG93biA9IGdlbmVMaXN0LmRvd25Mb29wKVxuXG4jIENyZWF0ZSB0aGUgRXVsZXIgcGxvdFxuZXVsZXJfZml0IDwtIGV1bGVyKHNldHNfbGlzdClcbnBsb3QoZXVsZXJfZml0LFxuICAgICBsYWJlbHMgPSBUUlVFLCAgIyBEaXNwbGF5IHNldCBsYWJlbHNcbiAgICAgZmlsbHMgPSBUUlVFLCAgICMgQ29sb3IgZmlsbCB0aGUgcmVnaW9uc1xuICAgICBxdWFudGl0aWVzID0gVFJVRSlcblxuXG4jIEdPXG5HTy51cCA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QudXBMb29wLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpXG5kb3RwbG90KEdPLnVwKVxuR08ubm8gPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0Lm5vTG9vcCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy5ubylcbkdPLmRvd24gPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0LmRvd25Mb29wLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpXG5kb3RwbG90KEdPLmRvd24pXG5cbiMgR08gdG8gb25seSBzcGVjaWZpYyBzdWJzZXRcbmdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYyA8LSBzZXRkaWZmKGdlbmVMaXN0LnVwTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC5kb3duTG9vcCkpXG5nZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5ub0xvb3AsIHVuaW9uKGdlbmVMaXN0LnVwTG9vcCwgZ2VuZUxpc3QuZG93bkxvb3ApKVxuZ2VuZUxpc3QuZG93bkxvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5kb3duTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC51cExvb3ApKVxuR08udXAgPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy51cClcbkdPLm5vIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08ubm8pXG5HTy5kb3duIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5kb3duTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy5kb3duKVxuXG5cbiMjIENoZWNraW5nIHBlcmNlbnRhZ2Ugb2YgYm9iYmllIGVhcmx5IGdlbmVcblxuIyMgSW1wb3J0aW5nIEJvYmJpZSBnZW5lIGNsYXNzaWZpY2F0aW9uXG5nZW5lQ2x1c3RlciA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxib2JiaWVfZ2VuZV9jbGFzc2lmaWNhdGlvbi5jc3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGdlbmUsIGVuc3QsIENsdXN0ZXIpXG5jb2xuYW1lcyhnZW5lQ2x1c3RlcikgPC0gYyhcXGdlbmVcXCwgXFxlbnNlbWJsX3RyYW5zY3JpcHRfaWRcXCwgXFxjbHVzdGVyXFwpXG5cblxuIyMgQ29udmVydGluZyB0cmFuc2NyaXB0IElEIHRvIGdlbmUgSURcbmlkUGFpcl90ZyA8LSBnZXRCTShhdHRyaWJ1dGVzID0gYyhcXGVuc2VtYmxfdHJhbnNjcmlwdF9pZFxcLCBcXGVuc2VtYmxfZ2VuZV9pZFxcKSxcbiAgICAgICAgICAgICAgICAgZmlsdGVycyA9IFxcZW5zZW1ibF90cmFuc2NyaXB0X2lkXFwsXG4gICAgICAgICAgICAgICAgIHZhbHVlcyA9IGdlbmVDbHVzdGVyJGVuc2VtYmxfdHJhbnNjcmlwdCxcbiAgICAgICAgICAgICAgICAgbWFydCA9IGVuc2VtYmwudjEwMilcbmdlbmVDbHVzdGVyIDwtIGdlbmVDbHVzdGVyICU+JSBkcGx5cjo6bGVmdF9qb2luKGlkUGFpcl90ZywgYnkgPSBjKFxcZW5zZW1ibF90cmFuc2NyaXB0X2lkXFwpKVxuXG4jIE1ha2luZyBkYXRhIGZvciBzdGFja2VkIGJhcnBsb3RcbmNvdW50R2VuZSA8LSBmdW5jdGlvbihnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBjbHVzdGVyTmFtZSl7XG4gIG51bSA8LSBucm93KGdlbmVDbHVzdGVyICU+JSBkcGx5cjo6ZmlsdGVyKGVuc2VtYmxfZ2VuZV9pZCAlaW4lIGdyb3VwTmFtZSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2x1c3RlciAlaW4lIGNsdXN0ZXJOYW1lKSlcbiAgcmV0dXJuKG51bSlcbn1cbmNvdW50R2VuZUxpc3QgPC0gZnVuY3Rpb24oZ2VuZUNsdXN0ZXIsIGdyb3VwTmFtZSl7XG4gIG4xIDwtIGNvdW50R2VuZShnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBcXEVhcmx5XFwpXG4gIG4yIDwtIGNvdW50R2VuZShnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBcXE1pZGRsZVxcKVxuICBuMyA8LWNvdW50R2VuZShnZW5lQ2x1c3RlciwgZ3JvdXBOYW1lLCBcXExhdGVcXClcbiAgbjQgPC0gY291bnRHZW5lKGdlbmVDbHVzdGVyLCBncm91cE5hbWUsIFxcVHJhbnNpZW50XFwpXG4gIHJldHVybihjKG4xLCBuMiwgbjMsIG40KSlcbn1cblxuZ3JvdXAgPC0gYyhyZXAoXFx1cFxcLCA0KSwgcmVwKFxcbm9cXCwgNCksIHJlcChcXGRvd25cXCwgNCkpXG5jbHVzdGVyIDwtIHJlcChjKFxcRWFybHlcXCwgXFxNaWRkbGVcXCwgXFxMYXRlXFwsIFxcVHJhbnNpZW50XFwpLCAzKVxuY2x1c3RlciA8LSBmYWN0b3IoY2x1c3RlciwgbGV2ZWxzID0gYyhcXEVhcmx5XFwsIFxcTWlkZGxlXFwsIFxcTGF0ZVxcLCBcXFRyYW5zaWVudFxcKSlcbnZhbHVlIDwtIGMoY291bnRHZW5lTGlzdChnZW5lQ2x1c3RlciwgZ2VuZUxpc3QudXBMb29wKSxcbiAgICAgICAgICAgY291bnRHZW5lTGlzdChnZW5lQ2x1c3RlciwgZ2VuZUxpc3Qubm9Mb29wKSxcbiAgICAgICAgICAgY291bnRHZW5lTGlzdChnZW5lQ2x1c3RlciwgZ2VuZUxpc3QuZG93bkxvb3ApKVxuXG5kYXRhIDwtIGRhdGEuZnJhbWUoZ3JvdXAsIGNsdXN0ZXIsIHZhbHVlKVxuZ2dwbG90KGRhdGEsIGFlcyhmaWxsPWNsdXN0ZXIsIHk9dmFsdWUsIHg9Z3JvdXApKSArIFxuICAgIGdlb21fYmFyKHBvc2l0aW9uPVxcc3RhY2tcXCwgc3RhdCA9IFxcaWRlbnRpdHlcXCkgKyB0aGVtZV9jbGFzc2ljKClcbmdncGxvdChkYXRhLCBhZXMoZmlsbD1jbHVzdGVyLCB5PXZhbHVlLCB4PWdyb3VwKSkgKyBcbiAgICBnZW9tX2Jhcihwb3NpdGlvbj1cXGZpbGxcXCwgc3RhdCA9IFxcaWRlbnRpdHlcXCkgKyB0aGVtZV9jbGFzc2ljKClcblxudmFsdWUgPC0gYyhjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBnZW5lTGlzdC51cExvb3Auc3BlY2lmaWMpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBnZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMpLFxuICAgICAgICAgICBjb3VudEdlbmVMaXN0KGdlbmVDbHVzdGVyLCBnZW5lTGlzdC5kb3duTG9vcC5zcGVjaWZpYykpXG5cbmRhdGEgPC0gZGF0YS5mcmFtZShncm91cCwgY2x1c3RlciwgdmFsdWUpXG4jIFBsb3R0aW5nXG5nZ3Bsb3QoZGF0YSwgYWVzKGZpbGw9Y2x1c3RlciwgeT12YWx1ZSwgeD1ncm91cCkpICsgXG4gICAgZ2VvbV9iYXIocG9zaXRpb249XFxzdGFja1xcLCBzdGF0ID0gXFxpZGVudGl0eVxcKSArIHRoZW1lX2NsYXNzaWMoKVxuZ2dwbG90KGRhdGEsIGFlcyhmaWxsPWNsdXN0ZXIsIHk9dmFsdWUsIHg9Z3JvdXApKSArIFxuICAgIGdlb21fYmFyKHBvc2l0aW9uPVxcZmlsbFxcLCBzdGF0ID0gXFxpZGVudGl0eVxcKSArIHRoZW1lX2NsYXNzaWMoKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-pe_ensemblList.tsv\)),
                                      diffCutoff = 0.2)

geneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \UP\) %>% unnest(gene))$gene)
geneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \NO\) %>% unnest(gene))$gene)
geneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \DOWN\) %>% unnest(gene))$gene)



# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN
sets_list <- list(up = geneList.upLoop,
                  no = geneList.noLoop,
                  down = geneList.downLoop)

# Create the Euler plot
euler_fit <- euler(sets_list)
plot(euler_fit,
     labels = TRUE,  # Display set labels
     fills = TRUE,   # Color fill the regions
     quantities = TRUE)


# GO
GO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down)

# GO to only specific subset
geneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))
geneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))
geneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))
GO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down)


## Checking percentage of bobbie early gene

## Importing Bobbie gene classification
geneCluster <- fread(here(refDir, \bobbie_gene_classification.csv\)) %>%
  dplyr::select(gene, enst, Cluster)
colnames(geneCluster) <- c(\gene\, \ensembl_transcript_id\, \cluster\)


## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c(\ensembl_transcript_id\, \ensembl_gene_id\),
                 filters = \ensembl_transcript_id\,
                 values = geneCluster$ensembl_transcript,
                 mart = ensembl.v102)
geneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\ensembl_transcript_id\))

# Making data for stacked barplot
countGene <- function(geneCluster, groupName, clusterName){
  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,
                                            cluster %in% clusterName))
  return(num)
}
countGeneList <- function(geneCluster, groupName){
  n1 <- countGene(geneCluster, groupName, \Early\)
  n2 <- countGene(geneCluster, groupName, \Middle\)
  n3 <-countGene(geneCluster, groupName, \Late\)
  n4 <- countGene(geneCluster, groupName, \Transient\)
  return(c(n1, n2, n3, n4))
}

group <- c(rep(\up\, 4), rep(\no\, 4), rep(\down\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 3)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, geneList.upLoop),
           countGeneList(geneCluster, geneList.noLoop),
           countGeneList(geneCluster, geneList.downLoop))

data <- data.frame(group, cluster, value)
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\stack\, stat = \identity\) + theme_classic()
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat = \identity\) + theme_classic()

value <- c(countGeneList(geneCluster, geneList.upLoop.specific),
           countGeneList(geneCluster, geneList.noLoop.specific),
           countGeneList(geneCluster, geneList.downLoop.specific))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\stack\, stat = \identity\) + theme_classic()
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat = \identity\) + theme_classic()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



## [2.25] Checking genes related to regulatory loops
### dTAG, Comparing to Async
#### P-P, P-E

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\nname <- \"chromo_cons_annoHierarchy\"\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = 0.2)\n\ngeneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \"UP\") %>% unnest(gene))$gene)\ngeneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \"NO\") %>% unnest(gene))$gene)\ngeneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \"DOWN\") %>% unnest(gene))$gene)\n\n\n\n# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN\nsets_list <- list(up = geneList.upLoop,\n                  no = geneList.noLoop,\n                  down = geneList.downLoop)\n\n# Create the Euler plot\neuler_fit <- euler(sets_list)\nplot(euler_fit,\n     labels = TRUE,  # Display set labels\n     fills = TRUE,   # Color fill the regions\n     quantities = TRUE)\n\n\n# GO\nGO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\")\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\")\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\")\ndotplot(GO.down)\n\n# GO to only specific subset\ngeneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))\ngeneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))\ngeneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))\nGO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\")\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\")\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \"ENSEMBL\", ont = \"BP\")\ndotplot(GO.down)\n\n\n## Checking percentage of bobbie early gene\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \"bobbie_gene_classification.csv\")) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\"gene\", \"ensembl_transcript_id\", \"cluster\")\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\"ensembl_transcript_id\", \"ensembl_gene_id\"),\n                 filters = \"ensembl_transcript_id\",\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\"ensembl_transcript_id\"))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \"Early\")\n  n2 <- countGene(geneCluster, groupName, \"Middle\")\n  n3 <-countGene(geneCluster, groupName, \"Late\")\n  n4 <- countGene(geneCluster, groupName, \"Transient\")\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\"up\", 4), rep(\"no\", 4), rep(\"down\", 4))\ncluster <- rep(c(\"Early\", \"Middle\", \"Late\", \"Transient\"), 3)\ncluster <- factor(cluster, levels = c(\"Early\", \"Middle\", \"Late\", \"Transient\"))\nvalue <- c(countGeneList(geneCluster, geneList.upLoop),\n           countGeneList(geneCluster, geneList.noLoop),\n           countGeneList(geneCluster, geneList.downLoop))\n\ndata <- data.frame(group, cluster, value)\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\"stack\", stat = \"identity\") + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\"fill\", stat = \"identity\") + theme_classic()\n\nvalue <- c(countGeneList(geneCluster, geneList.upLoop.specific),\n           countGeneList(geneCluster, geneList.noLoop.specific),\n           countGeneList(geneCluster, geneList.downLoop.specific))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\"stack\", stat = \"identity\") + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\"fill\", stat = \"identity\") + theme_classic()\n\n\n\n################## Checking how those genes behave in A485\ndiff.RNA <- fread(here(refDir, \"diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \"UP\",\n                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \"DOWN\",\n                                            TRUE ~ \"NO\"),\n                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoop ~ \"cohesin-upLoop\",\n                                                 ensembl_gene_id %in% geneList.noLoop ~ \"cohesin-noLoop\",\n                                                 ensembl_gene_id %in% geneList.downLoop ~ \"cohesin-downLoop\",\n                                                 TRUE ~ \"NA\"))\n\n\nggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +\n  geom_bar(position=\"fill\") + theme_bw()\n\n\nupLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-upLoop\", diff == \"DOWN\"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-upLoop\"))\nupLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-upLoop\", diff == \"UP\"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-upLoop\"))\n\nnoLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-noLoop\", diff == \"DOWN\"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-noLoop\"))\nnoLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-noLoop\", diff == \"UP\"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-noLoop\"))\n\ndownLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-downLoop\", diff == \"DOWN\"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-downLoop\"))\ndownLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-downLoop\", diff == \"UP\"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-downLoop\"))\n\n\ndata <- tibble(geneGroup = c(\"cohesin-upLoop\", \"cohesin-upLoop\", \n                     \"cohesin-noLoop\", \"cohesin-noLoop\", \n                     \"cohesin-downLoop\", \"cohesin-downLoop\"),\n       diff = rep(c(\"DOWN\", \"UP\"), 3),\n       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)\n\nggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +\n  geom_bar(stat = \"identity\", position = \"dodge\") + theme_bw()\n\n\n\n\ngeneList.noLoopUnique <- geneList.noLoop[!geneList.noLoop %in% unique(c(geneList.downLoop, geneList.upLoop))]\ngeneList.downLoopUnique <- geneList.downLoop[!geneList.downLoop %in% unique(c(geneList.noLoop, geneList.upLoop))]\ngeneList.upLoopUnique <- geneList.upLoop[!geneList.upLoop %in% unique(c(geneList.noLoop, geneList.downLoop))]\n\ndiff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \"UP\",\n                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \"DOWN\",\n                                            TRUE ~ \"NO\"),\n                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoopUnique  ~ \"cohesin-upLoop\",\n                                                 ensembl_gene_id %in% geneList.noLoopUnique ~ \"cohesin-noLoop\",\n                                                 ensembl_gene_id %in% geneList.downLoopUnique ~ \"cohesin-downLoop\",\n                                                 TRUE ~ \"NA\"))\n\n\nggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +\n  geom_bar(position=\"fill\") + theme_bw()\n\n\nupLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-upLoop\", diff == \"DOWN\"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-upLoop\"))\nupLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-upLoop\", diff == \"UP\"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-upLoop\"))\n\nnoLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-noLoop\", diff == \"DOWN\"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-noLoop\"))\nnoLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-noLoop\", diff == \"UP\"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-noLoop\"))\n\ndownLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-downLoop\", diff == \"DOWN\"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-downLoop\"))\ndownLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-downLoop\", diff == \"UP\"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \"cohesin-downLoop\"))\n\n\ndata <- tibble(geneGroup = c(\"cohesin-upLoop\", \"cohesin-upLoop\", \n                     \"cohesin-noLoop\", \"cohesin-noLoop\", \n                     \"cohesin-downLoop\", \"cohesin-downLoop\"),\n       diff = rep(c(\"DOWN\", \"UP\"), 3),\n       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)\n\nggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +\n  geom_bar(stat = \"identity\", position = \"dodge\") + theme_bw()\n\n```"} -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2)\n\ngeneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\UP\\) %>% unnest(gene))$gene)\ngeneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\NO\\) %>% unnest(gene))$gene)\ngeneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\DOWN\\) %>% unnest(gene))$gene)\n\n\n\n# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN\nsets_list <- list(up = geneList.upLoop,\n                  no = geneList.noLoop,\n                  down = geneList.downLoop)\n\n# Create the Euler plot\neuler_fit <- euler(sets_list)\nplot(euler_fit,\n     labels = TRUE,  # Display set labels\n     fills = TRUE,   # Color fill the regions\n     quantities = TRUE)\n\n\n# GO\nGO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.down)\n\n# GO to only specific subset\ngeneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))\ngeneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))\ngeneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))\nGO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.down)\n\n\n## Checking percentage of bobbie early gene\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \\bobbie_gene_classification.csv\\)) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\\gene\\, \\ensembl_transcript_id\\, \\cluster\\)\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\\ensembl_transcript_id\\, \\ensembl_gene_id\\),\n                 filters = \\ensembl_transcript_id\\,\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\\ensembl_transcript_id\\))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \\Early\\)\n  n2 <- countGene(geneCluster, groupName, \\Middle\\)\n  n3 <-countGene(geneCluster, groupName, \\Late\\)\n  n4 <- countGene(geneCluster, groupName, \\Transient\\)\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\\up\\, 4), rep(\\no\\, 4), rep(\\down\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 3)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, geneList.upLoop),\n           countGeneList(geneCluster, geneList.noLoop),\n           countGeneList(geneCluster, geneList.downLoop))\n\ndata <- data.frame(group, cluster, value)\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\stack\\, stat = \\identity\\) + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat = \\identity\\) + theme_classic()\n\nvalue <- c(countGeneList(geneCluster, geneList.upLoop.specific),\n           countGeneList(geneCluster, geneList.noLoop.specific),\n           countGeneList(geneCluster, geneList.downLoop.specific))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\stack\\, stat = \\identity\\) + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat = \\identity\\) + theme_classic()\n\n\n\n################## Checking how those genes behave in A485\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                            TRUE ~ \\NO\\),\n                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoop ~ \\cohesin-upLoop\\,\n                                                 ensembl_gene_id %in% geneList.noLoop ~ \\cohesin-noLoop\\,\n                                                 ensembl_gene_id %in% geneList.downLoop ~ \\cohesin-downLoop\\,\n                                                 TRUE ~ \\NA\\))\n\n\nggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +\n  geom_bar(position=\\fill\\) + theme_bw()\n\n\nupLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\nupLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\n\nnoLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\nnoLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\n\ndownLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\ndownLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\n\n\ndata <- tibble(geneGroup = c(\\cohesin-upLoop\\, \\cohesin-upLoop\\, \n                     \\cohesin-noLoop\\, \\cohesin-noLoop\\, \n                     \\cohesin-downLoop\\, \\cohesin-downLoop\\),\n       diff = rep(c(\\DOWN\\, \\UP\\), 3),\n       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)\n\nggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +\n  geom_bar(stat = \\identity\\, position = \\dodge\\) + theme_bw()\n\n\n\n\ngeneList.noLoopUnique <- geneList.noLoop[!geneList.noLoop %in% unique(c(geneList.downLoop, geneList.upLoop))]\ngeneList.downLoopUnique <- geneList.downLoop[!geneList.downLoop %in% unique(c(geneList.noLoop, geneList.upLoop))]\ngeneList.upLoopUnique <- geneList.upLoop[!geneList.upLoop %in% unique(c(geneList.noLoop, geneList.downLoop))]\n\ndiff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                            TRUE ~ \\NO\\),\n                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoopUnique  ~ \\cohesin-upLoop\\,\n                                                 ensembl_gene_id %in% geneList.noLoopUnique ~ \\cohesin-noLoop\\,\n                                                 ensembl_gene_id %in% geneList.downLoopUnique ~ \\cohesin-downLoop\\,\n                                                 TRUE ~ \\NA\\))\n\n\nggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +\n  geom_bar(position=\\fill\\) + theme_bw()\n\n\nupLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\nupLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\n\nnoLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\nnoLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\n\ndownLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\ndownLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\n\n\ndata <- tibble(geneGroup = c(\\cohesin-upLoop\\, \\cohesin-upLoop\\, \n                     \\cohesin-noLoop\\, \\cohesin-noLoop\\, \n                     \\cohesin-downLoop\\, \\cohesin-downLoop\\),\n       diff = rep(c(\\DOWN\\, \\UP\\), 3),\n       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)\n\nggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +\n  geom_bar(stat = \\identity\\, position = \\dodge\\) + theme_bw()\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2)

geneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \UP\) %>% unnest(gene))$gene)
geneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \NO\) %>% unnest(gene))$gene)
geneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \DOWN\) %>% unnest(gene))$gene)



# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN
sets_list <- list(up = geneList.upLoop,
                  no = geneList.noLoop,
                  down = geneList.downLoop)

# Create the Euler plot
euler_fit <- euler(sets_list)
plot(euler_fit,
     labels = TRUE,  # Display set labels
     fills = TRUE,   # Color fill the regions
     quantities = TRUE)


# GO
GO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down)

# GO to only specific subset
geneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))
geneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))
geneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))
GO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down)


## Checking percentage of bobbie early gene

## Importing Bobbie gene classification
geneCluster <- fread(here(refDir, \bobbie_gene_classification.csv\)) %>%
  dplyr::select(gene, enst, Cluster)
colnames(geneCluster) <- c(\gene\, \ensembl_transcript_id\, \cluster\)


## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c(\ensembl_transcript_id\, \ensembl_gene_id\),
                 filters = \ensembl_transcript_id\,
                 values = geneCluster$ensembl_transcript,
                 mart = ensembl.v102)
geneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\ensembl_transcript_id\))

# Making data for stacked barplot
countGene <- function(geneCluster, groupName, clusterName){
  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,
                                            cluster %in% clusterName))
  return(num)
}
countGeneList <- function(geneCluster, groupName){
  n1 <- countGene(geneCluster, groupName, \Early\)
  n2 <- countGene(geneCluster, groupName, \Middle\)
  n3 <-countGene(geneCluster, groupName, \Late\)
  n4 <- countGene(geneCluster, groupName, \Transient\)
  return(c(n1, n2, n3, n4))
}

group <- c(rep(\up\, 4), rep(\no\, 4), rep(\down\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 3)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, geneList.upLoop),
           countGeneList(geneCluster, geneList.noLoop),
           countGeneList(geneCluster, geneList.downLoop))

data <- data.frame(group, cluster, value)
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\stack\, stat = \identity\) + theme_classic()
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat = \identity\) + theme_classic()

value <- c(countGeneList(geneCluster, geneList.upLoop.specific),
           countGeneList(geneCluster, geneList.noLoop.specific),
           countGeneList(geneCluster, geneList.downLoop.specific))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\stack\, stat = \identity\) + theme_classic()
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat = \identity\) + theme_classic()



################## Checking how those genes behave in A485
diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                            TRUE ~ \NO\),
                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoop ~ \cohesin-upLoop\,
                                                 ensembl_gene_id %in% geneList.noLoop ~ \cohesin-noLoop\,
                                                 ensembl_gene_id %in% geneList.downLoop ~ \cohesin-downLoop\,
                                                 TRUE ~ \NA\))


ggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +
  geom_bar(position=\fill\) + theme_bw()


upLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\, diff == \DOWN\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\))
upLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\, diff == \UP\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\))

noLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\, diff == \DOWN\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\))
noLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\, diff == \UP\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\))

downLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\, diff == \DOWN\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\))
downLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\, diff == \UP\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\))


data <- tibble(geneGroup = c(\cohesin-upLoop\, \cohesin-upLoop\, 
                     \cohesin-noLoop\, \cohesin-noLoop\, 
                     \cohesin-downLoop\, \cohesin-downLoop\),
       diff = rep(c(\DOWN\, \UP\), 3),
       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)

ggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +
  geom_bar(stat = \identity\, position = \dodge\) + theme_bw()




geneList.noLoopUnique <- geneList.noLoop[!geneList.noLoop %in% unique(c(geneList.downLoop, geneList.upLoop))]
geneList.downLoopUnique <- geneList.downLoop[!geneList.downLoop %in% unique(c(geneList.noLoop, geneList.upLoop))]
geneList.upLoopUnique <- geneList.upLoop[!geneList.upLoop %in% unique(c(geneList.noLoop, geneList.downLoop))]

diff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                            TRUE ~ \NO\),
                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoopUnique  ~ \cohesin-upLoop\,
                                                 ensembl_gene_id %in% geneList.noLoopUnique ~ \cohesin-noLoop\,
                                                 ensembl_gene_id %in% geneList.downLoopUnique ~ \cohesin-downLoop\,
                                                 TRUE ~ \NA\))


ggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +
  geom_bar(position=\fill\) + theme_bw()


upLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\, diff == \DOWN\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\))
upLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\, diff == \UP\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\))

noLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\, diff == \DOWN\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\))
noLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\, diff == \UP\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\))

downLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\, diff == \DOWN\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\))
downLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\, diff == \UP\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\))


data <- tibble(geneGroup = c(\cohesin-upLoop\, \cohesin-upLoop\, 
                     \cohesin-noLoop\, \cohesin-noLoop\, 
                     \cohesin-downLoop\, \cohesin-downLoop\),
       diff = rep(c(\DOWN\, \UP\), 3),
       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)

ggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +
  geom_bar(stat = \identity\, position = \dodge\) + theme_bw()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2)\n\ngeneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\UP\\) %>% unnest(gene))$gene)\ngeneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\NO\\) %>% unnest(gene))$gene)\ngeneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\DOWN\\) %>% unnest(gene))$gene)\n\n\n\n# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN\nsets_list <- list(up = geneList.upLoop,\n                  no = geneList.noLoop,\n                  down = geneList.downLoop)\n\n# Create the Euler plot\neuler_fit <- euler(sets_list)\nplot(euler_fit,\n     labels = TRUE,  # Display set labels\n     fills = TRUE,   # Color fill the regions\n     quantities = TRUE)\n\n\n# GO\nGO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.down)\n\n# GO to only specific subset\ngeneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))\ngeneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))\ngeneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))\nGO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.down)\n\n\n## Checking percentage of bobbie early gene\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \\bobbie_gene_classification.csv\\)) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\\gene\\, \\ensembl_transcript_id\\, \\cluster\\)\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\\ensembl_transcript_id\\, \\ensembl_gene_id\\),\n                 filters = \\ensembl_transcript_id\\,\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\\ensembl_transcript_id\\))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \\Early\\)\n  n2 <- countGene(geneCluster, groupName, \\Middle\\)\n  n3 <-countGene(geneCluster, groupName, \\Late\\)\n  n4 <- countGene(geneCluster, groupName, \\Transient\\)\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\\up\\, 4), rep(\\no\\, 4), rep(\\down\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 3)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, geneList.upLoop),\n           countGeneList(geneCluster, geneList.noLoop),\n           countGeneList(geneCluster, geneList.downLoop))\n\ndata <- data.frame(group, cluster, value)\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\stack\\, stat = \\identity\\) + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat = \\identity\\) + theme_classic()\n\nvalue <- c(countGeneList(geneCluster, geneList.upLoop.specific),\n           countGeneList(geneCluster, geneList.noLoop.specific),\n           countGeneList(geneCluster, geneList.downLoop.specific))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\stack\\, stat = \\identity\\) + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat = \\identity\\) + theme_classic()\n\n\n\n################## Checking how those genes behave in A485\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                            TRUE ~ \\NO\\),\n                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoop ~ \\cohesin-upLoop\\,\n                                                 ensembl_gene_id %in% geneList.noLoop ~ \\cohesin-noLoop\\,\n                                                 ensembl_gene_id %in% geneList.downLoop ~ \\cohesin-downLoop\\,\n                                                 TRUE ~ \\NA\\))\n\n\nggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +\n  geom_bar(position=\\fill\\) + theme_bw()\n\n\nupLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\nupLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\n\nnoLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\nnoLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\n\ndownLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\ndownLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\n\n\ndata <- tibble(geneGroup = c(\\cohesin-upLoop\\, \\cohesin-upLoop\\, \n                     \\cohesin-noLoop\\, \\cohesin-noLoop\\, \n                     \\cohesin-downLoop\\, \\cohesin-downLoop\\),\n       diff = rep(c(\\DOWN\\, \\UP\\), 3),\n       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)\n\nggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +\n  geom_bar(stat = \\identity\\, position = \\dodge\\) + theme_bw()\n\n\n\n\ngeneList.noLoopUnique <- geneList.noLoop[!geneList.noLoop %in% unique(c(geneList.downLoop, geneList.upLoop))]\ngeneList.downLoopUnique <- geneList.downLoop[!geneList.downLoop %in% unique(c(geneList.noLoop, geneList.upLoop))]\ngeneList.upLoopUnique <- geneList.upLoop[!geneList.upLoop %in% unique(c(geneList.noLoop, geneList.downLoop))]\n\ndiff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                            TRUE ~ \\NO\\),\n                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoopUnique  ~ \\cohesin-upLoop\\,\n                                                 ensembl_gene_id %in% geneList.noLoopUnique ~ \\cohesin-noLoop\\,\n                                                 ensembl_gene_id %in% geneList.downLoopUnique ~ \\cohesin-downLoop\\,\n                                                 TRUE ~ \\NA\\))\n\n\nggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +\n  geom_bar(position=\\fill\\) + theme_bw()\n\n\nupLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\nupLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\n\nnoLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\nnoLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\n\ndownLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\ndownLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\n\n\ndata <- tibble(geneGroup = c(\\cohesin-upLoop\\, \\cohesin-upLoop\\, \n                     \\cohesin-noLoop\\, \\cohesin-noLoop\\, \n                     \\cohesin-downLoop\\, \\cohesin-downLoop\\),\n       diff = rep(c(\\DOWN\\, \\UP\\), 3),\n       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)\n\nggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +\n  geom_bar(stat = \\identity\\, position = \\dodge\\) + theme_bw()\n\n```\n```"} -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2)\n\ngeneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\UP\\) %>% unnest(gene))$gene)\ngeneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\NO\\) %>% unnest(gene))$gene)\ngeneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\DOWN\\) %>% unnest(gene))$gene)\n\n\n\n# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN\nsets_list <- list(up = geneList.upLoop,\n                  no = geneList.noLoop,\n                  down = geneList.downLoop)\n\n# Create the Euler plot\neuler_fit <- euler(sets_list)\nplot(euler_fit,\n     labels = TRUE,  # Display set labels\n     fills = TRUE,   # Color fill the regions\n     quantities = TRUE)\n\n\n# GO\nGO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.down)\n\n# GO to only specific subset\ngeneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))\ngeneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))\ngeneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))\nGO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.down)\n\n\n## Checking percentage of bobbie early gene\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \\bobbie_gene_classification.csv\\)) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\\gene\\, \\ensembl_transcript_id\\, \\cluster\\)\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\\ensembl_transcript_id\\, \\ensembl_gene_id\\),\n                 filters = \\ensembl_transcript_id\\,\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\\ensembl_transcript_id\\))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \\Early\\)\n  n2 <- countGene(geneCluster, groupName, \\Middle\\)\n  n3 <-countGene(geneCluster, groupName, \\Late\\)\n  n4 <- countGene(geneCluster, groupName, \\Transient\\)\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\\up\\, 4), rep(\\no\\, 4), rep(\\down\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 3)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, geneList.upLoop),\n           countGeneList(geneCluster, geneList.noLoop),\n           countGeneList(geneCluster, geneList.downLoop))\n\ndata <- data.frame(group, cluster, value)\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\stack\\, stat = \\identity\\) + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat = \\identity\\) + theme_classic()\n\nvalue <- c(countGeneList(geneCluster, geneList.upLoop.specific),\n           countGeneList(geneCluster, geneList.noLoop.specific),\n           countGeneList(geneCluster, geneList.downLoop.specific))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\stack\\, stat = \\identity\\) + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat = \\identity\\) + theme_classic()\n\n\n\n################## Checking how those genes behave in A485\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                            TRUE ~ \\NO\\),\n                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoop ~ \\cohesin-upLoop\\,\n                                                 ensembl_gene_id %in% geneList.noLoop ~ \\cohesin-noLoop\\,\n                                                 ensembl_gene_id %in% geneList.downLoop ~ \\cohesin-downLoop\\,\n                                                 TRUE ~ \\NA\\))\n\n\nggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +\n  geom_bar(position=\\fill\\) + theme_bw()\n\n\nupLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\nupLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\n\nnoLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\nnoLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\n\ndownLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\ndownLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\n\n\ndata <- tibble(geneGroup = c(\\cohesin-upLoop\\, \\cohesin-upLoop\\, \n                     \\cohesin-noLoop\\, \\cohesin-noLoop\\, \n                     \\cohesin-downLoop\\, \\cohesin-downLoop\\),\n       diff = rep(c(\\DOWN\\, \\UP\\), 3),\n       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)\n\nggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +\n  geom_bar(stat = \\identity\\, position = \\dodge\\) + theme_bw()\n\n\n\n\ngeneList.noLoopUnique <- geneList.noLoop[!geneList.noLoop %in% unique(c(geneList.downLoop, geneList.upLoop))]\ngeneList.downLoopUnique <- geneList.downLoop[!geneList.downLoop %in% unique(c(geneList.noLoop, geneList.upLoop))]\ngeneList.upLoopUnique <- geneList.upLoop[!geneList.upLoop %in% unique(c(geneList.noLoop, geneList.downLoop))]\n\ndiff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                            TRUE ~ \\NO\\),\n                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoopUnique  ~ \\cohesin-upLoop\\,\n                                                 ensembl_gene_id %in% geneList.noLoopUnique ~ \\cohesin-noLoop\\,\n                                                 ensembl_gene_id %in% geneList.downLoopUnique ~ \\cohesin-downLoop\\,\n                                                 TRUE ~ \\NA\\))\n\n\nggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +\n  geom_bar(position=\\fill\\) + theme_bw()\n\n\nupLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\nupLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\n\nnoLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\nnoLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\n\ndownLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\ndownLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\n\n\ndata <- tibble(geneGroup = c(\\cohesin-upLoop\\, \\cohesin-upLoop\\, \n                     \\cohesin-noLoop\\, \\cohesin-noLoop\\, \n                     \\cohesin-downLoop\\, \\cohesin-downLoop\\),\n       diff = rep(c(\\DOWN\\, \\UP\\), 3),\n       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)\n\nggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +\n  geom_bar(stat = \\identity\\, position = \\dodge\\) + theme_bw()\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2)\n\ngeneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\UP\\) %>% unnest(gene))$gene)\ngeneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\NO\\) %>% unnest(gene))$gene)\ngeneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \\DOWN\\) %>% unnest(gene))$gene)\n\n\n\n# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN\nsets_list <- list(up = geneList.upLoop,\n                  no = geneList.noLoop,\n                  down = geneList.downLoop)\n\n# Create the Euler plot\neuler_fit <- euler(sets_list)\nplot(euler_fit,\n     labels = TRUE,  # Display set labels\n     fills = TRUE,   # Color fill the regions\n     quantities = TRUE)\n\n\n# GO\nGO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.down)\n\n# GO to only specific subset\ngeneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))\ngeneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))\ngeneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))\nGO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.up)\nGO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.no)\nGO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \\ENSEMBL\\, ont = \\BP\\)\ndotplot(GO.down)\n\n\n## Checking percentage of bobbie early gene\n\n## Importing Bobbie gene classification\ngeneCluster <- fread(here(refDir, \\bobbie_gene_classification.csv\\)) %>%\n  dplyr::select(gene, enst, Cluster)\ncolnames(geneCluster) <- c(\\gene\\, \\ensembl_transcript_id\\, \\cluster\\)\n\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\\ensembl_transcript_id\\, \\ensembl_gene_id\\),\n                 filters = \\ensembl_transcript_id\\,\n                 values = geneCluster$ensembl_transcript,\n                 mart = ensembl.v102)\ngeneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\\ensembl_transcript_id\\))\n\n# Making data for stacked barplot\ncountGene <- function(geneCluster, groupName, clusterName){\n  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,\n                                            cluster %in% clusterName))\n  return(num)\n}\ncountGeneList <- function(geneCluster, groupName){\n  n1 <- countGene(geneCluster, groupName, \\Early\\)\n  n2 <- countGene(geneCluster, groupName, \\Middle\\)\n  n3 <-countGene(geneCluster, groupName, \\Late\\)\n  n4 <- countGene(geneCluster, groupName, \\Transient\\)\n  return(c(n1, n2, n3, n4))\n}\n\ngroup <- c(rep(\\up\\, 4), rep(\\no\\, 4), rep(\\down\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 3)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(countGeneList(geneCluster, geneList.upLoop),\n           countGeneList(geneCluster, geneList.noLoop),\n           countGeneList(geneCluster, geneList.downLoop))\n\ndata <- data.frame(group, cluster, value)\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\stack\\, stat = \\identity\\) + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat = \\identity\\) + theme_classic()\n\nvalue <- c(countGeneList(geneCluster, geneList.upLoop.specific),\n           countGeneList(geneCluster, geneList.noLoop.specific),\n           countGeneList(geneCluster, geneList.downLoop.specific))\n\ndata <- data.frame(group, cluster, value)\n# Plotting\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\stack\\, stat = \\identity\\) + theme_classic()\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat = \\identity\\) + theme_classic()\n\n\n\n################## Checking how those genes behave in A485\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                            TRUE ~ \\NO\\),\n                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoop ~ \\cohesin-upLoop\\,\n                                                 ensembl_gene_id %in% geneList.noLoop ~ \\cohesin-noLoop\\,\n                                                 ensembl_gene_id %in% geneList.downLoop ~ \\cohesin-downLoop\\,\n                                                 TRUE ~ \\NA\\))\n\n\nggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +\n  geom_bar(position=\\fill\\) + theme_bw()\n\n\nupLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\nupLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\n\nnoLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\nnoLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\n\ndownLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\ndownLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\n\n\ndata <- tibble(geneGroup = c(\\cohesin-upLoop\\, \\cohesin-upLoop\\, \n                     \\cohesin-noLoop\\, \\cohesin-noLoop\\, \n                     \\cohesin-downLoop\\, \\cohesin-downLoop\\),\n       diff = rep(c(\\DOWN\\, \\UP\\), 3),\n       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)\n\nggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +\n  geom_bar(stat = \\identity\\, position = \\dodge\\) + theme_bw()\n\n\n\n\ngeneList.noLoopUnique <- geneList.noLoop[!geneList.noLoop %in% unique(c(geneList.downLoop, geneList.upLoop))]\ngeneList.downLoopUnique <- geneList.downLoop[!geneList.downLoop %in% unique(c(geneList.noLoop, geneList.upLoop))]\ngeneList.upLoopUnique <- geneList.upLoop[!geneList.upLoop %in% unique(c(geneList.noLoop, geneList.downLoop))]\n\ndiff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                            TRUE ~ \\NO\\),\n                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoopUnique  ~ \\cohesin-upLoop\\,\n                                                 ensembl_gene_id %in% geneList.noLoopUnique ~ \\cohesin-noLoop\\,\n                                                 ensembl_gene_id %in% geneList.downLoopUnique ~ \\cohesin-downLoop\\,\n                                                 TRUE ~ \\NA\\))\n\n\nggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +\n  geom_bar(position=\\fill\\) + theme_bw()\n\n\nupLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\nupLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-upLoop\\))\n\nnoLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\nnoLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-noLoop\\))\n\ndownLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\DOWN\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\ndownLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\, diff == \\UP\\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \\cohesin-downLoop\\))\n\n\ndata <- tibble(geneGroup = c(\\cohesin-upLoop\\, \\cohesin-upLoop\\, \n                     \\cohesin-noLoop\\, \\cohesin-noLoop\\, \n                     \\cohesin-downLoop\\, \\cohesin-downLoop\\),\n       diff = rep(c(\\DOWN\\, \\UP\\), 3),\n       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)\n\nggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +\n  geom_bar(stat = \\identity\\, position = \\dodge\\) + theme_bw()\n\n```\n```"} -->

```r
```r
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2)

geneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \UP\) %>% unnest(gene))$gene)
geneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \NO\) %>% unnest(gene))$gene)
geneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == \DOWN\) %>% unnest(gene))$gene)



# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN
sets_list <- list(up = geneList.upLoop,
                  no = geneList.noLoop,
                  down = geneList.downLoop)

# Create the Euler plot
euler_fit <- euler(sets_list)
plot(euler_fit,
     labels = TRUE,  # Display set labels
     fills = TRUE,   # Color fill the regions
     quantities = TRUE)


# GO
GO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down)

# GO to only specific subset
geneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))
geneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))
geneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))
GO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down)


## Checking percentage of bobbie early gene

## Importing Bobbie gene classification
geneCluster <- fread(here(refDir, \bobbie_gene_classification.csv\)) %>%
  dplyr::select(gene, enst, Cluster)
colnames(geneCluster) <- c(\gene\, \ensembl_transcript_id\, \cluster\)


## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c(\ensembl_transcript_id\, \ensembl_gene_id\),
                 filters = \ensembl_transcript_id\,
                 values = geneCluster$ensembl_transcript,
                 mart = ensembl.v102)
geneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c(\ensembl_transcript_id\))

# Making data for stacked barplot
countGene <- function(geneCluster, groupName, clusterName){
  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,
                                            cluster %in% clusterName))
  return(num)
}
countGeneList <- function(geneCluster, groupName){
  n1 <- countGene(geneCluster, groupName, \Early\)
  n2 <- countGene(geneCluster, groupName, \Middle\)
  n3 <-countGene(geneCluster, groupName, \Late\)
  n4 <- countGene(geneCluster, groupName, \Transient\)
  return(c(n1, n2, n3, n4))
}

group <- c(rep(\up\, 4), rep(\no\, 4), rep(\down\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 3)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(countGeneList(geneCluster, geneList.upLoop),
           countGeneList(geneCluster, geneList.noLoop),
           countGeneList(geneCluster, geneList.downLoop))

data <- data.frame(group, cluster, value)
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\stack\, stat = \identity\) + theme_classic()
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat = \identity\) + theme_classic()

value <- c(countGeneList(geneCluster, geneList.upLoop.specific),
           countGeneList(geneCluster, geneList.noLoop.specific),
           countGeneList(geneCluster, geneList.downLoop.specific))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\stack\, stat = \identity\) + theme_classic()
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat = \identity\) + theme_classic()



################## Checking how those genes behave in A485
diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                            TRUE ~ \NO\),
                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoop ~ \cohesin-upLoop\,
                                                 ensembl_gene_id %in% geneList.noLoop ~ \cohesin-noLoop\,
                                                 ensembl_gene_id %in% geneList.downLoop ~ \cohesin-downLoop\,
                                                 TRUE ~ \NA\))


ggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +
  geom_bar(position=\fill\) + theme_bw()


upLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\, diff == \DOWN\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\))
upLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\, diff == \UP\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\))

noLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\, diff == \DOWN\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\))
noLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\, diff == \UP\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\))

downLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\, diff == \DOWN\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\))
downLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\, diff == \UP\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\))


data <- tibble(geneGroup = c(\cohesin-upLoop\, \cohesin-upLoop\, 
                     \cohesin-noLoop\, \cohesin-noLoop\, 
                     \cohesin-downLoop\, \cohesin-downLoop\),
       diff = rep(c(\DOWN\, \UP\), 3),
       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)

ggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +
  geom_bar(stat = \identity\, position = \dodge\) + theme_bw()




geneList.noLoopUnique <- geneList.noLoop[!geneList.noLoop %in% unique(c(geneList.downLoop, geneList.upLoop))]
geneList.downLoopUnique <- geneList.downLoop[!geneList.downLoop %in% unique(c(geneList.noLoop, geneList.upLoop))]
geneList.upLoopUnique <- geneList.upLoop[!geneList.upLoop %in% unique(c(geneList.noLoop, geneList.downLoop))]

diff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                            TRUE ~ \NO\),
                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoopUnique  ~ \cohesin-upLoop\,
                                                 ensembl_gene_id %in% geneList.noLoopUnique ~ \cohesin-noLoop\,
                                                 ensembl_gene_id %in% geneList.downLoopUnique ~ \cohesin-downLoop\,
                                                 TRUE ~ \NA\))


ggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +
  geom_bar(position=\fill\) + theme_bw()


upLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\, diff == \DOWN\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\))
upLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\, diff == \UP\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-upLoop\))

noLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\, diff == \DOWN\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\))
noLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\, diff == \UP\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-noLoop\))

downLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\, diff == \DOWN\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\))
downLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\, diff == \UP\))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == \cohesin-downLoop\))


data <- tibble(geneGroup = c(\cohesin-upLoop\, \cohesin-upLoop\, 
                     \cohesin-noLoop\, \cohesin-noLoop\, 
                     \cohesin-downLoop\, \cohesin-downLoop\),
       diff = rep(c(\DOWN\, \UP\), 3),
       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)

ggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +
  geom_bar(stat = \identity\, position = \dodge\) + theme_bw()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### dTAG
#### P-P, P-E

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVibUZ0WlNBOExTQmNJbU5vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGNJbHh1WEc1blpXNWxRVzV1YjBSaGRHRWdQQzBnYkc5aFpFeHZiM0JCYm01dlJHRjBZU2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lYM0F0Y0dWZlpXNXpaVzFpYkV4cGMzUXVkSE4yWENJcEtTeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWkdsbVprTjFkRzltWmlBOUlEQXVNaWxjYmx4dVoyVnVaVXhwYzNRdWRYQk1iMjl3SUR3dElIVnVhWEYxWlNnb1oyVnVaVUZ1Ym05RVlYUmhJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLSFZ3Wkc5M2JsOUJORGcxWDBSTlUwOGdQVDBnWENKVlVGd2lLU0FsUGlVZ2RXNXVaWE4wS0dkbGJtVXBLU1JuWlc1bEtWeHVaMlZ1WlV4cGMzUXVibTlNYjI5d0lEd3RJSFZ1YVhGMVpTZ29aMlZ1WlVGdWJtOUVZWFJoSUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0hWd1pHOTNibDlCTkRnMVgwUk5VMDhnUFQwZ1hDSk9UMXdpS1NBbFBpVWdkVzV1WlhOMEtHZGxibVVwS1NSblpXNWxLVnh1WjJWdVpVeHBjM1F1Wkc5M2JreHZiM0FnUEMwZ2RXNXBjWFZsS0NoblpXNWxRVzV1YjBSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9kWEJrYjNkdVgwRTBPRFZmUkUxVFR5QTlQU0JjSWtSUFYwNWNJaWtnSlQ0bElIVnVibVZ6ZENoblpXNWxLU2trWjJWdVpTbGNibHh1WEc1Y2JpTWdRMGhGUTB0SlRrY2dTRTlYSUUxQlRsa2dSMFZPUlZNZ1QxWkZVa3hCVUNCQlRVOU9SeUJWVUM5T1R5OUVUMWRPWEc1elpYUnpYMnhwYzNRZ1BDMGdiR2x6ZENoMWNDQTlJR2RsYm1WTWFYTjBMblZ3VEc5dmNDeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRzV2SUQwZ1oyVnVaVXhwYzNRdWJtOU1iMjl3TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1pHOTNiaUE5SUdkbGJtVk1hWE4wTG1SdmQyNU1iMjl3S1Z4dVhHNGpJRU55WldGMFpTQjBhR1VnUlhWc1pYSWdjR3h2ZEZ4dVpYVnNaWEpmWm1sMElEd3RJR1YxYkdWeUtITmxkSE5mYkdsemRDbGNibkJzYjNRb1pYVnNaWEpmWm1sMExGeHVJQ0FnSUNCc1lXSmxiSE1nUFNCVVVsVkZMQ0FnSXlCRWFYTndiR0Y1SUhObGRDQnNZV0psYkhOY2JpQWdJQ0FnWm1sc2JITWdQU0JVVWxWRkxDQWdJQ01nUTI5c2IzSWdabWxzYkNCMGFHVWdjbVZuYVc5dWMxeHVJQ0FnSUNCeGRXRnVkR2wwYVdWeklEMGdWRkpWUlNsY2JseHVYRzRqSUVkUFhHNUhUeTUxY0NBOExTQmxibkpwWTJoSFR5aG5aVzVsSUQwZ1oyVnVaVXhwYzNRdWRYQk1iMjl3TENCUGNtZEVZaUE5SUc5eVp5NU5iUzVsWnk1a1lpd2dhMlY1Vkhsd1pTQTlJRndpUlU1VFJVMUNURndpTENCdmJuUWdQU0JjSWtKUVhDSXBYRzVrYjNSd2JHOTBLRWRQTG5Wd0xDQnphRzkzUTJGMFpXZHZjbmtnUFNBeE5TbGNia2RQTG01dklEd3RJR1Z1Y21samFFZFBLR2RsYm1VZ1BTQm5aVzVsVEdsemRDNXViMHh2YjNBc0lFOXlaMFJpSUQwZ2IzSm5MazF0TG1WbkxtUmlMQ0JyWlhsVWVYQmxJRDBnWENKRlRsTkZUVUpNWENJc0lHOXVkQ0E5SUZ3aVFsQmNJaWxjYm1SdmRIQnNiM1FvUjA4dWJtOHNJSE5vYjNkRFlYUmxaMjl5ZVNBOUlERTFLVnh1UjA4dVpHOTNiaUE4TFNCbGJuSnBZMmhIVHloblpXNWxJRDBnWjJWdVpVeHBjM1F1Wkc5M2JreHZiM0FzSUU5eVowUmlJRDBnYjNKbkxrMXRMbVZuTG1SaUxDQnJaWGxVZVhCbElEMGdYQ0pGVGxORlRVSk1YQ0lzSUc5dWRDQTlJRndpUWxCY0lpbGNibVJ2ZEhCc2IzUW9SMDh1Wkc5M2Jpd2djMmh2ZDBOaGRHVm5iM0o1SUQwZ01qQXBYRzVjYmlNZ1IwOGdkRzhnYjI1c2VTQnpjR1ZqYVdacFl5QnpkV0p6WlhSY2JtZGxibVZNYVhOMExuVndURzl2Y0M1emNHVmphV1pwWXlBOExTQnpaWFJrYVdabUtHZGxibVZNYVhOMExuVndURzl2Y0N3Z2RXNXBiMjRvWjJWdVpVeHBjM1F1Ym05TWIyOXdMQ0JuWlc1bFRHbHpkQzVrYjNkdVRHOXZjQ2twWEc1blpXNWxUR2x6ZEM1dWIweHZiM0F1YzNCbFkybG1hV01nUEMwZ2MyVjBaR2xtWmloblpXNWxUR2x6ZEM1dWIweHZiM0FzSUhWdWFXOXVLR2RsYm1WTWFYTjBMblZ3VEc5dmNDd2daMlZ1WlV4cGMzUXVaRzkzYmt4dmIzQXBLVnh1WjJWdVpVeHBjM1F1Wkc5M2JreHZiM0F1YzNCbFkybG1hV01nUEMwZ2MyVjBaR2xtWmloblpXNWxUR2x6ZEM1a2IzZHVURzl2Y0N3Z2RXNXBiMjRvWjJWdVpVeHBjM1F1Ym05TWIyOXdMQ0JuWlc1bFRHbHpkQzUxY0V4dmIzQXBLVnh1UjA4dWRYQWdQQzBnWlc1eWFXTm9SMDhvWjJWdVpTQTlJR2RsYm1WTWFYTjBMblZ3VEc5dmNDNXpjR1ZqYVdacFl5d2dUM0puUkdJZ1BTQnZjbWN1VFcwdVpXY3VaR0lzSUd0bGVWUjVjR1VnUFNCY0lrVk9VMFZOUWt4Y0lpd2diMjUwSUQwZ1hDSkNVRndpS1Z4dVpHOTBjR3h2ZENoSFR5NTFjQ2xjYmtkUExtNXZJRHd0SUdWdWNtbGphRWRQS0dkbGJtVWdQU0JuWlc1bFRHbHpkQzV1YjB4dmIzQXVjM0JsWTJsbWFXTXNJRTl5WjBSaUlEMGdiM0puTGsxdExtVm5MbVJpTENCclpYbFVlWEJsSUQwZ1hDSkZUbE5GVFVKTVhDSXNJRzl1ZENBOUlGd2lRbEJjSWlsY2JtUnZkSEJzYjNRb1IwOHVibThwWEc1SFR5NWtiM2R1SUR3dElHVnVjbWxqYUVkUEtHZGxibVVnUFNCblpXNWxUR2x6ZEM1a2IzZHVURzl2Y0M1emNHVmphV1pwWXl3Z1QzSm5SR0lnUFNCdmNtY3VUVzB1WldjdVpHSXNJR3RsZVZSNWNHVWdQU0JjSWtWT1UwVk5Ra3hjSWl3Z2IyNTBJRDBnWENKQ1VGd2lLVnh1Wkc5MGNHeHZkQ2hIVHk1a2IzZHVMQ0J6YUc5M1EyRjBaV2R2Y25rZ1BTQXlNQ2xjYmx4dVhHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3AtcGVfZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IDAuMilcblxuZ2VuZUxpc3QudXBMb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9BNDg1X0RNU08gPT0gXFxVUFxcKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3Qubm9Mb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9BNDg1X0RNU08gPT0gXFxOT1xcKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3QuZG93bkxvb3AgPC0gdW5pcXVlKChnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIodXBkb3duX0E0ODVfRE1TTyA9PSBcXERPV05cXCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZSlcblxuXG5cbiMgQ0hFQ0tJTkcgSE9XIE1BTlkgR0VORVMgT1ZFUkxBUCBBTU9ORyBVUC9OTy9ET1dOXG5zZXRzX2xpc3QgPC0gbGlzdCh1cCA9IGdlbmVMaXN0LnVwTG9vcCxcbiAgICAgICAgICAgICAgICAgIG5vID0gZ2VuZUxpc3Qubm9Mb29wLFxuICAgICAgICAgICAgICAgICAgZG93biA9IGdlbmVMaXN0LmRvd25Mb29wKVxuXG4jIENyZWF0ZSB0aGUgRXVsZXIgcGxvdFxuZXVsZXJfZml0IDwtIGV1bGVyKHNldHNfbGlzdClcbnBsb3QoZXVsZXJfZml0LFxuICAgICBsYWJlbHMgPSBUUlVFLCAgIyBEaXNwbGF5IHNldCBsYWJlbHNcbiAgICAgZmlsbHMgPSBUUlVFLCAgICMgQ29sb3IgZmlsbCB0aGUgcmVnaW9uc1xuICAgICBxdWFudGl0aWVzID0gVFJVRSlcblxuXG4jIEdPXG5HTy51cCA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QudXBMb29wLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpXG5kb3RwbG90KEdPLnVwLCBzaG93Q2F0ZWdvcnkgPSAxNSlcbkdPLm5vIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ub0xvb3AsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08ubm8sIHNob3dDYXRlZ29yeSA9IDE1KVxuR08uZG93biA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QuZG93bkxvb3AsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08uZG93biwgc2hvd0NhdGVnb3J5ID0gMjApXG5cbiMgR08gdG8gb25seSBzcGVjaWZpYyBzdWJzZXRcbmdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYyA8LSBzZXRkaWZmKGdlbmVMaXN0LnVwTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC5kb3duTG9vcCkpXG5nZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5ub0xvb3AsIHVuaW9uKGdlbmVMaXN0LnVwTG9vcCwgZ2VuZUxpc3QuZG93bkxvb3ApKVxuZ2VuZUxpc3QuZG93bkxvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5kb3duTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC51cExvb3ApKVxuR08udXAgPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy51cClcbkdPLm5vIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08ubm8pXG5HTy5kb3duIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5kb3duTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy5kb3duLCBzaG93Q2F0ZWdvcnkgPSAyMClcblxuXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-pe_ensemblList.tsv\)),
                                      diffCutoff = 0.2)

geneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == \UP\) %>% unnest(gene))$gene)
geneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == \NO\) %>% unnest(gene))$gene)
geneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == \DOWN\) %>% unnest(gene))$gene)



# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN
sets_list <- list(up = geneList.upLoop,
                  no = geneList.noLoop,
                  down = geneList.downLoop)

# Create the Euler plot
euler_fit <- euler(sets_list)
plot(euler_fit,
     labels = TRUE,  # Display set labels
     fills = TRUE,   # Color fill the regions
     quantities = TRUE)


# GO
GO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up, showCategory = 15)
GO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no, showCategory = 15)
GO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down, showCategory = 20)

# GO to only specific subset
geneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))
geneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))
geneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))
GO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down, showCategory = 20)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJtRnRaU0E4TFNCY1hHTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsY1hGeHVYRzVuWlc1bFFXNXViMFJoZEdFZ1BDMGdiRzloWkV4dmIzQkJibTV2UkdGMFlTaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gzQXRjR1ZmWlc1elpXMWliRXhwYzNRdWRITjJYRndwS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdaR2xtWmtOMWRHOW1aaUE5SURBdU1pbGNibHh1WjJWdVpVeHBjM1F1ZFhCTWIyOXdJRHd0SUhWdWFYRjFaU2dvWjJWdVpVRnVibTlFWVhSaElDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtIVndaRzkzYmw5Qk5EZzFYMFJOVTA4Z1BUMGdYRnhWVUZ4Y0tTQWxQaVVnZFc1dVpYTjBLR2RsYm1VcEtTUm5aVzVsS1Z4dVoyVnVaVXhwYzNRdWJtOU1iMjl3SUR3dElIVnVhWEYxWlNnb1oyVnVaVUZ1Ym05RVlYUmhJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLSFZ3Wkc5M2JsOUJORGcxWDBSTlUwOGdQVDBnWEZ4T1QxeGNLU0FsUGlVZ2RXNXVaWE4wS0dkbGJtVXBLU1JuWlc1bEtWeHVaMlZ1WlV4cGMzUXVaRzkzYmt4dmIzQWdQQzBnZFc1cGNYVmxLQ2huWlc1bFFXNXViMFJoZEdFZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb2RYQmtiM2R1WDBFME9EVmZSRTFUVHlBOVBTQmNYRVJQVjA1Y1hDa2dKVDRsSUhWdWJtVnpkQ2huWlc1bEtTa2taMlZ1WlNsY2JseHVYRzVjYmlNZ1EwaEZRMHRKVGtjZ1NFOVhJRTFCVGxrZ1IwVk9SVk1nVDFaRlVreEJVQ0JCVFU5T1J5QlZVQzlPVHk5RVQxZE9YRzV6WlhSelgyeHBjM1FnUEMwZ2JHbHpkQ2gxY0NBOUlHZGxibVZNYVhOMExuVndURzl2Y0N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHNXZJRDBnWjJWdVpVeHBjM1F1Ym05TWIyOXdMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWkc5M2JpQTlJR2RsYm1WTWFYTjBMbVJ2ZDI1TWIyOXdLVnh1WEc0aklFTnlaV0YwWlNCMGFHVWdSWFZzWlhJZ2NHeHZkRnh1WlhWc1pYSmZabWwwSUR3dElHVjFiR1Z5S0hObGRITmZiR2x6ZENsY2JuQnNiM1FvWlhWc1pYSmZabWwwTEZ4dUlDQWdJQ0JzWVdKbGJITWdQU0JVVWxWRkxDQWdJeUJFYVhOd2JHRjVJSE5sZENCc1lXSmxiSE5jYmlBZ0lDQWdabWxzYkhNZ1BTQlVVbFZGTENBZ0lDTWdRMjlzYjNJZ1ptbHNiQ0IwYUdVZ2NtVm5hVzl1YzF4dUlDQWdJQ0J4ZFdGdWRHbDBhV1Z6SUQwZ1ZGSlZSU2xjYmx4dVhHNGpJRWRQWEc1SFR5NTFjQ0E4TFNCbGJuSnBZMmhIVHloblpXNWxJRDBnWjJWdVpVeHBjM1F1ZFhCTWIyOXdMQ0JQY21kRVlpQTlJRzl5Wnk1TmJTNWxaeTVrWWl3Z2EyVjVWSGx3WlNBOUlGeGNSVTVUUlUxQ1RGeGNMQ0J2Ym5RZ1BTQmNYRUpRWEZ3cFhHNWtiM1J3Ykc5MEtFZFBMblZ3TENCemFHOTNRMkYwWldkdmNua2dQU0F4TlNsY2JrZFBMbTV2SUR3dElHVnVjbWxqYUVkUEtHZGxibVVnUFNCblpXNWxUR2x6ZEM1dWIweHZiM0FzSUU5eVowUmlJRDBnYjNKbkxrMXRMbVZuTG1SaUxDQnJaWGxVZVhCbElEMGdYRnhGVGxORlRVSk1YRndzSUc5dWRDQTlJRnhjUWxCY1hDbGNibVJ2ZEhCc2IzUW9SMDh1Ym04c0lITm9iM2REWVhSbFoyOXllU0E5SURFMUtWeHVSMDh1Wkc5M2JpQThMU0JsYm5KcFkyaEhUeWhuWlc1bElEMGdaMlZ1WlV4cGMzUXVaRzkzYmt4dmIzQXNJRTl5WjBSaUlEMGdiM0puTGsxdExtVm5MbVJpTENCclpYbFVlWEJsSUQwZ1hGeEZUbE5GVFVKTVhGd3NJRzl1ZENBOUlGeGNRbEJjWENsY2JtUnZkSEJzYjNRb1IwOHVaRzkzYml3Z2MyaHZkME5oZEdWbmIzSjVJRDBnTWpBcFhHNWNiaU1nUjA4Z2RHOGdiMjVzZVNCemNHVmphV1pwWXlCemRXSnpaWFJjYm1kbGJtVk1hWE4wTG5Wd1RHOXZjQzV6Y0dWamFXWnBZeUE4TFNCelpYUmthV1ptS0dkbGJtVk1hWE4wTG5Wd1RHOXZjQ3dnZFc1cGIyNG9aMlZ1WlV4cGMzUXVibTlNYjI5d0xDQm5aVzVsVEdsemRDNWtiM2R1VEc5dmNDa3BYRzVuWlc1bFRHbHpkQzV1YjB4dmIzQXVjM0JsWTJsbWFXTWdQQzBnYzJWMFpHbG1aaWhuWlc1bFRHbHpkQzV1YjB4dmIzQXNJSFZ1YVc5dUtHZGxibVZNYVhOMExuVndURzl2Y0N3Z1oyVnVaVXhwYzNRdVpHOTNia3h2YjNBcEtWeHVaMlZ1WlV4cGMzUXVaRzkzYmt4dmIzQXVjM0JsWTJsbWFXTWdQQzBnYzJWMFpHbG1aaWhuWlc1bFRHbHpkQzVrYjNkdVRHOXZjQ3dnZFc1cGIyNG9aMlZ1WlV4cGMzUXVibTlNYjI5d0xDQm5aVzVsVEdsemRDNTFjRXh2YjNBcEtWeHVSMDh1ZFhBZ1BDMGdaVzV5YVdOb1IwOG9aMlZ1WlNBOUlHZGxibVZNYVhOMExuVndURzl2Y0M1emNHVmphV1pwWXl3Z1QzSm5SR0lnUFNCdmNtY3VUVzB1WldjdVpHSXNJR3RsZVZSNWNHVWdQU0JjWEVWT1UwVk5Ra3hjWEN3Z2IyNTBJRDBnWEZ4Q1VGeGNLVnh1Wkc5MGNHeHZkQ2hIVHk1MWNDbGNia2RQTG01dklEd3RJR1Z1Y21samFFZFBLR2RsYm1VZ1BTQm5aVzVsVEdsemRDNXViMHh2YjNBdWMzQmxZMmxtYVdNc0lFOXlaMFJpSUQwZ2IzSm5MazF0TG1WbkxtUmlMQ0JyWlhsVWVYQmxJRDBnWEZ4RlRsTkZUVUpNWEZ3c0lHOXVkQ0E5SUZ4Y1FsQmNYQ2xjYm1SdmRIQnNiM1FvUjA4dWJtOHBYRzVIVHk1a2IzZHVJRHd0SUdWdWNtbGphRWRQS0dkbGJtVWdQU0JuWlc1bFRHbHpkQzVrYjNkdVRHOXZjQzV6Y0dWamFXWnBZeXdnVDNKblJHSWdQU0J2Y21jdVRXMHVaV2N1WkdJc0lHdGxlVlI1Y0dVZ1BTQmNYRVZPVTBWTlFreGNYQ3dnYjI1MElEMGdYRnhDVUZ4Y0tWeHVaRzkwY0d4dmRDaEhUeTVrYjNkdUxDQnphRzkzUTJGMFpXZHZjbmtnUFNBeU1DbGNibHh1WEc1Z1lHQmNibUJnWUNKOSAtLT5cblxuYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3AtcGVfZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IDAuMilcblxuZ2VuZUxpc3QudXBMb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9BNDg1X0RNU08gPT0gXFxVUFxcKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3Qubm9Mb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9BNDg1X0RNU08gPT0gXFxOT1xcKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3QuZG93bkxvb3AgPC0gdW5pcXVlKChnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIodXBkb3duX0E0ODVfRE1TTyA9PSBcXERPV05cXCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZSlcblxuXG5cbiMgQ0hFQ0tJTkcgSE9XIE1BTlkgR0VORVMgT1ZFUkxBUCBBTU9ORyBVUC9OTy9ET1dOXG5zZXRzX2xpc3QgPC0gbGlzdCh1cCA9IGdlbmVMaXN0LnVwTG9vcCxcbiAgICAgICAgICAgICAgICAgIG5vID0gZ2VuZUxpc3Qubm9Mb29wLFxuICAgICAgICAgICAgICAgICAgZG93biA9IGdlbmVMaXN0LmRvd25Mb29wKVxuXG4jIENyZWF0ZSB0aGUgRXVsZXIgcGxvdFxuZXVsZXJfZml0IDwtIGV1bGVyKHNldHNfbGlzdClcbnBsb3QoZXVsZXJfZml0LFxuICAgICBsYWJlbHMgPSBUUlVFLCAgIyBEaXNwbGF5IHNldCBsYWJlbHNcbiAgICAgZmlsbHMgPSBUUlVFLCAgICMgQ29sb3IgZmlsbCB0aGUgcmVnaW9uc1xuICAgICBxdWFudGl0aWVzID0gVFJVRSlcblxuXG4jIEdPXG5HTy51cCA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QudXBMb29wLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpXG5kb3RwbG90KEdPLnVwLCBzaG93Q2F0ZWdvcnkgPSAxNSlcbkdPLm5vIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ub0xvb3AsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08ubm8sIHNob3dDYXRlZ29yeSA9IDE1KVxuR08uZG93biA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QuZG93bkxvb3AsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08uZG93biwgc2hvd0NhdGVnb3J5ID0gMjApXG5cbiMgR08gdG8gb25seSBzcGVjaWZpYyBzdWJzZXRcbmdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYyA8LSBzZXRkaWZmKGdlbmVMaXN0LnVwTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC5kb3duTG9vcCkpXG5nZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5ub0xvb3AsIHVuaW9uKGdlbmVMaXN0LnVwTG9vcCwgZ2VuZUxpc3QuZG93bkxvb3ApKVxuZ2VuZUxpc3QuZG93bkxvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5kb3duTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC51cExvb3ApKVxuR08udXAgPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy51cClcbkdPLm5vIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08ubm8pXG5HTy5kb3duIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5kb3duTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy5kb3duLCBzaG93Q2F0ZWdvcnkgPSAyMClcblxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3AtcGVfZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IDAuMilcblxuZ2VuZUxpc3QudXBMb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9BNDg1X0RNU08gPT0gXFxVUFxcKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3Qubm9Mb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9BNDg1X0RNU08gPT0gXFxOT1xcKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3QuZG93bkxvb3AgPC0gdW5pcXVlKChnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIodXBkb3duX0E0ODVfRE1TTyA9PSBcXERPV05cXCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZSlcblxuXG5cbiMgQ0hFQ0tJTkcgSE9XIE1BTlkgR0VORVMgT1ZFUkxBUCBBTU9ORyBVUC9OTy9ET1dOXG5zZXRzX2xpc3QgPC0gbGlzdCh1cCA9IGdlbmVMaXN0LnVwTG9vcCxcbiAgICAgICAgICAgICAgICAgIG5vID0gZ2VuZUxpc3Qubm9Mb29wLFxuICAgICAgICAgICAgICAgICAgZG93biA9IGdlbmVMaXN0LmRvd25Mb29wKVxuXG4jIENyZWF0ZSB0aGUgRXVsZXIgcGxvdFxuZXVsZXJfZml0IDwtIGV1bGVyKHNldHNfbGlzdClcbnBsb3QoZXVsZXJfZml0LFxuICAgICBsYWJlbHMgPSBUUlVFLCAgIyBEaXNwbGF5IHNldCBsYWJlbHNcbiAgICAgZmlsbHMgPSBUUlVFLCAgICMgQ29sb3IgZmlsbCB0aGUgcmVnaW9uc1xuICAgICBxdWFudGl0aWVzID0gVFJVRSlcblxuXG4jIEdPXG5HTy51cCA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QudXBMb29wLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpXG5kb3RwbG90KEdPLnVwLCBzaG93Q2F0ZWdvcnkgPSAxNSlcbkdPLm5vIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ub0xvb3AsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08ubm8sIHNob3dDYXRlZ29yeSA9IDE1KVxuR08uZG93biA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QuZG93bkxvb3AsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08uZG93biwgc2hvd0NhdGVnb3J5ID0gMjApXG5cbiMgR08gdG8gb25seSBzcGVjaWZpYyBzdWJzZXRcbmdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYyA8LSBzZXRkaWZmKGdlbmVMaXN0LnVwTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC5kb3duTG9vcCkpXG5nZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5ub0xvb3AsIHVuaW9uKGdlbmVMaXN0LnVwTG9vcCwgZ2VuZUxpc3QuZG93bkxvb3ApKVxuZ2VuZUxpc3QuZG93bkxvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5kb3duTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC51cExvb3ApKVxuR08udXAgPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy51cClcbkdPLm5vIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08ubm8pXG5HTy5kb3duIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5kb3duTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy5kb3duLCBzaG93Q2F0ZWdvcnkgPSAyMClcblxuXG5gYGBcbmBgYCJ9 -->

```r
```r
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-pe_ensemblList.tsv\)),
                                      diffCutoff = 0.2)

geneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == \UP\) %>% unnest(gene))$gene)
geneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == \NO\) %>% unnest(gene))$gene)
geneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == \DOWN\) %>% unnest(gene))$gene)



# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN
sets_list <- list(up = geneList.upLoop,
                  no = geneList.noLoop,
                  down = geneList.downLoop)

# Create the Euler plot
euler_fit <- euler(sets_list)
plot(euler_fit,
     labels = TRUE,  # Display set labels
     fills = TRUE,   # Color fill the regions
     quantities = TRUE)


# GO
GO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up, showCategory = 15)
GO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no, showCategory = 15)
GO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down, showCategory = 20)

# GO to only specific subset
geneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))
geneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))
geneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))
GO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down, showCategory = 20)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



#### P-N

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVibUZ0WlNBOExTQmNJbU5vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGNJbHh1WEc1blpXNWxRVzV1YjBSaGRHRWdQQzBnYkc5aFpFeHZiM0JCYm01dlJHRjBZU2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lYM0F0Ymw5bGJuTmxiV0pzVEdsemRDNTBjM1pjSWlrcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JrYVdabVEzVjBiMlptSUQwZ01DNHlLVnh1WEc1blpXNWxUR2x6ZEM1MWNFeHZiM0FnUEMwZ2RXNXBjWFZsS0NoblpXNWxRVzV1YjBSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9kWEJrYjNkdVgwRTBPRFZmUkUxVFR5QTlQU0JjSWxWUVhDSXBJQ1UrSlNCMWJtNWxjM1FvWjJWdVpTa3BKR2RsYm1VcFhHNW5aVzVsVEdsemRDNXViMHh2YjNBZ1BDMGdkVzVwY1hWbEtDaG5aVzVsUVc1dWIwUmhkR0VnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvZFhCa2IzZHVYMEUwT0RWZlJFMVRUeUE5UFNCY0lrNVBYQ0lwSUNVK0pTQjFibTVsYzNRb1oyVnVaU2twSkdkbGJtVXBYRzVuWlc1bFRHbHpkQzVrYjNkdVRHOXZjQ0E4TFNCMWJtbHhkV1VvS0dkbGJtVkJibTV2UkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaDFjR1J2ZDI1ZlFUUTROVjlFVFZOUElEMDlJRndpUkU5WFRsd2lLU0FsUGlVZ2RXNXVaWE4wS0dkbGJtVXBLU1JuWlc1bEtWeHVYRzVjYmx4dUl5QkRTRVZEUzBsT1J5QklUMWNnVFVGT1dTQkhSVTVGVXlCUFZrVlNURUZRSUVGTlQwNUhJRlZRTDA1UEwwUlBWMDVjYm5ObGRITmZiR2x6ZENBOExTQnNhWE4wS0hWd0lEMGdaMlZ1WlV4cGMzUXVkWEJNYjI5d0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdibThnUFNCblpXNWxUR2x6ZEM1dWIweHZiM0FzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCa2IzZHVJRDBnWjJWdVpVeHBjM1F1Wkc5M2JreHZiM0FwWEc1Y2JpTWdRM0psWVhSbElIUm9aU0JGZFd4bGNpQndiRzkwWEc1bGRXeGxjbDltYVhRZ1BDMGdaWFZzWlhJb2MyVjBjMTlzYVhOMEtWeHVjR3h2ZENobGRXeGxjbDltYVhRc1hHNGdJQ0FnSUd4aFltVnNjeUE5SUZSU1ZVVXNJQ0FqSUVScGMzQnNZWGtnYzJWMElHeGhZbVZzYzF4dUlDQWdJQ0JtYVd4c2N5QTlJRlJTVlVVc0lDQWdJeUJEYjJ4dmNpQm1hV3hzSUhSb1pTQnlaV2RwYjI1elhHNGdJQ0FnSUhGMVlXNTBhWFJwWlhNZ1BTQlVVbFZGS1Z4dVhHNWNiaU1nUjA5Y2JrZFBMblZ3SUR3dElHVnVjbWxqYUVkUEtHZGxibVVnUFNCblpXNWxUR2x6ZEM1MWNFeHZiM0FzSUU5eVowUmlJRDBnYjNKbkxrMXRMbVZuTG1SaUxDQnJaWGxVZVhCbElEMGdYQ0pGVGxORlRVSk1YQ0lzSUc5dWRDQTlJRndpUWxCY0lpbGNibVJ2ZEhCc2IzUW9SMDh1ZFhBcFhHNUhUeTV1YnlBOExTQmxibkpwWTJoSFR5aG5aVzVsSUQwZ1oyVnVaVXhwYzNRdWJtOU1iMjl3TENCUGNtZEVZaUE5SUc5eVp5NU5iUzVsWnk1a1lpd2dhMlY1Vkhsd1pTQTlJRndpUlU1VFJVMUNURndpTENCdmJuUWdQU0JjSWtKUVhDSXBYRzVrYjNSd2JHOTBLRWRQTG01dktWeHVSMDh1Wkc5M2JpQThMU0JsYm5KcFkyaEhUeWhuWlc1bElEMGdaMlZ1WlV4cGMzUXVaRzkzYmt4dmIzQXNJRTl5WjBSaUlEMGdiM0puTGsxdExtVm5MbVJpTENCclpYbFVlWEJsSUQwZ1hDSkZUbE5GVFVKTVhDSXNJRzl1ZENBOUlGd2lRbEJjSWlsY2JtUnZkSEJzYjNRb1IwOHVaRzkzYml3Z2MyaHZkME5oZEdWbmIzSjVJRDBnTWpBcFhHNWNiaU1nUjA4Z2RHOGdiMjVzZVNCemNHVmphV1pwWXlCemRXSnpaWFJjYm1kbGJtVk1hWE4wTG5Wd1RHOXZjQzV6Y0dWamFXWnBZeUE4TFNCelpYUmthV1ptS0dkbGJtVk1hWE4wTG5Wd1RHOXZjQ3dnZFc1cGIyNG9aMlZ1WlV4cGMzUXVibTlNYjI5d0xDQm5aVzVsVEdsemRDNWtiM2R1VEc5dmNDa3BYRzVuWlc1bFRHbHpkQzV1YjB4dmIzQXVjM0JsWTJsbWFXTWdQQzBnYzJWMFpHbG1aaWhuWlc1bFRHbHpkQzV1YjB4dmIzQXNJSFZ1YVc5dUtHZGxibVZNYVhOMExuVndURzl2Y0N3Z1oyVnVaVXhwYzNRdVpHOTNia3h2YjNBcEtWeHVaMlZ1WlV4cGMzUXVaRzkzYmt4dmIzQXVjM0JsWTJsbWFXTWdQQzBnYzJWMFpHbG1aaWhuWlc1bFRHbHpkQzVrYjNkdVRHOXZjQ3dnZFc1cGIyNG9aMlZ1WlV4cGMzUXVibTlNYjI5d0xDQm5aVzVsVEdsemRDNTFjRXh2YjNBcEtWeHVSMDh1ZFhBZ1BDMGdaVzV5YVdOb1IwOG9aMlZ1WlNBOUlHZGxibVZNYVhOMExuVndURzl2Y0M1emNHVmphV1pwWXl3Z1QzSm5SR0lnUFNCdmNtY3VUVzB1WldjdVpHSXNJR3RsZVZSNWNHVWdQU0JjSWtWT1UwVk5Ra3hjSWl3Z2IyNTBJRDBnWENKQ1VGd2lLVnh1Wkc5MGNHeHZkQ2hIVHk1MWNDbGNia2RQTG01dklEd3RJR1Z1Y21samFFZFBLR2RsYm1VZ1BTQm5aVzVsVEdsemRDNXViMHh2YjNBdWMzQmxZMmxtYVdNc0lFOXlaMFJpSUQwZ2IzSm5MazF0TG1WbkxtUmlMQ0JyWlhsVWVYQmxJRDBnWENKRlRsTkZUVUpNWENJc0lHOXVkQ0E5SUZ3aVFsQmNJaWxjYm1SdmRIQnNiM1FvUjA4dWJtOHBYRzVIVHk1a2IzZHVJRHd0SUdWdWNtbGphRWRQS0dkbGJtVWdQU0JuWlc1bFRHbHpkQzVrYjNkdVRHOXZjQzV6Y0dWamFXWnBZeXdnVDNKblJHSWdQU0J2Y21jdVRXMHVaV2N1WkdJc0lHdGxlVlI1Y0dVZ1BTQmNJa1ZPVTBWTlFreGNJaXdnYjI1MElEMGdYQ0pDVUZ3aUtWeHVaRzkwY0d4dmRDaEhUeTVrYjNkdUtWeHVYRzVjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5XFxcblxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLW5fZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IDAuMilcblxuZ2VuZUxpc3QudXBMb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9BNDg1X0RNU08gPT0gXFxVUFxcKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3Qubm9Mb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9BNDg1X0RNU08gPT0gXFxOT1xcKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuZ2VuZUxpc3QuZG93bkxvb3AgPC0gdW5pcXVlKChnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIodXBkb3duX0E0ODVfRE1TTyA9PSBcXERPV05cXCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZSlcblxuXG5cbiMgQ0hFQ0tJTkcgSE9XIE1BTlkgR0VORVMgT1ZFUkxBUCBBTU9ORyBVUC9OTy9ET1dOXG5zZXRzX2xpc3QgPC0gbGlzdCh1cCA9IGdlbmVMaXN0LnVwTG9vcCxcbiAgICAgICAgICAgICAgICAgIG5vID0gZ2VuZUxpc3Qubm9Mb29wLFxuICAgICAgICAgICAgICAgICAgZG93biA9IGdlbmVMaXN0LmRvd25Mb29wKVxuXG4jIENyZWF0ZSB0aGUgRXVsZXIgcGxvdFxuZXVsZXJfZml0IDwtIGV1bGVyKHNldHNfbGlzdClcbnBsb3QoZXVsZXJfZml0LFxuICAgICBsYWJlbHMgPSBUUlVFLCAgIyBEaXNwbGF5IHNldCBsYWJlbHNcbiAgICAgZmlsbHMgPSBUUlVFLCAgICMgQ29sb3IgZmlsbCB0aGUgcmVnaW9uc1xuICAgICBxdWFudGl0aWVzID0gVFJVRSlcblxuXG4jIEdPXG5HTy51cCA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QudXBMb29wLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpXG5kb3RwbG90KEdPLnVwKVxuR08ubm8gPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0Lm5vTG9vcCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy5ubylcbkdPLmRvd24gPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0LmRvd25Mb29wLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpXG5kb3RwbG90KEdPLmRvd24sIHNob3dDYXRlZ29yeSA9IDIwKVxuXG4jIEdPIHRvIG9ubHkgc3BlY2lmaWMgc3Vic2V0XG5nZW5lTGlzdC51cExvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC51cExvb3AsIHVuaW9uKGdlbmVMaXN0Lm5vTG9vcCwgZ2VuZUxpc3QuZG93bkxvb3ApKVxuZ2VuZUxpc3Qubm9Mb29wLnNwZWNpZmljIDwtIHNldGRpZmYoZ2VuZUxpc3Qubm9Mb29wLCB1bmlvbihnZW5lTGlzdC51cExvb3AsIGdlbmVMaXN0LmRvd25Mb29wKSlcbmdlbmVMaXN0LmRvd25Mb29wLnNwZWNpZmljIDwtIHNldGRpZmYoZ2VuZUxpc3QuZG93bkxvb3AsIHVuaW9uKGdlbmVMaXN0Lm5vTG9vcCwgZ2VuZUxpc3QudXBMb29wKSlcbkdPLnVwIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC51cExvb3Auc3BlY2lmaWMsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08udXApXG5HTy5ubyA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3Qubm9Mb29wLnNwZWNpZmljLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpXG5kb3RwbG90KEdPLm5vKVxuR08uZG93biA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QuZG93bkxvb3Auc3BlY2lmaWMsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08uZG93bilcblxuXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2)

geneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == \UP\) %>% unnest(gene))$gene)
geneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == \NO\) %>% unnest(gene))$gene)
geneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == \DOWN\) %>% unnest(gene))$gene)



# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN
sets_list <- list(up = geneList.upLoop,
                  no = geneList.noLoop,
                  down = geneList.downLoop)

# Create the Euler plot
euler_fit <- euler(sets_list)
plot(euler_fit,
     labels = TRUE,  # Display set labels
     fills = TRUE,   # Color fill the regions
     quantities = TRUE)


# GO
GO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down, showCategory = 20)

# GO to only specific subset
geneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))
geneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))
geneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))
GO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJtRnRaU0E4TFNCY1hHTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsY1hGeHVYRzVuWlc1bFFXNXViMFJoZEdFZ1BDMGdiRzloWkV4dmIzQkJibTV2UkdGMFlTaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gzQXRibDlsYm5ObGJXSnNUR2x6ZEM1MGMzWmNYQ2twTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmthV1ptUTNWMGIyWm1JRDBnTUM0eUtWeHVYRzVuWlc1bFRHbHpkQzUxY0V4dmIzQWdQQzBnZFc1cGNYVmxLQ2huWlc1bFFXNXViMFJoZEdFZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb2RYQmtiM2R1WDBFME9EVmZSRTFUVHlBOVBTQmNYRlZRWEZ3cElDVStKU0IxYm01bGMzUW9aMlZ1WlNrcEpHZGxibVVwWEc1blpXNWxUR2x6ZEM1dWIweHZiM0FnUEMwZ2RXNXBjWFZsS0NoblpXNWxRVzV1YjBSaGRHRWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9kWEJrYjNkdVgwRTBPRFZmUkUxVFR5QTlQU0JjWEU1UFhGd3BJQ1UrSlNCMWJtNWxjM1FvWjJWdVpTa3BKR2RsYm1VcFhHNW5aVzVsVEdsemRDNWtiM2R1VEc5dmNDQThMU0IxYm1seGRXVW9LR2RsYm1WQmJtNXZSR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2loMWNHUnZkMjVmUVRRNE5WOUVUVk5QSUQwOUlGeGNSRTlYVGx4Y0tTQWxQaVVnZFc1dVpYTjBLR2RsYm1VcEtTUm5aVzVsS1Z4dVhHNWNibHh1SXlCRFNFVkRTMGxPUnlCSVQxY2dUVUZPV1NCSFJVNUZVeUJQVmtWU1RFRlFJRUZOVDA1SElGVlFMMDVQTDBSUFYwNWNibk5sZEhOZmJHbHpkQ0E4TFNCc2FYTjBLSFZ3SUQwZ1oyVnVaVXhwYzNRdWRYQk1iMjl3TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JtOGdQU0JuWlc1bFRHbHpkQzV1YjB4dmIzQXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JrYjNkdUlEMGdaMlZ1WlV4cGMzUXVaRzkzYmt4dmIzQXBYRzVjYmlNZ1EzSmxZWFJsSUhSb1pTQkZkV3hsY2lCd2JHOTBYRzVsZFd4bGNsOW1hWFFnUEMwZ1pYVnNaWElvYzJWMGMxOXNhWE4wS1Z4dWNHeHZkQ2hsZFd4bGNsOW1hWFFzWEc0Z0lDQWdJR3hoWW1Wc2N5QTlJRlJTVlVVc0lDQWpJRVJwYzNCc1lYa2djMlYwSUd4aFltVnNjMXh1SUNBZ0lDQm1hV3hzY3lBOUlGUlNWVVVzSUNBZ0l5QkRiMnh2Y2lCbWFXeHNJSFJvWlNCeVpXZHBiMjV6WEc0Z0lDQWdJSEYxWVc1MGFYUnBaWE1nUFNCVVVsVkZLVnh1WEc1Y2JpTWdSMDljYmtkUExuVndJRHd0SUdWdWNtbGphRWRQS0dkbGJtVWdQU0JuWlc1bFRHbHpkQzUxY0V4dmIzQXNJRTl5WjBSaUlEMGdiM0puTGsxdExtVm5MbVJpTENCclpYbFVlWEJsSUQwZ1hGeEZUbE5GVFVKTVhGd3NJRzl1ZENBOUlGeGNRbEJjWENsY2JtUnZkSEJzYjNRb1IwOHVkWEFwWEc1SFR5NXVieUE4TFNCbGJuSnBZMmhIVHloblpXNWxJRDBnWjJWdVpVeHBjM1F1Ym05TWIyOXdMQ0JQY21kRVlpQTlJRzl5Wnk1TmJTNWxaeTVrWWl3Z2EyVjVWSGx3WlNBOUlGeGNSVTVUUlUxQ1RGeGNMQ0J2Ym5RZ1BTQmNYRUpRWEZ3cFhHNWtiM1J3Ykc5MEtFZFBMbTV2S1Z4dVIwOHVaRzkzYmlBOExTQmxibkpwWTJoSFR5aG5aVzVsSUQwZ1oyVnVaVXhwYzNRdVpHOTNia3h2YjNBc0lFOXlaMFJpSUQwZ2IzSm5MazF0TG1WbkxtUmlMQ0JyWlhsVWVYQmxJRDBnWEZ4RlRsTkZUVUpNWEZ3c0lHOXVkQ0E5SUZ4Y1FsQmNYQ2xjYm1SdmRIQnNiM1FvUjA4dVpHOTNiaXdnYzJodmQwTmhkR1ZuYjNKNUlEMGdNakFwWEc1Y2JpTWdSMDhnZEc4Z2IyNXNlU0J6Y0dWamFXWnBZeUJ6ZFdKelpYUmNibWRsYm1WTWFYTjBMblZ3VEc5dmNDNXpjR1ZqYVdacFl5QThMU0J6WlhSa2FXWm1LR2RsYm1WTWFYTjBMblZ3VEc5dmNDd2dkVzVwYjI0b1oyVnVaVXhwYzNRdWJtOU1iMjl3TENCblpXNWxUR2x6ZEM1a2IzZHVURzl2Y0NrcFhHNW5aVzVsVEdsemRDNXViMHh2YjNBdWMzQmxZMmxtYVdNZ1BDMGdjMlYwWkdsbVppaG5aVzVsVEdsemRDNXViMHh2YjNBc0lIVnVhVzl1S0dkbGJtVk1hWE4wTG5Wd1RHOXZjQ3dnWjJWdVpVeHBjM1F1Wkc5M2JreHZiM0FwS1Z4dVoyVnVaVXhwYzNRdVpHOTNia3h2YjNBdWMzQmxZMmxtYVdNZ1BDMGdjMlYwWkdsbVppaG5aVzVsVEdsemRDNWtiM2R1VEc5dmNDd2dkVzVwYjI0b1oyVnVaVXhwYzNRdWJtOU1iMjl3TENCblpXNWxUR2x6ZEM1MWNFeHZiM0FwS1Z4dVIwOHVkWEFnUEMwZ1pXNXlhV05vUjA4b1oyVnVaU0E5SUdkbGJtVk1hWE4wTG5Wd1RHOXZjQzV6Y0dWamFXWnBZeXdnVDNKblJHSWdQU0J2Y21jdVRXMHVaV2N1WkdJc0lHdGxlVlI1Y0dVZ1BTQmNYRVZPVTBWTlFreGNYQ3dnYjI1MElEMGdYRnhDVUZ4Y0tWeHVaRzkwY0d4dmRDaEhUeTUxY0NsY2JrZFBMbTV2SUR3dElHVnVjbWxqYUVkUEtHZGxibVVnUFNCblpXNWxUR2x6ZEM1dWIweHZiM0F1YzNCbFkybG1hV01zSUU5eVowUmlJRDBnYjNKbkxrMXRMbVZuTG1SaUxDQnJaWGxVZVhCbElEMGdYRnhGVGxORlRVSk1YRndzSUc5dWRDQTlJRnhjUWxCY1hDbGNibVJ2ZEhCc2IzUW9SMDh1Ym04cFhHNUhUeTVrYjNkdUlEd3RJR1Z1Y21samFFZFBLR2RsYm1VZ1BTQm5aVzVsVEdsemRDNWtiM2R1VEc5dmNDNXpjR1ZqYVdacFl5d2dUM0puUkdJZ1BTQnZjbWN1VFcwdVpXY3VaR0lzSUd0bGVWUjVjR1VnUFNCY1hFVk9VMFZOUWt4Y1hDd2diMjUwSUQwZ1hGeENVRnhjS1Z4dVpHOTBjR3h2ZENoSFR5NWtiM2R1S1Z4dVhHNWNibUJnWUZ4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG5gYGByXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5cbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1uX2Vuc2VtYmxMaXN0LnRzdlxcKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIpXG5cbmdlbmVMaXN0LnVwTG9vcCA8LSB1bmlxdWUoKGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OmZpbHRlcih1cGRvd25fQTQ4NV9ETVNPID09IFxcVVBcXCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZSlcbmdlbmVMaXN0Lm5vTG9vcCA8LSB1bmlxdWUoKGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OmZpbHRlcih1cGRvd25fQTQ4NV9ETVNPID09IFxcTk9cXCkgJT4lIHVubmVzdChnZW5lKSkkZ2VuZSlcbmdlbmVMaXN0LmRvd25Mb29wIDwtIHVuaXF1ZSgoZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKHVwZG93bl9BNDg1X0RNU08gPT0gXFxET1dOXFwpICU+JSB1bm5lc3QoZ2VuZSkpJGdlbmUpXG5cblxuXG4jIENIRUNLSU5HIEhPVyBNQU5ZIEdFTkVTIE9WRVJMQVAgQU1PTkcgVVAvTk8vRE9XTlxuc2V0c19saXN0IDwtIGxpc3QodXAgPSBnZW5lTGlzdC51cExvb3AsXG4gICAgICAgICAgICAgICAgICBubyA9IGdlbmVMaXN0Lm5vTG9vcCxcbiAgICAgICAgICAgICAgICAgIGRvd24gPSBnZW5lTGlzdC5kb3duTG9vcClcblxuIyBDcmVhdGUgdGhlIEV1bGVyIHBsb3RcbmV1bGVyX2ZpdCA8LSBldWxlcihzZXRzX2xpc3QpXG5wbG90KGV1bGVyX2ZpdCxcbiAgICAgbGFiZWxzID0gVFJVRSwgICMgRGlzcGxheSBzZXQgbGFiZWxzXG4gICAgIGZpbGxzID0gVFJVRSwgICAjIENvbG9yIGZpbGwgdGhlIHJlZ2lvbnNcbiAgICAgcXVhbnRpdGllcyA9IFRSVUUpXG5cblxuIyBHT1xuR08udXAgPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0LnVwTG9vcCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy51cClcbkdPLm5vIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ub0xvb3AsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08ubm8pXG5HTy5kb3duIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5kb3duTG9vcCwgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy5kb3duLCBzaG93Q2F0ZWdvcnkgPSAyMClcblxuIyBHTyB0byBvbmx5IHNwZWNpZmljIHN1YnNldFxuZ2VuZUxpc3QudXBMb29wLnNwZWNpZmljIDwtIHNldGRpZmYoZ2VuZUxpc3QudXBMb29wLCB1bmlvbihnZW5lTGlzdC5ub0xvb3AsIGdlbmVMaXN0LmRvd25Mb29wKSlcbmdlbmVMaXN0Lm5vTG9vcC5zcGVjaWZpYyA8LSBzZXRkaWZmKGdlbmVMaXN0Lm5vTG9vcCwgdW5pb24oZ2VuZUxpc3QudXBMb29wLCBnZW5lTGlzdC5kb3duTG9vcCkpXG5nZW5lTGlzdC5kb3duTG9vcC5zcGVjaWZpYyA8LSBzZXRkaWZmKGdlbmVMaXN0LmRvd25Mb29wLCB1bmlvbihnZW5lTGlzdC5ub0xvb3AsIGdlbmVMaXN0LnVwTG9vcCkpXG5HTy51cCA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QudXBMb29wLnNwZWNpZmljLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpXG5kb3RwbG90KEdPLnVwKVxuR08ubm8gPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0Lm5vTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy5ubylcbkdPLmRvd24gPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0LmRvd25Mb29wLnNwZWNpZmljLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpXG5kb3RwbG90KEdPLmRvd24pXG5cblxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3Atbl9lbnNlbWJsTGlzdC50c3ZcXCkpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yKVxuXG5nZW5lTGlzdC51cExvb3AgPC0gdW5pcXVlKChnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIodXBkb3duX0E0ODVfRE1TTyA9PSBcXFVQXFwpICU+JSB1bm5lc3QoZ2VuZSkpJGdlbmUpXG5nZW5lTGlzdC5ub0xvb3AgPC0gdW5pcXVlKChnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIodXBkb3duX0E0ODVfRE1TTyA9PSBcXE5PXFwpICU+JSB1bm5lc3QoZ2VuZSkpJGdlbmUpXG5nZW5lTGlzdC5kb3duTG9vcCA8LSB1bmlxdWUoKGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OmZpbHRlcih1cGRvd25fQTQ4NV9ETVNPID09IFxcRE9XTlxcKSAlPiUgdW5uZXN0KGdlbmUpKSRnZW5lKVxuXG5cblxuIyBDSEVDS0lORyBIT1cgTUFOWSBHRU5FUyBPVkVSTEFQIEFNT05HIFVQL05PL0RPV05cbnNldHNfbGlzdCA8LSBsaXN0KHVwID0gZ2VuZUxpc3QudXBMb29wLFxuICAgICAgICAgICAgICAgICAgbm8gPSBnZW5lTGlzdC5ub0xvb3AsXG4gICAgICAgICAgICAgICAgICBkb3duID0gZ2VuZUxpc3QuZG93bkxvb3ApXG5cbiMgQ3JlYXRlIHRoZSBFdWxlciBwbG90XG5ldWxlcl9maXQgPC0gZXVsZXIoc2V0c19saXN0KVxucGxvdChldWxlcl9maXQsXG4gICAgIGxhYmVscyA9IFRSVUUsICAjIERpc3BsYXkgc2V0IGxhYmVsc1xuICAgICBmaWxscyA9IFRSVUUsICAgIyBDb2xvciBmaWxsIHRoZSByZWdpb25zXG4gICAgIHF1YW50aXRpZXMgPSBUUlVFKVxuXG5cbiMgR09cbkdPLnVwIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC51cExvb3AsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08udXApXG5HTy5ubyA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3Qubm9Mb29wLCBPcmdEYiA9IG9yZy5NbS5lZy5kYiwga2V5VHlwZSA9IFxcRU5TRU1CTFxcLCBvbnQgPSBcXEJQXFwpXG5kb3RwbG90KEdPLm5vKVxuR08uZG93biA8LSBlbnJpY2hHTyhnZW5lID0gZ2VuZUxpc3QuZG93bkxvb3AsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08uZG93biwgc2hvd0NhdGVnb3J5ID0gMjApXG5cbiMgR08gdG8gb25seSBzcGVjaWZpYyBzdWJzZXRcbmdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYyA8LSBzZXRkaWZmKGdlbmVMaXN0LnVwTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC5kb3duTG9vcCkpXG5nZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5ub0xvb3AsIHVuaW9uKGdlbmVMaXN0LnVwTG9vcCwgZ2VuZUxpc3QuZG93bkxvb3ApKVxuZ2VuZUxpc3QuZG93bkxvb3Auc3BlY2lmaWMgPC0gc2V0ZGlmZihnZW5lTGlzdC5kb3duTG9vcCwgdW5pb24oZ2VuZUxpc3Qubm9Mb29wLCBnZW5lTGlzdC51cExvb3ApKVxuR08udXAgPC0gZW5yaWNoR08oZ2VuZSA9IGdlbmVMaXN0LnVwTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy51cClcbkdPLm5vIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5ub0xvb3Auc3BlY2lmaWMsIE9yZ0RiID0gb3JnLk1tLmVnLmRiLCBrZXlUeXBlID0gXFxFTlNFTUJMXFwsIG9udCA9IFxcQlBcXClcbmRvdHBsb3QoR08ubm8pXG5HTy5kb3duIDwtIGVucmljaEdPKGdlbmUgPSBnZW5lTGlzdC5kb3duTG9vcC5zcGVjaWZpYywgT3JnRGIgPSBvcmcuTW0uZWcuZGIsIGtleVR5cGUgPSBcXEVOU0VNQkxcXCwgb250ID0gXFxCUFxcKVxuZG90cGxvdChHTy5kb3duKVxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2)

geneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == \UP\) %>% unnest(gene))$gene)
geneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == \NO\) %>% unnest(gene))$gene)
geneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == \DOWN\) %>% unnest(gene))$gene)



# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN
sets_list <- list(up = geneList.upLoop,
                  no = geneList.noLoop,
                  down = geneList.downLoop)

# Create the Euler plot
euler_fit <- euler(sets_list)
plot(euler_fit,
     labels = TRUE,  # Display set labels
     fills = TRUE,   # Color fill the regions
     quantities = TRUE)


# GO
GO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down, showCategory = 20)

# GO to only specific subset
geneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))
geneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))
geneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))
GO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = \ENSEMBL\, ont = \BP\)
dotplot(GO.down)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

### A485
#### P-P, P-E

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore\n  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nname <- \"chromo_cons_annoHierarchy\"\n\n# UP loop\nloop.up <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\"))\nanchor.up <- (extractAnchor(loop.up))\n# NO loop\nloop.no <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\"))\nanchor.no <- (extractAnchor(loop.no))\n# UP NO\nloop.upno <- bind_rows(loop.up, loop.no)\nanchor.upno <- (extractAnchor(loop.upno))\n# DOWN loop\nloop.down <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\"))\nanchor.down <- (extractAnchor(loop.down))\n\ngetSumScores <- function(track, anchor) {\n  # Find overlaps between all anchors and track regions at once\n  overlaps <- findOverlaps(anchor, track)\n  \n  # Extract the scores and corresponding anchor indices\n  anchor_indices <- queryHits(overlaps)\n  track_scores <- score(track)[subjectHits(overlaps)]\n  \n  # Use tapply to calculate the median scores for each anchor\n  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)\n  \n  # Initialize a numeric vector to store the median scores for each anchor\n  all_median_scores <- rep(NA, length(anchor))\n  \n  # Populate the median scores for the anchors that have overlaps\n  all_median_scores[as.numeric(names(median_scores))] <- median_scores\n  \n  return(all_median_scores)\n}\n\nplotSumScores <- function(track, peak, name){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor.up)\n  b <- getSumScores(peakTrack, anchor.no)\n  c <- getSumScores(peakTrack, anchor.down)\n  a.tb <- tibble(loop = \"UP\",\n                 sumScore = a)\n  b.tb <- tibble(loop = \"NO\",\n                 sumScore = b)\n  c.tb <- tibble(loop = \"DOWN\",\n                 sumScore = c)\n  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\n  ggplot(data, aes(x = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(name, \" average peak score per anchor\")) +\n    geom_violin(aes(fill = group), color = \"black\",\n                linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n                show.legend = FALSE) +\n    geom_boxplot(width = 0.1, color = \"black\",\n                 linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \"point\", shape = 21, size = 1,\n      fill = \"red\", color = \"black\"\n    ) +\n    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.95))) + theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n}\n\nplotSumScoresBinary <- function(track, peak, name, anchor.upno, anchor.down){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  b <- getSumScores(peakTrack, anchor.upno)\n  c <- getSumScores(peakTrack, anchor.down)\n  b.tb <- tibble(loop = \"UP/NO\",\n                 sumScore = b)\n  c.tb <- tibble(loop = \"DOWN\",\n                 sumScore = c)\n  data <- bind_rows(b.tb, c.tb) %>% drop_na()\n  data$loop <- factor(data$loop, levels = c(\"UP/NO\", \"DOWN\"))\n  \n  p12 <- getPvalWilcox(data, \"UP/NO\", \"DOWN\")\n  p <-  ggplot(data, aes(x = name, fill = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(\"Average ChIP peak score at anchor)\")) +\n    introdataviz::geom_split_violin(linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n                                    alpha = .4) +\n    geom_boxplot(width = 0.3, color = \"black\",\n                 linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \"point\", shape = 21, size = 0.5,\n      fill = \"black\", color = \"black\", position = position_dodge(.3)\n    ) + theme(\n      axis.title = element_text(\n        size = fontSizeM, family = fontType, color = \"#000000\"\n      ),\n      axis.text = element_text(\n        size = fontSizeM, family = fontType, color = \"#000000\"\n      ),\n      axis.text.x = element_text(\n        angle = 0,\n      ),\n      axis.text.y = element_text(\n        size = fontSizeS,\n      ),\n      axis.line = element_line(\n        color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n      ),\n      axis.ticks = element_line(\n        color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n      ),\n      panel.background = element_rect(fill = \"transparent\"),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + \n    coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.9))) + \n    annotate(\n     \"text\", x = 1, y = quantile(data$sumScore, 0.5),\n     label = paste0(\"p12: \", convPvalue(p12)),\n     color = \"black\", hjust = 0, size = 3\n   ) +   guides(\n    fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n    )\n  )\n  \n   fileName <- paste0(\"ChIP_peak_avgPeakScore_\", name)\n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \"33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\"), format = \"BigWig\")\npeak <- importPeak(here(refDir, \"33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\"))\n#plotSumScores(track, peak, \"H3K4me3\")\nplotSumScoresBinary(track, peak, \"H3K4me3\", anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \"GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\"), format = \"BigWig\")\npeak <- importPeak(here(refDir, \"GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\"))\n#plotSumScores(track, peak, \"H3K27ac\")\nplotSumScoresBinary(track, peak, \"H3K27ac\", anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \"GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\"), format = \"BigWig\")\npeak <- importPeak(here(refDir, \"GSM2683440_J1_H3K14ac_mm10Lifted.bed\"))\n#plotSumScores(track, peak, \"H3K14ac\")\nplotSumScoresBinary(track, peak, \"H3K14ac\", anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \"33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\"), format = \"BigWig\")\npeak <- importPeak(here(refDir, \"33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\"))\n#plotSumScores(track, peak, \"CTCF\")\nplotSumScoresBinary(track, peak, \"CTCF\", anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \"33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\"), format = \"BigWig\")\npeak <- importPeak(here(refDir, \"33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\"))\n#plotSumScores(track, peak, \"RAD21\")\nplotSumScoresBinary(track, peak, \"RAD21\", anchor.upno, anchor.down)\n\n\n```"} -->\n\n```r\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore\n  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nname <- \\chromo_cons_annoHierarchy\\\n\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nanchor.up <- (extractAnchor(loop.up))\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.no <- (extractAnchor(loop.no))\n# UP NO\nloop.upno <- bind_rows(loop.up, loop.no)\nanchor.upno <- (extractAnchor(loop.upno))\n# DOWN loop\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- (extractAnchor(loop.down))\n\ngetSumScores <- function(track, anchor) {\n  # Find overlaps between all anchors and track regions at once\n  overlaps <- findOverlaps(anchor, track)\n  \n  # Extract the scores and corresponding anchor indices\n  anchor_indices <- queryHits(overlaps)\n  track_scores <- score(track)[subjectHits(overlaps)]\n  \n  # Use tapply to calculate the median scores for each anchor\n  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)\n  \n  # Initialize a numeric vector to store the median scores for each anchor\n  all_median_scores <- rep(NA, length(anchor))\n  \n  # Populate the median scores for the anchors that have overlaps\n  all_median_scores[as.numeric(names(median_scores))] <- median_scores\n  \n  return(all_median_scores)\n}\n\nplotSumScores <- function(track, peak, name){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor.up)\n  b <- getSumScores(peakTrack, anchor.no)\n  c <- getSumScores(peakTrack, anchor.down)\n  a.tb <- tibble(loop = \\UP\\,\n                 sumScore = a)\n  b.tb <- tibble(loop = \\NO\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\DOWN\\,\n                 sumScore = c)\n  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\n  ggplot(data, aes(x = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(name, \\ average peak score per anchor\\)) +\n    geom_violin(aes(fill = group), color = \\black\\,\n                linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                show.legend = FALSE) +\n    geom_boxplot(width = 0.1, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 1,\n      fill = \\red\\, color = \\black\\\n    ) +\n    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.95))) + theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n}\n\nplotSumScoresBinary <- function(track, peak, name, anchor.upno, anchor.down){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  b <- getSumScores(peakTrack, anchor.upno)\n  c <- getSumScores(peakTrack, anchor.down)\n  b.tb <- tibble(loop = \\UP/NO\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\DOWN\\,\n                 sumScore = c)\n  data <- bind_rows(b.tb, c.tb) %>% drop_na()\n  data$loop <- factor(data$loop, levels = c(\\UP/NO\\, \\DOWN\\))\n  \n  p12 <- getPvalWilcox(data, \\UP/NO\\, \\DOWN\\)\n  p <-  ggplot(data, aes(x = name, fill = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(\\Average ChIP peak score at anchor)\\)) +\n    introdataviz::geom_split_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                                    alpha = .4) +\n    geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) + theme(\n      axis.title = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 0,\n      ),\n      axis.text.y = element_text(\n        size = fontSizeS,\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + \n    coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.9))) + \n    annotate(\n     \\text\\, x = 1, y = quantile(data$sumScore, 0.5),\n     label = paste0(\\p12: \\, convPvalue(p12)),\n     color = \\black\\, hjust = 0, size = 3\n   ) +   guides(\n    fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n    )\n  )\n  \n   fileName <- paste0(\\ChIP_peak_avgPeakScore_\\, name)\n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\H3K4me3\\)\nplotSumScoresBinary(track, peak, \\H3K4me3\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\n#plotSumScores(track, peak, \\H3K27ac\\)\nplotSumScoresBinary(track, peak, \\H3K27ac\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.bed\\))\n#plotSumScores(track, peak, \\H3K14ac\\)\nplotSumScoresBinary(track, peak, \\H3K14ac\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\CTCF\\)\nplotSumScoresBinary(track, peak, \\CTCF\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\RAD21\\)\nplotSumScoresBinary(track, peak, \\RAD21\\, anchor.upno, anchor.down)\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore
  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

name <- \chromo_cons_annoHierarchy\

# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
# UP NO
loop.upno <- bind_rows(loop.up, loop.no)
anchor.upno <- (extractAnchor(loop.upno))
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))

getSumScores <- function(track, anchor) {
  # Find overlaps between all anchors and track regions at once
  overlaps <- findOverlaps(anchor, track)
  
  # Extract the scores and corresponding anchor indices
  anchor_indices <- queryHits(overlaps)
  track_scores <- score(track)[subjectHits(overlaps)]
  
  # Use tapply to calculate the median scores for each anchor
  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)
  
  # Initialize a numeric vector to store the median scores for each anchor
  all_median_scores <- rep(NA, length(anchor))
  
  # Populate the median scores for the anchors that have overlaps
  all_median_scores[as.numeric(names(median_scores))] <- median_scores
  
  return(all_median_scores)
}

plotSumScores <- function(track, peak, name){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  a <- getSumScores(peakTrack, anchor.up)
  b <- getSumScores(peakTrack, anchor.no)
  c <- getSumScores(peakTrack, anchor.down)
  a.tb <- tibble(loop = \UP\,
                 sumScore = a)
  b.tb <- tibble(loop = \NO\,
                 sumScore = b)
  c.tb <- tibble(loop = \DOWN\,
                 sumScore = c)
  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()
  ggplot(data, aes(x = loop, y = sumScore)) + 
    labs(x = NULL, y = paste0(name, \ average peak score per anchor\)) +
    geom_violin(aes(fill = group), color = \black\,
                linewidth = lineThick * mmToLineUnit, lineend = \square\,
                show.legend = FALSE) +
    geom_boxplot(width = 0.1, color = \black\,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\,
                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +
    stat_summary(
      aes(group = loop), fun = mean,
      geom = \point\, shape = 21, size = 1,
      fill = \red\, color = \black\
    ) +
    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.95))) + theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )
}

plotSumScoresBinary <- function(track, peak, name, anchor.upno, anchor.down){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  b <- getSumScores(peakTrack, anchor.upno)
  c <- getSumScores(peakTrack, anchor.down)
  b.tb <- tibble(loop = \UP/NO\,
                 sumScore = b)
  c.tb <- tibble(loop = \DOWN\,
                 sumScore = c)
  data <- bind_rows(b.tb, c.tb) %>% drop_na()
  data$loop <- factor(data$loop, levels = c(\UP/NO\, \DOWN\))
  
  p12 <- getPvalWilcox(data, \UP/NO\, \DOWN\)
  p <-  ggplot(data, aes(x = name, fill = loop, y = sumScore)) + 
    labs(x = NULL, y = paste0(\Average ChIP peak score at anchor)\)) +
    introdataviz::geom_split_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\,
                                    alpha = .4) +
    geom_boxplot(width = 0.3, color = \black\,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\,
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + theme_classic() +
    stat_summary(
      aes(group = loop), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) + theme(
      axis.title = element_text(
        size = fontSizeM, family = fontType, color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeM, family = fontType, color = \#000000\
      ),
      axis.text.x = element_text(
        angle = 0,
      ),
      axis.text.y = element_text(
        size = fontSizeS,
      ),
      axis.line = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    ) + 
    coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.9))) + 
    annotate(
     \text\, x = 1, y = quantile(data$sumScore, 0.5),
     label = paste0(\p12: \, convPvalue(p12)),
     color = \black\, hjust = 0, size = 3
   ) +   guides(
    fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
    )
  )
  
   fileName <- paste0(\ChIP_peak_avgPeakScore_\, name)
  width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# Sum peak score
####
track <- import(here(refDir, \33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\))
#plotSumScores(track, peak, \H3K4me3\)
plotSumScoresBinary(track, peak, \H3K4me3\, anchor.upno, anchor.down)

track <- import(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
#plotSumScores(track, peak, \H3K27ac\)
plotSumScoresBinary(track, peak, \H3K27ac\, anchor.upno, anchor.down)

track <- import(here(refDir, \GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM2683440_J1_H3K14ac_mm10Lifted.bed\))
#plotSumScores(track, peak, \H3K14ac\)
plotSumScoresBinary(track, peak, \H3K14ac\, anchor.upno, anchor.down)

track <- import(here(refDir, \33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))
#plotSumScores(track, peak, \CTCF\)
plotSumScoresBinary(track, peak, \CTCF\, anchor.upno, anchor.down)

track <- import(here(refDir, \33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))
#plotSumScores(track, peak, \RAD21\)
plotSumScoresBinary(track, peak, \RAD21\, anchor.upno, anchor.down)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore\n  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nname <- \\chromo_cons_annoHierarchy\\\n\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nanchor.up <- (extractAnchor(loop.up))\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.no <- (extractAnchor(loop.no))\n# UP NO\nloop.upno <- bind_rows(loop.up, loop.no)\nanchor.upno <- (extractAnchor(loop.upno))\n# DOWN loop\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- (extractAnchor(loop.down))\n\ngetSumScores <- function(track, anchor) {\n  # Find overlaps between all anchors and track regions at once\n  overlaps <- findOverlaps(anchor, track)\n  \n  # Extract the scores and corresponding anchor indices\n  anchor_indices <- queryHits(overlaps)\n  track_scores <- score(track)[subjectHits(overlaps)]\n  \n  # Use tapply to calculate the median scores for each anchor\n  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)\n  \n  # Initialize a numeric vector to store the median scores for each anchor\n  all_median_scores <- rep(NA, length(anchor))\n  \n  # Populate the median scores for the anchors that have overlaps\n  all_median_scores[as.numeric(names(median_scores))] <- median_scores\n  \n  return(all_median_scores)\n}\n\nplotSumScores <- function(track, peak, name){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor.up)\n  b <- getSumScores(peakTrack, anchor.no)\n  c <- getSumScores(peakTrack, anchor.down)\n  a.tb <- tibble(loop = \\UP\\,\n                 sumScore = a)\n  b.tb <- tibble(loop = \\NO\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\DOWN\\,\n                 sumScore = c)\n  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\n  ggplot(data, aes(x = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(name, \\ average peak score per anchor\\)) +\n    geom_violin(aes(fill = group), color = \\black\\,\n                linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                show.legend = FALSE) +\n    geom_boxplot(width = 0.1, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 1,\n      fill = \\red\\, color = \\black\\\n    ) +\n    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.95))) + theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n}\n\nplotSumScoresBinary <- function(track, peak, name, anchor.upno, anchor.down){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  b <- getSumScores(peakTrack, anchor.upno)\n  c <- getSumScores(peakTrack, anchor.down)\n  b.tb <- tibble(loop = \\UP/NO\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\DOWN\\,\n                 sumScore = c)\n  data <- bind_rows(b.tb, c.tb) %>% drop_na()\n  data$loop <- factor(data$loop, levels = c(\\UP/NO\\, \\DOWN\\))\n  \n  p12 <- getPvalWilcox(data, \\UP/NO\\, \\DOWN\\)\n  p <-  ggplot(data, aes(x = name, fill = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(\\Average ChIP peak score at anchor)\\)) +\n    introdataviz::geom_split_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                                    alpha = .4) +\n    geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) + theme(\n      axis.title = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 0,\n      ),\n      axis.text.y = element_text(\n        size = fontSizeS,\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + \n    coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.9))) + \n    annotate(\n     \\text\\, x = 1, y = quantile(data$sumScore, 0.5),\n     label = paste0(\\p12: \\, convPvalue(p12)),\n     color = \\black\\, hjust = 0, size = 3\n   ) +   guides(\n    fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n    )\n  )\n  \n   fileName <- paste0(\\ChIP_peak_avgPeakScore_\\, name)\n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\H3K4me3\\)\nplotSumScoresBinary(track, peak, \\H3K4me3\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\n#plotSumScores(track, peak, \\H3K27ac\\)\nplotSumScoresBinary(track, peak, \\H3K27ac\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.bed\\))\n#plotSumScores(track, peak, \\H3K14ac\\)\nplotSumScoresBinary(track, peak, \\H3K14ac\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\CTCF\\)\nplotSumScoresBinary(track, peak, \\CTCF\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\RAD21\\)\nplotSumScoresBinary(track, peak, \\RAD21\\, anchor.upno, anchor.down)\n\n\n```\n```"} -->\n\n```r\n```r\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore\n  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nname <- \\chromo_cons_annoHierarchy\\\n\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nanchor.up <- (extractAnchor(loop.up))\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.no <- (extractAnchor(loop.no))\n# UP NO\nloop.upno <- bind_rows(loop.up, loop.no)\nanchor.upno <- (extractAnchor(loop.upno))\n# DOWN loop\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- (extractAnchor(loop.down))\n\ngetSumScores <- function(track, anchor) {\n  # Find overlaps between all anchors and track regions at once\n  overlaps <- findOverlaps(anchor, track)\n  \n  # Extract the scores and corresponding anchor indices\n  anchor_indices <- queryHits(overlaps)\n  track_scores <- score(track)[subjectHits(overlaps)]\n  \n  # Use tapply to calculate the median scores for each anchor\n  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)\n  \n  # Initialize a numeric vector to store the median scores for each anchor\n  all_median_scores <- rep(NA, length(anchor))\n  \n  # Populate the median scores for the anchors that have overlaps\n  all_median_scores[as.numeric(names(median_scores))] <- median_scores\n  \n  return(all_median_scores)\n}\n\nplotSumScores <- function(track, peak, name){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor.up)\n  b <- getSumScores(peakTrack, anchor.no)\n  c <- getSumScores(peakTrack, anchor.down)\n  a.tb <- tibble(loop = \\UP\\,\n                 sumScore = a)\n  b.tb <- tibble(loop = \\NO\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\DOWN\\,\n                 sumScore = c)\n  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\n  ggplot(data, aes(x = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(name, \\ average peak score per anchor\\)) +\n    geom_violin(aes(fill = group), color = \\black\\,\n                linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                show.legend = FALSE) +\n    geom_boxplot(width = 0.1, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 1,\n      fill = \\red\\, color = \\black\\\n    ) +\n    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.95))) + theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n}\n\nplotSumScoresBinary <- function(track, peak, name, anchor.upno, anchor.down){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  b <- getSumScores(peakTrack, anchor.upno)\n  c <- getSumScores(peakTrack, anchor.down)\n  b.tb <- tibble(loop = \\UP/NO\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\DOWN\\,\n                 sumScore = c)\n  data <- bind_rows(b.tb, c.tb) %>% drop_na()\n  data$loop <- factor(data$loop, levels = c(\\UP/NO\\, \\DOWN\\))\n  \n  p12 <- getPvalWilcox(data, \\UP/NO\\, \\DOWN\\)\n  p <-  ggplot(data, aes(x = name, fill = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(\\Average ChIP peak score at anchor)\\)) +\n    introdataviz::geom_split_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                                    alpha = .4) +\n    geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) + theme(\n      axis.title = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 0,\n      ),\n      axis.text.y = element_text(\n        size = fontSizeS,\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + \n    coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.9))) + \n    annotate(\n     \\text\\, x = 1, y = quantile(data$sumScore, 0.5),\n     label = paste0(\\p12: \\, convPvalue(p12)),\n     color = \\black\\, hjust = 0, size = 3\n   ) +   guides(\n    fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n    )\n  )\n  \n   fileName <- paste0(\\ChIP_peak_avgPeakScore_\\, name)\n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\H3K4me3\\)\nplotSumScoresBinary(track, peak, \\H3K4me3\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\n#plotSumScores(track, peak, \\H3K27ac\\)\nplotSumScoresBinary(track, peak, \\H3K27ac\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.bed\\))\n#plotSumScores(track, peak, \\H3K14ac\\)\nplotSumScoresBinary(track, peak, \\H3K14ac\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\CTCF\\)\nplotSumScoresBinary(track, peak, \\CTCF\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\RAD21\\)\nplotSumScoresBinary(track, peak, \\RAD21\\, anchor.upno, anchor.down)\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore\n  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nname <- \\chromo_cons_annoHierarchy\\\n\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nanchor.up <- (extractAnchor(loop.up))\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.no <- (extractAnchor(loop.no))\n# UP NO\nloop.upno <- bind_rows(loop.up, loop.no)\nanchor.upno <- (extractAnchor(loop.upno))\n# DOWN loop\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- (extractAnchor(loop.down))\n\ngetSumScores <- function(track, anchor) {\n  # Find overlaps between all anchors and track regions at once\n  overlaps <- findOverlaps(anchor, track)\n  \n  # Extract the scores and corresponding anchor indices\n  anchor_indices <- queryHits(overlaps)\n  track_scores <- score(track)[subjectHits(overlaps)]\n  \n  # Use tapply to calculate the median scores for each anchor\n  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)\n  \n  # Initialize a numeric vector to store the median scores for each anchor\n  all_median_scores <- rep(NA, length(anchor))\n  \n  # Populate the median scores for the anchors that have overlaps\n  all_median_scores[as.numeric(names(median_scores))] <- median_scores\n  \n  return(all_median_scores)\n}\n\nplotSumScores <- function(track, peak, name){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor.up)\n  b <- getSumScores(peakTrack, anchor.no)\n  c <- getSumScores(peakTrack, anchor.down)\n  a.tb <- tibble(loop = \\UP\\,\n                 sumScore = a)\n  b.tb <- tibble(loop = \\NO\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\DOWN\\,\n                 sumScore = c)\n  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\n  ggplot(data, aes(x = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(name, \\ average peak score per anchor\\)) +\n    geom_violin(aes(fill = group), color = \\black\\,\n                linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                show.legend = FALSE) +\n    geom_boxplot(width = 0.1, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 1,\n      fill = \\red\\, color = \\black\\\n    ) +\n    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.95))) + theme(\n    axis.title = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n}\n\nplotSumScoresBinary <- function(track, peak, name, anchor.upno, anchor.down){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  b <- getSumScores(peakTrack, anchor.upno)\n  c <- getSumScores(peakTrack, anchor.down)\n  b.tb <- tibble(loop = \\UP/NO\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\DOWN\\,\n                 sumScore = c)\n  data <- bind_rows(b.tb, c.tb) %>% drop_na()\n  data$loop <- factor(data$loop, levels = c(\\UP/NO\\, \\DOWN\\))\n  \n  p12 <- getPvalWilcox(data, \\UP/NO\\, \\DOWN\\)\n  p <-  ggplot(data, aes(x = name, fill = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(\\Average ChIP peak score at anchor)\\)) +\n    introdataviz::geom_split_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                                    alpha = .4) +\n    geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) + theme(\n      axis.title = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeM, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 0,\n      ),\n      axis.text.y = element_text(\n        size = fontSizeS,\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + \n    coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.9))) + \n    annotate(\n     \\text\\, x = 1, y = quantile(data$sumScore, 0.5),\n     label = paste0(\\p12: \\, convPvalue(p12)),\n     color = \\black\\, hjust = 0, size = 3\n   ) +   guides(\n    fill = guide_legend(\n        keywidth = 0.2,  # Adjust the width of the legend keys\n        keyheight = 0.2  # Adjust the height of the legend keys\n    )\n  )\n  \n   fileName <- paste0(\\ChIP_peak_avgPeakScore_\\, name)\n  width <- panelSize(1.5)*mmToInch\n  height <- panelSize(1.2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\H3K4me3\\)\nplotSumScoresBinary(track, peak, \\H3K4me3\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\n#plotSumScores(track, peak, \\H3K27ac\\)\nplotSumScoresBinary(track, peak, \\H3K27ac\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.bed\\))\n#plotSumScores(track, peak, \\H3K14ac\\)\nplotSumScoresBinary(track, peak, \\H3K14ac\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\CTCF\\)\nplotSumScoresBinary(track, peak, \\CTCF\\, anchor.upno, anchor.down)\n\ntrack <- import(here(refDir, \\33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\RAD21\\)\nplotSumScoresBinary(track, peak, \\RAD21\\, anchor.upno, anchor.down)\n\n\n```\n```"} -->

```r
```r
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore
  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

name <- \chromo_cons_annoHierarchy\

# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
# UP NO
loop.upno <- bind_rows(loop.up, loop.no)
anchor.upno <- (extractAnchor(loop.upno))
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))

getSumScores <- function(track, anchor) {
  # Find overlaps between all anchors and track regions at once
  overlaps <- findOverlaps(anchor, track)
  
  # Extract the scores and corresponding anchor indices
  anchor_indices <- queryHits(overlaps)
  track_scores <- score(track)[subjectHits(overlaps)]
  
  # Use tapply to calculate the median scores for each anchor
  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)
  
  # Initialize a numeric vector to store the median scores for each anchor
  all_median_scores <- rep(NA, length(anchor))
  
  # Populate the median scores for the anchors that have overlaps
  all_median_scores[as.numeric(names(median_scores))] <- median_scores
  
  return(all_median_scores)
}

plotSumScores <- function(track, peak, name){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  a <- getSumScores(peakTrack, anchor.up)
  b <- getSumScores(peakTrack, anchor.no)
  c <- getSumScores(peakTrack, anchor.down)
  a.tb <- tibble(loop = \UP\,
                 sumScore = a)
  b.tb <- tibble(loop = \NO\,
                 sumScore = b)
  c.tb <- tibble(loop = \DOWN\,
                 sumScore = c)
  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()
  ggplot(data, aes(x = loop, y = sumScore)) + 
    labs(x = NULL, y = paste0(name, \ average peak score per anchor\)) +
    geom_violin(aes(fill = group), color = \black\,
                linewidth = lineThick * mmToLineUnit, lineend = \square\,
                show.legend = FALSE) +
    geom_boxplot(width = 0.1, color = \black\,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\,
                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +
    stat_summary(
      aes(group = loop), fun = mean,
      geom = \point\, shape = 21, size = 1,
      fill = \red\, color = \black\
    ) +
    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.95))) + theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )
}

plotSumScoresBinary <- function(track, peak, name, anchor.upno, anchor.down){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  b <- getSumScores(peakTrack, anchor.upno)
  c <- getSumScores(peakTrack, anchor.down)
  b.tb <- tibble(loop = \UP/NO\,
                 sumScore = b)
  c.tb <- tibble(loop = \DOWN\,
                 sumScore = c)
  data <- bind_rows(b.tb, c.tb) %>% drop_na()
  data$loop <- factor(data$loop, levels = c(\UP/NO\, \DOWN\))
  
  p12 <- getPvalWilcox(data, \UP/NO\, \DOWN\)
  p <-  ggplot(data, aes(x = name, fill = loop, y = sumScore)) + 
    labs(x = NULL, y = paste0(\Average ChIP peak score at anchor)\)) +
    introdataviz::geom_split_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\,
                                    alpha = .4) +
    geom_boxplot(width = 0.3, color = \black\,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\,
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + theme_classic() +
    stat_summary(
      aes(group = loop), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) + theme(
      axis.title = element_text(
        size = fontSizeM, family = fontType, color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeM, family = fontType, color = \#000000\
      ),
      axis.text.x = element_text(
        angle = 0,
      ),
      axis.text.y = element_text(
        size = fontSizeS,
      ),
      axis.line = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    ) + 
    coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.9))) + 
    annotate(
     \text\, x = 1, y = quantile(data$sumScore, 0.5),
     label = paste0(\p12: \, convPvalue(p12)),
     color = \black\, hjust = 0, size = 3
   ) +   guides(
    fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
    )
  )
  
   fileName <- paste0(\ChIP_peak_avgPeakScore_\, name)
  width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# Sum peak score
####
track <- import(here(refDir, \33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\))
#plotSumScores(track, peak, \H3K4me3\)
plotSumScoresBinary(track, peak, \H3K4me3\, anchor.upno, anchor.down)

track <- import(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
#plotSumScores(track, peak, \H3K27ac\)
plotSumScoresBinary(track, peak, \H3K27ac\, anchor.upno, anchor.down)

track <- import(here(refDir, \GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM2683440_J1_H3K14ac_mm10Lifted.bed\))
#plotSumScores(track, peak, \H3K14ac\)
plotSumScoresBinary(track, peak, \H3K14ac\, anchor.upno, anchor.down)

track <- import(here(refDir, \33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))
#plotSumScores(track, peak, \CTCF\)
plotSumScoresBinary(track, peak, \CTCF\, anchor.upno, anchor.down)

track <- import(here(refDir, \33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))
#plotSumScores(track, peak, \RAD21\)
plotSumScoresBinary(track, peak, \RAD21\, anchor.upno, anchor.down)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### P-N

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuXG4jIFVQIGxvb3Bcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcIikpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG4jIE5PIGxvb3Bcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX05PX2RpZmYwLjIuYmVkcGVcIikpXG5hbmNob3Iubm8gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5ubykpXG4jIERPV04gbG9vcFxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcIikpXG5hbmNob3IuZG93biA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxuXG5nZXRTdW1TY29yZXMgPC0gZnVuY3Rpb24odHJhY2ssIGFuY2hvcikge1xuICAjIEZpbmQgb3ZlcmxhcHMgYmV0d2VlbiBhbGwgYW5jaG9ycyBhbmQgdHJhY2sgcmVnaW9ucyBhdCBvbmNlXG4gIG92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IsIHRyYWNrKVxuICBcbiAgIyBFeHRyYWN0IHRoZSBzY29yZXMgYW5kIGNvcnJlc3BvbmRpbmcgYW5jaG9yIGluZGljZXNcbiAgYW5jaG9yX2luZGljZXMgPC0gcXVlcnlIaXRzKG92ZXJsYXBzKVxuICB0cmFja19zY29yZXMgPC0gc2NvcmUodHJhY2spW3N1YmplY3RIaXRzKG92ZXJsYXBzKV1cbiAgXG4gICMgVXNlIHRhcHBseSB0byBjYWxjdWxhdGUgdGhlIG1lZGlhbiBzY29yZXMgZm9yIGVhY2ggYW5jaG9yXG4gIG1lZGlhbl9zY29yZXMgPC0gdGFwcGx5KHRyYWNrX3Njb3JlcywgYW5jaG9yX2luZGljZXMsIHN1bSwgbmEucm0gPSBUUlVFKVxuICBcbiAgIyBJbml0aWFsaXplIGEgbnVtZXJpYyB2ZWN0b3IgdG8gc3RvcmUgdGhlIG1lZGlhbiBzY29yZXMgZm9yIGVhY2ggYW5jaG9yXG4gIGFsbF9tZWRpYW5fc2NvcmVzIDwtIHJlcChOQSwgbGVuZ3RoKGFuY2hvcikpXG4gIFxuICAjIFBvcHVsYXRlIHRoZSBtZWRpYW4gc2NvcmVzIGZvciB0aGUgYW5jaG9ycyB0aGF0IGhhdmUgb3ZlcmxhcHNcbiAgYWxsX21lZGlhbl9zY29yZXNbYXMubnVtZXJpYyhuYW1lcyhtZWRpYW5fc2NvcmVzKSldIDwtIG1lZGlhbl9zY29yZXNcbiAgXG4gIHJldHVybihhbGxfbWVkaWFuX3Njb3Jlcylcbn1cblxucGxvdFN1bVNjb3JlcyA8LSBmdW5jdGlvbih0cmFjaywgcGVhaywgbmFtZSl7XG4gIHBlYWtUcmFjayA8LSB0cmFja1t1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyh0cmFjaywgcGVhaykpKV1cbiAgYSA8LSBnZXRTdW1TY29yZXMocGVha1RyYWNrLCBhbmNob3IudXApXG4gIGIgPC0gZ2V0U3VtU2NvcmVzKHBlYWtUcmFjaywgYW5jaG9yLm5vKVxuICBjIDwtIGdldFN1bVNjb3JlcyhwZWFrVHJhY2ssIGFuY2hvci5kb3duKVxuICBhLnRiIDwtIHRpYmJsZShsb29wID0gXCJVUFwiLFxuICAgICAgICAgICAgICAgICBzdW1TY29yZSA9IGEpXG4gIGIudGIgPC0gdGliYmxlKGxvb3AgPSBcIk5PXCIsXG4gICAgICAgICAgICAgICAgIHN1bVNjb3JlID0gYilcbiAgYy50YiA8LSB0aWJibGUobG9vcCA9IFwiRE9XTlwiLFxuICAgICAgICAgICAgICAgICBzdW1TY29yZSA9IGMpXG4gIGRhdGEgPC0gYmluZF9yb3dzKGEudGIsIGIudGIsIGMudGIpICU+JSBkcm9wX25hKClcbiAgZ2dwbG90KGRhdGEsIGFlcyh4ID0gbG9vcCwgeSA9IHN1bVNjb3JlKSkgKyBnZW9tX2JveHBsb3Qob3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUocGFzdGUwKG5hbWUsIFwiIHN1bSBwZWFrXCIpKSArXG4gICAgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuOSkpKVxufVxuXG4jIFN1bSBwZWFrIHNjb3JlXG4jIyMjXG50cmFjayA8LSBpbXBvcnQoaGVyZShyZWZEaXIsIFwiMzMyNTVfSDNLNG1lM18wNC03NDVfQnJ1Y2UtNF90cmltX3EyMF9kZWR1cF9ibGFja19kZXB0aE5vcm0uYndcIiksIGZvcm1hdCA9IFwiQmlnV2lnXCIpXG5wZWFrIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFwiMzMyNTVfSDNLNG1lM18wNC03NDVfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXCIpKVxucGxvdFN1bVNjb3Jlcyh0cmFjaywgcGVhaywgXCJIM0s0bWUzXCIpXG5cbnRyYWNrIDwtIGltcG9ydChoZXJlKHJlZkRpciwgXCJHU00yNDM4NDc2X0VDLURHLTM0NTgtSDNLMjdBQ19BU1lOXzEuYndcIiksIGZvcm1hdCA9IFwiQmlnV2lnXCIpXG5wZWFrIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFwiR1NNMjQzODQ3Nl9FQy1ERy0zNDU4LUgzSzI3QUNfQVNZTl8xLm5hcnJvd1BlYWsuYmVkXCIpKVxucGxvdFN1bVNjb3Jlcyh0cmFjaywgcGVhaywgXCJIM0syN2FjXCIpXG5cbnRyYWNrIDwtIGltcG9ydChoZXJlKHJlZkRpciwgXCJHU00yNjgzNDQwX0oxX0gzSzE0YWNfbW0xMExpZnRlZC5ibGFjay5id1wiKSwgZm9ybWF0ID0gXCJCaWdXaWdcIilcbnBlYWsgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXCJHU00yNjgzNDQwX0oxX0gzSzE0YWNfbW0xMExpZnRlZC5iZWRcIikpXG5wbG90U3VtU2NvcmVzKHRyYWNrLCBwZWFrLCBcIkgzSzE0YWNcIilcblxudHJhY2sgPC0gaW1wb3J0KGhlcmUocmVmRGlyLCBcIjMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfdHJpbV9xMjBfZGVkdXBfYmxhY2tfZGVwdGhOb3JtLmJ3XCIpLCBmb3JtYXQgPSBcIkJpZ1dpZ1wiKVxucGVhayA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcIjMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLmJlZFwiKSlcbnBsb3RTdW1TY29yZXModHJhY2ssIHBlYWssIFwiQ1RDRlwiKVxuXG50cmFjayA8LSBpbXBvcnQoaGVyZShyZWZEaXIsIFwiMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF90cmltX3EyMF9kZWR1cF9ibGFja19kZXB0aE5vcm0uYndcIiksIGZvcm1hdCA9IFwiQmlnV2lnXCIpXG5wZWFrLnRlbXAgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShWMiA9IFYyIC0gMTAwMCxcbiAgICAgICAgICAgICAgICBWMyA9IFYzICsgMTAwMClcbmNvbG5hbWVzKHBlYWsudGVtcCkgPC0gYyhcImNoclwiLCBcInN0YXJ0XCIsIFwiZW5kXCIpXG5wZWFrIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShwZWFrLnRlbXApXG5wbG90U3VtU2NvcmVzKHRyYWNrLCBwZWFrLCBcIllZMVwiKVxuXG5cbiMjIyBGb3IgdGhvc2Ugd2l0aCBvbmx5IHN1bW1pdFxudHJhY2sgPC0gaW1wb3J0KGhlcmUocmVmRGlyLCBcIkdTTTU1NzE4OTVfRVNDX1lZMV8xLmJ3XCIpLCBmb3JtYXQgPSBcIkJpZ1dpZ1wiKVxucGVhayA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcIkdTTTU1NzE4OTVfRVNDX1lZMV9zdW1taXQuYmVkXCIpKVxucGxvdFN1bVNjb3Jlcyh0cmFjaywgcGVhaywgXCJSQUQyMVwiKVxuXG4jIyMgRk9SIFRIT1NFIFdJVEhPVVQgUEVBS1NcbnRyYWNrIDwtIGltcG9ydChoZXJlKHJlZkRpciwgXCJHU00yMDgyNzA4X0VTQy5IM0syN21lMy4xX21tMTBMaWZ0ZWQuYmxhY2suYndcIiksIGZvcm1hdCA9IFwiQmlnV2lnXCIpXG5hIDwtIGdldFN1bVNjb3Jlcyh0cmFjaywgYW5jaG9yLnVwKVxuYiA8LSBnZXRTdW1TY29yZXModHJhY2ssIGFuY2hvci5ubylcbmMgPC0gZ2V0U3VtU2NvcmVzKHRyYWNrLCBhbmNob3IuZG93bilcbmEudGIgPC0gdGliYmxlKGxvb3AgPSBcIlVQXCIsXG4gICAgICAgICAgICAgICBzdW1TY29yZSA9IGEpXG5iLnRiIDwtIHRpYmJsZShsb29wID0gXCJOT1wiLFxuICAgICAgICAgICAgICAgc3VtU2NvcmUgPSBiKVxuYy50YiA8LSB0aWJibGUobG9vcCA9IFwiRE9XTlwiLFxuICAgICAgICAgICAgICAgc3VtU2NvcmUgPSBjKVxuZGF0YSA8LSBiaW5kX3Jvd3MoYS50YiwgYi50YiwgYy50YikgJT4lIGRyb3BfbmEoKVxuZ2dwbG90KGRhdGEsIGFlcyh4ID0gbG9vcCwgeSA9IHN1bVNjb3JlKSkgKyBnZW9tX2JveHBsb3Qob3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUocGFzdGUwKFwiSDNLMjdtZTMgc3VtIG5vIHBlYWtcIikpICtcbiAgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuOSkpKVxuYGBgIn0= -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\\))\nanchor.up <- (extractAnchor(loop.up))\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\\))\nanchor.no <- (extractAnchor(loop.no))\n# DOWN loop\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- (extractAnchor(loop.down))\n\ngetSumScores <- function(track, anchor) {\n  # Find overlaps between all anchors and track regions at once\n  overlaps <- findOverlaps(anchor, track)\n  \n  # Extract the scores and corresponding anchor indices\n  anchor_indices <- queryHits(overlaps)\n  track_scores <- score(track)[subjectHits(overlaps)]\n  \n  # Use tapply to calculate the median scores for each anchor\n  median_scores <- tapply(track_scores, anchor_indices, sum, na.rm = TRUE)\n  \n  # Initialize a numeric vector to store the median scores for each anchor\n  all_median_scores <- rep(NA, length(anchor))\n  \n  # Populate the median scores for the anchors that have overlaps\n  all_median_scores[as.numeric(names(median_scores))] <- median_scores\n  \n  return(all_median_scores)\n}\n\nplotSumScores <- function(track, peak, name){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor.up)\n  b <- getSumScores(peakTrack, anchor.no)\n  c <- getSumScores(peakTrack, anchor.down)\n  a.tb <- tibble(loop = \\UP\\,\n                 sumScore = a)\n  b.tb <- tibble(loop = \\NO\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\DOWN\\,\n                 sumScore = c)\n  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\n  ggplot(data, aes(x = loop, y = sumScore)) + geom_boxplot(outlier.shape = NA) + theme_classic() + ggtitle(paste0(name, \\ sum peak\\)) +\n    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.9)))\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\\))\nplotSumScores(track, peak, \\H3K4me3\\)\n\ntrack <- import(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\nplotSumScores(track, peak, \\H3K27ac\\)\n\ntrack <- import(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.bed\\))\nplotSumScores(track, peak, \\H3K14ac\\)\n\ntrack <- import(here(refDir, \\33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\\))\nplotSumScores(track, peak, \\CTCF\\)\n\ntrack <- import(here(refDir, \\33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak.temp <- fread(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\)) %>%\n  dplyr::mutate(V2 = V2 - 1000,\n                V3 = V3 + 1000)\ncolnames(peak.temp) <- c(\\chr\\, \\start\\, \\end\\)\npeak <- makeGRangesFromDataFrame(peak.temp)\nplotSumScores(track, peak, \\YY1\\)\n\n\n### For those with only summit\ntrack <- import(here(refDir, \\GSM5571895_ESC_YY1_1.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM5571895_ESC_YY1_summit.bed\\))\nplotSumScores(track, peak, \\RAD21\\)\n\n### FOR THOSE WITHOUT PEAKS\ntrack <- import(here(refDir, \\GSM2082708_ESC.H3K27me3.1_mm10Lifted.black.bw\\), format = \\BigWig\\)\na <- getSumScores(track, anchor.up)\nb <- getSumScores(track, anchor.no)\nc <- getSumScores(track, anchor.down)\na.tb <- tibble(loop = \\UP\\,\n               sumScore = a)\nb.tb <- tibble(loop = \\NO\\,\n               sumScore = b)\nc.tb <- tibble(loop = \\DOWN\\,\n               sumScore = c)\ndata <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\nggplot(data, aes(x = loop, y = sumScore)) + geom_boxplot(outlier.shape = NA) + theme_classic() + ggtitle(paste0(\\H3K27me3 sum no peak\\)) +\n  coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.9)))\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\

# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))

getSumScores <- function(track, anchor) {
  # Find overlaps between all anchors and track regions at once
  overlaps <- findOverlaps(anchor, track)
  
  # Extract the scores and corresponding anchor indices
  anchor_indices <- queryHits(overlaps)
  track_scores <- score(track)[subjectHits(overlaps)]
  
  # Use tapply to calculate the median scores for each anchor
  median_scores <- tapply(track_scores, anchor_indices, sum, na.rm = TRUE)
  
  # Initialize a numeric vector to store the median scores for each anchor
  all_median_scores <- rep(NA, length(anchor))
  
  # Populate the median scores for the anchors that have overlaps
  all_median_scores[as.numeric(names(median_scores))] <- median_scores
  
  return(all_median_scores)
}

plotSumScores <- function(track, peak, name){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  a <- getSumScores(peakTrack, anchor.up)
  b <- getSumScores(peakTrack, anchor.no)
  c <- getSumScores(peakTrack, anchor.down)
  a.tb <- tibble(loop = \UP\,
                 sumScore = a)
  b.tb <- tibble(loop = \NO\,
                 sumScore = b)
  c.tb <- tibble(loop = \DOWN\,
                 sumScore = c)
  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()
  ggplot(data, aes(x = loop, y = sumScore)) + geom_boxplot(outlier.shape = NA) + theme_classic() + ggtitle(paste0(name, \ sum peak\)) +
    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.9)))
}

# Sum peak score
####
track <- import(here(refDir, \33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\))
plotSumScores(track, peak, \H3K4me3\)

track <- import(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
plotSumScores(track, peak, \H3K27ac\)

track <- import(here(refDir, \GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM2683440_J1_H3K14ac_mm10Lifted.bed\))
plotSumScores(track, peak, \H3K14ac\)

track <- import(here(refDir, \33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))
plotSumScores(track, peak, \CTCF\)

track <- import(here(refDir, \33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak.temp <- fread(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\)) %>%
  dplyr::mutate(V2 = V2 - 1000,
                V3 = V3 + 1000)
colnames(peak.temp) <- c(\chr\, \start\, \end\)
peak <- makeGRangesFromDataFrame(peak.temp)
plotSumScores(track, peak, \YY1\)


### For those with only summit
track <- import(here(refDir, \GSM5571895_ESC_YY1_1.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM5571895_ESC_YY1_summit.bed\))
plotSumScores(track, peak, \RAD21\)

### FOR THOSE WITHOUT PEAKS
track <- import(here(refDir, \GSM2082708_ESC.H3K27me3.1_mm10Lifted.black.bw\), format = \BigWig\)
a <- getSumScores(track, anchor.up)
b <- getSumScores(track, anchor.no)
c <- getSumScores(track, anchor.down)
a.tb <- tibble(loop = \UP\,
               sumScore = a)
b.tb <- tibble(loop = \NO\,
               sumScore = b)
c.tb <- tibble(loop = \DOWN\,
               sumScore = c)
data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()
ggplot(data, aes(x = loop, y = sumScore)) + geom_boxplot(outlier.shape = NA) + theme_classic() + ggtitle(paste0(\H3K27me3 sum no peak\)) +
  coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.9)))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG4jIFVQIGxvb3Bcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG4jIE5PIGxvb3Bcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3Iubm8gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5ubykpXG4jIERPV04gbG9vcFxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IuZG93biA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxuXG5nZXRTdW1TY29yZXMgPC0gZnVuY3Rpb24odHJhY2ssIGFuY2hvcikge1xuICAjIEZpbmQgb3ZlcmxhcHMgYmV0d2VlbiBhbGwgYW5jaG9ycyBhbmQgdHJhY2sgcmVnaW9ucyBhdCBvbmNlXG4gIG92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IsIHRyYWNrKVxuICBcbiAgIyBFeHRyYWN0IHRoZSBzY29yZXMgYW5kIGNvcnJlc3BvbmRpbmcgYW5jaG9yIGluZGljZXNcbiAgYW5jaG9yX2luZGljZXMgPC0gcXVlcnlIaXRzKG92ZXJsYXBzKVxuICB0cmFja19zY29yZXMgPC0gc2NvcmUodHJhY2spW3N1YmplY3RIaXRzKG92ZXJsYXBzKV1cbiAgXG4gICMgVXNlIHRhcHBseSB0byBjYWxjdWxhdGUgdGhlIG1lZGlhbiBzY29yZXMgZm9yIGVhY2ggYW5jaG9yXG4gIG1lZGlhbl9zY29yZXMgPC0gdGFwcGx5KHRyYWNrX3Njb3JlcywgYW5jaG9yX2luZGljZXMsIHN1bSwgbmEucm0gPSBUUlVFKVxuICBcbiAgIyBJbml0aWFsaXplIGEgbnVtZXJpYyB2ZWN0b3IgdG8gc3RvcmUgdGhlIG1lZGlhbiBzY29yZXMgZm9yIGVhY2ggYW5jaG9yXG4gIGFsbF9tZWRpYW5fc2NvcmVzIDwtIHJlcChOQSwgbGVuZ3RoKGFuY2hvcikpXG4gIFxuICAjIFBvcHVsYXRlIHRoZSBtZWRpYW4gc2NvcmVzIGZvciB0aGUgYW5jaG9ycyB0aGF0IGhhdmUgb3ZlcmxhcHNcbiAgYWxsX21lZGlhbl9zY29yZXNbYXMubnVtZXJpYyhuYW1lcyhtZWRpYW5fc2NvcmVzKSldIDwtIG1lZGlhbl9zY29yZXNcbiAgXG4gIHJldHVybihhbGxfbWVkaWFuX3Njb3Jlcylcbn1cblxucGxvdFN1bVNjb3JlcyA8LSBmdW5jdGlvbih0cmFjaywgcGVhaywgbmFtZSl7XG4gIHBlYWtUcmFjayA8LSB0cmFja1t1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyh0cmFjaywgcGVhaykpKV1cbiAgYSA8LSBnZXRTdW1TY29yZXMocGVha1RyYWNrLCBhbmNob3IudXApXG4gIGIgPC0gZ2V0U3VtU2NvcmVzKHBlYWtUcmFjaywgYW5jaG9yLm5vKVxuICBjIDwtIGdldFN1bVNjb3JlcyhwZWFrVHJhY2ssIGFuY2hvci5kb3duKVxuICBhLnRiIDwtIHRpYmJsZShsb29wID0gXFxVUFxcLFxuICAgICAgICAgICAgICAgICBzdW1TY29yZSA9IGEpXG4gIGIudGIgPC0gdGliYmxlKGxvb3AgPSBcXE5PXFwsXG4gICAgICAgICAgICAgICAgIHN1bVNjb3JlID0gYilcbiAgYy50YiA8LSB0aWJibGUobG9vcCA9IFxcRE9XTlxcLFxuICAgICAgICAgICAgICAgICBzdW1TY29yZSA9IGMpXG4gIGRhdGEgPC0gYmluZF9yb3dzKGEudGIsIGIudGIsIGMudGIpICU+JSBkcm9wX25hKClcbiAgZ2dwbG90KGRhdGEsIGFlcyh4ID0gbG9vcCwgeSA9IHN1bVNjb3JlKSkgKyBnZW9tX2JveHBsb3Qob3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUocGFzdGUwKG5hbWUsIFxcIHN1bSBwZWFrXFwpKSArXG4gICAgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuOSkpKVxufVxuXG4jIFN1bSBwZWFrIHNjb3JlXG4jIyMjXG50cmFjayA8LSBpbXBvcnQoaGVyZShyZWZEaXIsIFxcMzMyNTVfSDNLNG1lM18wNC03NDVfQnJ1Y2UtNF90cmltX3EyMF9kZWR1cF9ibGFja19kZXB0aE5vcm0uYndcXCksIGZvcm1hdCA9IFxcQmlnV2lnXFwpXG5wZWFrIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcMzMyNTVfSDNLNG1lM18wNC03NDVfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKVxucGxvdFN1bVNjb3Jlcyh0cmFjaywgcGVhaywgXFxIM0s0bWUzXFwpXG5cbnRyYWNrIDwtIGltcG9ydChoZXJlKHJlZkRpciwgXFxHU00yNDM4NDc2X0VDLURHLTM0NTgtSDNLMjdBQ19BU1lOXzEuYndcXCksIGZvcm1hdCA9IFxcQmlnV2lnXFwpXG5wZWFrIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcR1NNMjQzODQ3Nl9FQy1ERy0zNDU4LUgzSzI3QUNfQVNZTl8xLm5hcnJvd1BlYWsuYmVkXFwpKVxucGxvdFN1bVNjb3Jlcyh0cmFjaywgcGVhaywgXFxIM0syN2FjXFwpXG5cbnRyYWNrIDwtIGltcG9ydChoZXJlKHJlZkRpciwgXFxHU00yNjgzNDQwX0oxX0gzSzE0YWNfbW0xMExpZnRlZC5ibGFjay5id1xcKSwgZm9ybWF0ID0gXFxCaWdXaWdcXClcbnBlYWsgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFxHU00yNjgzNDQwX0oxX0gzSzE0YWNfbW0xMExpZnRlZC5iZWRcXCkpXG5wbG90U3VtU2NvcmVzKHRyYWNrLCBwZWFrLCBcXEgzSzE0YWNcXClcblxudHJhY2sgPC0gaW1wb3J0KGhlcmUocmVmRGlyLCBcXDMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfdHJpbV9xMjBfZGVkdXBfYmxhY2tfZGVwdGhOb3JtLmJ3XFwpLCBmb3JtYXQgPSBcXEJpZ1dpZ1xcKVxucGVhayA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXDMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLmJlZFxcKSlcbnBsb3RTdW1TY29yZXModHJhY2ssIHBlYWssIFxcQ1RDRlxcKVxuXG50cmFjayA8LSBpbXBvcnQoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF90cmltX3EyMF9kZWR1cF9ibGFja19kZXB0aE5vcm0uYndcXCksIGZvcm1hdCA9IFxcQmlnV2lnXFwpXG5wZWFrLnRlbXAgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShWMiA9IFYyIC0gMTAwMCxcbiAgICAgICAgICAgICAgICBWMyA9IFYzICsgMTAwMClcbmNvbG5hbWVzKHBlYWsudGVtcCkgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5wZWFrIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShwZWFrLnRlbXApXG5wbG90U3VtU2NvcmVzKHRyYWNrLCBwZWFrLCBcXFlZMVxcKVxuXG5cbiMjIyBGb3IgdGhvc2Ugd2l0aCBvbmx5IHN1bW1pdFxudHJhY2sgPC0gaW1wb3J0KGhlcmUocmVmRGlyLCBcXEdTTTU1NzE4OTVfRVNDX1lZMV8xLmJ3XFwpLCBmb3JtYXQgPSBcXEJpZ1dpZ1xcKVxucGVhayA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXEdTTTU1NzE4OTVfRVNDX1lZMV9zdW1taXQuYmVkXFwpKVxucGxvdFN1bVNjb3Jlcyh0cmFjaywgcGVhaywgXFxSQUQyMVxcKVxuXG4jIyMgRk9SIFRIT1NFIFdJVEhPVVQgUEVBS1NcbnRyYWNrIDwtIGltcG9ydChoZXJlKHJlZkRpciwgXFxHU00yMDgyNzA4X0VTQy5IM0syN21lMy4xX21tMTBMaWZ0ZWQuYmxhY2suYndcXCksIGZvcm1hdCA9IFxcQmlnV2lnXFwpXG5hIDwtIGdldFN1bVNjb3Jlcyh0cmFjaywgYW5jaG9yLnVwKVxuYiA8LSBnZXRTdW1TY29yZXModHJhY2ssIGFuY2hvci5ubylcbmMgPC0gZ2V0U3VtU2NvcmVzKHRyYWNrLCBhbmNob3IuZG93bilcbmEudGIgPC0gdGliYmxlKGxvb3AgPSBcXFVQXFwsXG4gICAgICAgICAgICAgICBzdW1TY29yZSA9IGEpXG5iLnRiIDwtIHRpYmJsZShsb29wID0gXFxOT1xcLFxuICAgICAgICAgICAgICAgc3VtU2NvcmUgPSBiKVxuYy50YiA8LSB0aWJibGUobG9vcCA9IFxcRE9XTlxcLFxuICAgICAgICAgICAgICAgc3VtU2NvcmUgPSBjKVxuZGF0YSA8LSBiaW5kX3Jvd3MoYS50YiwgYi50YiwgYy50YikgJT4lIGRyb3BfbmEoKVxuZ2dwbG90KGRhdGEsIGFlcyh4ID0gbG9vcCwgeSA9IHN1bVNjb3JlKSkgKyBnZW9tX2JveHBsb3Qob3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUocGFzdGUwKFxcSDNLMjdtZTMgc3VtIG5vIHBlYWtcXCkpICtcbiAgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuOSkpKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\\))\nanchor.up <- (extractAnchor(loop.up))\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\\))\nanchor.no <- (extractAnchor(loop.no))\n# DOWN loop\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- (extractAnchor(loop.down))\n\ngetSumScores <- function(track, anchor) {\n  # Find overlaps between all anchors and track regions at once\n  overlaps <- findOverlaps(anchor, track)\n  \n  # Extract the scores and corresponding anchor indices\n  anchor_indices <- queryHits(overlaps)\n  track_scores <- score(track)[subjectHits(overlaps)]\n  \n  # Use tapply to calculate the median scores for each anchor\n  median_scores <- tapply(track_scores, anchor_indices, sum, na.rm = TRUE)\n  \n  # Initialize a numeric vector to store the median scores for each anchor\n  all_median_scores <- rep(NA, length(anchor))\n  \n  # Populate the median scores for the anchors that have overlaps\n  all_median_scores[as.numeric(names(median_scores))] <- median_scores\n  \n  return(all_median_scores)\n}\n\nplotSumScores <- function(track, peak, name){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor.up)\n  b <- getSumScores(peakTrack, anchor.no)\n  c <- getSumScores(peakTrack, anchor.down)\n  a.tb <- tibble(loop = \\UP\\,\n                 sumScore = a)\n  b.tb <- tibble(loop = \\NO\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\DOWN\\,\n                 sumScore = c)\n  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\n  ggplot(data, aes(x = loop, y = sumScore)) + geom_boxplot(outlier.shape = NA) + theme_classic() + ggtitle(paste0(name, \\ sum peak\\)) +\n    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.9)))\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\\))\nplotSumScores(track, peak, \\H3K4me3\\)\n\ntrack <- import(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\nplotSumScores(track, peak, \\H3K27ac\\)\n\ntrack <- import(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.bed\\))\nplotSumScores(track, peak, \\H3K14ac\\)\n\ntrack <- import(here(refDir, \\33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\\))\nplotSumScores(track, peak, \\CTCF\\)\n\ntrack <- import(here(refDir, \\33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak.temp <- fread(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\)) %>%\n  dplyr::mutate(V2 = V2 - 1000,\n                V3 = V3 + 1000)\ncolnames(peak.temp) <- c(\\chr\\, \\start\\, \\end\\)\npeak <- makeGRangesFromDataFrame(peak.temp)\nplotSumScores(track, peak, \\YY1\\)\n\n\n### For those with only summit\ntrack <- import(here(refDir, \\GSM5571895_ESC_YY1_1.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM5571895_ESC_YY1_summit.bed\\))\nplotSumScores(track, peak, \\RAD21\\)\n\n### FOR THOSE WITHOUT PEAKS\ntrack <- import(here(refDir, \\GSM2082708_ESC.H3K27me3.1_mm10Lifted.black.bw\\), format = \\BigWig\\)\na <- getSumScores(track, anchor.up)\nb <- getSumScores(track, anchor.no)\nc <- getSumScores(track, anchor.down)\na.tb <- tibble(loop = \\UP\\,\n               sumScore = a)\nb.tb <- tibble(loop = \\NO\\,\n               sumScore = b)\nc.tb <- tibble(loop = \\DOWN\\,\n               sumScore = c)\ndata <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\nggplot(data, aes(x = loop, y = sumScore)) + geom_boxplot(outlier.shape = NA) + theme_classic() + ggtitle(paste0(\\H3K27me3 sum no peak\\)) +\n  coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.9)))\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG4jIFVQIGxvb3Bcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG4jIE5PIGxvb3Bcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3Iubm8gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5ubykpXG4jIERPV04gbG9vcFxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfQTQ4NXZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IuZG93biA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxuXG5nZXRTdW1TY29yZXMgPC0gZnVuY3Rpb24odHJhY2ssIGFuY2hvcikge1xuICAjIEZpbmQgb3ZlcmxhcHMgYmV0d2VlbiBhbGwgYW5jaG9ycyBhbmQgdHJhY2sgcmVnaW9ucyBhdCBvbmNlXG4gIG92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhhbmNob3IsIHRyYWNrKVxuICBcbiAgIyBFeHRyYWN0IHRoZSBzY29yZXMgYW5kIGNvcnJlc3BvbmRpbmcgYW5jaG9yIGluZGljZXNcbiAgYW5jaG9yX2luZGljZXMgPC0gcXVlcnlIaXRzKG92ZXJsYXBzKVxuICB0cmFja19zY29yZXMgPC0gc2NvcmUodHJhY2spW3N1YmplY3RIaXRzKG92ZXJsYXBzKV1cbiAgXG4gICMgVXNlIHRhcHBseSB0byBjYWxjdWxhdGUgdGhlIG1lZGlhbiBzY29yZXMgZm9yIGVhY2ggYW5jaG9yXG4gIG1lZGlhbl9zY29yZXMgPC0gdGFwcGx5KHRyYWNrX3Njb3JlcywgYW5jaG9yX2luZGljZXMsIHN1bSwgbmEucm0gPSBUUlVFKVxuICBcbiAgIyBJbml0aWFsaXplIGEgbnVtZXJpYyB2ZWN0b3IgdG8gc3RvcmUgdGhlIG1lZGlhbiBzY29yZXMgZm9yIGVhY2ggYW5jaG9yXG4gIGFsbF9tZWRpYW5fc2NvcmVzIDwtIHJlcChOQSwgbGVuZ3RoKGFuY2hvcikpXG4gIFxuICAjIFBvcHVsYXRlIHRoZSBtZWRpYW4gc2NvcmVzIGZvciB0aGUgYW5jaG9ycyB0aGF0IGhhdmUgb3ZlcmxhcHNcbiAgYWxsX21lZGlhbl9zY29yZXNbYXMubnVtZXJpYyhuYW1lcyhtZWRpYW5fc2NvcmVzKSldIDwtIG1lZGlhbl9zY29yZXNcbiAgXG4gIHJldHVybihhbGxfbWVkaWFuX3Njb3Jlcylcbn1cblxucGxvdFN1bVNjb3JlcyA8LSBmdW5jdGlvbih0cmFjaywgcGVhaywgbmFtZSl7XG4gIHBlYWtUcmFjayA8LSB0cmFja1t1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyh0cmFjaywgcGVhaykpKV1cbiAgYSA8LSBnZXRTdW1TY29yZXMocGVha1RyYWNrLCBhbmNob3IudXApXG4gIGIgPC0gZ2V0U3VtU2NvcmVzKHBlYWtUcmFjaywgYW5jaG9yLm5vKVxuICBjIDwtIGdldFN1bVNjb3JlcyhwZWFrVHJhY2ssIGFuY2hvci5kb3duKVxuICBhLnRiIDwtIHRpYmJsZShsb29wID0gXFxVUFxcLFxuICAgICAgICAgICAgICAgICBzdW1TY29yZSA9IGEpXG4gIGIudGIgPC0gdGliYmxlKGxvb3AgPSBcXE5PXFwsXG4gICAgICAgICAgICAgICAgIHN1bVNjb3JlID0gYilcbiAgYy50YiA8LSB0aWJibGUobG9vcCA9IFxcRE9XTlxcLFxuICAgICAgICAgICAgICAgICBzdW1TY29yZSA9IGMpXG4gIGRhdGEgPC0gYmluZF9yb3dzKGEudGIsIGIudGIsIGMudGIpICU+JSBkcm9wX25hKClcbiAgZ2dwbG90KGRhdGEsIGFlcyh4ID0gbG9vcCwgeSA9IHN1bVNjb3JlKSkgKyBnZW9tX2JveHBsb3Qob3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUocGFzdGUwKG5hbWUsIFxcIHN1bSBwZWFrXFwpKSArXG4gICAgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuOSkpKVxufVxuXG4jIFN1bSBwZWFrIHNjb3JlXG4jIyMjXG50cmFjayA8LSBpbXBvcnQoaGVyZShyZWZEaXIsIFxcMzMyNTVfSDNLNG1lM18wNC03NDVfQnJ1Y2UtNF90cmltX3EyMF9kZWR1cF9ibGFja19kZXB0aE5vcm0uYndcXCksIGZvcm1hdCA9IFxcQmlnV2lnXFwpXG5wZWFrIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcMzMyNTVfSDNLNG1lM18wNC03NDVfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKVxucGxvdFN1bVNjb3Jlcyh0cmFjaywgcGVhaywgXFxIM0s0bWUzXFwpXG5cbnRyYWNrIDwtIGltcG9ydChoZXJlKHJlZkRpciwgXFxHU00yNDM4NDc2X0VDLURHLTM0NTgtSDNLMjdBQ19BU1lOXzEuYndcXCksIGZvcm1hdCA9IFxcQmlnV2lnXFwpXG5wZWFrIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcR1NNMjQzODQ3Nl9FQy1ERy0zNDU4LUgzSzI3QUNfQVNZTl8xLm5hcnJvd1BlYWsuYmVkXFwpKVxucGxvdFN1bVNjb3Jlcyh0cmFjaywgcGVhaywgXFxIM0syN2FjXFwpXG5cbnRyYWNrIDwtIGltcG9ydChoZXJlKHJlZkRpciwgXFxHU00yNjgzNDQwX0oxX0gzSzE0YWNfbW0xMExpZnRlZC5ibGFjay5id1xcKSwgZm9ybWF0ID0gXFxCaWdXaWdcXClcbnBlYWsgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFxHU00yNjgzNDQwX0oxX0gzSzE0YWNfbW0xMExpZnRlZC5iZWRcXCkpXG5wbG90U3VtU2NvcmVzKHRyYWNrLCBwZWFrLCBcXEgzSzE0YWNcXClcblxudHJhY2sgPC0gaW1wb3J0KGhlcmUocmVmRGlyLCBcXDMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfdHJpbV9xMjBfZGVkdXBfYmxhY2tfZGVwdGhOb3JtLmJ3XFwpLCBmb3JtYXQgPSBcXEJpZ1dpZ1xcKVxucGVhayA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXDMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLmJlZFxcKSlcbnBsb3RTdW1TY29yZXModHJhY2ssIHBlYWssIFxcQ1RDRlxcKVxuXG50cmFjayA8LSBpbXBvcnQoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF90cmltX3EyMF9kZWR1cF9ibGFja19kZXB0aE5vcm0uYndcXCksIGZvcm1hdCA9IFxcQmlnV2lnXFwpXG5wZWFrLnRlbXAgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShWMiA9IFYyIC0gMTAwMCxcbiAgICAgICAgICAgICAgICBWMyA9IFYzICsgMTAwMClcbmNvbG5hbWVzKHBlYWsudGVtcCkgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5wZWFrIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShwZWFrLnRlbXApXG5wbG90U3VtU2NvcmVzKHRyYWNrLCBwZWFrLCBcXFlZMVxcKVxuXG5cbiMjIyBGb3IgdGhvc2Ugd2l0aCBvbmx5IHN1bW1pdFxudHJhY2sgPC0gaW1wb3J0KGhlcmUocmVmRGlyLCBcXEdTTTU1NzE4OTVfRVNDX1lZMV8xLmJ3XFwpLCBmb3JtYXQgPSBcXEJpZ1dpZ1xcKVxucGVhayA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXEdTTTU1NzE4OTVfRVNDX1lZMV9zdW1taXQuYmVkXFwpKVxucGxvdFN1bVNjb3Jlcyh0cmFjaywgcGVhaywgXFxSQUQyMVxcKVxuXG4jIyMgRk9SIFRIT1NFIFdJVEhPVVQgUEVBS1NcbnRyYWNrIDwtIGltcG9ydChoZXJlKHJlZkRpciwgXFxHU00yMDgyNzA4X0VTQy5IM0syN21lMy4xX21tMTBMaWZ0ZWQuYmxhY2suYndcXCksIGZvcm1hdCA9IFxcQmlnV2lnXFwpXG5hIDwtIGdldFN1bVNjb3Jlcyh0cmFjaywgYW5jaG9yLnVwKVxuYiA8LSBnZXRTdW1TY29yZXModHJhY2ssIGFuY2hvci5ubylcbmMgPC0gZ2V0U3VtU2NvcmVzKHRyYWNrLCBhbmNob3IuZG93bilcbmEudGIgPC0gdGliYmxlKGxvb3AgPSBcXFVQXFwsXG4gICAgICAgICAgICAgICBzdW1TY29yZSA9IGEpXG5iLnRiIDwtIHRpYmJsZShsb29wID0gXFxOT1xcLFxuICAgICAgICAgICAgICAgc3VtU2NvcmUgPSBiKVxuYy50YiA8LSB0aWJibGUobG9vcCA9IFxcRE9XTlxcLFxuICAgICAgICAgICAgICAgc3VtU2NvcmUgPSBjKVxuZGF0YSA8LSBiaW5kX3Jvd3MoYS50YiwgYi50YiwgYy50YikgJT4lIGRyb3BfbmEoKVxuZ2dwbG90KGRhdGEsIGFlcyh4ID0gbG9vcCwgeSA9IHN1bVNjb3JlKSkgKyBnZW9tX2JveHBsb3Qob3V0bGllci5zaGFwZSA9IE5BKSArIHRoZW1lX2NsYXNzaWMoKSArIGdndGl0bGUocGFzdGUwKFxcSDNLMjdtZTMgc3VtIG5vIHBlYWtcXCkpICtcbiAgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuOSkpKVxuYGBgXG5gYGAifQ== -->

```r
```r
name <- \chromo_cons_annoHierarchy\

# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))

getSumScores <- function(track, anchor) {
  # Find overlaps between all anchors and track regions at once
  overlaps <- findOverlaps(anchor, track)
  
  # Extract the scores and corresponding anchor indices
  anchor_indices <- queryHits(overlaps)
  track_scores <- score(track)[subjectHits(overlaps)]
  
  # Use tapply to calculate the median scores for each anchor
  median_scores <- tapply(track_scores, anchor_indices, sum, na.rm = TRUE)
  
  # Initialize a numeric vector to store the median scores for each anchor
  all_median_scores <- rep(NA, length(anchor))
  
  # Populate the median scores for the anchors that have overlaps
  all_median_scores[as.numeric(names(median_scores))] <- median_scores
  
  return(all_median_scores)
}

plotSumScores <- function(track, peak, name){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  a <- getSumScores(peakTrack, anchor.up)
  b <- getSumScores(peakTrack, anchor.no)
  c <- getSumScores(peakTrack, anchor.down)
  a.tb <- tibble(loop = \UP\,
                 sumScore = a)
  b.tb <- tibble(loop = \NO\,
                 sumScore = b)
  c.tb <- tibble(loop = \DOWN\,
                 sumScore = c)
  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()
  ggplot(data, aes(x = loop, y = sumScore)) + geom_boxplot(outlier.shape = NA) + theme_classic() + ggtitle(paste0(name, \ sum peak\)) +
    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.9)))
}

# Sum peak score
####
track <- import(here(refDir, \33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\))
plotSumScores(track, peak, \H3K4me3\)

track <- import(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
plotSumScores(track, peak, \H3K27ac\)

track <- import(here(refDir, \GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM2683440_J1_H3K14ac_mm10Lifted.bed\))
plotSumScores(track, peak, \H3K14ac\)

track <- import(here(refDir, \33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))
plotSumScores(track, peak, \CTCF\)

track <- import(here(refDir, \33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak.temp <- fread(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\)) %>%
  dplyr::mutate(V2 = V2 - 1000,
                V3 = V3 + 1000)
colnames(peak.temp) <- c(\chr\, \start\, \end\)
peak <- makeGRangesFromDataFrame(peak.temp)
plotSumScores(track, peak, \YY1\)


### For those with only summit
track <- import(here(refDir, \GSM5571895_ESC_YY1_1.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM5571895_ESC_YY1_summit.bed\))
plotSumScores(track, peak, \RAD21\)

### FOR THOSE WITHOUT PEAKS
track <- import(here(refDir, \GSM2082708_ESC.H3K27me3.1_mm10Lifted.black.bw\), format = \BigWig\)
a <- getSumScores(track, anchor.up)
b <- getSumScores(track, anchor.no)
c <- getSumScores(track, anchor.down)
a.tb <- tibble(loop = \UP\,
               sumScore = a)
b.tb <- tibble(loop = \NO\,
               sumScore = b)
c.tb <- tibble(loop = \DOWN\,
               sumScore = c)
data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()
ggplot(data, aes(x = loop, y = sumScore)) + geom_boxplot(outlier.shape = NA) + theme_classic() + ggtitle(paste0(\H3K27me3 sum no peak\)) +
  coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.9)))
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

## [2.26] Checking the ChIP intensity at anchors
This doesn't have to be restricted to P-N loops. Let's check all loops first.
Also instead of density (mean), median could be better choice. Sum is not appropriate here since
the size of anchors are not same.
#### Limited to peaks to reduce noise
##### dTAG

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVibUZ0WlNBOExTQmNJbU5vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGNJbHh1WEc0aklGVlFJR3h2YjNCY2JteHZiM0F1ZFhBZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGd2lZMmh5YjIxdlgyTnZibk5mWVc1dWIwaHBaWEpoY21Ob2VWOXdaUzF3WlY5a1ZFRkhkbk5FVFZOUFgxVlFYMlJwWm1Zd0xqSXVZbVZrY0dWY0lpa3BYRzVoYm1Ob2IzSXVkWEFnUEMwZ0tHVjRkSEpoWTNSQmJtTm9iM0lvYkc5dmNDNTFjQ2twWEc0aklFNVBJR3h2YjNCY2JteHZiM0F1Ym04Z1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGd2lZMmh5YjIxdlgyTnZibk5mWVc1dWIwaHBaWEpoY21Ob2VWOXdaUzF3WlY5a1ZFRkhkbk5FVFZOUFgwNVBYMlJwWm1Zd0xqSXVZbVZrY0dWY0lpa3BYRzVoYm1Ob2IzSXVibThnUEMwZ0tHVjRkSEpoWTNSQmJtTm9iM0lvYkc5dmNDNXVieWtwWEc0aklFUlBWMDRnYkc5dmNGeHViRzl2Y0M1a2IzZHVJRHd0SUdaeVpXRmtLR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0JjSW1Ob2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxmY0dVdGNHVmZaRlJCUjNaelJFMVRUMTlFVDFkT1gyUnBabVl3TGpJdVltVmtjR1ZjSWlrcFhHNWhibU5vYjNJdVpHOTNiaUE4TFNBb1pYaDBjbUZqZEVGdVkyaHZjaWhzYjI5d0xtUnZkMjRwS1Z4dVhHNWNibkJsWVdzdVNETkxORzFsTXlBOExTQnBiWEJ2Y25SUVpXRnJLR2hsY21Vb2NtVm1SR2x5TENCY0lqTXpNalUxWDBnelN6UnRaVE5mTURRdE56UTFYMEp5ZFdObExUUmZjR1ZoYTNNdWJXVnlaMlZRWldGckxtSmxaRndpS1NsY2JuQmxZV3N1U0ROTE1qZGhZeUE4TFNCcGJYQnZjblJRWldGcktHaGxjbVVvY21WbVJHbHlMQ0JjSWtkVFRUSTBNemcwTnpaZlJVTXRSRWN0TXpRMU9DMUlNMHN5TjBGRFgwRlRXVTVmTVM1dVlYSnliM2RRWldGckxtSmxaRndpS1NsY2JuQmxZV3N1UTFSRFJpQThMU0JwYlhCdmNuUlFaV0ZyS0dobGNtVW9jbVZtUkdseUxDQmNJak16TWpRNFgwTlVRMFpmTURjdE56STVYMEp5ZFdObExUUmZjR1ZoYTNNdWJXVnlaMlZRWldGckxtSmxaRndpS1NsY2JuQmxZV3N1ZEdWdGNDQThMU0JtY21WaFpDaG9aWEpsS0hKbFprUnBjaXdnWENJek16STFNRjlTUVVReU1WOWhZams1TWw5Q2NuVmpaUzAwWDNCbFlXdHpMbTFsY21kbFVHVmhheTVpWldSY0lpa3BJQ1UrSlZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0ZZeUlEMGdWaklnTFNBeE1EQXdMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRll6SUQwZ1ZqTWdLeUF4TURBd0tWeHVZMjlzYm1GdFpYTW9jR1ZoYXk1MFpXMXdLU0E4TFNCaktGd2lZMmh5WENJc0lGd2ljM1JoY25SY0lpd2dYQ0psYm1SY0lpbGNibkJsWVdzdVVrRkVNakVnUEMwZ2JXRnJaVWRTWVc1blpYTkdjbTl0UkdGMFlVWnlZVzFsS0hCbFlXc3VkR1Z0Y0NsY2JseHVYRzVqWVd4amRXeGhkR1ZRWldGclJHVnVjMmwwZVNBOExTQm1kVzVqZEdsdmJpaHdaV0ZyTENCdWIzUmxLWHRjYmlBZ1hHNGdJRzkyWlhKc1lYQmZZMjkxYm5SeklEd3RJR052ZFc1MFQzWmxjbXhoY0hNb1lXNWphRzl5TG5Wd0xDQndaV0ZyS1Z4dUlDQmhibU5vYjNKZmQybGtkR2h6SUR3dElDaDNhV1IwYUNoaGJtTm9iM0l1ZFhBcExURXBMekV3TURCY2JpQWdaR1Z1YzJsMGVTQThMU0J2ZG1WeWJHRndYMk52ZFc1MGN5QXZJR0Z1WTJodmNsOTNhV1IwYUhOY2JpQWdaR0YwWVRFZ1BDMGdkR2xpWW14bEtIUjVjR1VnUFNCY0lsVlFYQ0lzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCa1pXNXphWFI1VUdWeVMySWdQU0JrWlc1emFYUjVLVnh1SUNCY2JpQWdiM1psY214aGNGOWpiM1Z1ZEhNZ1BDMGdZMjkxYm5SUGRtVnliR0Z3Y3loaGJtTm9iM0l1Ym04c0lIQmxZV3NwWEc0Z0lHRnVZMmh2Y2w5M2FXUjBhSE1nUEMwZ0tIZHBaSFJvS0dGdVkyaHZjaTV1YnlrdE1Ta3ZNVEF3TUZ4dUlDQmtaVzV6YVhSNUlEd3RJRzkyWlhKc1lYQmZZMjkxYm5SeklDOGdZVzVqYUc5eVgzZHBaSFJvYzF4dUlDQnRZMjlzY3loaGJtTm9iM0l1Ym04cEpHUmxibk5wZEhrZ1BDMGdaR1Z1YzJsMGVWeHVJQ0JrWVhSaE1pQThMU0IwYVdKaWJHVW9kSGx3WlNBOUlGd2lUazljSWl4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHUmxibk5wZEhsUVpYSkxZaUE5SUdSbGJuTnBkSGtwWEc0Z0lGeHVJQ0J2ZG1WeWJHRndYMk52ZFc1MGN5QThMU0JqYjNWdWRFOTJaWEpzWVhCektHRnVZMmh2Y2k1a2IzZHVMQ0J3WldGcktWeHVJQ0JoYm1Ob2IzSmZkMmxrZEdoeklEd3RJQ2gzYVdSMGFDaGhibU5vYjNJdVpHOTNiaWt0TVNrdk1UQXdNRnh1SUNCa1pXNXphWFI1SUR3dElHOTJaWEpzWVhCZlkyOTFiblJ6SUM4Z1lXNWphRzl5WDNkcFpIUm9jMXh1SUNCdFkyOXNjeWhoYm1Ob2IzSXVaRzkzYmlra1pHVnVjMmwwZVNBOExTQmtaVzV6YVhSNVhHNGdJR1JoZEdFeklEd3RJSFJwWW1Kc1pTaDBlWEJsSUQwZ1hDSkVUMWRPWENJc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmtaVzV6YVhSNVVHVnlTMklnUFNCa1pXNXphWFI1S1Z4dUlDQmNiaUFnWkdGMFlTQThMU0JpYVc1a1gzSnZkM01vWkdGMFlURXNJR1JoZEdFeUxDQmtZWFJoTXlsY2JpQWdYRzRnSUdkbmNHeHZkQ2hrWVhSaExDQmhaWE1vZUNBOUlIUjVjR1VzSUhrZ1BTQmtaVzV6YVhSNVVHVnlTMklwS1NBZ0t5Qm5aVzl0WDNacGIyeHBiaWdwSUNzZ1oyVnZiVjlpYjNod2JHOTBLRzkxZEd4cFpYSXVjMmhoY0dVZ1BTQk9RU3dnZDJsa2RHZ2dQU0F3TGpFZ0tTQXJJSFJvWlcxbFgySjNLQ2tnS3lCblozUnBkR3hsS0c1dmRHVXBJQ3RjYmlBZ0lDQmpiMjl5WkY5allYSjBaWE5wWVc0b2VXeHBiU0E5SUdNb01Dd2djWFZoYm5ScGJHVW9aR0YwWVNSemRXMVRZMjl5WlN3Z01DNDVLU2twWEc1OVhHNWNibU5oYkdOMWJHRjBaVkJsWVd0RVpXNXphWFI1S0hCbFlXc3VTRE5MTkcxbE15d2dYQ0pJTTBzMGJXVXpYQ0lwWEc1allXeGpkV3hoZEdWUVpXRnJSR1Z1YzJsMGVTaHdaV0ZyTGtnelN6STNZV01zSUZ3aVNETkxNamRoWTF3aUtWeHVZMkZzWTNWc1lYUmxVR1ZoYTBSbGJuTnBkSGtvY0dWaGF5NURWRU5HTENCY0lrTlVRMFpjSWlsY2JtTmhiR04xYkdGMFpWQmxZV3RFWlc1emFYUjVLSEJsWVdzdVVrRkVNakVzSUZ3aVVrRkVNakZjSWlsY2JseHVZR0JnSW4wPSAtLT5cblxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG4jIFVQIGxvb3Bcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG4jIE5PIGxvb3Bcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3Iubm8gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5ubykpXG4jIERPV04gbG9vcFxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IuZG93biA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxuXG5cbnBlYWsuSDNLNG1lMyA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXDMzMjU1X0gzSzRtZTNfMDQtNzQ1X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLmJlZFxcKSlcbnBlYWsuSDNLMjdhYyA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXEdTTTI0Mzg0NzZfRUMtREctMzQ1OC1IM0syN0FDX0FTWU5fMS5uYXJyb3dQZWFrLmJlZFxcKSlcbnBlYWsuQ1RDRiA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXDMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLmJlZFxcKSlcbnBlYWsudGVtcCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFwzMzI1MF9SQUQyMV9hYjk5Ml9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFYyID0gVjIgLSAxMDAwLFxuICAgICAgICAgICAgICAgIFYzID0gVjMgKyAxMDAwKVxuY29sbmFtZXMocGVhay50ZW1wKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnBlYWsuUkFEMjEgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHBlYWsudGVtcClcblxuXG5jYWxjdWxhdGVQZWFrRGVuc2l0eSA8LSBmdW5jdGlvbihwZWFrLCBub3RlKXtcbiAgXG4gIG92ZXJsYXBfY291bnRzIDwtIGNvdW50T3ZlcmxhcHMoYW5jaG9yLnVwLCBwZWFrKVxuICBhbmNob3Jfd2lkdGhzIDwtICh3aWR0aChhbmNob3IudXApLTEpLzEwMDBcbiAgZGVuc2l0eSA8LSBvdmVybGFwX2NvdW50cyAvIGFuY2hvcl93aWR0aHNcbiAgZGF0YTEgPC0gdGliYmxlKHR5cGUgPSBcXFVQXFwsXG4gICAgICAgICAgICAgICAgICBkZW5zaXR5UGVyS2IgPSBkZW5zaXR5KVxuICBcbiAgb3ZlcmxhcF9jb3VudHMgPC0gY291bnRPdmVybGFwcyhhbmNob3Iubm8sIHBlYWspXG4gIGFuY2hvcl93aWR0aHMgPC0gKHdpZHRoKGFuY2hvci5ubyktMSkvMTAwMFxuICBkZW5zaXR5IDwtIG92ZXJsYXBfY291bnRzIC8gYW5jaG9yX3dpZHRoc1xuICBtY29scyhhbmNob3Iubm8pJGRlbnNpdHkgPC0gZGVuc2l0eVxuICBkYXRhMiA8LSB0aWJibGUodHlwZSA9IFxcTk9cXCxcbiAgICAgICAgICAgICAgICAgIGRlbnNpdHlQZXJLYiA9IGRlbnNpdHkpXG4gIFxuICBvdmVybGFwX2NvdW50cyA8LSBjb3VudE92ZXJsYXBzKGFuY2hvci5kb3duLCBwZWFrKVxuICBhbmNob3Jfd2lkdGhzIDwtICh3aWR0aChhbmNob3IuZG93biktMSkvMTAwMFxuICBkZW5zaXR5IDwtIG92ZXJsYXBfY291bnRzIC8gYW5jaG9yX3dpZHRoc1xuICBtY29scyhhbmNob3IuZG93bikkZGVuc2l0eSA8LSBkZW5zaXR5XG4gIGRhdGEzIDwtIHRpYmJsZSh0eXBlID0gXFxET1dOXFwsXG4gICAgICAgICAgICAgICAgICBkZW5zaXR5UGVyS2IgPSBkZW5zaXR5KVxuICBcbiAgZGF0YSA8LSBiaW5kX3Jvd3MoZGF0YTEsIGRhdGEyLCBkYXRhMylcbiAgXG4gIGdncGxvdChkYXRhLCBhZXMoeCA9IHR5cGUsIHkgPSBkZW5zaXR5UGVyS2IpKSAgKyBnZW9tX3Zpb2xpbigpICsgZ2VvbV9ib3hwbG90KG91dGxpZXIuc2hhcGUgPSBOQSwgd2lkdGggPSAwLjEgKSArIHRoZW1lX2J3KCkgKyBnZ3RpdGxlKG5vdGUpICtcbiAgICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgcXVhbnRpbGUoZGF0YSRzdW1TY29yZSwgMC45KSkpXG59XG5cbmNhbGN1bGF0ZVBlYWtEZW5zaXR5KHBlYWsuSDNLNG1lMywgXFxIM0s0bWUzXFwpXG5jYWxjdWxhdGVQZWFrRGVuc2l0eShwZWFrLkgzSzI3YWMsIFxcSDNLMjdhY1xcKVxuY2FsY3VsYXRlUGVha0RlbnNpdHkocGVhay5DVENGLCBcXENUQ0ZcXClcbmNhbGN1bGF0ZVBlYWtEZW5zaXR5KHBlYWsuUkFEMjEsIFxcUkFEMjFcXClcblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
name <- \chromo_cons_annoHierarchy\

# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))


peak.H3K4me3 <- importPeak(here(refDir, \33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\))
peak.H3K27ac <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
peak.CTCF <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))
peak.temp <- fread(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\)) %>%
  dplyr::mutate(V2 = V2 - 1000,
                V3 = V3 + 1000)
colnames(peak.temp) <- c(\chr\, \start\, \end\)
peak.RAD21 <- makeGRangesFromDataFrame(peak.temp)


calculatePeakDensity <- function(peak, note){
  
  overlap_counts <- countOverlaps(anchor.up, peak)
  anchor_widths <- (width(anchor.up)-1)/1000
  density <- overlap_counts / anchor_widths
  data1 <- tibble(type = \UP\,
                  densityPerKb = density)
  
  overlap_counts <- countOverlaps(anchor.no, peak)
  anchor_widths <- (width(anchor.no)-1)/1000
  density <- overlap_counts / anchor_widths
  mcols(anchor.no)$density <- density
  data2 <- tibble(type = \NO\,
                  densityPerKb = density)
  
  overlap_counts <- countOverlaps(anchor.down, peak)
  anchor_widths <- (width(anchor.down)-1)/1000
  density <- overlap_counts / anchor_widths
  mcols(anchor.down)$density <- density
  data3 <- tibble(type = \DOWN\,
                  densityPerKb = density)
  
  data <- bind_rows(data1, data2, data3)
  
  ggplot(data, aes(x = type, y = densityPerKb))  + geom_violin() + geom_boxplot(outlier.shape = NA, width = 0.1 ) + theme_bw() + ggtitle(note) +
    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.9)))
}

calculatePeakDensity(peak.H3K4me3, \H3K4me3\)
calculatePeakDensity(peak.H3K27ac, \H3K27ac\)
calculatePeakDensity(peak.CTCF, \CTCF\)
calculatePeakDensity(peak.RAD21, \RAD21\)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJtRnRaU0E4TFNCY1hHTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsY1hGeHVYRzRqSUZWUUlHeHZiM0JjYm14dmIzQXVkWEFnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ4Y1kyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5d1pTMXdaVjlrVkVGSGRuTkVUVk5QWDFWUVgyUnBabVl3TGpJdVltVmtjR1ZjWENrcFhHNWhibU5vYjNJdWRYQWdQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1MWNDa3BYRzRqSUU1UElHeHZiM0JjYm14dmIzQXVibThnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ4Y1kyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5d1pTMXdaVjlrVkVGSGRuTkVUVk5QWDA1UFgyUnBabVl3TGpJdVltVmtjR1ZjWENrcFhHNWhibU5vYjNJdWJtOGdQQzBnS0dWNGRISmhZM1JCYm1Ob2IzSW9iRzl2Y0M1dWJ5a3BYRzRqSUVSUFYwNGdiRzl2Y0Z4dWJHOXZjQzVrYjNkdUlEd3RJR1p5WldGa0tHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQmNYR05vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGZjR1V0Y0dWZlpGUkJSM1p6UkUxVFQxOUVUMWRPWDJScFptWXdMakl1WW1Wa2NHVmNYQ2twWEc1aGJtTm9iM0l1Wkc5M2JpQThMU0FvWlhoMGNtRmpkRUZ1WTJodmNpaHNiMjl3TG1SdmQyNHBLVnh1WEc1Y2JuQmxZV3N1U0ROTE5HMWxNeUE4TFNCcGJYQnZjblJRWldGcktHaGxjbVVvY21WbVJHbHlMQ0JjWERNek1qVTFYMGd6U3pSdFpUTmZNRFF0TnpRMVgwSnlkV05sTFRSZmNHVmhhM011YldWeVoyVlFaV0ZyTG1KbFpGeGNLU2xjYm5CbFlXc3VTRE5MTWpkaFl5QThMU0JwYlhCdmNuUlFaV0ZyS0dobGNtVW9jbVZtUkdseUxDQmNYRWRUVFRJME16ZzBOelpmUlVNdFJFY3RNelExT0MxSU0wc3lOMEZEWDBGVFdVNWZNUzV1WVhKeWIzZFFaV0ZyTG1KbFpGeGNLU2xjYm5CbFlXc3VRMVJEUmlBOExTQnBiWEJ2Y25SUVpXRnJLR2hsY21Vb2NtVm1SR2x5TENCY1hETXpNalE0WDBOVVEwWmZNRGN0TnpJNVgwSnlkV05sTFRSZmNHVmhhM011YldWeVoyVlFaV0ZyTG1KbFpGeGNLU2xjYm5CbFlXc3VkR1Z0Y0NBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYRnd6TXpJMU1GOVNRVVF5TVY5aFlqazVNbDlDY25WalpTMDBYM0JsWVd0ekxtMWxjbWRsVUdWaGF5NWlaV1JjWENrcElDVStKVnh1SUNCa2NHeDVjam82YlhWMFlYUmxLRll5SUQwZ1ZqSWdMU0F4TURBd0xGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGWXpJRDBnVmpNZ0t5QXhNREF3S1Z4dVkyOXNibUZ0WlhNb2NHVmhheTUwWlcxd0tTQThMU0JqS0Z4Y1kyaHlYRndzSUZ4Y2MzUmhjblJjWEN3Z1hGeGxibVJjWENsY2JuQmxZV3N1VWtGRU1qRWdQQzBnYldGclpVZFNZVzVuWlhOR2NtOXRSR0YwWVVaeVlXMWxLSEJsWVdzdWRHVnRjQ2xjYmx4dVhHNWpZV3hqZFd4aGRHVlFaV0ZyUkdWdWMybDBlU0E4TFNCbWRXNWpkR2x2Ymlod1pXRnJMQ0J1YjNSbEtYdGNiaUFnWEc0Z0lHOTJaWEpzWVhCZlkyOTFiblJ6SUR3dElHTnZkVzUwVDNabGNteGhjSE1vWVc1amFHOXlMblZ3TENCd1pXRnJLVnh1SUNCaGJtTm9iM0pmZDJsa2RHaHpJRHd0SUNoM2FXUjBhQ2hoYm1Ob2IzSXVkWEFwTFRFcEx6RXdNREJjYmlBZ1pHVnVjMmwwZVNBOExTQnZkbVZ5YkdGd1gyTnZkVzUwY3lBdklHRnVZMmh2Y2w5M2FXUjBhSE5jYmlBZ1pHRjBZVEVnUEMwZ2RHbGlZbXhsS0hSNWNHVWdQU0JjWEZWUVhGd3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JrWlc1emFYUjVVR1Z5UzJJZ1BTQmtaVzV6YVhSNUtWeHVJQ0JjYmlBZ2IzWmxjbXhoY0Y5amIzVnVkSE1nUEMwZ1kyOTFiblJQZG1WeWJHRndjeWhoYm1Ob2IzSXVibThzSUhCbFlXc3BYRzRnSUdGdVkyaHZjbDkzYVdSMGFITWdQQzBnS0hkcFpIUm9LR0Z1WTJodmNpNXVieWt0TVNrdk1UQXdNRnh1SUNCa1pXNXphWFI1SUR3dElHOTJaWEpzWVhCZlkyOTFiblJ6SUM4Z1lXNWphRzl5WDNkcFpIUm9jMXh1SUNCdFkyOXNjeWhoYm1Ob2IzSXVibThwSkdSbGJuTnBkSGtnUEMwZ1pHVnVjMmwwZVZ4dUlDQmtZWFJoTWlBOExTQjBhV0ppYkdVb2RIbHdaU0E5SUZ4Y1RrOWNYQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdSbGJuTnBkSGxRWlhKTFlpQTlJR1JsYm5OcGRIa3BYRzRnSUZ4dUlDQnZkbVZ5YkdGd1gyTnZkVzUwY3lBOExTQmpiM1Z1ZEU5MlpYSnNZWEJ6S0dGdVkyaHZjaTVrYjNkdUxDQndaV0ZyS1Z4dUlDQmhibU5vYjNKZmQybGtkR2h6SUR3dElDaDNhV1IwYUNoaGJtTm9iM0l1Wkc5M2Jpa3RNU2t2TVRBd01GeHVJQ0JrWlc1emFYUjVJRHd0SUc5MlpYSnNZWEJmWTI5MWJuUnpJQzhnWVc1amFHOXlYM2RwWkhSb2MxeHVJQ0J0WTI5c2N5aGhibU5vYjNJdVpHOTNiaWtrWkdWdWMybDBlU0E4TFNCa1pXNXphWFI1WEc0Z0lHUmhkR0V6SUR3dElIUnBZbUpzWlNoMGVYQmxJRDBnWEZ4RVQxZE9YRndzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCa1pXNXphWFI1VUdWeVMySWdQU0JrWlc1emFYUjVLVnh1SUNCY2JpQWdaR0YwWVNBOExTQmlhVzVrWDNKdmQzTW9aR0YwWVRFc0lHUmhkR0V5TENCa1lYUmhNeWxjYmlBZ1hHNGdJR2RuY0d4dmRDaGtZWFJoTENCaFpYTW9lQ0E5SUhSNWNHVXNJSGtnUFNCa1pXNXphWFI1VUdWeVMySXBLU0FnS3lCblpXOXRYM1pwYjJ4cGJpZ3BJQ3NnWjJWdmJWOWliM2h3Ykc5MEtHOTFkR3hwWlhJdWMyaGhjR1VnUFNCT1FTd2dkMmxrZEdnZ1BTQXdMakVnS1NBcklIUm9aVzFsWDJKM0tDa2dLeUJuWjNScGRHeGxLRzV2ZEdVcElDdGNiaUFnSUNCamIyOXlaRjlqWVhKMFpYTnBZVzRvZVd4cGJTQTlJR01vTUN3Z2NYVmhiblJwYkdVb1pHRjBZU1J6ZFcxVFkyOXlaU3dnTUM0NUtTa3BYRzU5WEc1Y2JtTmhiR04xYkdGMFpWQmxZV3RFWlc1emFYUjVLSEJsWVdzdVNETkxORzFsTXl3Z1hGeElNMHMwYldVelhGd3BYRzVqWVd4amRXeGhkR1ZRWldGclJHVnVjMmwwZVNod1pXRnJMa2d6U3pJM1lXTXNJRnhjU0ROTE1qZGhZMXhjS1Z4dVkyRnNZM1ZzWVhSbFVHVmhhMFJsYm5OcGRIa29jR1ZoYXk1RFZFTkdMQ0JjWEVOVVEwWmNYQ2xjYm1OaGJHTjFiR0YwWlZCbFlXdEVaVzV6YVhSNUtIQmxZV3N1VWtGRU1qRXNJRnhjVWtGRU1qRmNYQ2xjYmx4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5XFxcblxuIyBVUCBsb29wXG5sb29wLnVwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLnVwIDwtIChleHRyYWN0QW5jaG9yKGxvb3AudXApKVxuIyBOTyBsb29wXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLm5vIDwtIChleHRyYWN0QW5jaG9yKGxvb3Aubm8pKVxuIyBET1dOIGxvb3Bcbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX2RUQUd2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLmRvd24gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5kb3duKSlcblxuXG5wZWFrLkgzSzRtZTMgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFwzMzI1NV9IM0s0bWUzXzA0LTc0NV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcXCkpXG5wZWFrLkgzSzI3YWMgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFxHU00yNDM4NDc2X0VDLURHLTM0NTgtSDNLMjdBQ19BU1lOXzEubmFycm93UGVhay5iZWRcXCkpXG5wZWFrLkNUQ0YgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFwzMzI0OF9DVENGXzA3LTcyOV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcXCkpXG5wZWFrLnRlbXAgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShWMiA9IFYyIC0gMTAwMCxcbiAgICAgICAgICAgICAgICBWMyA9IFYzICsgMTAwMClcbmNvbG5hbWVzKHBlYWsudGVtcCkgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5wZWFrLlJBRDIxIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShwZWFrLnRlbXApXG5cblxuY2FsY3VsYXRlUGVha0RlbnNpdHkgPC0gZnVuY3Rpb24ocGVhaywgbm90ZSl7XG4gIFxuICBvdmVybGFwX2NvdW50cyA8LSBjb3VudE92ZXJsYXBzKGFuY2hvci51cCwgcGVhaylcbiAgYW5jaG9yX3dpZHRocyA8LSAod2lkdGgoYW5jaG9yLnVwKS0xKS8xMDAwXG4gIGRlbnNpdHkgPC0gb3ZlcmxhcF9jb3VudHMgLyBhbmNob3Jfd2lkdGhzXG4gIGRhdGExIDwtIHRpYmJsZSh0eXBlID0gXFxVUFxcLFxuICAgICAgICAgICAgICAgICAgZGVuc2l0eVBlcktiID0gZGVuc2l0eSlcbiAgXG4gIG92ZXJsYXBfY291bnRzIDwtIGNvdW50T3ZlcmxhcHMoYW5jaG9yLm5vLCBwZWFrKVxuICBhbmNob3Jfd2lkdGhzIDwtICh3aWR0aChhbmNob3Iubm8pLTEpLzEwMDBcbiAgZGVuc2l0eSA8LSBvdmVybGFwX2NvdW50cyAvIGFuY2hvcl93aWR0aHNcbiAgbWNvbHMoYW5jaG9yLm5vKSRkZW5zaXR5IDwtIGRlbnNpdHlcbiAgZGF0YTIgPC0gdGliYmxlKHR5cGUgPSBcXE5PXFwsXG4gICAgICAgICAgICAgICAgICBkZW5zaXR5UGVyS2IgPSBkZW5zaXR5KVxuICBcbiAgb3ZlcmxhcF9jb3VudHMgPC0gY291bnRPdmVybGFwcyhhbmNob3IuZG93biwgcGVhaylcbiAgYW5jaG9yX3dpZHRocyA8LSAod2lkdGgoYW5jaG9yLmRvd24pLTEpLzEwMDBcbiAgZGVuc2l0eSA8LSBvdmVybGFwX2NvdW50cyAvIGFuY2hvcl93aWR0aHNcbiAgbWNvbHMoYW5jaG9yLmRvd24pJGRlbnNpdHkgPC0gZGVuc2l0eVxuICBkYXRhMyA8LSB0aWJibGUodHlwZSA9IFxcRE9XTlxcLFxuICAgICAgICAgICAgICAgICAgZGVuc2l0eVBlcktiID0gZGVuc2l0eSlcbiAgXG4gIGRhdGEgPC0gYmluZF9yb3dzKGRhdGExLCBkYXRhMiwgZGF0YTMpXG4gIFxuICBnZ3Bsb3QoZGF0YSwgYWVzKHggPSB0eXBlLCB5ID0gZGVuc2l0eVBlcktiKSkgICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdChvdXRsaWVyLnNoYXBlID0gTkEsIHdpZHRoID0gMC4xICkgKyB0aGVtZV9idygpICsgZ2d0aXRsZShub3RlKSArXG4gICAgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuOSkpKVxufVxuXG5jYWxjdWxhdGVQZWFrRGVuc2l0eShwZWFrLkgzSzRtZTMsIFxcSDNLNG1lM1xcKVxuY2FsY3VsYXRlUGVha0RlbnNpdHkocGVhay5IM0syN2FjLCBcXEgzSzI3YWNcXClcbmNhbGN1bGF0ZVBlYWtEZW5zaXR5KHBlYWsuQ1RDRiwgXFxDVENGXFwpXG5jYWxjdWxhdGVQZWFrRGVuc2l0eShwZWFrLlJBRDIxLCBcXFJBRDIxXFwpXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG4jIFVQIGxvb3Bcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG4jIE5PIGxvb3Bcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3Iubm8gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5ubykpXG4jIERPV04gbG9vcFxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IuZG93biA8LSAoZXh0cmFjdEFuY2hvcihsb29wLmRvd24pKVxuXG5cbnBlYWsuSDNLNG1lMyA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXDMzMjU1X0gzSzRtZTNfMDQtNzQ1X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLmJlZFxcKSlcbnBlYWsuSDNLMjdhYyA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXEdTTTI0Mzg0NzZfRUMtREctMzQ1OC1IM0syN0FDX0FTWU5fMS5uYXJyb3dQZWFrLmJlZFxcKSlcbnBlYWsuQ1RDRiA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXDMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLmJlZFxcKSlcbnBlYWsudGVtcCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFwzMzI1MF9SQUQyMV9hYjk5Ml9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFYyID0gVjIgLSAxMDAwLFxuICAgICAgICAgICAgICAgIFYzID0gVjMgKyAxMDAwKVxuY29sbmFtZXMocGVhay50ZW1wKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnBlYWsuUkFEMjEgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHBlYWsudGVtcClcblxuXG5jYWxjdWxhdGVQZWFrRGVuc2l0eSA8LSBmdW5jdGlvbihwZWFrLCBub3RlKXtcbiAgXG4gIG92ZXJsYXBfY291bnRzIDwtIGNvdW50T3ZlcmxhcHMoYW5jaG9yLnVwLCBwZWFrKVxuICBhbmNob3Jfd2lkdGhzIDwtICh3aWR0aChhbmNob3IudXApLTEpLzEwMDBcbiAgZGVuc2l0eSA8LSBvdmVybGFwX2NvdW50cyAvIGFuY2hvcl93aWR0aHNcbiAgZGF0YTEgPC0gdGliYmxlKHR5cGUgPSBcXFVQXFwsXG4gICAgICAgICAgICAgICAgICBkZW5zaXR5UGVyS2IgPSBkZW5zaXR5KVxuICBcbiAgb3ZlcmxhcF9jb3VudHMgPC0gY291bnRPdmVybGFwcyhhbmNob3Iubm8sIHBlYWspXG4gIGFuY2hvcl93aWR0aHMgPC0gKHdpZHRoKGFuY2hvci5ubyktMSkvMTAwMFxuICBkZW5zaXR5IDwtIG92ZXJsYXBfY291bnRzIC8gYW5jaG9yX3dpZHRoc1xuICBtY29scyhhbmNob3Iubm8pJGRlbnNpdHkgPC0gZGVuc2l0eVxuICBkYXRhMiA8LSB0aWJibGUodHlwZSA9IFxcTk9cXCxcbiAgICAgICAgICAgICAgICAgIGRlbnNpdHlQZXJLYiA9IGRlbnNpdHkpXG4gIFxuICBvdmVybGFwX2NvdW50cyA8LSBjb3VudE92ZXJsYXBzKGFuY2hvci5kb3duLCBwZWFrKVxuICBhbmNob3Jfd2lkdGhzIDwtICh3aWR0aChhbmNob3IuZG93biktMSkvMTAwMFxuICBkZW5zaXR5IDwtIG92ZXJsYXBfY291bnRzIC8gYW5jaG9yX3dpZHRoc1xuICBtY29scyhhbmNob3IuZG93bikkZGVuc2l0eSA8LSBkZW5zaXR5XG4gIGRhdGEzIDwtIHRpYmJsZSh0eXBlID0gXFxET1dOXFwsXG4gICAgICAgICAgICAgICAgICBkZW5zaXR5UGVyS2IgPSBkZW5zaXR5KVxuICBcbiAgZGF0YSA8LSBiaW5kX3Jvd3MoZGF0YTEsIGRhdGEyLCBkYXRhMylcbiAgXG4gIGdncGxvdChkYXRhLCBhZXMoeCA9IHR5cGUsIHkgPSBkZW5zaXR5UGVyS2IpKSAgKyBnZW9tX3Zpb2xpbigpICsgZ2VvbV9ib3hwbG90KG91dGxpZXIuc2hhcGUgPSBOQSwgd2lkdGggPSAwLjEgKSArIHRoZW1lX2J3KCkgKyBnZ3RpdGxlKG5vdGUpICtcbiAgICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgcXVhbnRpbGUoZGF0YSRzdW1TY29yZSwgMC45KSkpXG59XG5cbmNhbGN1bGF0ZVBlYWtEZW5zaXR5KHBlYWsuSDNLNG1lMywgXFxIM0s0bWUzXFwpXG5jYWxjdWxhdGVQZWFrRGVuc2l0eShwZWFrLkgzSzI3YWMsIFxcSDNLMjdhY1xcKVxuY2FsY3VsYXRlUGVha0RlbnNpdHkocGVhay5DVENGLCBcXENUQ0ZcXClcbmNhbGN1bGF0ZVBlYWtEZW5zaXR5KHBlYWsuUkFEMjEsIFxcUkFEMjFcXClcblxuYGBgXG5gYGAifQ== -->

```r
```r
name <- \chromo_cons_annoHierarchy\

# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))


peak.H3K4me3 <- importPeak(here(refDir, \33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\))
peak.H3K27ac <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
peak.CTCF <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))
peak.temp <- fread(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\)) %>%
  dplyr::mutate(V2 = V2 - 1000,
                V3 = V3 + 1000)
colnames(peak.temp) <- c(\chr\, \start\, \end\)
peak.RAD21 <- makeGRangesFromDataFrame(peak.temp)


calculatePeakDensity <- function(peak, note){
  
  overlap_counts <- countOverlaps(anchor.up, peak)
  anchor_widths <- (width(anchor.up)-1)/1000
  density <- overlap_counts / anchor_widths
  data1 <- tibble(type = \UP\,
                  densityPerKb = density)
  
  overlap_counts <- countOverlaps(anchor.no, peak)
  anchor_widths <- (width(anchor.no)-1)/1000
  density <- overlap_counts / anchor_widths
  mcols(anchor.no)$density <- density
  data2 <- tibble(type = \NO\,
                  densityPerKb = density)
  
  overlap_counts <- countOverlaps(anchor.down, peak)
  anchor_widths <- (width(anchor.down)-1)/1000
  density <- overlap_counts / anchor_widths
  mcols(anchor.down)$density <- density
  data3 <- tibble(type = \DOWN\,
                  densityPerKb = density)
  
  data <- bind_rows(data1, data2, data3)
  
  ggplot(data, aes(x = type, y = densityPerKb))  + geom_violin() + geom_boxplot(outlier.shape = NA, width = 0.1 ) + theme_bw() + ggtitle(note) +
    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.9)))
}

calculatePeakDensity(peak.H3K4me3, \H3K4me3\)
calculatePeakDensity(peak.H3K27ac, \H3K27ac\)
calculatePeakDensity(peak.CTCF, \CTCF\)
calculatePeakDensity(peak.RAD21, \RAD21\)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### A485

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVibUZ0WlNBOExTQmNJbU5vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGNJbHh1Ykc5dmNDQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2dYQ0pqYUhKdmJXOWZZMjl1YzE5aGJtNXZTR2xsY21GeVkyaDVYM0JsTFhCbExtSmxaSEJsWENJcEtWeHVZVzVqYUc5eUlEd3RJR1Y0ZEhKaFkzUkJibU5vYjNJb2JHOXZjQ2xjYmx4dUl5TWpJRmRvZVhSbFhHNXVJRHd0SUd4bGJtZDBhQ2gxYm1seGRXVW9jM1ZpYW1WamRFaHBkSE1vWm1sdVpFOTJaWEpzWVhCektHRnVZMmh2Y2l3Z2NHVmhheTVYYUhsMFpTNVRSU2twS1NsY2JuUnZkR0ZzSUR3dElHeGxibWQwYUNod1pXRnJMbGRvZVhSbExsTkZLVnh1WTI5MWJuUnpJRHd0SUdNb2Jpd2dkRzkwWVd3Z0xTQnVLVnh1YkdGaVpXeHpJRHd0SUhCaGMzUmxLR01vWENKamIzWmxjbVZrWENJc0lGd2lUazlVSUdOdmRtVnlaV1JjSWlrc0lHTnZkVzUwY3lsY2JuQnBaU2hqYjNWdWRITXNJR3hoWW1Wc2N5QTlJR3hoWW1Wc2N5d2dJRzFoYVc0Z1BTQndZWE4wWlRBb1hDSlhhSGwwWlNCVFJTQmpiM1psY21GblpTQmNYRzVjSWl3Z2RHOTBZV3dwTENCamIyd2dQU0JqS0Z3aVozSmxlVndpTENCY0luZG9hWFJsWENJcEtWeHVYRzVtYVd4bFRtRnRaU0E4TFNCb1pYSmxLR1pwWjBScGNpd2dYQ0p3YVdWZlUwVmZWMmg1ZEdWY0lpbGNibmRwWkhSb0lEd3RJSEJoYm1Wc1UybDZaU2cwS1NwdGJWUnZTVzVqYUZ4dWFHVnBaMmgwSUR3dElIQmhibVZzVTJsNlpTZzBLU3B0YlZSdlNXNWphRnh1SXlCemRtZHNhWFJsS0hCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWENJdWMzWm5YQ0lwTENCM2FXUjBhQ0E5SUhkcFpIUm9MQ0JvWldsbmFIUWdQV2hsYVdkb2RDbGNiaU1nY0dsbEtHTnZkVzUwY3l3Z2JHRmlaV3h6SUQwZ2JHRmlaV3h6TENBZ2JXRnBiaUE5SUhCaGMzUmxNQ2hjSWxkb2VYUmxJRk5GSUdOdmRtVnlZV2RsSUZ4Y2Jsd2lMQ0IwYjNSaGJDa3NJR052YkNBOUlHTW9YQ0puY21WNVhDSXNJRndpZDJocGRHVmNJaWtzWEc0aklDQWdJQ0JqWlhnZ1BTQXhMQ0JqWlhndWJXRnBiaUE5SURFcFhHNGpJR1JsZGk1dlptWW9LVnh1WEc1Y2JseHVJeU1qSUVSNWJHRnVYRzV1SUR3dElHeGxibWQwYUNoMWJtbHhkV1VvYzNWaWFtVmpkRWhwZEhNb1ptbHVaRTkyWlhKc1lYQnpLR0Z1WTJodmNpd2djR1ZoYXk1RWVXeGhiaTVUUlNrcEtTbGNiblJ2ZEdGc0lEd3RJR3hsYm1kMGFDaHdaV0ZyTGtSNWJHRnVMbE5GS1Z4dVkyOTFiblJ6SUR3dElHTW9iaXdnZEc5MFlXd2dMU0J1S1Z4dWJHRmlaV3h6SUR3dElIQmhjM1JsS0dNb1hDSmpiM1psY21Wa1hDSXNJRndpVGs5VUlHTnZkbVZ5WldSY0lpa3NJR052ZFc1MGN5bGNibkJwWlNoamIzVnVkSE1zSUd4aFltVnNjeUE5SUd4aFltVnNjeXdnYldGcGJpQTlJSEJoYzNSbE1DaGNJa1I1YkdGdUlGTkZJR052ZG1WeVlXZGxJRnhjYmx3aUxDQjBiM1JoYkNrc0lHTnZiQ0E5SUdNb1hDSm5jbVY1WENJc0lGd2lkMmhwZEdWY0lpa3BYRzVjYm1acGJHVk9ZVzFsSUR3dElHaGxjbVVvWm1sblJHbHlMQ0JjSW5CcFpWOVRSVjlOZFhKd2FIbGNJaWxjYm5kcFpIUm9JRHd0SUhCaGJtVnNVMmw2WlNnMEtTcHRiVlJ2U1c1amFGeHVhR1ZwWjJoMElEd3RJSEJoYm1Wc1UybDZaU2cwS1NwdGJWUnZTVzVqYUZ4dUl5QnpkbWRzYVhSbEtIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hDSXVjM1puWENJcExDQjNhV1IwYUNBOUlIZHBaSFJvTENCb1pXbG5hSFFnUFdobGFXZG9kQ2xjYmlNZ2NHbGxLR052ZFc1MGN5d2diR0ZpWld4eklEMGdiR0ZpWld4ekxDQnRZV2x1SUQwZ2NHRnpkR1V3S0Z3aVRYVnljR2g1SUZORklHTnZkbVZ5WVdkbElGeGNibHdpTENCMGIzUmhiQ2tzSUdOdmJDQTlJR01vWENKbmNtVjVYQ0lzSUZ3aWQyaHBkR1ZjSWlrcFhHNGpJRnh1SXlCa1pYWXViMlptS0NsY2JseHVZR0JnSW4wPSAtLT5cblxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxubG9vcCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlLmJlZHBlXFwpKVxuYW5jaG9yIDwtIGV4dHJhY3RBbmNob3IobG9vcClcblxuIyMjIFdoeXRlXG5uIDwtIGxlbmd0aCh1bmlxdWUoc3ViamVjdEhpdHMoZmluZE92ZXJsYXBzKGFuY2hvciwgcGVhay5XaHl0ZS5TRSkpKSlcbnRvdGFsIDwtIGxlbmd0aChwZWFrLldoeXRlLlNFKVxuY291bnRzIDwtIGMobiwgdG90YWwgLSBuKVxubGFiZWxzIDwtIHBhc3RlKGMoXFxjb3ZlcmVkXFwsIFxcTk9UIGNvdmVyZWRcXCksIGNvdW50cylcbnBpZShjb3VudHMsIGxhYmVscyA9IGxhYmVscywgIG1haW4gPSBwYXN0ZTAoXFxXaHl0ZSBTRSBjb3ZlcmFnZSBcXG5cXCwgdG90YWwpLCBjb2wgPSBjKFxcZ3JleVxcLCBcXHdoaXRlXFwpKVxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgXFxwaWVfU0VfV2h5dGVcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSg0KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSg0KSptbVRvSW5jaFxuIyBzdmdsaXRlKHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpLCB3aWR0aCA9IHdpZHRoLCBoZWlnaHQgPWhlaWdodClcbiMgcGllKGNvdW50cywgbGFiZWxzID0gbGFiZWxzLCAgbWFpbiA9IHBhc3RlMChcXFdoeXRlIFNFIGNvdmVyYWdlIFxcblxcLCB0b3RhbCksIGNvbCA9IGMoXFxncmV5XFwsIFxcd2hpdGVcXCksXG4jICAgICBjZXggPSAxLCBjZXgubWFpbiA9IDEpXG4jIGRldi5vZmYoKVxuXG5cblxuIyMjIER5bGFuXG5uIDwtIGxlbmd0aCh1bmlxdWUoc3ViamVjdEhpdHMoZmluZE92ZXJsYXBzKGFuY2hvciwgcGVhay5EeWxhbi5TRSkpKSlcbnRvdGFsIDwtIGxlbmd0aChwZWFrLkR5bGFuLlNFKVxuY291bnRzIDwtIGMobiwgdG90YWwgLSBuKVxubGFiZWxzIDwtIHBhc3RlKGMoXFxjb3ZlcmVkXFwsIFxcTk9UIGNvdmVyZWRcXCksIGNvdW50cylcbnBpZShjb3VudHMsIGxhYmVscyA9IGxhYmVscywgbWFpbiA9IHBhc3RlMChcXER5bGFuIFNFIGNvdmVyYWdlIFxcblxcLCB0b3RhbCksIGNvbCA9IGMoXFxncmV5XFwsIFxcd2hpdGVcXCkpXG5cbmZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBcXHBpZV9TRV9NdXJwaHlcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSg0KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSg0KSptbVRvSW5jaFxuIyBzdmdsaXRlKHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpLCB3aWR0aCA9IHdpZHRoLCBoZWlnaHQgPWhlaWdodClcbiMgcGllKGNvdW50cywgbGFiZWxzID0gbGFiZWxzLCBtYWluID0gcGFzdGUwKFxcTXVycGh5IFNFIGNvdmVyYWdlIFxcblxcLCB0b3RhbCksIGNvbCA9IGMoXFxncmV5XFwsIFxcd2hpdGVcXCkpXG4jIFxuIyBkZXYub2ZmKClcblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
name <- \chromo_cons_annoHierarchy\
loop <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\))
anchor <- extractAnchor(loop)

### Whyte
n <- length(unique(subjectHits(findOverlaps(anchor, peak.Whyte.SE))))
total <- length(peak.Whyte.SE)
counts <- c(n, total - n)
labels <- paste(c(\covered\, \NOT covered\), counts)
pie(counts, labels = labels,  main = paste0(\Whyte SE coverage \n\, total), col = c(\grey\, \white\))

fileName <- here(figDir, \pie_SE_Whyte\)
width <- panelSize(4)*mmToInch
height <- panelSize(4)*mmToInch
# svglite(paste0(fileName, \.svg\), width = width, height =height)
# pie(counts, labels = labels,  main = paste0(\Whyte SE coverage \n\, total), col = c(\grey\, \white\),
#     cex = 1, cex.main = 1)
# dev.off()



### Dylan
n <- length(unique(subjectHits(findOverlaps(anchor, peak.Dylan.SE))))
total <- length(peak.Dylan.SE)
counts <- c(n, total - n)
labels <- paste(c(\covered\, \NOT covered\), counts)
pie(counts, labels = labels, main = paste0(\Dylan SE coverage \n\, total), col = c(\grey\, \white\))

fileName <- here(figDir, \pie_SE_Murphy\)
width <- panelSize(4)*mmToInch
height <- panelSize(4)*mmToInch
# svglite(paste0(fileName, \.svg\), width = width, height =height)
# pie(counts, labels = labels, main = paste0(\Murphy SE coverage \n\, total), col = c(\grey\, \white\))
# 
# dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJtRnRaU0E4TFNCY1hHTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsY1hGeHViRzl2Y0NBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z1hGeGphSEp2Ylc5ZlkyOXVjMTloYm01dlNHbGxjbUZ5WTJoNVgzQmxMWEJsTG1KbFpIQmxYRndwS1Z4dVlXNWphRzl5SUR3dElHVjRkSEpoWTNSQmJtTm9iM0lvYkc5dmNDbGNibHh1SXlNaklGZG9lWFJsWEc1dUlEd3RJR3hsYm1kMGFDaDFibWx4ZFdVb2MzVmlhbVZqZEVocGRITW9abWx1WkU5MlpYSnNZWEJ6S0dGdVkyaHZjaXdnY0dWaGF5NVhhSGwwWlM1VFJTa3BLU2xjYm5SdmRHRnNJRHd0SUd4bGJtZDBhQ2h3WldGckxsZG9lWFJsTGxORktWeHVZMjkxYm5SeklEd3RJR01vYml3Z2RHOTBZV3dnTFNCdUtWeHViR0ZpWld4eklEd3RJSEJoYzNSbEtHTW9YRnhqYjNabGNtVmtYRndzSUZ4Y1RrOVVJR052ZG1WeVpXUmNYQ2tzSUdOdmRXNTBjeWxjYm5CcFpTaGpiM1Z1ZEhNc0lHeGhZbVZzY3lBOUlHeGhZbVZzY3l3Z0lHMWhhVzRnUFNCd1lYTjBaVEFvWEZ4WGFIbDBaU0JUUlNCamIzWmxjbUZuWlNCY1hHNWNYQ3dnZEc5MFlXd3BMQ0JqYjJ3Z1BTQmpLRnhjWjNKbGVWeGNMQ0JjWEhkb2FYUmxYRndwS1Z4dVhHNW1hV3hsVG1GdFpTQThMU0JvWlhKbEtHWnBaMFJwY2l3Z1hGeHdhV1ZmVTBWZlYyaDVkR1ZjWENsY2JuZHBaSFJvSUR3dElIQmhibVZzVTJsNlpTZzBLU3B0YlZSdlNXNWphRnh1YUdWcFoyaDBJRHd0SUhCaGJtVnNVMmw2WlNnMEtTcHRiVlJ2U1c1amFGeHVJeUJ6ZG1kc2FYUmxLSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYRnd1YzNablhGd3BMQ0IzYVdSMGFDQTlJSGRwWkhSb0xDQm9aV2xuYUhRZ1BXaGxhV2RvZENsY2JpTWdjR2xsS0dOdmRXNTBjeXdnYkdGaVpXeHpJRDBnYkdGaVpXeHpMQ0FnYldGcGJpQTlJSEJoYzNSbE1DaGNYRmRvZVhSbElGTkZJR052ZG1WeVlXZGxJRnhjYmx4Y0xDQjBiM1JoYkNrc0lHTnZiQ0E5SUdNb1hGeG5jbVY1WEZ3c0lGeGNkMmhwZEdWY1hDa3NYRzRqSUNBZ0lDQmpaWGdnUFNBeExDQmpaWGd1YldGcGJpQTlJREVwWEc0aklHUmxkaTV2Wm1Zb0tWeHVYRzVjYmx4dUl5TWpJRVI1YkdGdVhHNXVJRHd0SUd4bGJtZDBhQ2gxYm1seGRXVW9jM1ZpYW1WamRFaHBkSE1vWm1sdVpFOTJaWEpzWVhCektHRnVZMmh2Y2l3Z2NHVmhheTVFZVd4aGJpNVRSU2twS1NsY2JuUnZkR0ZzSUR3dElHeGxibWQwYUNod1pXRnJMa1I1YkdGdUxsTkZLVnh1WTI5MWJuUnpJRHd0SUdNb2Jpd2dkRzkwWVd3Z0xTQnVLVnh1YkdGaVpXeHpJRHd0SUhCaGMzUmxLR01vWEZ4amIzWmxjbVZrWEZ3c0lGeGNUazlVSUdOdmRtVnlaV1JjWENrc0lHTnZkVzUwY3lsY2JuQnBaU2hqYjNWdWRITXNJR3hoWW1Wc2N5QTlJR3hoWW1Wc2N5d2diV0ZwYmlBOUlIQmhjM1JsTUNoY1hFUjViR0Z1SUZORklHTnZkbVZ5WVdkbElGeGNibHhjTENCMGIzUmhiQ2tzSUdOdmJDQTlJR01vWEZ4bmNtVjVYRndzSUZ4Y2QyaHBkR1ZjWENrcFhHNWNibVpwYkdWT1lXMWxJRHd0SUdobGNtVW9abWxuUkdseUxDQmNYSEJwWlY5VFJWOU5kWEp3YUhsY1hDbGNibmRwWkhSb0lEd3RJSEJoYm1Wc1UybDZaU2cwS1NwdGJWUnZTVzVqYUZ4dWFHVnBaMmgwSUR3dElIQmhibVZzVTJsNlpTZzBLU3B0YlZSdlNXNWphRnh1SXlCemRtZHNhWFJsS0hCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWEZ3dWMzWm5YRndwTENCM2FXUjBhQ0E5SUhkcFpIUm9MQ0JvWldsbmFIUWdQV2hsYVdkb2RDbGNiaU1nY0dsbEtHTnZkVzUwY3l3Z2JHRmlaV3h6SUQwZ2JHRmlaV3h6TENCdFlXbHVJRDBnY0dGemRHVXdLRnhjVFhWeWNHaDVJRk5GSUdOdmRtVnlZV2RsSUZ4Y2JseGNMQ0IwYjNSaGJDa3NJR052YkNBOUlHTW9YRnhuY21WNVhGd3NJRnhjZDJocGRHVmNYQ2twWEc0aklGeHVJeUJrWlhZdWIyWm1LQ2xjYmx4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5XFxcbmxvb3AgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZS5iZWRwZVxcKSlcbmFuY2hvciA8LSBleHRyYWN0QW5jaG9yKGxvb3ApXG5cbiMjIyBXaHl0ZVxubiA8LSBsZW5ndGgodW5pcXVlKHN1YmplY3RIaXRzKGZpbmRPdmVybGFwcyhhbmNob3IsIHBlYWsuV2h5dGUuU0UpKSkpXG50b3RhbCA8LSBsZW5ndGgocGVhay5XaHl0ZS5TRSlcbmNvdW50cyA8LSBjKG4sIHRvdGFsIC0gbilcbmxhYmVscyA8LSBwYXN0ZShjKFxcY292ZXJlZFxcLCBcXE5PVCBjb3ZlcmVkXFwpLCBjb3VudHMpXG5waWUoY291bnRzLCBsYWJlbHMgPSBsYWJlbHMsICBtYWluID0gcGFzdGUwKFxcV2h5dGUgU0UgY292ZXJhZ2UgXFxuXFwsIHRvdGFsKSwgY29sID0gYyhcXGdyZXlcXCwgXFx3aGl0ZVxcKSlcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIFxccGllX1NFX1doeXRlXFwpXG53aWR0aCA8LSBwYW5lbFNpemUoNCkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoNCkqbW1Ub0luY2hcbiMgc3ZnbGl0ZShwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSwgd2lkdGggPSB3aWR0aCwgaGVpZ2h0ID1oZWlnaHQpXG4jIHBpZShjb3VudHMsIGxhYmVscyA9IGxhYmVscywgIG1haW4gPSBwYXN0ZTAoXFxXaHl0ZSBTRSBjb3ZlcmFnZSBcXG5cXCwgdG90YWwpLCBjb2wgPSBjKFxcZ3JleVxcLCBcXHdoaXRlXFwpLFxuIyAgICAgY2V4ID0gMSwgY2V4Lm1haW4gPSAxKVxuIyBkZXYub2ZmKClcblxuXG5cbiMjIyBEeWxhblxubiA8LSBsZW5ndGgodW5pcXVlKHN1YmplY3RIaXRzKGZpbmRPdmVybGFwcyhhbmNob3IsIHBlYWsuRHlsYW4uU0UpKSkpXG50b3RhbCA8LSBsZW5ndGgocGVhay5EeWxhbi5TRSlcbmNvdW50cyA8LSBjKG4sIHRvdGFsIC0gbilcbmxhYmVscyA8LSBwYXN0ZShjKFxcY292ZXJlZFxcLCBcXE5PVCBjb3ZlcmVkXFwpLCBjb3VudHMpXG5waWUoY291bnRzLCBsYWJlbHMgPSBsYWJlbHMsIG1haW4gPSBwYXN0ZTAoXFxEeWxhbiBTRSBjb3ZlcmFnZSBcXG5cXCwgdG90YWwpLCBjb2wgPSBjKFxcZ3JleVxcLCBcXHdoaXRlXFwpKVxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgXFxwaWVfU0VfTXVycGh5XFwpXG53aWR0aCA8LSBwYW5lbFNpemUoNCkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoNCkqbW1Ub0luY2hcbiMgc3ZnbGl0ZShwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSwgd2lkdGggPSB3aWR0aCwgaGVpZ2h0ID1oZWlnaHQpXG4jIHBpZShjb3VudHMsIGxhYmVscyA9IGxhYmVscywgbWFpbiA9IHBhc3RlMChcXE11cnBoeSBTRSBjb3ZlcmFnZSBcXG5cXCwgdG90YWwpLCBjb2wgPSBjKFxcZ3JleVxcLCBcXHdoaXRlXFwpKVxuIyBcbiMgZGV2Lm9mZigpXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxubG9vcCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlLmJlZHBlXFwpKVxuYW5jaG9yIDwtIGV4dHJhY3RBbmNob3IobG9vcClcblxuIyMjIFdoeXRlXG5uIDwtIGxlbmd0aCh1bmlxdWUoc3ViamVjdEhpdHMoZmluZE92ZXJsYXBzKGFuY2hvciwgcGVhay5XaHl0ZS5TRSkpKSlcbnRvdGFsIDwtIGxlbmd0aChwZWFrLldoeXRlLlNFKVxuY291bnRzIDwtIGMobiwgdG90YWwgLSBuKVxubGFiZWxzIDwtIHBhc3RlKGMoXFxjb3ZlcmVkXFwsIFxcTk9UIGNvdmVyZWRcXCksIGNvdW50cylcbnBpZShjb3VudHMsIGxhYmVscyA9IGxhYmVscywgIG1haW4gPSBwYXN0ZTAoXFxXaHl0ZSBTRSBjb3ZlcmFnZSBcXG5cXCwgdG90YWwpLCBjb2wgPSBjKFxcZ3JleVxcLCBcXHdoaXRlXFwpKVxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgXFxwaWVfU0VfV2h5dGVcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSg0KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSg0KSptbVRvSW5jaFxuIyBzdmdsaXRlKHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpLCB3aWR0aCA9IHdpZHRoLCBoZWlnaHQgPWhlaWdodClcbiMgcGllKGNvdW50cywgbGFiZWxzID0gbGFiZWxzLCAgbWFpbiA9IHBhc3RlMChcXFdoeXRlIFNFIGNvdmVyYWdlIFxcblxcLCB0b3RhbCksIGNvbCA9IGMoXFxncmV5XFwsIFxcd2hpdGVcXCksXG4jICAgICBjZXggPSAxLCBjZXgubWFpbiA9IDEpXG4jIGRldi5vZmYoKVxuXG5cblxuIyMjIER5bGFuXG5uIDwtIGxlbmd0aCh1bmlxdWUoc3ViamVjdEhpdHMoZmluZE92ZXJsYXBzKGFuY2hvciwgcGVhay5EeWxhbi5TRSkpKSlcbnRvdGFsIDwtIGxlbmd0aChwZWFrLkR5bGFuLlNFKVxuY291bnRzIDwtIGMobiwgdG90YWwgLSBuKVxubGFiZWxzIDwtIHBhc3RlKGMoXFxjb3ZlcmVkXFwsIFxcTk9UIGNvdmVyZWRcXCksIGNvdW50cylcbnBpZShjb3VudHMsIGxhYmVscyA9IGxhYmVscywgbWFpbiA9IHBhc3RlMChcXER5bGFuIFNFIGNvdmVyYWdlIFxcblxcLCB0b3RhbCksIGNvbCA9IGMoXFxncmV5XFwsIFxcd2hpdGVcXCkpXG5cbmZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBcXHBpZV9TRV9NdXJwaHlcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSg0KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSg0KSptbVRvSW5jaFxuIyBzdmdsaXRlKHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpLCB3aWR0aCA9IHdpZHRoLCBoZWlnaHQgPWhlaWdodClcbiMgcGllKGNvdW50cywgbGFiZWxzID0gbGFiZWxzLCBtYWluID0gcGFzdGUwKFxcTXVycGh5IFNFIGNvdmVyYWdlIFxcblxcLCB0b3RhbCksIGNvbCA9IGMoXFxncmV5XFwsIFxcd2hpdGVcXCkpXG4jIFxuIyBkZXYub2ZmKClcblxuYGBgXG5gYGAifQ== -->

```r
```r
name <- \chromo_cons_annoHierarchy\
loop <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\))
anchor <- extractAnchor(loop)

### Whyte
n <- length(unique(subjectHits(findOverlaps(anchor, peak.Whyte.SE))))
total <- length(peak.Whyte.SE)
counts <- c(n, total - n)
labels <- paste(c(\covered\, \NOT covered\), counts)
pie(counts, labels = labels,  main = paste0(\Whyte SE coverage \n\, total), col = c(\grey\, \white\))

fileName <- here(figDir, \pie_SE_Whyte\)
width <- panelSize(4)*mmToInch
height <- panelSize(4)*mmToInch
# svglite(paste0(fileName, \.svg\), width = width, height =height)
# pie(counts, labels = labels,  main = paste0(\Whyte SE coverage \n\, total), col = c(\grey\, \white\),
#     cex = 1, cex.main = 1)
# dev.off()



### Dylan
n <- length(unique(subjectHits(findOverlaps(anchor, peak.Dylan.SE))))
total <- length(peak.Dylan.SE)
counts <- c(n, total - n)
labels <- paste(c(\covered\, \NOT covered\), counts)
pie(counts, labels = labels, main = paste0(\Dylan SE coverage \n\, total), col = c(\grey\, \white\))

fileName <- here(figDir, \pie_SE_Murphy\)
width <- panelSize(4)*mmToInch
height <- panelSize(4)*mmToInch
# svglite(paste0(fileName, \.svg\), width = width, height =height)
# pie(counts, labels = labels, main = paste0(\Murphy SE coverage \n\, total), col = c(\grey\, \white\))
# 
# dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Peak density instead of intensity

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\nname <- \"chromo_cons_annoHierarchy\"\nloop <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe.bedpe\"))\n\ngetOverlapLoopNum <- function(loop, peak){\n  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))\n  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))\n  a <- queryHits(findOverlaps(anchor1, peak))\n  b <- queryHits(findOverlaps(anchor2, peak))\n  return(length(unique(c(a, b))))\n}\n\ngetSEOverlapFisher <- function(allLoop, subsetLoop, peak){\n  all.overlap <- getOverlapLoopNum(allLoop, peak)\n  all.notOverlap <- nrow(allLoop) - all.overlap\n  \n  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)\n  subset.notOverlap <- nrow(subsetLoop) - subset.overlap\n  \n  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,\n                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)\n  colnames(contingency_table) <- c(\"Overlapping\", \"Not_Overlapping\")\n  rownames(contingency_table) <- c(\"All loops\", \"Subset loops\")\n  \n  # Perform Fisher's Exact Test\n  fisher_test_result <- fisher.test(contingency_table)\n  return(fisher_test_result)\n}\n\n\n\nloop.up <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\"))\nloop.no <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\"))\nloop.upno <- bind_rows(loop.up, loop.no)\nloop.down <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\"))\n\n### Dylan\n# Seeding\ntemp <- getSEOverlapFisher(loop, loop.upno, peak.Dylan.SE)\nresult.tb <- tibble(loopType = \"UP/NO\",\n                    target = \"Dylan SE\",\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\n\n# temp <- getSEOverlapFisher(loop, loop.up, peak.Dylan.SE)\n# result.tb <- tibble(loopType = \"UP\",\n#                     target = \"Dylan SE\",\n#                     pvalue = temp$p.value,\n#                     oddsRatio = temp$estimate)\n# Add row\n# temp <- getSEOverlapFisher(loop, loop.no, peak.Dylan.SE)\n# result.tb <- result.tb %>% \n#   add_row(loopType = \"NO\",\n#           target = \"Dylan SE\",\n#           pvalue = temp$p.value,\n#           oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Dylan.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \"DOWN\",\n          target = \"Dylan SE\",\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n### Whyte\n# Seeding\n# temp <- getSEOverlapFisher(loop, loop.up, peak.Whyte.SE)\n# result.tb <- result.tb %>% \n#   add_row(loopType = \"UP\",\n#                     target = \"Whyte SE\",\n#                     pvalue = temp$p.value,\n#                     oddsRatio = temp$estimate)\n\n# Add row\ntemp <- getSEOverlapFisher(loop, loop.upno, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \"UP/NO\",\n          target = \"Whyte SE\",\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \"DOWN\",\n          target = \"Whyte SE\",\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\n# Visualization\nlibrary(circlize)\ndata <- result.tb\nheatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%\npivot_wider(names_from = loopType, values_from = oddsRatio) %>%\n  column_to_rownames(var = \"target\")\n\npvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%\n  pivot_wider(names_from = loopType, values_from = pvalue) %>%\n  column_to_rownames(var = \"target\")\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\"#4852A0\", \"white\", \"#CB333A\"))\n\np <- Heatmap(as.matrix(heatmap_data),\n        name = \"Odds Ratio\",\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \"n.s.\", sprintf(\"%.2e\", pval))\n          grid.text(label, x, y, gp = gpar(fontsize = fontSizeS, fontfamily = fontType))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        row_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),\n  column_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),\n        heatmap_legend_param = list(\n          at = c(0, 1, 2),\n          labels = c(\"0\", \"1\", \"2\"),\n          title_gp = gpar(fontfamily = fontType, fontsize = fontSizeS),\n          labels_gp = gpar(fontfamily = fontType, fontsize = fontSizeS)\n        )\n)\n\n# fileName <- here(figDir, \"heatmap_SE_enrichment\")\n# width <- panelSize(1.5)*mmToInch\n# height <- panelSize(0.7)*mmToInch\n# svglite(paste0(fileName, \".svg\"), width = width, height =height)\n# print(p)\n# dev.off()\n# png(paste0(fileName, \".png\"), width = width, height =height, res = 600, unit = \"in\")\n# print(p)\n# dev.off()\n\n#######################\n\ndata$loopType <- factor(data$loopType, levels = c(\"UP/NO\", \"DOWN\"))\ndata$target <- factor(data$target, levels = c(\"Whyte SE\", \"Dylan SE\"))\n\np <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\"#4852A0\", \"white\", \"#CB333A\"),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \"white\", high = \"#CB333A\",\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) +\n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \"heatmap_SE_enrichment_dotplot\")\nwidth <- panelSize(1.8)*mmToInch\nheight <- panelSize(1.1)*mmToInch\n# png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n# print(p)\n# dev.off()\nsvglite(paste0(fileName, \".svg\"),  height = height, width = width)\nprint(p)\ndev.off()\n\n```"} -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\nloop <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\))\n\ngetOverlapLoopNum <- function(loop, peak){\n  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))\n  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))\n  a <- queryHits(findOverlaps(anchor1, peak))\n  b <- queryHits(findOverlaps(anchor2, peak))\n  return(length(unique(c(a, b))))\n}\n\ngetSEOverlapFisher <- function(allLoop, subsetLoop, peak){\n  all.overlap <- getOverlapLoopNum(allLoop, peak)\n  all.notOverlap <- nrow(allLoop) - all.overlap\n  \n  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)\n  subset.notOverlap <- nrow(subsetLoop) - subset.overlap\n  \n  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,\n                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)\n  colnames(contingency_table) <- c(\\Overlapping\\, \\Not_Overlapping\\)\n  rownames(contingency_table) <- c(\\All loops\\, \\Subset loops\\)\n  \n  # Perform Fisher's Exact Test\n  fisher_test_result <- fisher.test(contingency_table)\n  return(fisher_test_result)\n}\n\n\n\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nloop.upno <- bind_rows(loop.up, loop.no)\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\n\n### Dylan\n# Seeding\ntemp <- getSEOverlapFisher(loop, loop.upno, peak.Dylan.SE)\nresult.tb <- tibble(loopType = \\UP/NO\\,\n                    target = \\Dylan SE\\,\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\n\n# temp <- getSEOverlapFisher(loop, loop.up, peak.Dylan.SE)\n# result.tb <- tibble(loopType = \\UP\\,\n#                     target = \\Dylan SE\\,\n#                     pvalue = temp$p.value,\n#                     oddsRatio = temp$estimate)\n# Add row\n# temp <- getSEOverlapFisher(loop, loop.no, peak.Dylan.SE)\n# result.tb <- result.tb %>% \n#   add_row(loopType = \\NO\\,\n#           target = \\Dylan SE\\,\n#           pvalue = temp$p.value,\n#           oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Dylan.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target = \\Dylan SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n### Whyte\n# Seeding\n# temp <- getSEOverlapFisher(loop, loop.up, peak.Whyte.SE)\n# result.tb <- result.tb %>% \n#   add_row(loopType = \\UP\\,\n#                     target = \\Whyte SE\\,\n#                     pvalue = temp$p.value,\n#                     oddsRatio = temp$estimate)\n\n# Add row\ntemp <- getSEOverlapFisher(loop, loop.upno, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\UP/NO\\,\n          target = \\Whyte SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target = \\Whyte SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\n# Visualization\nlibrary(circlize)\ndata <- result.tb\nheatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%\npivot_wider(names_from = loopType, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%\n  pivot_wider(names_from = loopType, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\#4852A0\\, \\white\\, \\#CB333A\\))\n\np <- Heatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = fontSizeS, fontfamily = fontType))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        row_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),\n  column_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),\n        heatmap_legend_param = list(\n          at = c(0, 1, 2),\n          labels = c(\\0\\, \\1\\, \\2\\),\n          title_gp = gpar(fontfamily = fontType, fontsize = fontSizeS),\n          labels_gp = gpar(fontfamily = fontType, fontsize = fontSizeS)\n        )\n)\n\n# fileName <- here(figDir, \\heatmap_SE_enrichment\\)\n# width <- panelSize(1.5)*mmToInch\n# height <- panelSize(0.7)*mmToInch\n# svglite(paste0(fileName, \\.svg\\), width = width, height =height)\n# print(p)\n# dev.off()\n# png(paste0(fileName, \\.png\\), width = width, height =height, res = 600, unit = \\in\\)\n# print(p)\n# dev.off()\n\n#######################\n\ndata$loopType <- factor(data$loopType, levels = c(\\UP/NO\\, \\DOWN\\))\ndata$target <- factor(data$target, levels = c(\\Whyte SE\\, \\Dylan SE\\))\n\np <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\\#4852A0\\, \\white\\, \\#CB333A\\),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \\white\\, high = \\#CB333A\\,\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) +\n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\heatmap_SE_enrichment_dotplot\\)\nwidth <- panelSize(1.8)*mmToInch\nheight <- panelSize(1.1)*mmToInch\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\nsvglite(paste0(fileName, \\.svg\\),  height = height, width = width)\nprint(p)\ndev.off()\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\
loop <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\))

getOverlapLoopNum <- function(loop, peak){
  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))
  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))
  a <- queryHits(findOverlaps(anchor1, peak))
  b <- queryHits(findOverlaps(anchor2, peak))
  return(length(unique(c(a, b))))
}

getSEOverlapFisher <- function(allLoop, subsetLoop, peak){
  all.overlap <- getOverlapLoopNum(allLoop, peak)
  all.notOverlap <- nrow(allLoop) - all.overlap
  
  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)
  subset.notOverlap <- nrow(subsetLoop) - subset.overlap
  
  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,
                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)
  colnames(contingency_table) <- c(\Overlapping\, \Not_Overlapping\)
  rownames(contingency_table) <- c(\All loops\, \Subset loops\)
  
  # Perform Fisher's Exact Test
  fisher_test_result <- fisher.test(contingency_table)
  return(fisher_test_result)
}



loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
loop.upno <- bind_rows(loop.up, loop.no)
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))

### Dylan
# Seeding
temp <- getSEOverlapFisher(loop, loop.upno, peak.Dylan.SE)
result.tb <- tibble(loopType = \UP/NO\,
                    target = \Dylan SE\,
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)

# temp <- getSEOverlapFisher(loop, loop.up, peak.Dylan.SE)
# result.tb <- tibble(loopType = \UP\,
#                     target = \Dylan SE\,
#                     pvalue = temp$p.value,
#                     oddsRatio = temp$estimate)
# Add row
# temp <- getSEOverlapFisher(loop, loop.no, peak.Dylan.SE)
# result.tb <- result.tb %>% 
#   add_row(loopType = \NO\,
#           target = \Dylan SE\,
#           pvalue = temp$p.value,
#           oddsRatio = temp$estimate)

temp <- getSEOverlapFisher(loop, loop.down, peak.Dylan.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \DOWN\,
          target = \Dylan SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

### Whyte
# Seeding
# temp <- getSEOverlapFisher(loop, loop.up, peak.Whyte.SE)
# result.tb <- result.tb %>% 
#   add_row(loopType = \UP\,
#                     target = \Whyte SE\,
#                     pvalue = temp$p.value,
#                     oddsRatio = temp$estimate)

# Add row
temp <- getSEOverlapFisher(loop, loop.upno, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \UP/NO\,
          target = \Whyte SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

temp <- getSEOverlapFisher(loop, loop.down, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \DOWN\,
          target = \Whyte SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)


# Visualization
library(circlize)
data <- result.tb
heatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%
pivot_wider(names_from = loopType, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%
  pivot_wider(names_from = loopType, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 2), 
                      c(\#4852A0\, \white\, \#CB333A\))

p <- Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = fontSizeS, fontfamily = fontType))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        row_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),
  column_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),
        heatmap_legend_param = list(
          at = c(0, 1, 2),
          labels = c(\0\, \1\, \2\),
          title_gp = gpar(fontfamily = fontType, fontsize = fontSizeS),
          labels_gp = gpar(fontfamily = fontType, fontsize = fontSizeS)
        )
)

# fileName <- here(figDir, \heatmap_SE_enrichment\)
# width <- panelSize(1.5)*mmToInch
# height <- panelSize(0.7)*mmToInch
# svglite(paste0(fileName, \.svg\), width = width, height =height)
# print(p)
# dev.off()
# png(paste0(fileName, \.png\), width = width, height =height, res = 600, unit = \in\)
# print(p)
# dev.off()

#######################

data$loopType <- factor(data$loopType, levels = c(\UP/NO\, \DOWN\))
data$target <- factor(data$target, levels = c(\Whyte SE\, \Dylan SE\))

p <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
  scale_fill_gradientn(colors = c(\#4852A0\, \white\, \#CB333A\),  # Define gradient colors
                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), 
                      #low = \white\, high = \#CB333A\,
                      #                  limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) +
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, \heatmap_SE_enrichment_dotplot\)
width <- panelSize(1.8)*mmToInch
height <- panelSize(1.1)*mmToInch
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
svglite(paste0(fileName, \.svg\),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\nloop <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\))\n\ngetOverlapLoopNum <- function(loop, peak){\n  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))\n  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))\n  a <- queryHits(findOverlaps(anchor1, peak))\n  b <- queryHits(findOverlaps(anchor2, peak))\n  return(length(unique(c(a, b))))\n}\n\ngetSEOverlapFisher <- function(allLoop, subsetLoop, peak){\n  all.overlap <- getOverlapLoopNum(allLoop, peak)\n  all.notOverlap <- nrow(allLoop) - all.overlap\n  \n  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)\n  subset.notOverlap <- nrow(subsetLoop) - subset.overlap\n  \n  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,\n                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)\n  colnames(contingency_table) <- c(\\Overlapping\\, \\Not_Overlapping\\)\n  rownames(contingency_table) <- c(\\All loops\\, \\Subset loops\\)\n  \n  # Perform Fisher's Exact Test\n  fisher_test_result <- fisher.test(contingency_table)\n  return(fisher_test_result)\n}\n\n\n\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nloop.upno <- bind_rows(loop.up, loop.no)\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\n\n### Dylan\n# Seeding\ntemp <- getSEOverlapFisher(loop, loop.upno, peak.Dylan.SE)\nresult.tb <- tibble(loopType = \\UP/NO\\,\n                    target = \\Dylan SE\\,\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\n\n# temp <- getSEOverlapFisher(loop, loop.up, peak.Dylan.SE)\n# result.tb <- tibble(loopType = \\UP\\,\n#                     target = \\Dylan SE\\,\n#                     pvalue = temp$p.value,\n#                     oddsRatio = temp$estimate)\n# Add row\n# temp <- getSEOverlapFisher(loop, loop.no, peak.Dylan.SE)\n# result.tb <- result.tb %>% \n#   add_row(loopType = \\NO\\,\n#           target = \\Dylan SE\\,\n#           pvalue = temp$p.value,\n#           oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Dylan.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target = \\Dylan SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n### Whyte\n# Seeding\n# temp <- getSEOverlapFisher(loop, loop.up, peak.Whyte.SE)\n# result.tb <- result.tb %>% \n#   add_row(loopType = \\UP\\,\n#                     target = \\Whyte SE\\,\n#                     pvalue = temp$p.value,\n#                     oddsRatio = temp$estimate)\n\n# Add row\ntemp <- getSEOverlapFisher(loop, loop.upno, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\UP/NO\\,\n          target = \\Whyte SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target = \\Whyte SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\n# Visualization\nlibrary(circlize)\ndata <- result.tb\nheatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%\npivot_wider(names_from = loopType, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%\n  pivot_wider(names_from = loopType, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\#4852A0\\, \\white\\, \\#CB333A\\))\n\np <- Heatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = fontSizeS, fontfamily = fontType))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        row_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),\n  column_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),\n        heatmap_legend_param = list(\n          at = c(0, 1, 2),\n          labels = c(\\0\\, \\1\\, \\2\\),\n          title_gp = gpar(fontfamily = fontType, fontsize = fontSizeS),\n          labels_gp = gpar(fontfamily = fontType, fontsize = fontSizeS)\n        )\n)\n\n# fileName <- here(figDir, \\heatmap_SE_enrichment\\)\n# width <- panelSize(1.5)*mmToInch\n# height <- panelSize(0.7)*mmToInch\n# svglite(paste0(fileName, \\.svg\\), width = width, height =height)\n# print(p)\n# dev.off()\n# png(paste0(fileName, \\.png\\), width = width, height =height, res = 600, unit = \\in\\)\n# print(p)\n# dev.off()\n\n#######################\n\ndata$loopType <- factor(data$loopType, levels = c(\\UP/NO\\, \\DOWN\\))\ndata$target <- factor(data$target, levels = c(\\Whyte SE\\, \\Dylan SE\\))\n\np <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\\#4852A0\\, \\white\\, \\#CB333A\\),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \\white\\, high = \\#CB333A\\,\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) +\n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\heatmap_SE_enrichment_dotplot\\)\nwidth <- panelSize(1.8)*mmToInch\nheight <- panelSize(1.1)*mmToInch\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\nsvglite(paste0(fileName, \\.svg\\),  height = height, width = width)\nprint(p)\ndev.off()\n\n```\n```"} -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\nloop <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\))\n\ngetOverlapLoopNum <- function(loop, peak){\n  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))\n  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))\n  a <- queryHits(findOverlaps(anchor1, peak))\n  b <- queryHits(findOverlaps(anchor2, peak))\n  return(length(unique(c(a, b))))\n}\n\ngetSEOverlapFisher <- function(allLoop, subsetLoop, peak){\n  all.overlap <- getOverlapLoopNum(allLoop, peak)\n  all.notOverlap <- nrow(allLoop) - all.overlap\n  \n  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)\n  subset.notOverlap <- nrow(subsetLoop) - subset.overlap\n  \n  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,\n                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)\n  colnames(contingency_table) <- c(\\Overlapping\\, \\Not_Overlapping\\)\n  rownames(contingency_table) <- c(\\All loops\\, \\Subset loops\\)\n  \n  # Perform Fisher's Exact Test\n  fisher_test_result <- fisher.test(contingency_table)\n  return(fisher_test_result)\n}\n\n\n\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nloop.upno <- bind_rows(loop.up, loop.no)\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\n\n### Dylan\n# Seeding\ntemp <- getSEOverlapFisher(loop, loop.upno, peak.Dylan.SE)\nresult.tb <- tibble(loopType = \\UP/NO\\,\n                    target = \\Dylan SE\\,\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\n\n# temp <- getSEOverlapFisher(loop, loop.up, peak.Dylan.SE)\n# result.tb <- tibble(loopType = \\UP\\,\n#                     target = \\Dylan SE\\,\n#                     pvalue = temp$p.value,\n#                     oddsRatio = temp$estimate)\n# Add row\n# temp <- getSEOverlapFisher(loop, loop.no, peak.Dylan.SE)\n# result.tb <- result.tb %>% \n#   add_row(loopType = \\NO\\,\n#           target = \\Dylan SE\\,\n#           pvalue = temp$p.value,\n#           oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Dylan.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target = \\Dylan SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n### Whyte\n# Seeding\n# temp <- getSEOverlapFisher(loop, loop.up, peak.Whyte.SE)\n# result.tb <- result.tb %>% \n#   add_row(loopType = \\UP\\,\n#                     target = \\Whyte SE\\,\n#                     pvalue = temp$p.value,\n#                     oddsRatio = temp$estimate)\n\n# Add row\ntemp <- getSEOverlapFisher(loop, loop.upno, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\UP/NO\\,\n          target = \\Whyte SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target = \\Whyte SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\n# Visualization\nlibrary(circlize)\ndata <- result.tb\nheatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%\npivot_wider(names_from = loopType, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%\n  pivot_wider(names_from = loopType, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\#4852A0\\, \\white\\, \\#CB333A\\))\n\np <- Heatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = fontSizeS, fontfamily = fontType))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        row_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),\n  column_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),\n        heatmap_legend_param = list(\n          at = c(0, 1, 2),\n          labels = c(\\0\\, \\1\\, \\2\\),\n          title_gp = gpar(fontfamily = fontType, fontsize = fontSizeS),\n          labels_gp = gpar(fontfamily = fontType, fontsize = fontSizeS)\n        )\n)\n\n# fileName <- here(figDir, \\heatmap_SE_enrichment\\)\n# width <- panelSize(1.5)*mmToInch\n# height <- panelSize(0.7)*mmToInch\n# svglite(paste0(fileName, \\.svg\\), width = width, height =height)\n# print(p)\n# dev.off()\n# png(paste0(fileName, \\.png\\), width = width, height =height, res = 600, unit = \\in\\)\n# print(p)\n# dev.off()\n\n#######################\n\ndata$loopType <- factor(data$loopType, levels = c(\\UP/NO\\, \\DOWN\\))\ndata$target <- factor(data$target, levels = c(\\Whyte SE\\, \\Dylan SE\\))\n\np <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\\#4852A0\\, \\white\\, \\#CB333A\\),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \\white\\, high = \\#CB333A\\,\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) +\n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\heatmap_SE_enrichment_dotplot\\)\nwidth <- panelSize(1.8)*mmToInch\nheight <- panelSize(1.1)*mmToInch\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\nsvglite(paste0(fileName, \\.svg\\),  height = height, width = width)\nprint(p)\ndev.off()\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\nloop <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\))\n\ngetOverlapLoopNum <- function(loop, peak){\n  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))\n  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))\n  a <- queryHits(findOverlaps(anchor1, peak))\n  b <- queryHits(findOverlaps(anchor2, peak))\n  return(length(unique(c(a, b))))\n}\n\ngetSEOverlapFisher <- function(allLoop, subsetLoop, peak){\n  all.overlap <- getOverlapLoopNum(allLoop, peak)\n  all.notOverlap <- nrow(allLoop) - all.overlap\n  \n  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)\n  subset.notOverlap <- nrow(subsetLoop) - subset.overlap\n  \n  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,\n                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)\n  colnames(contingency_table) <- c(\\Overlapping\\, \\Not_Overlapping\\)\n  rownames(contingency_table) <- c(\\All loops\\, \\Subset loops\\)\n  \n  # Perform Fisher's Exact Test\n  fisher_test_result <- fisher.test(contingency_table)\n  return(fisher_test_result)\n}\n\n\n\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nloop.upno <- bind_rows(loop.up, loop.no)\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\n\n### Dylan\n# Seeding\ntemp <- getSEOverlapFisher(loop, loop.upno, peak.Dylan.SE)\nresult.tb <- tibble(loopType = \\UP/NO\\,\n                    target = \\Dylan SE\\,\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\n\n# temp <- getSEOverlapFisher(loop, loop.up, peak.Dylan.SE)\n# result.tb <- tibble(loopType = \\UP\\,\n#                     target = \\Dylan SE\\,\n#                     pvalue = temp$p.value,\n#                     oddsRatio = temp$estimate)\n# Add row\n# temp <- getSEOverlapFisher(loop, loop.no, peak.Dylan.SE)\n# result.tb <- result.tb %>% \n#   add_row(loopType = \\NO\\,\n#           target = \\Dylan SE\\,\n#           pvalue = temp$p.value,\n#           oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Dylan.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target = \\Dylan SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n### Whyte\n# Seeding\n# temp <- getSEOverlapFisher(loop, loop.up, peak.Whyte.SE)\n# result.tb <- result.tb %>% \n#   add_row(loopType = \\UP\\,\n#                     target = \\Whyte SE\\,\n#                     pvalue = temp$p.value,\n#                     oddsRatio = temp$estimate)\n\n# Add row\ntemp <- getSEOverlapFisher(loop, loop.upno, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\UP/NO\\,\n          target = \\Whyte SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target = \\Whyte SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\n# Visualization\nlibrary(circlize)\ndata <- result.tb\nheatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%\npivot_wider(names_from = loopType, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%\n  pivot_wider(names_from = loopType, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 2), \n                      c(\\#4852A0\\, \\white\\, \\#CB333A\\))\n\np <- Heatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = fontSizeS, fontfamily = fontType))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        row_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),\n  column_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),\n        heatmap_legend_param = list(\n          at = c(0, 1, 2),\n          labels = c(\\0\\, \\1\\, \\2\\),\n          title_gp = gpar(fontfamily = fontType, fontsize = fontSizeS),\n          labels_gp = gpar(fontfamily = fontType, fontsize = fontSizeS)\n        )\n)\n\n# fileName <- here(figDir, \\heatmap_SE_enrichment\\)\n# width <- panelSize(1.5)*mmToInch\n# height <- panelSize(0.7)*mmToInch\n# svglite(paste0(fileName, \\.svg\\), width = width, height =height)\n# print(p)\n# dev.off()\n# png(paste0(fileName, \\.png\\), width = width, height =height, res = 600, unit = \\in\\)\n# print(p)\n# dev.off()\n\n#######################\n\ndata$loopType <- factor(data$loopType, levels = c(\\UP/NO\\, \\DOWN\\))\ndata$target <- factor(data$target, levels = c(\\Whyte SE\\, \\Dylan SE\\))\n\np <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\\#4852A0\\, \\white\\, \\#CB333A\\),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \\white\\, high = \\#CB333A\\,\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) +\n  labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\nfileName <- here(figDir, \\heatmap_SE_enrichment_dotplot\\)\nwidth <- panelSize(1.8)*mmToInch\nheight <- panelSize(1.1)*mmToInch\n# png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# print(p)\n# dev.off()\nsvglite(paste0(fileName, \\.svg\\),  height = height, width = width)\nprint(p)\ndev.off()\n\n```\n```"} -->

```r
```r
name <- \chromo_cons_annoHierarchy\
loop <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\))

getOverlapLoopNum <- function(loop, peak){
  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))
  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))
  a <- queryHits(findOverlaps(anchor1, peak))
  b <- queryHits(findOverlaps(anchor2, peak))
  return(length(unique(c(a, b))))
}

getSEOverlapFisher <- function(allLoop, subsetLoop, peak){
  all.overlap <- getOverlapLoopNum(allLoop, peak)
  all.notOverlap <- nrow(allLoop) - all.overlap
  
  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)
  subset.notOverlap <- nrow(subsetLoop) - subset.overlap
  
  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,
                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)
  colnames(contingency_table) <- c(\Overlapping\, \Not_Overlapping\)
  rownames(contingency_table) <- c(\All loops\, \Subset loops\)
  
  # Perform Fisher's Exact Test
  fisher_test_result <- fisher.test(contingency_table)
  return(fisher_test_result)
}



loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
loop.upno <- bind_rows(loop.up, loop.no)
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))

### Dylan
# Seeding
temp <- getSEOverlapFisher(loop, loop.upno, peak.Dylan.SE)
result.tb <- tibble(loopType = \UP/NO\,
                    target = \Dylan SE\,
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)

# temp <- getSEOverlapFisher(loop, loop.up, peak.Dylan.SE)
# result.tb <- tibble(loopType = \UP\,
#                     target = \Dylan SE\,
#                     pvalue = temp$p.value,
#                     oddsRatio = temp$estimate)
# Add row
# temp <- getSEOverlapFisher(loop, loop.no, peak.Dylan.SE)
# result.tb <- result.tb %>% 
#   add_row(loopType = \NO\,
#           target = \Dylan SE\,
#           pvalue = temp$p.value,
#           oddsRatio = temp$estimate)

temp <- getSEOverlapFisher(loop, loop.down, peak.Dylan.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \DOWN\,
          target = \Dylan SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

### Whyte
# Seeding
# temp <- getSEOverlapFisher(loop, loop.up, peak.Whyte.SE)
# result.tb <- result.tb %>% 
#   add_row(loopType = \UP\,
#                     target = \Whyte SE\,
#                     pvalue = temp$p.value,
#                     oddsRatio = temp$estimate)

# Add row
temp <- getSEOverlapFisher(loop, loop.upno, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \UP/NO\,
          target = \Whyte SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

temp <- getSEOverlapFisher(loop, loop.down, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \DOWN\,
          target = \Whyte SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)


# Visualization
library(circlize)
data <- result.tb
heatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%
pivot_wider(names_from = loopType, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%
  pivot_wider(names_from = loopType, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 2), 
                      c(\#4852A0\, \white\, \#CB333A\))

p <- Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = fontSizeS, fontfamily = fontType))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        row_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),
  column_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),
        heatmap_legend_param = list(
          at = c(0, 1, 2),
          labels = c(\0\, \1\, \2\),
          title_gp = gpar(fontfamily = fontType, fontsize = fontSizeS),
          labels_gp = gpar(fontfamily = fontType, fontsize = fontSizeS)
        )
)

# fileName <- here(figDir, \heatmap_SE_enrichment\)
# width <- panelSize(1.5)*mmToInch
# height <- panelSize(0.7)*mmToInch
# svglite(paste0(fileName, \.svg\), width = width, height =height)
# print(p)
# dev.off()
# png(paste0(fileName, \.png\), width = width, height =height, res = 600, unit = \in\)
# print(p)
# dev.off()

#######################

data$loopType <- factor(data$loopType, levels = c(\UP/NO\, \DOWN\))
data$target <- factor(data$target, levels = c(\Whyte SE\, \Dylan SE\))

p <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
  scale_fill_gradientn(colors = c(\#4852A0\, \white\, \#CB333A\),  # Define gradient colors
                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), 
                      #low = \white\, high = \#CB333A\,
                      #                  limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) +
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, \heatmap_SE_enrichment_dotplot\)
width <- panelSize(1.8)*mmToInch
height <- panelSize(1.1)*mmToInch
# png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# print(p)
# dev.off()
svglite(paste0(fileName, \.svg\),  height = height, width = width)
print(p)
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


## [2.27] Overlap with SE?
#### Q1. How many SEs are covered with Micro-C loops?

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxubG9vcCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlLmJlZHBlXCIpKVxuXG5nZXRPdmVybGFwTG9vcE51bSA8LSBmdW5jdGlvbihsb29wLCBwZWFrKXtcbiAgYW5jaG9yMSA8LSBHUmFuZ2VzKHNlcW5hbWVzID0gbG9vcCRWMSwgcmFuZ2VzID0gSVJhbmdlcyhzdGFydCA9IGxvb3AkVjIsIGVuZCA9IGxvb3AkVjMpKVxuICBhbmNob3IyIDwtIEdSYW5nZXMoc2VxbmFtZXMgPSBsb29wJFY0LCByYW5nZXMgPSBJUmFuZ2VzKHN0YXJ0ID0gbG9vcCRWNSwgZW5kID0gbG9vcCRWNikpXG4gIGEgPC0gcXVlcnlIaXRzKGZpbmRPdmVybGFwcyhhbmNob3IxLCBwZWFrKSlcbiAgYiA8LSBxdWVyeUhpdHMoZmluZE92ZXJsYXBzKGFuY2hvcjIsIHBlYWspKVxuICByZXR1cm4obGVuZ3RoKHVuaXF1ZShjKGEsIGIpKSkpXG59XG5cbmdldFNFT3ZlcmxhcEZpc2hlciA8LSBmdW5jdGlvbihhbGxMb29wLCBzdWJzZXRMb29wLCBwZWFrKXtcbiAgYWxsLm92ZXJsYXAgPC0gZ2V0T3ZlcmxhcExvb3BOdW0oYWxsTG9vcCwgcGVhaylcbiAgYWxsLm5vdE92ZXJsYXAgPC0gbnJvdyhhbGxMb29wKSAtIGFsbC5vdmVybGFwXG4gIFxuICBzdWJzZXQub3ZlcmxhcCA8LSBnZXRPdmVybGFwTG9vcE51bShzdWJzZXRMb29wLCBwZWFrKVxuICBzdWJzZXQubm90T3ZlcmxhcCA8LSBucm93KHN1YnNldExvb3ApIC0gc3Vic2V0Lm92ZXJsYXBcbiAgXG4gIGNvbnRpbmdlbmN5X3RhYmxlIDwtIG1hdHJpeChjKHN1YnNldC5vdmVybGFwLCBzdWJzZXQubm90T3ZlcmxhcCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWxsLm92ZXJsYXAsIGFsbC5ub3RPdmVybGFwKSwgbnJvdyA9IDIsIGJ5cm93ID0gVFJVRSlcbiAgY29sbmFtZXMoY29udGluZ2VuY3lfdGFibGUpIDwtIGMoXCJPdmVybGFwcGluZ1wiLCBcIk5vdF9PdmVybGFwcGluZ1wiKVxuICByb3duYW1lcyhjb250aW5nZW5jeV90YWJsZSkgPC0gYyhcIkFsbCBsb29wc1wiLCBcIlN1YnNldCBsb29wc1wiKVxuICBcbiAgIyBQZXJmb3JtIEZpc2hlcidzIEV4YWN0IFRlc3RcbiAgZmlzaGVyX3Rlc3RfcmVzdWx0IDwtIGZpc2hlci50ZXN0KGNvbnRpbmdlbmN5X3RhYmxlKVxuICByZXR1cm4oZmlzaGVyX3Rlc3RfcmVzdWx0KVxufVxuXG5cblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVwiKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX05PX2RpZmYwLjIuYmVkcGVcIikpXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVwiKSlcblxuIyMjIER5bGFuXG4jIFNlZWRpbmdcbnRlbXAgPC0gZ2V0U0VPdmVybGFwRmlzaGVyKGxvb3AsIGxvb3AudXAsIHBlYWsuRHlsYW4uU0UpXG5yZXN1bHQudGIgPC0gdGliYmxlKGxvb3BUeXBlID0gXCJVUFwiLFxuICAgICAgICAgICAgICAgICAgICB0YXJnZXQgPSBcIkR5bGFuIFNFXCIsXG4gICAgICAgICAgICAgICAgICAgIHB2YWx1ZSA9IHRlbXAkcC52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgb2Rkc1JhdGlvID0gdGVtcCRlc3RpbWF0ZSlcbiMgQWRkIHJvd1xudGVtcCA8LSBnZXRTRU92ZXJsYXBGaXNoZXIobG9vcCwgbG9vcC5ubywgcGVhay5EeWxhbi5TRSlcbnJlc3VsdC50YiA8LSByZXN1bHQudGIgJT4lIFxuICBhZGRfcm93KGxvb3BUeXBlID0gXCJOT1wiLFxuICAgICAgICAgIHRhcmdldCA9IFwiRHlsYW4gU0VcIixcbiAgICAgICAgICBwdmFsdWUgPSB0ZW1wJHAudmFsdWUsXG4gICAgICAgICAgb2Rkc1JhdGlvID0gdGVtcCRlc3RpbWF0ZSlcblxudGVtcCA8LSBnZXRTRU92ZXJsYXBGaXNoZXIobG9vcCwgbG9vcC5kb3duLCBwZWFrLkR5bGFuLlNFKVxucmVzdWx0LnRiIDwtIHJlc3VsdC50YiAlPiUgXG4gIGFkZF9yb3cobG9vcFR5cGUgPSBcIkRPV05cIixcbiAgICAgICAgICB0YXJnZXQgPSBcIkR5bGFuIFNFXCIsXG4gICAgICAgICAgcHZhbHVlID0gdGVtcCRwLnZhbHVlLFxuICAgICAgICAgIG9kZHNSYXRpbyA9IHRlbXAkZXN0aW1hdGUpXG5cbiMjIyBXaHl0ZVxuIyBTZWVkaW5nXG50ZW1wIDwtIGdldFNFT3ZlcmxhcEZpc2hlcihsb29wLCBsb29wLnVwLCBwZWFrLldoeXRlLlNFKVxucmVzdWx0LnRiIDwtIHJlc3VsdC50YiAlPiUgXG4gIGFkZF9yb3cobG9vcFR5cGUgPSBcIlVQXCIsXG4gICAgICAgICAgICAgICAgICAgIHRhcmdldCA9IFwiV2h5dGUgU0VcIixcbiAgICAgICAgICAgICAgICAgICAgcHZhbHVlID0gdGVtcCRwLnZhbHVlLFxuICAgICAgICAgICAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuIyBBZGQgcm93XG50ZW1wIDwtIGdldFNFT3ZlcmxhcEZpc2hlcihsb29wLCBsb29wLm5vLCBwZWFrLldoeXRlLlNFKVxucmVzdWx0LnRiIDwtIHJlc3VsdC50YiAlPiUgXG4gIGFkZF9yb3cobG9vcFR5cGUgPSBcIk5PXCIsXG4gICAgICAgICAgdGFyZ2V0ID0gXCJXaHl0ZSBTRVwiLFxuICAgICAgICAgIHB2YWx1ZSA9IHRlbXAkcC52YWx1ZSxcbiAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuXG50ZW1wIDwtIGdldFNFT3ZlcmxhcEZpc2hlcihsb29wLCBsb29wLmRvd24sIHBlYWsuV2h5dGUuU0UpXG5yZXN1bHQudGIgPC0gcmVzdWx0LnRiICU+JSBcbiAgYWRkX3Jvdyhsb29wVHlwZSA9IFwiRE9XTlwiLFxuICAgICAgICAgIHRhcmdldCA9IFwiV2h5dGUgU0VcIixcbiAgICAgICAgICBwdmFsdWUgPSB0ZW1wJHAudmFsdWUsXG4gICAgICAgICAgb2Rkc1JhdGlvID0gdGVtcCRlc3RpbWF0ZSlcblxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5kYXRhIDwtIHJlc3VsdC50YlxuaGVhdG1hcF9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBsb29wVHlwZSwgb2Rkc1JhdGlvKSAlPiVcbnBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBsb29wVHlwZSwgdmFsdWVzX2Zyb20gPSBvZGRzUmF0aW8pICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXCJ0YXJnZXRcIilcblxucHZhbHVlX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGxvb3BUeXBlLCBwdmFsdWUpICU+JVxuICBwaXZvdF93aWRlcihuYW1lc19mcm9tID0gbG9vcFR5cGUsIHZhbHVlc19mcm9tID0gcHZhbHVlKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFwidGFyZ2V0XCIpXG5cbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEsIDUpLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFwiYmx1ZVwiLCBcIndoaXRlXCIsIFwicmVkXCIpKVxuXG5IZWF0bWFwKGFzLm1hdHJpeChoZWF0bWFwX2RhdGEpLFxuICAgICAgICBuYW1lID0gXCJPZGRzIFJhdGlvXCIsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4sXG4gICAgICAgICMgQWRkIGFubm90YXRpb24gZm9yIHAtdmFsdWVzXG4gICAgICAgIGNlbGxfZnVuID0gZnVuY3Rpb24oaiwgaSwgeCwgeSwgd2lkdGgsIGhlaWdodCwgZmlsbCkge1xuICAgICAgICAgIHB2YWwgPC0gcHZhbHVlX2RhdGFbaSwgal1cbiAgICAgICAgICBsYWJlbCA8LSBpZmVsc2UocHZhbCA+IDAuMDUsIFwibi5zLlwiLCBzcHJpbnRmKFwiJS4yZVwiLCBwdmFsKSlcbiAgICAgICAgICBncmlkLnRleHQobGFiZWwsIHgsIHksIGdwID0gZ3Bhcihmb250c2l6ZSA9IDEwKSlcbiAgICAgICAgfSxcbiAgICAgICAgIyBDdXN0b21pemUgdGhlIGhlYXRtYXAgbGF5b3V0XG4gICAgICAgIGNsdXN0ZXJfcm93cyA9IFRSVUUsXG4gICAgICAgIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgICAgICAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsXG4gICAgICAgIGNvbHVtbl90aXRsZSA9IFwiSW50ZXJlc3RcIixcbiAgICAgICAgcm93X3RpdGxlID0gXCJUYXJnZXRcIixcbiAgICAgICAgaGVhdG1hcF9sZWdlbmRfcGFyYW0gPSBsaXN0KGF0ID0gYygwLCAxLCAyLCAzLCA0LCA1KSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsYWJlbHMgPSBjKFwiMFwiLCBcIjFcIiwgXCIyXCIsIFwiM1wiLCBcIjRcIiwgXCI1XCIpKSlcblxuXG5cbmBgYCJ9 -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\nloop <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\))\n\ngetOverlapLoopNum <- function(loop, peak){\n  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))\n  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))\n  a <- queryHits(findOverlaps(anchor1, peak))\n  b <- queryHits(findOverlaps(anchor2, peak))\n  return(length(unique(c(a, b))))\n}\n\ngetSEOverlapFisher <- function(allLoop, subsetLoop, peak){\n  all.overlap <- getOverlapLoopNum(allLoop, peak)\n  all.notOverlap <- nrow(allLoop) - all.overlap\n  \n  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)\n  subset.notOverlap <- nrow(subsetLoop) - subset.overlap\n  \n  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,\n                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)\n  colnames(contingency_table) <- c(\\Overlapping\\, \\Not_Overlapping\\)\n  rownames(contingency_table) <- c(\\All loops\\, \\Subset loops\\)\n  \n  # Perform Fisher's Exact Test\n  fisher_test_result <- fisher.test(contingency_table)\n  return(fisher_test_result)\n}\n\n\n\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\\))\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\\))\n\n### Dylan\n# Seeding\ntemp <- getSEOverlapFisher(loop, loop.up, peak.Dylan.SE)\nresult.tb <- tibble(loopType = \\UP\\,\n                    target = \\Dylan SE\\,\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\n# Add row\ntemp <- getSEOverlapFisher(loop, loop.no, peak.Dylan.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\NO\\,\n          target = \\Dylan SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Dylan.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target = \\Dylan SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n### Whyte\n# Seeding\ntemp <- getSEOverlapFisher(loop, loop.up, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\UP\\,\n                    target = \\Whyte SE\\,\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\n# Add row\ntemp <- getSEOverlapFisher(loop, loop.no, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\NO\\,\n          target = \\Whyte SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target = \\Whyte SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\n# Visualization\nlibrary(circlize)\ndata <- result.tb\nheatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%\npivot_wider(names_from = loopType, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%\n  pivot_wider(names_from = loopType, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 5), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\, \\4\\, \\5\\)))\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\
loop <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\))

getOverlapLoopNum <- function(loop, peak){
  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))
  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))
  a <- queryHits(findOverlaps(anchor1, peak))
  b <- queryHits(findOverlaps(anchor2, peak))
  return(length(unique(c(a, b))))
}

getSEOverlapFisher <- function(allLoop, subsetLoop, peak){
  all.overlap <- getOverlapLoopNum(allLoop, peak)
  all.notOverlap <- nrow(allLoop) - all.overlap
  
  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)
  subset.notOverlap <- nrow(subsetLoop) - subset.overlap
  
  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,
                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)
  colnames(contingency_table) <- c(\Overlapping\, \Not_Overlapping\)
  rownames(contingency_table) <- c(\All loops\, \Subset loops\)
  
  # Perform Fisher's Exact Test
  fisher_test_result <- fisher.test(contingency_table)
  return(fisher_test_result)
}



loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\))

### Dylan
# Seeding
temp <- getSEOverlapFisher(loop, loop.up, peak.Dylan.SE)
result.tb <- tibble(loopType = \UP\,
                    target = \Dylan SE\,
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)
# Add row
temp <- getSEOverlapFisher(loop, loop.no, peak.Dylan.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \NO\,
          target = \Dylan SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

temp <- getSEOverlapFisher(loop, loop.down, peak.Dylan.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \DOWN\,
          target = \Dylan SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

### Whyte
# Seeding
temp <- getSEOverlapFisher(loop, loop.up, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \UP\,
                    target = \Whyte SE\,
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)
# Add row
temp <- getSEOverlapFisher(loop, loop.no, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \NO\,
          target = \Whyte SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

temp <- getSEOverlapFisher(loop, loop.down, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \DOWN\,
          target = \Whyte SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)


# Visualization
library(circlize)
data <- result.tb
heatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%
pivot_wider(names_from = loopType, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%
  pivot_wider(names_from = loopType, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 5), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), 
                                    labels = c(\0\, \1\, \2\, \3\, \4\, \5\)))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxubG9vcCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlLmJlZHBlXFwpKVxuXG5nZXRPdmVybGFwTG9vcE51bSA8LSBmdW5jdGlvbihsb29wLCBwZWFrKXtcbiAgYW5jaG9yMSA8LSBHUmFuZ2VzKHNlcW5hbWVzID0gbG9vcCRWMSwgcmFuZ2VzID0gSVJhbmdlcyhzdGFydCA9IGxvb3AkVjIsIGVuZCA9IGxvb3AkVjMpKVxuICBhbmNob3IyIDwtIEdSYW5nZXMoc2VxbmFtZXMgPSBsb29wJFY0LCByYW5nZXMgPSBJUmFuZ2VzKHN0YXJ0ID0gbG9vcCRWNSwgZW5kID0gbG9vcCRWNikpXG4gIGEgPC0gcXVlcnlIaXRzKGZpbmRPdmVybGFwcyhhbmNob3IxLCBwZWFrKSlcbiAgYiA8LSBxdWVyeUhpdHMoZmluZE92ZXJsYXBzKGFuY2hvcjIsIHBlYWspKVxuICByZXR1cm4obGVuZ3RoKHVuaXF1ZShjKGEsIGIpKSkpXG59XG5cbmdldFNFT3ZlcmxhcEZpc2hlciA8LSBmdW5jdGlvbihhbGxMb29wLCBzdWJzZXRMb29wLCBwZWFrKXtcbiAgYWxsLm92ZXJsYXAgPC0gZ2V0T3ZlcmxhcExvb3BOdW0oYWxsTG9vcCwgcGVhaylcbiAgYWxsLm5vdE92ZXJsYXAgPC0gbnJvdyhhbGxMb29wKSAtIGFsbC5vdmVybGFwXG4gIFxuICBzdWJzZXQub3ZlcmxhcCA8LSBnZXRPdmVybGFwTG9vcE51bShzdWJzZXRMb29wLCBwZWFrKVxuICBzdWJzZXQubm90T3ZlcmxhcCA8LSBucm93KHN1YnNldExvb3ApIC0gc3Vic2V0Lm92ZXJsYXBcbiAgXG4gIGNvbnRpbmdlbmN5X3RhYmxlIDwtIG1hdHJpeChjKHN1YnNldC5vdmVybGFwLCBzdWJzZXQubm90T3ZlcmxhcCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWxsLm92ZXJsYXAsIGFsbC5ub3RPdmVybGFwKSwgbnJvdyA9IDIsIGJ5cm93ID0gVFJVRSlcbiAgY29sbmFtZXMoY29udGluZ2VuY3lfdGFibGUpIDwtIGMoXFxPdmVybGFwcGluZ1xcLCBcXE5vdF9PdmVybGFwcGluZ1xcKVxuICByb3duYW1lcyhjb250aW5nZW5jeV90YWJsZSkgPC0gYyhcXEFsbCBsb29wc1xcLCBcXFN1YnNldCBsb29wc1xcKVxuICBcbiAgIyBQZXJmb3JtIEZpc2hlcidzIEV4YWN0IFRlc3RcbiAgZmlzaGVyX3Rlc3RfcmVzdWx0IDwtIGZpc2hlci50ZXN0KGNvbnRpbmdlbmN5X3RhYmxlKVxuICByZXR1cm4oZmlzaGVyX3Rlc3RfcmVzdWx0KVxufVxuXG5cblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVxcKSlcblxuIyMjIER5bGFuXG4jIFNlZWRpbmdcbnRlbXAgPC0gZ2V0U0VPdmVybGFwRmlzaGVyKGxvb3AsIGxvb3AudXAsIHBlYWsuRHlsYW4uU0UpXG5yZXN1bHQudGIgPC0gdGliYmxlKGxvb3BUeXBlID0gXFxVUFxcLFxuICAgICAgICAgICAgICAgICAgICB0YXJnZXQgPSBcXER5bGFuIFNFXFwsXG4gICAgICAgICAgICAgICAgICAgIHB2YWx1ZSA9IHRlbXAkcC52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgb2Rkc1JhdGlvID0gdGVtcCRlc3RpbWF0ZSlcbiMgQWRkIHJvd1xudGVtcCA8LSBnZXRTRU92ZXJsYXBGaXNoZXIobG9vcCwgbG9vcC5ubywgcGVhay5EeWxhbi5TRSlcbnJlc3VsdC50YiA8LSByZXN1bHQudGIgJT4lIFxuICBhZGRfcm93KGxvb3BUeXBlID0gXFxOT1xcLFxuICAgICAgICAgIHRhcmdldCA9IFxcRHlsYW4gU0VcXCxcbiAgICAgICAgICBwdmFsdWUgPSB0ZW1wJHAudmFsdWUsXG4gICAgICAgICAgb2Rkc1JhdGlvID0gdGVtcCRlc3RpbWF0ZSlcblxudGVtcCA8LSBnZXRTRU92ZXJsYXBGaXNoZXIobG9vcCwgbG9vcC5kb3duLCBwZWFrLkR5bGFuLlNFKVxucmVzdWx0LnRiIDwtIHJlc3VsdC50YiAlPiUgXG4gIGFkZF9yb3cobG9vcFR5cGUgPSBcXERPV05cXCxcbiAgICAgICAgICB0YXJnZXQgPSBcXER5bGFuIFNFXFwsXG4gICAgICAgICAgcHZhbHVlID0gdGVtcCRwLnZhbHVlLFxuICAgICAgICAgIG9kZHNSYXRpbyA9IHRlbXAkZXN0aW1hdGUpXG5cbiMjIyBXaHl0ZVxuIyBTZWVkaW5nXG50ZW1wIDwtIGdldFNFT3ZlcmxhcEZpc2hlcihsb29wLCBsb29wLnVwLCBwZWFrLldoeXRlLlNFKVxucmVzdWx0LnRiIDwtIHJlc3VsdC50YiAlPiUgXG4gIGFkZF9yb3cobG9vcFR5cGUgPSBcXFVQXFwsXG4gICAgICAgICAgICAgICAgICAgIHRhcmdldCA9IFxcV2h5dGUgU0VcXCxcbiAgICAgICAgICAgICAgICAgICAgcHZhbHVlID0gdGVtcCRwLnZhbHVlLFxuICAgICAgICAgICAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuIyBBZGQgcm93XG50ZW1wIDwtIGdldFNFT3ZlcmxhcEZpc2hlcihsb29wLCBsb29wLm5vLCBwZWFrLldoeXRlLlNFKVxucmVzdWx0LnRiIDwtIHJlc3VsdC50YiAlPiUgXG4gIGFkZF9yb3cobG9vcFR5cGUgPSBcXE5PXFwsXG4gICAgICAgICAgdGFyZ2V0ID0gXFxXaHl0ZSBTRVxcLFxuICAgICAgICAgIHB2YWx1ZSA9IHRlbXAkcC52YWx1ZSxcbiAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuXG50ZW1wIDwtIGdldFNFT3ZlcmxhcEZpc2hlcihsb29wLCBsb29wLmRvd24sIHBlYWsuV2h5dGUuU0UpXG5yZXN1bHQudGIgPC0gcmVzdWx0LnRiICU+JSBcbiAgYWRkX3Jvdyhsb29wVHlwZSA9IFxcRE9XTlxcLFxuICAgICAgICAgIHRhcmdldCA9IFxcV2h5dGUgU0VcXCxcbiAgICAgICAgICBwdmFsdWUgPSB0ZW1wJHAudmFsdWUsXG4gICAgICAgICAgb2Rkc1JhdGlvID0gdGVtcCRlc3RpbWF0ZSlcblxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5kYXRhIDwtIHJlc3VsdC50YlxuaGVhdG1hcF9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBsb29wVHlwZSwgb2Rkc1JhdGlvKSAlPiVcbnBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBsb29wVHlwZSwgdmFsdWVzX2Zyb20gPSBvZGRzUmF0aW8pICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFx0YXJnZXRcXClcblxucHZhbHVlX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGxvb3BUeXBlLCBwdmFsdWUpICU+JVxuICBwaXZvdF93aWRlcihuYW1lc19mcm9tID0gbG9vcFR5cGUsIHZhbHVlc19mcm9tID0gcHZhbHVlKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEsIDUpLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFxcYmx1ZVxcLCBcXHdoaXRlXFwsIFxccmVkXFwpKVxuXG5IZWF0bWFwKGFzLm1hdHJpeChoZWF0bWFwX2RhdGEpLFxuICAgICAgICBuYW1lID0gXFxPZGRzIFJhdGlvXFwsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4sXG4gICAgICAgICMgQWRkIGFubm90YXRpb24gZm9yIHAtdmFsdWVzXG4gICAgICAgIGNlbGxfZnVuID0gZnVuY3Rpb24oaiwgaSwgeCwgeSwgd2lkdGgsIGhlaWdodCwgZmlsbCkge1xuICAgICAgICAgIHB2YWwgPC0gcHZhbHVlX2RhdGFbaSwgal1cbiAgICAgICAgICBsYWJlbCA8LSBpZmVsc2UocHZhbCA+IDAuMDUsIFxcbi5zLlxcLCBzcHJpbnRmKFxcJS4yZVxcLCBwdmFsKSlcbiAgICAgICAgICBncmlkLnRleHQobGFiZWwsIHgsIHksIGdwID0gZ3Bhcihmb250c2l6ZSA9IDEwKSlcbiAgICAgICAgfSxcbiAgICAgICAgIyBDdXN0b21pemUgdGhlIGhlYXRtYXAgbGF5b3V0XG4gICAgICAgIGNsdXN0ZXJfcm93cyA9IFRSVUUsXG4gICAgICAgIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgICAgICAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsXG4gICAgICAgIGNvbHVtbl90aXRsZSA9IFxcSW50ZXJlc3RcXCxcbiAgICAgICAgcm93X3RpdGxlID0gXFxUYXJnZXRcXCxcbiAgICAgICAgaGVhdG1hcF9sZWdlbmRfcGFyYW0gPSBsaXN0KGF0ID0gYygwLCAxLCAyLCAzLCA0LCA1KSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsYWJlbHMgPSBjKFxcMFxcLCBcXDFcXCwgXFwyXFwsIFxcM1xcLCBcXDRcXCwgXFw1XFwpKSlcblxuXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\nloop <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\))\n\ngetOverlapLoopNum <- function(loop, peak){\n  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))\n  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))\n  a <- queryHits(findOverlaps(anchor1, peak))\n  b <- queryHits(findOverlaps(anchor2, peak))\n  return(length(unique(c(a, b))))\n}\n\ngetSEOverlapFisher <- function(allLoop, subsetLoop, peak){\n  all.overlap <- getOverlapLoopNum(allLoop, peak)\n  all.notOverlap <- nrow(allLoop) - all.overlap\n  \n  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)\n  subset.notOverlap <- nrow(subsetLoop) - subset.overlap\n  \n  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,\n                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)\n  colnames(contingency_table) <- c(\\Overlapping\\, \\Not_Overlapping\\)\n  rownames(contingency_table) <- c(\\All loops\\, \\Subset loops\\)\n  \n  # Perform Fisher's Exact Test\n  fisher_test_result <- fisher.test(contingency_table)\n  return(fisher_test_result)\n}\n\n\n\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\\))\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\\))\n\n### Dylan\n# Seeding\ntemp <- getSEOverlapFisher(loop, loop.up, peak.Dylan.SE)\nresult.tb <- tibble(loopType = \\UP\\,\n                    target = \\Dylan SE\\,\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\n# Add row\ntemp <- getSEOverlapFisher(loop, loop.no, peak.Dylan.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\NO\\,\n          target = \\Dylan SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Dylan.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target = \\Dylan SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n### Whyte\n# Seeding\ntemp <- getSEOverlapFisher(loop, loop.up, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\UP\\,\n                    target = \\Whyte SE\\,\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\n# Add row\ntemp <- getSEOverlapFisher(loop, loop.no, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\NO\\,\n          target = \\Whyte SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\ntemp <- getSEOverlapFisher(loop, loop.down, peak.Whyte.SE)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target = \\Whyte SE\\,\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\n# Visualization\nlibrary(circlize)\ndata <- result.tb\nheatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%\npivot_wider(names_from = loopType, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%\n  pivot_wider(names_from = loopType, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\ncol_fun <- colorRamp2(c(0, 1, 5), \n                      c(\\blue\\, \\white\\, \\red\\))\n\nHeatmap(as.matrix(heatmap_data),\n        name = \\Odds Ratio\\,\n        col = col_fun,\n        # Add annotation for p-values\n        cell_fun = function(j, i, x, y, width, height, fill) {\n          pval <- pvalue_data[i, j]\n          label <- ifelse(pval > 0.05, \\n.s.\\, sprintf(\\%.2e\\, pval))\n          grid.text(label, x, y, gp = gpar(fontsize = 10))\n        },\n        # Customize the heatmap layout\n        cluster_rows = TRUE,\n        show_row_dend = FALSE,\n        cluster_columns = FALSE,\n        column_title = \\Interest\\,\n        row_title = \\Target\\,\n        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), \n                                    labels = c(\\0\\, \\1\\, \\2\\, \\3\\, \\4\\, \\5\\)))\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxubG9vcCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlLmJlZHBlXFwpKVxuXG5nZXRPdmVybGFwTG9vcE51bSA8LSBmdW5jdGlvbihsb29wLCBwZWFrKXtcbiAgYW5jaG9yMSA8LSBHUmFuZ2VzKHNlcW5hbWVzID0gbG9vcCRWMSwgcmFuZ2VzID0gSVJhbmdlcyhzdGFydCA9IGxvb3AkVjIsIGVuZCA9IGxvb3AkVjMpKVxuICBhbmNob3IyIDwtIEdSYW5nZXMoc2VxbmFtZXMgPSBsb29wJFY0LCByYW5nZXMgPSBJUmFuZ2VzKHN0YXJ0ID0gbG9vcCRWNSwgZW5kID0gbG9vcCRWNikpXG4gIGEgPC0gcXVlcnlIaXRzKGZpbmRPdmVybGFwcyhhbmNob3IxLCBwZWFrKSlcbiAgYiA8LSBxdWVyeUhpdHMoZmluZE92ZXJsYXBzKGFuY2hvcjIsIHBlYWspKVxuICByZXR1cm4obGVuZ3RoKHVuaXF1ZShjKGEsIGIpKSkpXG59XG5cbmdldFNFT3ZlcmxhcEZpc2hlciA8LSBmdW5jdGlvbihhbGxMb29wLCBzdWJzZXRMb29wLCBwZWFrKXtcbiAgYWxsLm92ZXJsYXAgPC0gZ2V0T3ZlcmxhcExvb3BOdW0oYWxsTG9vcCwgcGVhaylcbiAgYWxsLm5vdE92ZXJsYXAgPC0gbnJvdyhhbGxMb29wKSAtIGFsbC5vdmVybGFwXG4gIFxuICBzdWJzZXQub3ZlcmxhcCA8LSBnZXRPdmVybGFwTG9vcE51bShzdWJzZXRMb29wLCBwZWFrKVxuICBzdWJzZXQubm90T3ZlcmxhcCA8LSBucm93KHN1YnNldExvb3ApIC0gc3Vic2V0Lm92ZXJsYXBcbiAgXG4gIGNvbnRpbmdlbmN5X3RhYmxlIDwtIG1hdHJpeChjKHN1YnNldC5vdmVybGFwLCBzdWJzZXQubm90T3ZlcmxhcCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWxsLm92ZXJsYXAsIGFsbC5ub3RPdmVybGFwKSwgbnJvdyA9IDIsIGJ5cm93ID0gVFJVRSlcbiAgY29sbmFtZXMoY29udGluZ2VuY3lfdGFibGUpIDwtIGMoXFxPdmVybGFwcGluZ1xcLCBcXE5vdF9PdmVybGFwcGluZ1xcKVxuICByb3duYW1lcyhjb250aW5nZW5jeV90YWJsZSkgPC0gYyhcXEFsbCBsb29wc1xcLCBcXFN1YnNldCBsb29wc1xcKVxuICBcbiAgIyBQZXJmb3JtIEZpc2hlcidzIEV4YWN0IFRlc3RcbiAgZmlzaGVyX3Rlc3RfcmVzdWx0IDwtIGZpc2hlci50ZXN0KGNvbnRpbmdlbmN5X3RhYmxlKVxuICByZXR1cm4oZmlzaGVyX3Rlc3RfcmVzdWx0KVxufVxuXG5cblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVxcKSlcblxuIyMjIER5bGFuXG4jIFNlZWRpbmdcbnRlbXAgPC0gZ2V0U0VPdmVybGFwRmlzaGVyKGxvb3AsIGxvb3AudXAsIHBlYWsuRHlsYW4uU0UpXG5yZXN1bHQudGIgPC0gdGliYmxlKGxvb3BUeXBlID0gXFxVUFxcLFxuICAgICAgICAgICAgICAgICAgICB0YXJnZXQgPSBcXER5bGFuIFNFXFwsXG4gICAgICAgICAgICAgICAgICAgIHB2YWx1ZSA9IHRlbXAkcC52YWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgb2Rkc1JhdGlvID0gdGVtcCRlc3RpbWF0ZSlcbiMgQWRkIHJvd1xudGVtcCA8LSBnZXRTRU92ZXJsYXBGaXNoZXIobG9vcCwgbG9vcC5ubywgcGVhay5EeWxhbi5TRSlcbnJlc3VsdC50YiA8LSByZXN1bHQudGIgJT4lIFxuICBhZGRfcm93KGxvb3BUeXBlID0gXFxOT1xcLFxuICAgICAgICAgIHRhcmdldCA9IFxcRHlsYW4gU0VcXCxcbiAgICAgICAgICBwdmFsdWUgPSB0ZW1wJHAudmFsdWUsXG4gICAgICAgICAgb2Rkc1JhdGlvID0gdGVtcCRlc3RpbWF0ZSlcblxudGVtcCA8LSBnZXRTRU92ZXJsYXBGaXNoZXIobG9vcCwgbG9vcC5kb3duLCBwZWFrLkR5bGFuLlNFKVxucmVzdWx0LnRiIDwtIHJlc3VsdC50YiAlPiUgXG4gIGFkZF9yb3cobG9vcFR5cGUgPSBcXERPV05cXCxcbiAgICAgICAgICB0YXJnZXQgPSBcXER5bGFuIFNFXFwsXG4gICAgICAgICAgcHZhbHVlID0gdGVtcCRwLnZhbHVlLFxuICAgICAgICAgIG9kZHNSYXRpbyA9IHRlbXAkZXN0aW1hdGUpXG5cbiMjIyBXaHl0ZVxuIyBTZWVkaW5nXG50ZW1wIDwtIGdldFNFT3ZlcmxhcEZpc2hlcihsb29wLCBsb29wLnVwLCBwZWFrLldoeXRlLlNFKVxucmVzdWx0LnRiIDwtIHJlc3VsdC50YiAlPiUgXG4gIGFkZF9yb3cobG9vcFR5cGUgPSBcXFVQXFwsXG4gICAgICAgICAgICAgICAgICAgIHRhcmdldCA9IFxcV2h5dGUgU0VcXCxcbiAgICAgICAgICAgICAgICAgICAgcHZhbHVlID0gdGVtcCRwLnZhbHVlLFxuICAgICAgICAgICAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuIyBBZGQgcm93XG50ZW1wIDwtIGdldFNFT3ZlcmxhcEZpc2hlcihsb29wLCBsb29wLm5vLCBwZWFrLldoeXRlLlNFKVxucmVzdWx0LnRiIDwtIHJlc3VsdC50YiAlPiUgXG4gIGFkZF9yb3cobG9vcFR5cGUgPSBcXE5PXFwsXG4gICAgICAgICAgdGFyZ2V0ID0gXFxXaHl0ZSBTRVxcLFxuICAgICAgICAgIHB2YWx1ZSA9IHRlbXAkcC52YWx1ZSxcbiAgICAgICAgICBvZGRzUmF0aW8gPSB0ZW1wJGVzdGltYXRlKVxuXG50ZW1wIDwtIGdldFNFT3ZlcmxhcEZpc2hlcihsb29wLCBsb29wLmRvd24sIHBlYWsuV2h5dGUuU0UpXG5yZXN1bHQudGIgPC0gcmVzdWx0LnRiICU+JSBcbiAgYWRkX3Jvdyhsb29wVHlwZSA9IFxcRE9XTlxcLFxuICAgICAgICAgIHRhcmdldCA9IFxcV2h5dGUgU0VcXCxcbiAgICAgICAgICBwdmFsdWUgPSB0ZW1wJHAudmFsdWUsXG4gICAgICAgICAgb2Rkc1JhdGlvID0gdGVtcCRlc3RpbWF0ZSlcblxuXG4jIFZpc3VhbGl6YXRpb25cbmxpYnJhcnkoY2lyY2xpemUpXG5kYXRhIDwtIHJlc3VsdC50YlxuaGVhdG1hcF9kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QodGFyZ2V0LCBsb29wVHlwZSwgb2Rkc1JhdGlvKSAlPiVcbnBpdm90X3dpZGVyKG5hbWVzX2Zyb20gPSBsb29wVHlwZSwgdmFsdWVzX2Zyb20gPSBvZGRzUmF0aW8pICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFx0YXJnZXRcXClcblxucHZhbHVlX2RhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCh0YXJnZXQsIGxvb3BUeXBlLCBwdmFsdWUpICU+JVxuICBwaXZvdF93aWRlcihuYW1lc19mcm9tID0gbG9vcFR5cGUsIHZhbHVlc19mcm9tID0gcHZhbHVlKSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcdGFyZ2V0XFwpXG5cbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEsIDUpLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFxcYmx1ZVxcLCBcXHdoaXRlXFwsIFxccmVkXFwpKVxuXG5IZWF0bWFwKGFzLm1hdHJpeChoZWF0bWFwX2RhdGEpLFxuICAgICAgICBuYW1lID0gXFxPZGRzIFJhdGlvXFwsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4sXG4gICAgICAgICMgQWRkIGFubm90YXRpb24gZm9yIHAtdmFsdWVzXG4gICAgICAgIGNlbGxfZnVuID0gZnVuY3Rpb24oaiwgaSwgeCwgeSwgd2lkdGgsIGhlaWdodCwgZmlsbCkge1xuICAgICAgICAgIHB2YWwgPC0gcHZhbHVlX2RhdGFbaSwgal1cbiAgICAgICAgICBsYWJlbCA8LSBpZmVsc2UocHZhbCA+IDAuMDUsIFxcbi5zLlxcLCBzcHJpbnRmKFxcJS4yZVxcLCBwdmFsKSlcbiAgICAgICAgICBncmlkLnRleHQobGFiZWwsIHgsIHksIGdwID0gZ3Bhcihmb250c2l6ZSA9IDEwKSlcbiAgICAgICAgfSxcbiAgICAgICAgIyBDdXN0b21pemUgdGhlIGhlYXRtYXAgbGF5b3V0XG4gICAgICAgIGNsdXN0ZXJfcm93cyA9IFRSVUUsXG4gICAgICAgIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgICAgICAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsXG4gICAgICAgIGNvbHVtbl90aXRsZSA9IFxcSW50ZXJlc3RcXCxcbiAgICAgICAgcm93X3RpdGxlID0gXFxUYXJnZXRcXCxcbiAgICAgICAgaGVhdG1hcF9sZWdlbmRfcGFyYW0gPSBsaXN0KGF0ID0gYygwLCAxLCAyLCAzLCA0LCA1KSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsYWJlbHMgPSBjKFxcMFxcLCBcXDFcXCwgXFwyXFwsIFxcM1xcLCBcXDRcXCwgXFw1XFwpKSlcblxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
name <- \chromo_cons_annoHierarchy\
loop <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\))

getOverlapLoopNum <- function(loop, peak){
  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))
  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))
  a <- queryHits(findOverlaps(anchor1, peak))
  b <- queryHits(findOverlaps(anchor2, peak))
  return(length(unique(c(a, b))))
}

getSEOverlapFisher <- function(allLoop, subsetLoop, peak){
  all.overlap <- getOverlapLoopNum(allLoop, peak)
  all.notOverlap <- nrow(allLoop) - all.overlap
  
  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)
  subset.notOverlap <- nrow(subsetLoop) - subset.overlap
  
  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,
                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)
  colnames(contingency_table) <- c(\Overlapping\, \Not_Overlapping\)
  rownames(contingency_table) <- c(\All loops\, \Subset loops\)
  
  # Perform Fisher's Exact Test
  fisher_test_result <- fisher.test(contingency_table)
  return(fisher_test_result)
}



loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\))

### Dylan
# Seeding
temp <- getSEOverlapFisher(loop, loop.up, peak.Dylan.SE)
result.tb <- tibble(loopType = \UP\,
                    target = \Dylan SE\,
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)
# Add row
temp <- getSEOverlapFisher(loop, loop.no, peak.Dylan.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \NO\,
          target = \Dylan SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

temp <- getSEOverlapFisher(loop, loop.down, peak.Dylan.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \DOWN\,
          target = \Dylan SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

### Whyte
# Seeding
temp <- getSEOverlapFisher(loop, loop.up, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \UP\,
                    target = \Whyte SE\,
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)
# Add row
temp <- getSEOverlapFisher(loop, loop.no, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \NO\,
          target = \Whyte SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

temp <- getSEOverlapFisher(loop, loop.down, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = \DOWN\,
          target = \Whyte SE\,
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)


# Visualization
library(circlize)
data <- result.tb
heatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%
pivot_wider(names_from = loopType, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%
  pivot_wider(names_from = loopType, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

col_fun <- colorRamp2(c(0, 1, 5), 
                      c(\blue\, \white\, \red\))

Heatmap(as.matrix(heatmap_data),
        name = \Odds Ratio\,
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, \n.s.\, sprintf(\%.2e\, pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = \Interest\,
        row_title = \Target\,
        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), 
                                    labels = c(\0\, \1\, \2\, \3\, \4\, \5\)))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Q2. Fisher's exact test?
##### dTAG

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVaR2xtWmtOMWRHOW1aaUE4TFNBd0xqSmNibTVoYldVZ1BDMGdYQ0pqYUhKdmJXOWZZMjl1YzE5aGJtNXZTR2xsY21GeVkyaDVYQ0pjYm1SaGRHRWdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY0lpNTBjM1pjSWlrcEtWeHVaR0YwWVNBOExTQmtZWFJoSUNVK0pWeHVJQ0FnSUdSd2JIbHlPanB0ZFhSaGRHVW9kWEJrYjNkdVgyUlVRVWRmUkUxVFR5QTlJR2xtWld4elpTaGthV1ptWDJSVVFVZGZSRTFUVHlBK0lHUnBabVpEZFhSdlptWXNJRndpVlZCY0lpd2dYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xtWld4elpTaGthV1ptWDJSVVFVZGZSRTFUVHlBK0lDMWthV1ptUTNWMGIyWm1MQ0JjSWs1UFhDSXNJRndpUkU5WFRsd2lLU2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCMWNHUnZkMjVmUVRRNE5WOUVUVk5QSUQwZ2FXWmxiSE5sS0dScFptWmZRVFE0TlY5RVRWTlBJRDRnWkdsbVprTjFkRzltWml3Z1hDSlZVRndpTENCY2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2FXWmxiSE5sS0dScFptWmZRVFE0TlY5RVRWTlBJRDRnTFdScFptWkRkWFJ2Wm1Zc0lGd2lUazljSWl3Z1hDSkVUMWRPWENJcEtTbGNibHh1SUhSbGJYQWdQQzBnWkdGMFlWeHVJQ0IwWlcxd0pHUmxibk5wZEhrZ1BDMGdaMlYwWDJSbGJuTnBkSGtvZEdWdGNDUmthV1ptWDJSVVFVZGZSRTFUVHl3Z2RHVnRjQ1JrYVdabVgwRTBPRFZmUkUxVFR5d2diaUE5SURFd01DbGNiaUFnZEdWdGNDQThMU0IwWlcxd0lDVStKU0JrY0d4NWNqbzZZWEp5WVc1blpTaGtaVzV6YVhSNUtWeHVJQ0JjYmlBZ2NERWdQQzBnWjJkd2JHOTBLSFJsYlhBc0lHRmxjeWg0SUQwZ1pHbG1abDlrVkVGSFgwUk5VMDhzSUhrZ1BTQmthV1ptWDBFME9EVmZSRTFUVHl3Z1kyOXNiM0lnUFNCa1pXNXphWFI1S1NrZ0sxeHVJQ0FnSUdkbGIyMWZjRzlwYm5Rb2MyaHZkeTVzWldkbGJtUWdQU0JHUVV4VFJTa2dLeUJjYmlBZ0lDQnpZMkZzWlY5amIyeHZjbDkyYVhKcFpHbHpLQ2tnS3lCY2JpQWdJQ0JuWlc5dFgyaHNhVzVsS0hscGJuUmxjbU5sY0hRZ1BTQmthV1ptUTNWMGIyWm1MQ0JoYkhCb1lTQTlJREVzSUdOdmJHOXlJRDBnWENKaWJHRmphMXdpS1NBclhHNGdJQ0FnWjJWdmJWOW9iR2x1WlNoNWFXNTBaWEpqWlhCMElEMGdMV1JwWm1aRGRYUnZabVlzSUdGc2NHaGhJRDBnTVN3Z1kyOXNiM0lnUFNCY0ltSnNZV05yWENJcElDdGNiaUFnSUNCblpXOXRYM1pzYVc1bEtIaHBiblJsY21ObGNIUWdQU0JrYVdabVEzVjBiMlptTENCaGJIQm9ZU0E5SURFc0lHTnZiRzl5SUQwZ1hDSmliR0ZqYTF3aUtTQXJYRzRnSUNBZ1oyVnZiVjkyYkdsdVpTaDRhVzUwWlhKalpYQjBJRDBnTFdScFptWkRkWFJ2Wm1Zc0lHRnNjR2hoSUQwZ01Td2dZMjlzYjNJZ1BTQmNJbUpzWVdOclhDSXBJQ3RjYmlBZ0lDQm5aVzl0WDJoc2FXNWxLSGxwYm5SbGNtTmxjSFFnUFNBd0xDQmhiSEJvWVNBOUlEQXVOU3dnWTI5c2IzSWdQU0JjSW1keVpYbGNJaWtnSzF4dUlDQWdJR2RsYjIxZmRteHBibVVvZUdsdWRHVnlZMlZ3ZENBOUlEQXNJR0ZzY0doaElEMGdNQzQxTENCamIyeHZjaUE5SUZ3aVozSmxlVndpS1NBclkyOXZjbVJmWm1sNFpXUW9jbUYwYVc4Z1BTQXhMQ0I1YkdsdElEMGdZeWd0TVN3Z01Ta3NJSGhzYVcwZ1BTQmpLQzB4TENBeEtTa2dLeUJjYmlBZ0lDQjBhR1Z0WlY5amJHRnpjMmxqS0NsY2JpQWdYRzRnSUdacGJHVk9ZVzFsSUR3dElIQmhjM1JsTUNoY0luTmpZWFIwWlhKd2JHOTBYMXdpTENCdVlXMWxMQ0JjSWw5Y0lpd2daR2xtWmtOMWRHOW1aaXdnWENKZlpHbG1abDljSWl3Z2JHOXZjRTVoYldVc0lGd2lYMlJVUVVjdFhDSXNJR1JwWm1aT1lXMWxLVnh1SUNCd2JtY29hR1Z5WlNobWFXZEVhWElzSUhCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWENJdWNHNW5YQ0lwS1N3Z2NtVnpJRDBnTmpBd0xDQjFibWwwY3lBOUlGd2lhVzVjSWl3Z2QybGtkR2dnUFNBekxqVXNJR2hsYVdkb2RDQTlJRE1wWEc0Z0lIQnlhVzUwS0hBeEtWeHVJQ0JrWlhZdWIyWm1LQ2xjYmlBZ2MzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNJaTV6ZG1kY0lpa3BMQ0JjYmlBZ0lDQWdJQ0FnSUNCM2FXUjBhQ0E5SURNdU5Td2dhR1ZwWjJoMElEMGdNeWxjYmlBZ2NISnBiblFvY0RFcFhHNGdJR1JsZGk1dlptWW9LVnh1WEc1Y2JseHVZR0JnSW4wPSAtLT5cblxuYGBgclxuZGlmZkN1dG9mZiA8LSAwLjJcbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5XFxcbmRhdGEgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpKVxuZGF0YSA8LSBkYXRhICU+JVxuICAgIGRwbHlyOjptdXRhdGUodXBkb3duX2RUQUdfRE1TTyA9IGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IGRpZmZDdXRvZmYsIFxcVVBcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcXE5PXFwsIFxcRE9XTlxcKSksXG4gICAgICAgICAgICAgICAgICB1cGRvd25fQTQ4NV9ETVNPID0gaWZlbHNlKGRpZmZfQTQ4NV9ETVNPID4gZGlmZkN1dG9mZiwgXFxVUFxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGRpZmZfQTQ4NV9ETVNPID4gLWRpZmZDdXRvZmYsIFxcTk9cXCwgXFxET1dOXFwpKSlcblxuIHRlbXAgPC0gZGF0YVxuICB0ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRkaWZmX2RUQUdfRE1TTywgdGVtcCRkaWZmX0E0ODVfRE1TTywgbiA9IDEwMClcbiAgdGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuICBcbiAgcDEgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gZGlmZl9kVEFHX0RNU08sIHkgPSBkaWZmX0E0ODVfRE1TTywgY29sb3IgPSBkZW5zaXR5KSkgK1xuICAgIGdlb21fcG9pbnQoc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBzY2FsZV9jb2xvcl92aXJpZGlzKCkgKyBcbiAgICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBhbHBoYSA9IDEsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gLWRpZmZDdXRvZmYsIGFscGhhID0gMSwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBhbHBoYSA9IDEsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gLWRpZmZDdXRvZmYsIGFscGhhID0gMSwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICAgIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArY29vcmRfZml4ZWQocmF0aW8gPSAxLCB5bGltID0gYygtMSwgMSksIHhsaW0gPSBjKC0xLCAxKSkgKyBcbiAgICB0aGVtZV9jbGFzc2ljKClcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXHNjYXR0ZXJwbG90X1xcLCBuYW1lLCBcXF9cXCwgZGlmZkN1dG9mZiwgXFxfZGlmZl9cXCwgbG9vcE5hbWUsIFxcX2RUQUctXFwsIGRpZmZOYW1lKVxuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0cyA9IFxcaW5cXCwgd2lkdGggPSAzLjUsIGhlaWdodCA9IDMpXG4gIHByaW50KHAxKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCBcbiAgICAgICAgICB3aWR0aCA9IDMuNSwgaGVpZ2h0ID0gMylcbiAgcHJpbnQocDEpXG4gIGRldi5vZmYoKVxuXG5cblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
diffCutoff <- 0.2
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)))

 temp <- data
  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)
  temp <- temp %>% dplyr::arrange(density)
  
  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() + 
    geom_hline(yintercept = diffCutoff, alpha = 1, color = \black\) +
    geom_hline(yintercept = -diffCutoff, alpha = 1, color = \black\) +
    geom_vline(xintercept = diffCutoff, alpha = 1, color = \black\) +
    geom_vline(xintercept = -diffCutoff, alpha = 1, color = \black\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + 
    theme_classic()
  
  fileName <- paste0(\scatterplot_\, name, \_\, diffCutoff, \_diff_\, loopName, \_dTAG-\, diffName)
  png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 3.5, height = 3)
  print(p1)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVpHbG1aa04xZEc5bVppQThMU0F3TGpKY2JtNWhiV1VnUEMwZ1hGeGphSEp2Ylc5ZlkyOXVjMTloYm01dlNHbGxjbUZ5WTJoNVhGeGNibVJoZEdFZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lIQmhjM1JsTUNodVlXMWxMQ0JjWEM1MGMzWmNYQ2twS1Z4dVpHRjBZU0E4TFNCa1lYUmhJQ1UrSlZ4dUlDQWdJR1J3YkhseU9qcHRkWFJoZEdVb2RYQmtiM2R1WDJSVVFVZGZSRTFUVHlBOUlHbG1aV3h6WlNoa2FXWm1YMlJVUVVkZlJFMVRUeUErSUdScFptWkRkWFJ2Wm1Zc0lGeGNWVkJjWEN3Z1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbG1aV3h6WlNoa2FXWm1YMlJVUVVkZlJFMVRUeUErSUMxa2FXWm1RM1YwYjJabUxDQmNYRTVQWEZ3c0lGeGNSRTlYVGx4Y0tTa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0IxY0dSdmQyNWZRVFE0TlY5RVRWTlBJRDBnYVdabGJITmxLR1JwWm1aZlFUUTROVjlFVFZOUElENGdaR2xtWmtOMWRHOW1aaXdnWEZ4VlVGeGNMQ0JjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVdabGJITmxLR1JwWm1aZlFUUTROVjlFVFZOUElENGdMV1JwWm1aRGRYUnZabVlzSUZ4Y1RrOWNYQ3dnWEZ4RVQxZE9YRndwS1NsY2JseHVJSFJsYlhBZ1BDMGdaR0YwWVZ4dUlDQjBaVzF3SkdSbGJuTnBkSGtnUEMwZ1oyVjBYMlJsYm5OcGRIa29kR1Z0Y0NSa2FXWm1YMlJVUVVkZlJFMVRUeXdnZEdWdGNDUmthV1ptWDBFME9EVmZSRTFUVHl3Z2JpQTlJREV3TUNsY2JpQWdkR1Z0Y0NBOExTQjBaVzF3SUNVK0pTQmtjR3g1Y2pvNllYSnlZVzVuWlNoa1pXNXphWFI1S1Z4dUlDQmNiaUFnY0RFZ1BDMGdaMmR3Ykc5MEtIUmxiWEFzSUdGbGN5aDRJRDBnWkdsbVpsOWtWRUZIWDBSTlUwOHNJSGtnUFNCa2FXWm1YMEUwT0RWZlJFMVRUeXdnWTI5c2IzSWdQU0JrWlc1emFYUjVLU2tnSzF4dUlDQWdJR2RsYjIxZmNHOXBiblFvYzJodmR5NXNaV2RsYm1RZ1BTQkdRVXhUUlNrZ0t5QmNiaUFnSUNCelkyRnNaVjlqYjJ4dmNsOTJhWEpwWkdsektDa2dLeUJjYmlBZ0lDQm5aVzl0WDJoc2FXNWxLSGxwYm5SbGNtTmxjSFFnUFNCa2FXWm1RM1YwYjJabUxDQmhiSEJvWVNBOUlERXNJR052Ykc5eUlEMGdYRnhpYkdGamExeGNLU0FyWEc0Z0lDQWdaMlZ2YlY5b2JHbHVaU2g1YVc1MFpYSmpaWEIwSUQwZ0xXUnBabVpEZFhSdlptWXNJR0ZzY0doaElEMGdNU3dnWTI5c2IzSWdQU0JjWEdKc1lXTnJYRndwSUN0Y2JpQWdJQ0JuWlc5dFgzWnNhVzVsS0hocGJuUmxjbU5sY0hRZ1BTQmthV1ptUTNWMGIyWm1MQ0JoYkhCb1lTQTlJREVzSUdOdmJHOXlJRDBnWEZ4aWJHRmphMXhjS1NBclhHNGdJQ0FnWjJWdmJWOTJiR2x1WlNoNGFXNTBaWEpqWlhCMElEMGdMV1JwWm1aRGRYUnZabVlzSUdGc2NHaGhJRDBnTVN3Z1kyOXNiM0lnUFNCY1hHSnNZV05yWEZ3cElDdGNiaUFnSUNCblpXOXRYMmhzYVc1bEtIbHBiblJsY21ObGNIUWdQU0F3TENCaGJIQm9ZU0E5SURBdU5Td2dZMjlzYjNJZ1BTQmNYR2R5WlhsY1hDa2dLMXh1SUNBZ0lHZGxiMjFmZG14cGJtVW9lR2x1ZEdWeVkyVndkQ0E5SURBc0lHRnNjR2hoSUQwZ01DNDFMQ0JqYjJ4dmNpQTlJRnhjWjNKbGVWeGNLU0FyWTI5dmNtUmZabWw0WldRb2NtRjBhVzhnUFNBeExDQjViR2x0SUQwZ1l5Z3RNU3dnTVNrc0lIaHNhVzBnUFNCaktDMHhMQ0F4S1NrZ0t5QmNiaUFnSUNCMGFHVnRaVjlqYkdGemMybGpLQ2xjYmlBZ1hHNGdJR1pwYkdWT1lXMWxJRHd0SUhCaGMzUmxNQ2hjWEhOallYUjBaWEp3Ykc5MFgxeGNMQ0J1WVcxbExDQmNYRjljWEN3Z1pHbG1aa04xZEc5bVppd2dYRnhmWkdsbVpsOWNYQ3dnYkc5dmNFNWhiV1VzSUZ4Y1gyUlVRVWN0WEZ3c0lHUnBabVpPWVcxbEtWeHVJQ0J3Ym1jb2FHVnlaU2htYVdkRWFYSXNJSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYRnd1Y0c1blhGd3BLU3dnY21WeklEMGdOakF3TENCMWJtbDBjeUE5SUZ4Y2FXNWNYQ3dnZDJsa2RHZ2dQU0F6TGpVc0lHaGxhV2RvZENBOUlETXBYRzRnSUhCeWFXNTBLSEF4S1Z4dUlDQmtaWFl1YjJabUtDbGNiaUFnYzNabmJHbDBaU2hvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY1hDNXpkbWRjWENrcExDQmNiaUFnSUNBZ0lDQWdJQ0IzYVdSMGFDQTlJRE11TlN3Z2FHVnBaMmgwSUQwZ015bGNiaUFnY0hKcGJuUW9jREVwWEc0Z0lHUmxkaTV2Wm1Zb0tWeHVYRzVjYmx4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbmRpZmZDdXRvZmYgPC0gMC4yXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcbmRhdGEgPC0gZGF0YSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKHVwZG93bl9kVEFHX0RNU08gPSBpZmVsc2UoZGlmZl9kVEFHX0RNU08gPiBkaWZmQ3V0b2ZmLCBcXFVQXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlmZl9kVEFHX0RNU08gPiAtZGlmZkN1dG9mZiwgXFxOT1xcLCBcXERPV05cXCkpLFxuICAgICAgICAgICAgICAgICAgdXBkb3duX0E0ODVfRE1TTyA9IGlmZWxzZShkaWZmX0E0ODVfRE1TTyA+IGRpZmZDdXRvZmYsIFxcVVBcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX0E0ODVfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcXE5PXFwsIFxcRE9XTlxcKSkpXG5cbiB0ZW1wIDwtIGRhdGFcbiAgdGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkZGlmZl9kVEFHX0RNU08sIHRlbXAkZGlmZl9BNDg1X0RNU08sIG4gPSAxMDApXG4gIHRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbiAgXG4gIHAxIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGRpZmZfZFRBR19ETVNPLCB5ID0gZGlmZl9BNDg1X0RNU08sIGNvbG9yID0gZGVuc2l0eSkpICtcbiAgICBnZW9tX3BvaW50KHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gICAgc2NhbGVfY29sb3JfdmlyaWRpcygpICsgXG4gICAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgYWxwaGEgPSAxLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIGdlb21faGxpbmUoeWludGVyY2VwdCA9IC1kaWZmQ3V0b2ZmLCBhbHBoYSA9IDEsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gZGlmZkN1dG9mZiwgYWxwaGEgPSAxLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICAgIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IC1kaWZmQ3V0b2ZmLCBhbHBoYSA9IDEsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCwgYWxwaGEgPSAwLjUsIGNvbG9yID0gXFxncmV5XFwpICtcbiAgICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK2Nvb3JkX2ZpeGVkKHJhdGlvID0gMSwgeWxpbSA9IGMoLTEsIDEpLCB4bGltID0gYygtMSwgMSkpICsgXG4gICAgdGhlbWVfY2xhc3NpYygpXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXFxzY2F0dGVycGxvdF9cXCwgbmFtZSwgXFxfXFwsIGRpZmZDdXRvZmYsIFxcX2RpZmZfXFwsIGxvb3BOYW1lLCBcXF9kVEFHLVxcLCBkaWZmTmFtZSlcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gMy41LCBoZWlnaHQgPSAzKVxuICBwcmludChwMSlcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgXG4gICAgICAgICAgd2lkdGggPSAzLjUsIGhlaWdodCA9IDMpXG4gIHByaW50KHAxKVxuICBkZXYub2ZmKClcblxuXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZGlmZkN1dG9mZiA8LSAwLjJcbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5XFxcbmRhdGEgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpKVxuZGF0YSA8LSBkYXRhICU+JVxuICAgIGRwbHlyOjptdXRhdGUodXBkb3duX2RUQUdfRE1TTyA9IGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IGRpZmZDdXRvZmYsIFxcVVBcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShkaWZmX2RUQUdfRE1TTyA+IC1kaWZmQ3V0b2ZmLCBcXE5PXFwsIFxcRE9XTlxcKSksXG4gICAgICAgICAgICAgICAgICB1cGRvd25fQTQ4NV9ETVNPID0gaWZlbHNlKGRpZmZfQTQ4NV9ETVNPID4gZGlmZkN1dG9mZiwgXFxVUFxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGRpZmZfQTQ4NV9ETVNPID4gLWRpZmZDdXRvZmYsIFxcTk9cXCwgXFxET1dOXFwpKSlcblxuIHRlbXAgPC0gZGF0YVxuICB0ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRkaWZmX2RUQUdfRE1TTywgdGVtcCRkaWZmX0E0ODVfRE1TTywgbiA9IDEwMClcbiAgdGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuICBcbiAgcDEgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gZGlmZl9kVEFHX0RNU08sIHkgPSBkaWZmX0E0ODVfRE1TTywgY29sb3IgPSBkZW5zaXR5KSkgK1xuICAgIGdlb21fcG9pbnQoc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgICBzY2FsZV9jb2xvcl92aXJpZGlzKCkgKyBcbiAgICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBhbHBoYSA9IDEsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gLWRpZmZDdXRvZmYsIGFscGhhID0gMSwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBkaWZmQ3V0b2ZmLCBhbHBoYSA9IDEsIGNvbG9yID0gXFxibGFja1xcKSArXG4gICAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gLWRpZmZDdXRvZmYsIGFscGhhID0gMSwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBhbHBoYSA9IDAuNSwgY29sb3IgPSBcXGdyZXlcXCkgK1xuICAgIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArY29vcmRfZml4ZWQocmF0aW8gPSAxLCB5bGltID0gYygtMSwgMSksIHhsaW0gPSBjKC0xLCAxKSkgKyBcbiAgICB0aGVtZV9jbGFzc2ljKClcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXHNjYXR0ZXJwbG90X1xcLCBuYW1lLCBcXF9cXCwgZGlmZkN1dG9mZiwgXFxfZGlmZl9cXCwgbG9vcE5hbWUsIFxcX2RUQUctXFwsIGRpZmZOYW1lKVxuICBwbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0cyA9IFxcaW5cXCwgd2lkdGggPSAzLjUsIGhlaWdodCA9IDMpXG4gIHByaW50KHAxKVxuICBkZXYub2ZmKClcbiAgc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCBcbiAgICAgICAgICB3aWR0aCA9IDMuNSwgaGVpZ2h0ID0gMylcbiAgcHJpbnQocDEpXG4gIGRldi5vZmYoKVxuXG5cblxuYGBgXG5gYGAifQ== -->

```r
```r
diffCutoff <- 0.2
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)))

 temp <- data
  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)
  temp <- temp %>% dplyr::arrange(density)
  
  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() + 
    geom_hline(yintercept = diffCutoff, alpha = 1, color = \black\) +
    geom_hline(yintercept = -diffCutoff, alpha = 1, color = \black\) +
    geom_vline(xintercept = diffCutoff, alpha = 1, color = \black\) +
    geom_vline(xintercept = -diffCutoff, alpha = 1, color = \black\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + 
    theme_classic()
  
  fileName <- paste0(\scatterplot_\, name, \_\, diffCutoff, \_diff_\, loopName, \_dTAG-\, diffName)
  png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 3.5, height = 3)
  print(p1)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### A485

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\nname <- \"chromo_cons_annoHierarchy\"\ndata <- fread(here(consensusDir, paste0(name, \".tsv\")))\ndata <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \"UP\", \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \"NO\", \"DOWN\")),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \"UP\", \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \"NO\", \"DOWN\")))\n\nmakeAcrossSampleScatterplotdTAG <- function(data, AnnoList, diff, name, loopName, diffName){\n  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,\n                                 updown_dTAG_DMSO %in% diff)\n  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)\n  temp <- temp %>% dplyr::arrange(density)\n\n  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +\n    geom_point(show.legend = FALSE) + \n    scale_color_viridis() + \n    geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + \n    theme_classic() + ggtitle(paste0(name, \"_\", loopName, \"_dTAG-\", diffName)) + theme(plot.title = element_text(size = 5))\n  \n  fileName <- paste0(\"scatterplot_\", name, \"_\", diffCutoff, \"_diff_\", loopName, \"_dTAG-\", diffName)\n  png(here(figDir, paste0(fileName, \".png\")), res = 600, units = \"in\", width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n}\n\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\"UP\", \"NO\", \"DOWN\"), name, \"all\", \"all\")\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\"UP\"), name, \"all\", \"UP\")\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\"NO\"), name, \"all\", \"NO\")\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\"DOWN\"), name, \"all\", \"DOWN\")\n\nmakeAcrossSampleScatterplotdTAG(data, c(\"P-P\", \"P-E\", \"E-E\"), c(\"UP\", \"NO\", \"DOWN\"), name, \"pe-pe\", \"all\")\nmakeAcrossSampleScatterplotdTAG(data, c(\"P-P\", \"P-E\", \"E-E\"), c(\"UP\"), name, \"pe-pe\", \"UP\")\nmakeAcrossSampleScatterplotdTAG(data, c(\"P-P\", \"P-E\", \"E-E\"), c(\"NO\"), name, \"pe-pe\", \"NO\")\nmakeAcrossSampleScatterplotdTAG(data, c(\"P-P\", \"P-E\", \"E-E\"), c(\"DOWN\"), name, \"pe-pe\", \"DOWN\")\n\nmakeAcrossSampleScatterplotdTAG(data, c(\"S-S\", \"S-X\"), c(\"UP\", \"NO\", \"DOWN\"), name, \"str\", \"all\")\nmakeAcrossSampleScatterplotdTAG(data, c(\"S-S\", \"S-X\"), c(\"UP\"), name, \"str\", \"UP\")\nmakeAcrossSampleScatterplotdTAG(data, c(\"S-S\", \"S-X\"), c(\"NO\"), name, \"str\", \"NO\")\nmakeAcrossSampleScatterplotdTAG(data, c(\"S-S\", \"S-X\"), c(\"DOWN\"), name, \"str\", \"DOWN\")\n\nmakeAcrossSampleScatterplotA485 <- function(data, AnnoList, diff, name, loopName, diffName){\n  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,\n                                 updown_A485_DMSO %in% diff)\n  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)\n  temp <- temp %>% dplyr::arrange(density)\n\n  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +\n    geom_point(show.legend = FALSE) + \n    scale_color_viridis() + \n    geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + \n    theme_classic() + ggtitle(paste0(name, \"_\", loopName, \"_A485G-\", diffName)) + theme(plot.title = element_text(size = 5))\n  \n  fileName <- paste0(\"scatterplot_\", name, \"_\", diffCutoff, \"_diff_\", loopName, \"_A485-\", diffName)\n  png(here(figDir, paste0(fileName, \".png\")), res = 600, units = \"in\", width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n}\n\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\"UP\", \"NO\", \"DOWN\"), name, \"all\", \"all\")\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\"UP\"), name, \"all\", \"UP\")\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\"NO\"), name, \"all\", \"NO\")\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\"DOWN\"), name, \"all\", \"DOWN\")\n\nmakeAcrossSampleScatterplotA485(data, c(\"P-P\", \"P-E\", \"E-E\"), c(\"UP\", \"NO\", \"DOWN\"), name, \"pe-pe\", \"all\")\nmakeAcrossSampleScatterplotA485(data, c(\"P-P\", \"P-E\", \"E-E\"), c(\"UP\"), name, \"pe-pe\", \"UP\")\nmakeAcrossSampleScatterplotA485(data, c(\"P-P\", \"P-E\", \"E-E\"), c(\"NO\"), name, \"pe-pe\", \"NO\")\nmakeAcrossSampleScatterplotA485(data, c(\"P-P\", \"P-E\", \"E-E\"), c(\"DOWN\"), name, \"pe-pe\", \"DOWN\")\n\nmakeAcrossSampleScatterplotA485(data, c(\"S-S\", \"S-X\"), c(\"UP\", \"NO\", \"DOWN\"), name, \"str\", \"all\")\nmakeAcrossSampleScatterplotA485(data, c(\"S-S\", \"S-X\"), c(\"UP\"), name, \"str\", \"UP\")\nmakeAcrossSampleScatterplotA485(data, c(\"S-S\", \"S-X\"), c(\"NO\"), name, \"str\", \"NO\")\nmakeAcrossSampleScatterplotA485(data, c(\"S-S\", \"S-X\"), c(\"DOWN\"), name, \"str\", \"DOWN\")\n\n######## Barplot\ntemp <- data %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO)\nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \"dashed\") +\n  geom_hline(yintercept = -0.2, linetype = \"dashed\") + coord_cartesian(ylim = c(-0.5, 0.5))\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\"P-P\", \"P-E\", \"E-E\")) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) \nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \"dashed\") +\n  geom_hline(yintercept = -0.2, linetype = \"dashed\") + coord_cartesian(ylim = c(-0.5, 0.5))\n\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\"S-S\", \"S-X\")) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) \nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \"dashed\") +\n  geom_hline(yintercept = -0.2, linetype = \"dashed\") + coord_cartesian(ylim = c(-0.5, 0.5))\n\n###\ntemp <- data %>% dplyr::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \"dashed\") +\n  geom_hline(yintercept = -0.2, linetype = \"dashed\") + coord_cartesian(ylim = c(-0.5, 0.5))\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\"P-P\", \"P-E\", \"E-E\")) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \"dashed\") +\n  geom_hline(yintercept = -0.2, linetype = \"dashed\") + coord_cartesian(ylim = c(-0.5, 0.5))\n\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\"S-S\", \"S-X\")) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \"dashed\") +\n  geom_hline(yintercept = -0.2, linetype = \"dashed\") + coord_cartesian(ylim = c(-0.5, 0.5))\n\n```"} -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ndata <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)))\n\nmakeAcrossSampleScatterplotdTAG <- function(data, AnnoList, diff, name, loopName, diffName){\n  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,\n                                 updown_dTAG_DMSO %in% diff)\n  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)\n  temp <- temp %>% dplyr::arrange(density)\n\n  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +\n    geom_point(show.legend = FALSE) + \n    scale_color_viridis() + \n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + \n    theme_classic() + ggtitle(paste0(name, \\_\\, loopName, \\_dTAG-\\, diffName)) + theme(plot.title = element_text(size = 5))\n  \n  fileName <- paste0(\\scatterplot_\\, name, \\_\\, diffCutoff, \\_diff_\\, loopName, \\_dTAG-\\, diffName)\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n}\n\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\all\\, \\all\\)\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\UP\\), name, \\all\\, \\UP\\)\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\NO\\), name, \\all\\, \\NO\\)\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\DOWN\\), name, \\all\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\pe-pe\\, \\all\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\), name, \\pe-pe\\, \\UP\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\NO\\), name, \\pe-pe\\, \\NO\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\DOWN\\), name, \\pe-pe\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\str\\, \\all\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\UP\\), name, \\str\\, \\UP\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\NO\\), name, \\str\\, \\NO\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\DOWN\\), name, \\str\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotA485 <- function(data, AnnoList, diff, name, loopName, diffName){\n  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,\n                                 updown_A485_DMSO %in% diff)\n  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)\n  temp <- temp %>% dplyr::arrange(density)\n\n  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +\n    geom_point(show.legend = FALSE) + \n    scale_color_viridis() + \n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + \n    theme_classic() + ggtitle(paste0(name, \\_\\, loopName, \\_A485G-\\, diffName)) + theme(plot.title = element_text(size = 5))\n  \n  fileName <- paste0(\\scatterplot_\\, name, \\_\\, diffCutoff, \\_diff_\\, loopName, \\_A485-\\, diffName)\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n}\n\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\all\\, \\all\\)\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\UP\\), name, \\all\\, \\UP\\)\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\NO\\), name, \\all\\, \\NO\\)\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\DOWN\\), name, \\all\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\pe-pe\\, \\all\\)\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\), name, \\pe-pe\\, \\UP\\)\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\NO\\), name, \\pe-pe\\, \\NO\\)\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\DOWN\\), name, \\pe-pe\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\str\\, \\all\\)\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\UP\\), name, \\str\\, \\UP\\)\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\NO\\), name, \\str\\, \\NO\\)\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\DOWN\\), name, \\str\\, \\DOWN\\)\n\n######## Barplot\ntemp <- data %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO)\nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\)) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) \nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\S-S\\, \\S-X\\)) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) \nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n###\ntemp <- data %>% dplyr::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\)) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\S-S\\, \\S-X\\)) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)))

makeAcrossSampleScatterplotdTAG <- function(data, AnnoList, diff, name, loopName, diffName){
  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,
                                 updown_dTAG_DMSO %in% diff)
  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)
  temp <- temp %>% dplyr::arrange(density)

  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() + 
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + 
    theme_classic() + ggtitle(paste0(name, \_\, loopName, \_dTAG-\, diffName)) + theme(plot.title = element_text(size = 5))
  
  fileName <- paste0(\scatterplot_\, name, \_\, diffCutoff, \_diff_\, loopName, \_dTAG-\, diffName)
  png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 3.5, height = 3)
  print(p1)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()
}

makeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\UP\, \NO\, \DOWN\), name, \all\, \all\)
makeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\UP\), name, \all\, \UP\)
makeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\NO\), name, \all\, \NO\)
makeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\DOWN\), name, \all\, \DOWN\)

makeAcrossSampleScatterplotdTAG(data, c(\P-P\, \P-E\, \E-E\), c(\UP\, \NO\, \DOWN\), name, \pe-pe\, \all\)
makeAcrossSampleScatterplotdTAG(data, c(\P-P\, \P-E\, \E-E\), c(\UP\), name, \pe-pe\, \UP\)
makeAcrossSampleScatterplotdTAG(data, c(\P-P\, \P-E\, \E-E\), c(\NO\), name, \pe-pe\, \NO\)
makeAcrossSampleScatterplotdTAG(data, c(\P-P\, \P-E\, \E-E\), c(\DOWN\), name, \pe-pe\, \DOWN\)

makeAcrossSampleScatterplotdTAG(data, c(\S-S\, \S-X\), c(\UP\, \NO\, \DOWN\), name, \str\, \all\)
makeAcrossSampleScatterplotdTAG(data, c(\S-S\, \S-X\), c(\UP\), name, \str\, \UP\)
makeAcrossSampleScatterplotdTAG(data, c(\S-S\, \S-X\), c(\NO\), name, \str\, \NO\)
makeAcrossSampleScatterplotdTAG(data, c(\S-S\, \S-X\), c(\DOWN\), name, \str\, \DOWN\)

makeAcrossSampleScatterplotA485 <- function(data, AnnoList, diff, name, loopName, diffName){
  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,
                                 updown_A485_DMSO %in% diff)
  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)
  temp <- temp %>% dplyr::arrange(density)

  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() + 
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + 
    theme_classic() + ggtitle(paste0(name, \_\, loopName, \_A485G-\, diffName)) + theme(plot.title = element_text(size = 5))
  
  fileName <- paste0(\scatterplot_\, name, \_\, diffCutoff, \_diff_\, loopName, \_A485-\, diffName)
  png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 3.5, height = 3)
  print(p1)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()
}

makeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\UP\, \NO\, \DOWN\), name, \all\, \all\)
makeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\UP\), name, \all\, \UP\)
makeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\NO\), name, \all\, \NO\)
makeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\DOWN\), name, \all\, \DOWN\)

makeAcrossSampleScatterplotA485(data, c(\P-P\, \P-E\, \E-E\), c(\UP\, \NO\, \DOWN\), name, \pe-pe\, \all\)
makeAcrossSampleScatterplotA485(data, c(\P-P\, \P-E\, \E-E\), c(\UP\), name, \pe-pe\, \UP\)
makeAcrossSampleScatterplotA485(data, c(\P-P\, \P-E\, \E-E\), c(\NO\), name, \pe-pe\, \NO\)
makeAcrossSampleScatterplotA485(data, c(\P-P\, \P-E\, \E-E\), c(\DOWN\), name, \pe-pe\, \DOWN\)

makeAcrossSampleScatterplotA485(data, c(\S-S\, \S-X\), c(\UP\, \NO\, \DOWN\), name, \str\, \all\)
makeAcrossSampleScatterplotA485(data, c(\S-S\, \S-X\), c(\UP\), name, \str\, \UP\)
makeAcrossSampleScatterplotA485(data, c(\S-S\, \S-X\), c(\NO\), name, \str\, \NO\)
makeAcrossSampleScatterplotA485(data, c(\S-S\, \S-X\), c(\DOWN\), name, \str\, \DOWN\)

######## Barplot
temp <- data %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO)
ggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = \dashed\) +
  geom_hline(yintercept = -0.2, linetype = \dashed\) + coord_cartesian(ylim = c(-0.5, 0.5))

temp <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\)) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) 
ggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = \dashed\) +
  geom_hline(yintercept = -0.2, linetype = \dashed\) + coord_cartesian(ylim = c(-0.5, 0.5))


temp <- data %>% dplyr::filter(Anno2 %in% c(\S-S\, \S-X\)) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) 
ggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = \dashed\) +
  geom_hline(yintercept = -0.2, linetype = \dashed\) + coord_cartesian(ylim = c(-0.5, 0.5))

###
temp <- data %>% dplyr::select(updown_A485_DMSO, diff_dTAG_DMSO)
ggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = \dashed\) +
  geom_hline(yintercept = -0.2, linetype = \dashed\) + coord_cartesian(ylim = c(-0.5, 0.5))

temp <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\)) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)
ggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = \dashed\) +
  geom_hline(yintercept = -0.2, linetype = \dashed\) + coord_cartesian(ylim = c(-0.5, 0.5))


temp <- data %>% dplyr::filter(Anno2 %in% c(\S-S\, \S-X\)) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)
ggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = \dashed\) +
  geom_hline(yintercept = -0.2, linetype = \dashed\) + coord_cartesian(ylim = c(-0.5, 0.5))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ndata <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)))\n\nmakeAcrossSampleScatterplotdTAG <- function(data, AnnoList, diff, name, loopName, diffName){\n  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,\n                                 updown_dTAG_DMSO %in% diff)\n  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)\n  temp <- temp %>% dplyr::arrange(density)\n\n  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +\n    geom_point(show.legend = FALSE) + \n    scale_color_viridis() + \n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + \n    theme_classic() + ggtitle(paste0(name, \\_\\, loopName, \\_dTAG-\\, diffName)) + theme(plot.title = element_text(size = 5))\n  \n  fileName <- paste0(\\scatterplot_\\, name, \\_\\, diffCutoff, \\_diff_\\, loopName, \\_dTAG-\\, diffName)\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n}\n\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\all\\, \\all\\)\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\UP\\), name, \\all\\, \\UP\\)\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\NO\\), name, \\all\\, \\NO\\)\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\DOWN\\), name, \\all\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\pe-pe\\, \\all\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\), name, \\pe-pe\\, \\UP\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\NO\\), name, \\pe-pe\\, \\NO\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\DOWN\\), name, \\pe-pe\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\str\\, \\all\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\UP\\), name, \\str\\, \\UP\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\NO\\), name, \\str\\, \\NO\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\DOWN\\), name, \\str\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotA485 <- function(data, AnnoList, diff, name, loopName, diffName){\n  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,\n                                 updown_A485_DMSO %in% diff)\n  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)\n  temp <- temp %>% dplyr::arrange(density)\n\n  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +\n    geom_point(show.legend = FALSE) + \n    scale_color_viridis() + \n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + \n    theme_classic() + ggtitle(paste0(name, \\_\\, loopName, \\_A485G-\\, diffName)) + theme(plot.title = element_text(size = 5))\n  \n  fileName <- paste0(\\scatterplot_\\, name, \\_\\, diffCutoff, \\_diff_\\, loopName, \\_A485-\\, diffName)\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n}\n\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\all\\, \\all\\)\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\UP\\), name, \\all\\, \\UP\\)\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\NO\\), name, \\all\\, \\NO\\)\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\DOWN\\), name, \\all\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\pe-pe\\, \\all\\)\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\), name, \\pe-pe\\, \\UP\\)\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\NO\\), name, \\pe-pe\\, \\NO\\)\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\DOWN\\), name, \\pe-pe\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\str\\, \\all\\)\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\UP\\), name, \\str\\, \\UP\\)\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\NO\\), name, \\str\\, \\NO\\)\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\DOWN\\), name, \\str\\, \\DOWN\\)\n\n######## Barplot\ntemp <- data %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO)\nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\)) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) \nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\S-S\\, \\S-X\\)) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) \nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n###\ntemp <- data %>% dplyr::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\)) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\S-S\\, \\S-X\\)) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n```\n```"} -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ndata <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)))\n\nmakeAcrossSampleScatterplotdTAG <- function(data, AnnoList, diff, name, loopName, diffName){\n  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,\n                                 updown_dTAG_DMSO %in% diff)\n  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)\n  temp <- temp %>% dplyr::arrange(density)\n\n  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +\n    geom_point(show.legend = FALSE) + \n    scale_color_viridis() + \n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + \n    theme_classic() + ggtitle(paste0(name, \\_\\, loopName, \\_dTAG-\\, diffName)) + theme(plot.title = element_text(size = 5))\n  \n  fileName <- paste0(\\scatterplot_\\, name, \\_\\, diffCutoff, \\_diff_\\, loopName, \\_dTAG-\\, diffName)\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n}\n\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\all\\, \\all\\)\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\UP\\), name, \\all\\, \\UP\\)\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\NO\\), name, \\all\\, \\NO\\)\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\DOWN\\), name, \\all\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\pe-pe\\, \\all\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\), name, \\pe-pe\\, \\UP\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\NO\\), name, \\pe-pe\\, \\NO\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\DOWN\\), name, \\pe-pe\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\str\\, \\all\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\UP\\), name, \\str\\, \\UP\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\NO\\), name, \\str\\, \\NO\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\DOWN\\), name, \\str\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotA485 <- function(data, AnnoList, diff, name, loopName, diffName){\n  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,\n                                 updown_A485_DMSO %in% diff)\n  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)\n  temp <- temp %>% dplyr::arrange(density)\n\n  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +\n    geom_point(show.legend = FALSE) + \n    scale_color_viridis() + \n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + \n    theme_classic() + ggtitle(paste0(name, \\_\\, loopName, \\_A485G-\\, diffName)) + theme(plot.title = element_text(size = 5))\n  \n  fileName <- paste0(\\scatterplot_\\, name, \\_\\, diffCutoff, \\_diff_\\, loopName, \\_A485-\\, diffName)\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n}\n\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\all\\, \\all\\)\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\UP\\), name, \\all\\, \\UP\\)\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\NO\\), name, \\all\\, \\NO\\)\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\DOWN\\), name, \\all\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\pe-pe\\, \\all\\)\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\), name, \\pe-pe\\, \\UP\\)\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\NO\\), name, \\pe-pe\\, \\NO\\)\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\DOWN\\), name, \\pe-pe\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\str\\, \\all\\)\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\UP\\), name, \\str\\, \\UP\\)\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\NO\\), name, \\str\\, \\NO\\)\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\DOWN\\), name, \\str\\, \\DOWN\\)\n\n######## Barplot\ntemp <- data %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO)\nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\)) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) \nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\S-S\\, \\S-X\\)) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) \nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n###\ntemp <- data %>% dplyr::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\)) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\S-S\\, \\S-X\\)) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ndata <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)),\n                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \\UP\\, \n                                            ifelse(diff_A485_DMSO > -diffCutoff, \\NO\\, \\DOWN\\)))\n\nmakeAcrossSampleScatterplotdTAG <- function(data, AnnoList, diff, name, loopName, diffName){\n  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,\n                                 updown_dTAG_DMSO %in% diff)\n  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)\n  temp <- temp %>% dplyr::arrange(density)\n\n  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +\n    geom_point(show.legend = FALSE) + \n    scale_color_viridis() + \n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + \n    theme_classic() + ggtitle(paste0(name, \\_\\, loopName, \\_dTAG-\\, diffName)) + theme(plot.title = element_text(size = 5))\n  \n  fileName <- paste0(\\scatterplot_\\, name, \\_\\, diffCutoff, \\_diff_\\, loopName, \\_dTAG-\\, diffName)\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n}\n\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\all\\, \\all\\)\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\UP\\), name, \\all\\, \\UP\\)\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\NO\\), name, \\all\\, \\NO\\)\nmakeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\\DOWN\\), name, \\all\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\pe-pe\\, \\all\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\), name, \\pe-pe\\, \\UP\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\NO\\), name, \\pe-pe\\, \\NO\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\DOWN\\), name, \\pe-pe\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\str\\, \\all\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\UP\\), name, \\str\\, \\UP\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\NO\\), name, \\str\\, \\NO\\)\nmakeAcrossSampleScatterplotdTAG(data, c(\\S-S\\, \\S-X\\), c(\\DOWN\\), name, \\str\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotA485 <- function(data, AnnoList, diff, name, loopName, diffName){\n  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,\n                                 updown_A485_DMSO %in% diff)\n  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)\n  temp <- temp %>% dplyr::arrange(density)\n\n  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +\n    geom_point(show.legend = FALSE) + \n    scale_color_viridis() + \n    geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \\grey\\, linetype = \\dotted\\) +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + \n    theme_classic() + ggtitle(paste0(name, \\_\\, loopName, \\_A485G-\\, diffName)) + theme(plot.title = element_text(size = 5))\n  \n  fileName <- paste0(\\scatterplot_\\, name, \\_\\, diffCutoff, \\_diff_\\, loopName, \\_A485-\\, diffName)\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, units = \\in\\, width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)), \n          width = 3.5, height = 3)\n  print(p1)\n  dev.off()\n}\n\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\all\\, \\all\\)\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\UP\\), name, \\all\\, \\UP\\)\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\NO\\), name, \\all\\, \\NO\\)\nmakeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\\DOWN\\), name, \\all\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\pe-pe\\, \\all\\)\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\UP\\), name, \\pe-pe\\, \\UP\\)\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\NO\\), name, \\pe-pe\\, \\NO\\)\nmakeAcrossSampleScatterplotA485(data, c(\\P-P\\, \\P-E\\, \\E-E\\), c(\\DOWN\\), name, \\pe-pe\\, \\DOWN\\)\n\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\UP\\, \\NO\\, \\DOWN\\), name, \\str\\, \\all\\)\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\UP\\), name, \\str\\, \\UP\\)\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\NO\\), name, \\str\\, \\NO\\)\nmakeAcrossSampleScatterplotA485(data, c(\\S-S\\, \\S-X\\), c(\\DOWN\\), name, \\str\\, \\DOWN\\)\n\n######## Barplot\ntemp <- data %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO)\nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\)) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) \nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\S-S\\, \\S-X\\)) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) \nggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n###\ntemp <- data %>% dplyr::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\)) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n\ntemp <- data %>% dplyr::filter(Anno2 %in% c(\\S-S\\, \\S-X\\)) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)\nggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +\n  geom_hline(yintercept = 0) +\n  geom_hline(yintercept = 0.2, linetype = \\dashed\\) +\n  geom_hline(yintercept = -0.2, linetype = \\dashed\\) + coord_cartesian(ylim = c(-0.5, 0.5))\n\n```\n```"} -->

```r
```r
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\)))

makeAcrossSampleScatterplotdTAG <- function(data, AnnoList, diff, name, loopName, diffName){
  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,
                                 updown_dTAG_DMSO %in% diff)
  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)
  temp <- temp %>% dplyr::arrange(density)

  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() + 
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + 
    theme_classic() + ggtitle(paste0(name, \_\, loopName, \_dTAG-\, diffName)) + theme(plot.title = element_text(size = 5))
  
  fileName <- paste0(\scatterplot_\, name, \_\, diffCutoff, \_diff_\, loopName, \_dTAG-\, diffName)
  png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 3.5, height = 3)
  print(p1)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()
}

makeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\UP\, \NO\, \DOWN\), name, \all\, \all\)
makeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\UP\), name, \all\, \UP\)
makeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\NO\), name, \all\, \NO\)
makeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c(\DOWN\), name, \all\, \DOWN\)

makeAcrossSampleScatterplotdTAG(data, c(\P-P\, \P-E\, \E-E\), c(\UP\, \NO\, \DOWN\), name, \pe-pe\, \all\)
makeAcrossSampleScatterplotdTAG(data, c(\P-P\, \P-E\, \E-E\), c(\UP\), name, \pe-pe\, \UP\)
makeAcrossSampleScatterplotdTAG(data, c(\P-P\, \P-E\, \E-E\), c(\NO\), name, \pe-pe\, \NO\)
makeAcrossSampleScatterplotdTAG(data, c(\P-P\, \P-E\, \E-E\), c(\DOWN\), name, \pe-pe\, \DOWN\)

makeAcrossSampleScatterplotdTAG(data, c(\S-S\, \S-X\), c(\UP\, \NO\, \DOWN\), name, \str\, \all\)
makeAcrossSampleScatterplotdTAG(data, c(\S-S\, \S-X\), c(\UP\), name, \str\, \UP\)
makeAcrossSampleScatterplotdTAG(data, c(\S-S\, \S-X\), c(\NO\), name, \str\, \NO\)
makeAcrossSampleScatterplotdTAG(data, c(\S-S\, \S-X\), c(\DOWN\), name, \str\, \DOWN\)

makeAcrossSampleScatterplotA485 <- function(data, AnnoList, diff, name, loopName, diffName){
  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,
                                 updown_A485_DMSO %in% diff)
  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)
  temp <- temp %>% dplyr::arrange(density)

  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() + 
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + 
    theme_classic() + ggtitle(paste0(name, \_\, loopName, \_A485G-\, diffName)) + theme(plot.title = element_text(size = 5))
  
  fileName <- paste0(\scatterplot_\, name, \_\, diffCutoff, \_diff_\, loopName, \_A485-\, diffName)
  png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 3.5, height = 3)
  print(p1)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()
}

makeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\UP\, \NO\, \DOWN\), name, \all\, \all\)
makeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\UP\), name, \all\, \UP\)
makeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\NO\), name, \all\, \NO\)
makeAcrossSampleScatterplotA485(data, unique(data$Anno2), c(\DOWN\), name, \all\, \DOWN\)

makeAcrossSampleScatterplotA485(data, c(\P-P\, \P-E\, \E-E\), c(\UP\, \NO\, \DOWN\), name, \pe-pe\, \all\)
makeAcrossSampleScatterplotA485(data, c(\P-P\, \P-E\, \E-E\), c(\UP\), name, \pe-pe\, \UP\)
makeAcrossSampleScatterplotA485(data, c(\P-P\, \P-E\, \E-E\), c(\NO\), name, \pe-pe\, \NO\)
makeAcrossSampleScatterplotA485(data, c(\P-P\, \P-E\, \E-E\), c(\DOWN\), name, \pe-pe\, \DOWN\)

makeAcrossSampleScatterplotA485(data, c(\S-S\, \S-X\), c(\UP\, \NO\, \DOWN\), name, \str\, \all\)
makeAcrossSampleScatterplotA485(data, c(\S-S\, \S-X\), c(\UP\), name, \str\, \UP\)
makeAcrossSampleScatterplotA485(data, c(\S-S\, \S-X\), c(\NO\), name, \str\, \NO\)
makeAcrossSampleScatterplotA485(data, c(\S-S\, \S-X\), c(\DOWN\), name, \str\, \DOWN\)

######## Barplot
temp <- data %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO)
ggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = \dashed\) +
  geom_hline(yintercept = -0.2, linetype = \dashed\) + coord_cartesian(ylim = c(-0.5, 0.5))

temp <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\)) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) 
ggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = \dashed\) +
  geom_hline(yintercept = -0.2, linetype = \dashed\) + coord_cartesian(ylim = c(-0.5, 0.5))


temp <- data %>% dplyr::filter(Anno2 %in% c(\S-S\, \S-X\)) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) 
ggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = \dashed\) +
  geom_hline(yintercept = -0.2, linetype = \dashed\) + coord_cartesian(ylim = c(-0.5, 0.5))

###
temp <- data %>% dplyr::select(updown_A485_DMSO, diff_dTAG_DMSO)
ggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = \dashed\) +
  geom_hline(yintercept = -0.2, linetype = \dashed\) + coord_cartesian(ylim = c(-0.5, 0.5))

temp <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\)) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)
ggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = \dashed\) +
  geom_hline(yintercept = -0.2, linetype = \dashed\) + coord_cartesian(ylim = c(-0.5, 0.5))


temp <- data %>% dplyr::filter(Anno2 %in% c(\S-S\, \S-X\)) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)
ggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = \dashed\) +
  geom_hline(yintercept = -0.2, linetype = \dashed\) + coord_cartesian(ylim = c(-0.5, 0.5))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



## [2.28] Comparing differential loops in dTAG to A485
The question I want to ask here is whether perturbed loops in dTAG experiments are either perturbed or not perturbed in A485 experiment. If there is compensation going on between RAD21 and A485, UP loop in RAD21 should be more DOWN in A485 and vice versa
#### Exploratory part

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyMjIElNUE9SVElORyBDT01QQVJNVE5FVCBTQ09SRVNcbmNvbXBEaXIgPC0gaGVyZShcIi4uLy4uXCIsIFwicmVzdWx0XCIsIFwiY29tcGFydG1lbnRcIiwgXCJDc2NvcmVUb29sc1wiKVxuXG5jc2NvcmUuRE1TTyA8LSBhc190aWJibGUoZnJlYWQoaGVyZShjb21wRGlyLCBcIkcxRE1TT19NZXJnZWRfMTBrYl9jc2NvcmVfZmluYWwuYmVkZ3JhcGhcIiksIHNraXAgPSAxKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVjIgPSBWMiArIDEpXG5jb2xuYW1lcyhjc2NvcmUuRE1TTykgPC0gYyhcImNoclwiLCBcInN0YXJ0XCIsIFwiZW5kXCIsIFwiY3Njb3JlX0RNU09cIilcblxuY3Njb3JlLkE0ODUgPC0gYXNfdGliYmxlKGZyZWFkKGhlcmUoY29tcERpciwgXCJHMUE0ODVfTWVyZ2VkXzEwa2JfY3Njb3JlX2ZpbmFsLmJlZGdyYXBoXCIpLCBza2lwID0gMSkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFYyID0gVjIgKyAxKVxuY29sbmFtZXMoY3Njb3JlLkE0ODUpIDwtIGMoXCJjaHJcIiwgXCJzdGFydFwiLCBcImVuZFwiLCBcImNzY29yZV9BNDg1XCIpXG5cblxuY3Njb3JlIDwtIGRwbHlyOjpmdWxsX2pvaW4oY3Njb3JlLkRNU08sIGNzY29yZS5BNDg1LCBieSA9IGMoXCJjaHJcIiwgXCJzdGFydFwiLCBcImVuZFwiKSlcblxuIyBGSUxURVIgUk9XUyBXSVRIIE5BXG5jc2NvcmUgPC0gY3Njb3JlICU+JSBmaWx0ZXIoIWlmX2FueShldmVyeXRoaW5nKCksIGlzLm5hKSlcblxuIyBBbm5vdGF0aW5nIGhvdyB0aGUgY29tcGFydG1lbnQgY2hhbmdlZFxudGhyZXNob2xkIDwtIDAuMVxuY3Njb3JlIDwtIGNzY29yZSAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKGlzQUJfRE1TTyA9IGlmZWxzZShjc2NvcmVfRE1TTyA+IDAsIFwiQVwiLCBcIkJcIiksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaXNBQl9BNDg1ID0gaWZlbHNlKGNzY29yZV9BNDg1ID4gMCwgXCJBXCIsIFwiQlwiKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjaGFuZ2VUeXBlID0gY2FzZV93aGVuKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWJzKGNzY29yZV9ETVNPIC0gY3Njb3JlX0E0ODUpIDwgdGhyZXNob2xkIH4gXCJVbmNoYW5nZWRcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlzQUJfRE1TTyA9PSBcIkFcIiAmIGlzQUJfQTQ4NSA9PSBcIkJcIiB+IFwiQXRvQlwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaXNBQl9ETVNPID09IFwiQlwiICYgaXNBQl9BNDg1ID09IFwiQVwiIH4gXCJCdG9BXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpc0FCX0RNU08gPT0gXCJBXCIgJiBpc0FCX0E0ODUgPT0gXCJBXCIgJiBhYnMoY3Njb3JlX0RNU08pID4gYWJzKGNzY29yZV9BNDg1KSB+IFwiQV93ZWFrZW5pbmdcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlzQUJfRE1TTyA9PSBcIkFcIiAmIGlzQUJfQTQ4NSA9PSBcIkFcIiAmIGFicyhjc2NvcmVfRE1TTykgPD0gYWJzKGNzY29yZV9BNDg1KSB+IFwiQV9zdHJlbmd0aGVuaW5nXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpc0FCX0RNU08gPT0gXCJCXCIgJiBpc0FCX0E0ODUgPT0gXCJCXCIgJiBhYnMoY3Njb3JlX0RNU08pID4gYWJzKGNzY29yZV9BNDg1KSB+IFwiQl93ZWFrZW5pbmdcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlzQUJfRE1TTyA9PSBcIkJcIiAmIGlzQUJfQTQ4NSA9PSBcIkJcIiAmIGFicyhjc2NvcmVfRE1TTykgPD0gYWJzKGNzY29yZV9BNDg1KSB+IFwiQl9zdHJlbmd0aGVuaW5nXCIgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKSlcbmNzY29yZV9zdW1tYXJ5IDwtIHRpYmJsZShjb21wYXJpc29uID0gcmVwKFwiQTQ4NV92c19ETVNPXCIsIDcpLFxuICAgICAgICAgICAgICAgICAgICAgICAgIGNoYW5nZVR5cGUgPSBjKFwiQXRvQlwiLCBcIkJ0b0FcIiwgXCJBX3dlYWtlbmluZ1wiLCBcIkFfc3RyZW5ndGhlbmluZ1wiLCBcIkJfd2Vha2VuaW5nXCIsIFwiQl9zdHJlbmd0aGVuaW5nXCIsIFwiVW5jaGFuZ2VkXCIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgIHZhbHVlID0gYyhzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXCJBdG9CXCIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXCJCdG9BXCIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXCJBX3dlYWtlbmluZ1wiKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3VtKGNzY29yZSRjaGFuZ2VUeXBlID09IFwiQV9zdHJlbmd0aGVuaW5nXCIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXCJCX3dlYWtlbmluZ1wiKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3VtKGNzY29yZSRjaGFuZ2VUeXBlID09IFwiQl9zdHJlbmd0aGVuaW5nXCIpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXCJVbmNoYW5nZWRcIikpKVxuY3Njb3JlX3N1bW1hcnkkY2hhbmdlVHlwZSA8LSBmYWN0b3IoY3Njb3JlX3N1bW1hcnkkY2hhbmdlVHlwZSwgbGV2ZWxzID0gYyhcIkFfd2Vha2VuaW5nXCIsIFwiQXRvQlwiLCBcIkJfc3RyZW5ndGhlbmluZ1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIkJfd2Vha2VuaW5nXCIsIFwiQnRvQVwiLCBcIkFfc3RyZW5ndGhlbmluZ1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcIlVuY2hhbmdlZFwiKSlcbmdncGxvdChjc2NvcmVfc3VtbWFyeSwgYWVzKHggPSBjb21wYXJpc29uLCB5ID0gdmFsdWUsIGZpbGwgPSBjaGFuZ2VUeXBlKSkgKyBnZW9tX2Jhcihwb3NpdGlvbiA9IFwic3RhY2tcIiwgc3RhdCA9IFwiaWRlbnRpdHlcIikgK1xuICB0aGVtZV9idygpICtcbiAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcInNreWJsdWVcIiwgXCJibHVlXCIsIFwiZGFya2JsdWVcIiwgXCJwaW5rXCIsIFwicmVkMlwiLCBcImRhcmtyZWRcIiAsXCJncmV5XCIpKVxuICBcbmBgYCJ9 -->\n\n```r\n### IMPORTING COMPARMTNET SCORES\ncompDir <- here(\\../..\\, \\result\\, \\compartment\\, \\CscoreTools\\)\n\ncscore.DMSO <- as_tibble(fread(here(compDir, \\G1DMSO_Merged_10kb_cscore_final.bedgraph\\), skip = 1)) %>%\n  dplyr::mutate(V2 = V2 + 1)\ncolnames(cscore.DMSO) <- c(\\chr\\, \\start\\, \\end\\, \\cscore_DMSO\\)\n\ncscore.A485 <- as_tibble(fread(here(compDir, \\G1A485_Merged_10kb_cscore_final.bedgraph\\), skip = 1)) %>%\n  dplyr::mutate(V2 = V2 + 1)\ncolnames(cscore.A485) <- c(\\chr\\, \\start\\, \\end\\, \\cscore_A485\\)\n\n\ncscore <- dplyr::full_join(cscore.DMSO, cscore.A485, by = c(\\chr\\, \\start\\, \\end\\))\n\n# FILTER ROWS WITH NA\ncscore <- cscore %>% filter(!if_any(everything(), is.na))\n\n# Annotating how the compartment changed\nthreshold <- 0.1\ncscore <- cscore %>% rowwise() %>% dplyr::mutate(isAB_DMSO = ifelse(cscore_DMSO > 0, \\A\\, \\B\\),\n                                                 isAB_A485 = ifelse(cscore_A485 > 0, \\A\\, \\B\\),\n                                                 changeType = case_when(\n                                                   abs(cscore_DMSO - cscore_A485) < threshold ~ \\Unchanged\\,\n                                                   isAB_DMSO == \\A\\ & isAB_A485 == \\B\\ ~ \\AtoB\\,\n                                                   isAB_DMSO == \\B\\ & isAB_A485 == \\A\\ ~ \\BtoA\\,\n                                                   isAB_DMSO == \\A\\ & isAB_A485 == \\A\\ & abs(cscore_DMSO) > abs(cscore_A485) ~ \\A_weakening\\,\n                                                   isAB_DMSO == \\A\\ & isAB_A485 == \\A\\ & abs(cscore_DMSO) <= abs(cscore_A485) ~ \\A_strengthening\\,\n                                                   isAB_DMSO == \\B\\ & isAB_A485 == \\B\\ & abs(cscore_DMSO) > abs(cscore_A485) ~ \\B_weakening\\,\n                                                   isAB_DMSO == \\B\\ & isAB_A485 == \\B\\ & abs(cscore_DMSO) <= abs(cscore_A485) ~ \\B_strengthening\\                                                 ))\ncscore_summary <- tibble(comparison = rep(\\A485_vs_DMSO\\, 7),\n                         changeType = c(\\AtoB\\, \\BtoA\\, \\A_weakening\\, \\A_strengthening\\, \\B_weakening\\, \\B_strengthening\\, \\Unchanged\\),\n                         value = c(sum(cscore$changeType == \\AtoB\\),\n                                   sum(cscore$changeType == \\BtoA\\),\n                                   sum(cscore$changeType == \\A_weakening\\),\n                                   sum(cscore$changeType == \\A_strengthening\\),\n                                   sum(cscore$changeType == \\B_weakening\\),\n                                   sum(cscore$changeType == \\B_strengthening\\),\n                                   sum(cscore$changeType == \\Unchanged\\)))\ncscore_summary$changeType <- factor(cscore_summary$changeType, levels = c(\\A_weakening\\, \\AtoB\\, \\B_strengthening\\,\n                                                                          \\B_weakening\\, \\BtoA\\, \\A_strengthening\\,\n                                                                          \\Unchanged\\))\nggplot(cscore_summary, aes(x = comparison, y = value, fill = changeType)) + geom_bar(position = \\stack\\, stat = \\identity\\) +\n  theme_bw() +\n  scale_fill_manual(values = c(\\skyblue\\, \\blue\\, \\darkblue\\, \\pink\\, \\red2\\, \\darkred\\ ,\\grey\\))\n  \n```\n\n<!-- rnb-source-end -->\n"} -->
### IMPORTING COMPARMTNET SCORES
compDir <- here(\../..\, \result\, \compartment\, \CscoreTools\)

cscore.DMSO <- as_tibble(fread(here(compDir, \G1DMSO_Merged_10kb_cscore_final.bedgraph\), skip = 1)) %>%
  dplyr::mutate(V2 = V2 + 1)
colnames(cscore.DMSO) <- c(\chr\, \start\, \end\, \cscore_DMSO\)

cscore.A485 <- as_tibble(fread(here(compDir, \G1A485_Merged_10kb_cscore_final.bedgraph\), skip = 1)) %>%
  dplyr::mutate(V2 = V2 + 1)
colnames(cscore.A485) <- c(\chr\, \start\, \end\, \cscore_A485\)


cscore <- dplyr::full_join(cscore.DMSO, cscore.A485, by = c(\chr\, \start\, \end\))

# FILTER ROWS WITH NA
cscore <- cscore %>% filter(!if_any(everything(), is.na))

# Annotating how the compartment changed
threshold <- 0.1
cscore <- cscore %>% rowwise() %>% dplyr::mutate(isAB_DMSO = ifelse(cscore_DMSO > 0, \A\, \B\),
                                                 isAB_A485 = ifelse(cscore_A485 > 0, \A\, \B\),
                                                 changeType = case_when(
                                                   abs(cscore_DMSO - cscore_A485) < threshold ~ \Unchanged\,
                                                   isAB_DMSO == \A\ & isAB_A485 == \B\ ~ \AtoB\,
                                                   isAB_DMSO == \B\ & isAB_A485 == \A\ ~ \BtoA\,
                                                   isAB_DMSO == \A\ & isAB_A485 == \A\ & abs(cscore_DMSO) > abs(cscore_A485) ~ \A_weakening\,
                                                   isAB_DMSO == \A\ & isAB_A485 == \A\ & abs(cscore_DMSO) <= abs(cscore_A485) ~ \A_strengthening\,
                                                   isAB_DMSO == \B\ & isAB_A485 == \B\ & abs(cscore_DMSO) > abs(cscore_A485) ~ \B_weakening\,
                                                   isAB_DMSO == \B\ & isAB_A485 == \B\ & abs(cscore_DMSO) <= abs(cscore_A485) ~ \B_strengthening\                                                 ))
cscore_summary <- tibble(comparison = rep(\A485_vs_DMSO\, 7),
                         changeType = c(\AtoB\, \BtoA\, \A_weakening\, \A_strengthening\, \B_weakening\, \B_strengthening\, \Unchanged\),
                         value = c(sum(cscore$changeType == \AtoB\),
                                   sum(cscore$changeType == \BtoA\),
                                   sum(cscore$changeType == \A_weakening\),
                                   sum(cscore$changeType == \A_strengthening\),
                                   sum(cscore$changeType == \B_weakening\),
                                   sum(cscore$changeType == \B_strengthening\),
                                   sum(cscore$changeType == \Unchanged\)))
cscore_summary$changeType <- factor(cscore_summary$changeType, levels = c(\A_weakening\, \AtoB\, \B_strengthening\,
                                                                          \B_weakening\, \BtoA\, \A_strengthening\,
                                                                          \Unchanged\))
ggplot(cscore_summary, aes(x = comparison, y = value, fill = changeType)) + geom_bar(position = \stack\, stat = \identity\) +
  theme_bw() +
  scale_fill_manual(values = c(\skyblue\, \blue\, \darkblue\, \pink\, \red2\, \darkred\ ,\grey\))
  



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIElNUE9SVElORyBDT01QQVJNVE5FVCBTQ09SRVNcbmNvbXBEaXIgPC0gaGVyZShcXC4uLy4uXFwsIFxccmVzdWx0XFwsIFxcY29tcGFydG1lbnRcXCwgXFxDc2NvcmVUb29sc1xcKVxuXG5jc2NvcmUuRE1TTyA8LSBhc190aWJibGUoZnJlYWQoaGVyZShjb21wRGlyLCBcXEcxRE1TT19NZXJnZWRfMTBrYl9jc2NvcmVfZmluYWwuYmVkZ3JhcGhcXCksIHNraXAgPSAxKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVjIgPSBWMiArIDEpXG5jb2xuYW1lcyhjc2NvcmUuRE1TTykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcY3Njb3JlX0RNU09cXClcblxuY3Njb3JlLkE0ODUgPC0gYXNfdGliYmxlKGZyZWFkKGhlcmUoY29tcERpciwgXFxHMUE0ODVfTWVyZ2VkXzEwa2JfY3Njb3JlX2ZpbmFsLmJlZGdyYXBoXFwpLCBza2lwID0gMSkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFYyID0gVjIgKyAxKVxuY29sbmFtZXMoY3Njb3JlLkE0ODUpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGNzY29yZV9BNDg1XFwpXG5cblxuY3Njb3JlIDwtIGRwbHlyOjpmdWxsX2pvaW4oY3Njb3JlLkRNU08sIGNzY29yZS5BNDg1LCBieSA9IGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKSlcblxuIyBGSUxURVIgUk9XUyBXSVRIIE5BXG5jc2NvcmUgPC0gY3Njb3JlICU+JSBmaWx0ZXIoIWlmX2FueShldmVyeXRoaW5nKCksIGlzLm5hKSlcblxuIyBBbm5vdGF0aW5nIGhvdyB0aGUgY29tcGFydG1lbnQgY2hhbmdlZFxudGhyZXNob2xkIDwtIDAuMVxuY3Njb3JlIDwtIGNzY29yZSAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKGlzQUJfRE1TTyA9IGlmZWxzZShjc2NvcmVfRE1TTyA+IDAsIFxcQVxcLCBcXEJcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaXNBQl9BNDg1ID0gaWZlbHNlKGNzY29yZV9BNDg1ID4gMCwgXFxBXFwsIFxcQlxcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjaGFuZ2VUeXBlID0gY2FzZV93aGVuKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWJzKGNzY29yZV9ETVNPIC0gY3Njb3JlX0E0ODUpIDwgdGhyZXNob2xkIH4gXFxVbmNoYW5nZWRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlzQUJfRE1TTyA9PSBcXEFcXCAmIGlzQUJfQTQ4NSA9PSBcXEJcXCB+IFxcQXRvQlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaXNBQl9ETVNPID09IFxcQlxcICYgaXNBQl9BNDg1ID09IFxcQVxcIH4gXFxCdG9BXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpc0FCX0RNU08gPT0gXFxBXFwgJiBpc0FCX0E0ODUgPT0gXFxBXFwgJiBhYnMoY3Njb3JlX0RNU08pID4gYWJzKGNzY29yZV9BNDg1KSB+IFxcQV93ZWFrZW5pbmdcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlzQUJfRE1TTyA9PSBcXEFcXCAmIGlzQUJfQTQ4NSA9PSBcXEFcXCAmIGFicyhjc2NvcmVfRE1TTykgPD0gYWJzKGNzY29yZV9BNDg1KSB+IFxcQV9zdHJlbmd0aGVuaW5nXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpc0FCX0RNU08gPT0gXFxCXFwgJiBpc0FCX0E0ODUgPT0gXFxCXFwgJiBhYnMoY3Njb3JlX0RNU08pID4gYWJzKGNzY29yZV9BNDg1KSB+IFxcQl93ZWFrZW5pbmdcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlzQUJfRE1TTyA9PSBcXEJcXCAmIGlzQUJfQTQ4NSA9PSBcXEJcXCAmIGFicyhjc2NvcmVfRE1TTykgPD0gYWJzKGNzY29yZV9BNDg1KSB+IFxcQl9zdHJlbmd0aGVuaW5nXFwgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKSlcbmNzY29yZV9zdW1tYXJ5IDwtIHRpYmJsZShjb21wYXJpc29uID0gcmVwKFxcQTQ4NV92c19ETVNPXFwsIDcpLFxuICAgICAgICAgICAgICAgICAgICAgICAgIGNoYW5nZVR5cGUgPSBjKFxcQXRvQlxcLCBcXEJ0b0FcXCwgXFxBX3dlYWtlbmluZ1xcLCBcXEFfc3RyZW5ndGhlbmluZ1xcLCBcXEJfd2Vha2VuaW5nXFwsIFxcQl9zdHJlbmd0aGVuaW5nXFwsIFxcVW5jaGFuZ2VkXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgIHZhbHVlID0gYyhzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXFxBdG9CXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXFxCdG9BXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXFxBX3dlYWtlbmluZ1xcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3VtKGNzY29yZSRjaGFuZ2VUeXBlID09IFxcQV9zdHJlbmd0aGVuaW5nXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXFxCX3dlYWtlbmluZ1xcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3VtKGNzY29yZSRjaGFuZ2VUeXBlID09IFxcQl9zdHJlbmd0aGVuaW5nXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXFxVbmNoYW5nZWRcXCkpKVxuY3Njb3JlX3N1bW1hcnkkY2hhbmdlVHlwZSA8LSBmYWN0b3IoY3Njb3JlX3N1bW1hcnkkY2hhbmdlVHlwZSwgbGV2ZWxzID0gYyhcXEFfd2Vha2VuaW5nXFwsIFxcQXRvQlxcLCBcXEJfc3RyZW5ndGhlbmluZ1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXEJfd2Vha2VuaW5nXFwsIFxcQnRvQVxcLCBcXEFfc3RyZW5ndGhlbmluZ1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFVuY2hhbmdlZFxcKSlcbmdncGxvdChjc2NvcmVfc3VtbWFyeSwgYWVzKHggPSBjb21wYXJpc29uLCB5ID0gdmFsdWUsIGZpbGwgPSBjaGFuZ2VUeXBlKSkgKyBnZW9tX2Jhcihwb3NpdGlvbiA9IFxcc3RhY2tcXCwgc3RhdCA9IFxcaWRlbnRpdHlcXCkgK1xuICB0aGVtZV9idygpICtcbiAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcXHNreWJsdWVcXCwgXFxibHVlXFwsIFxcZGFya2JsdWVcXCwgXFxwaW5rXFwsIFxccmVkMlxcLCBcXGRhcmtyZWRcXCAsXFxncmV5XFwpKVxuICBcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\n### IMPORTING COMPARMTNET SCORES\ncompDir <- here(\\../..\\, \\result\\, \\compartment\\, \\CscoreTools\\)\n\ncscore.DMSO <- as_tibble(fread(here(compDir, \\G1DMSO_Merged_10kb_cscore_final.bedgraph\\), skip = 1)) %>%\n  dplyr::mutate(V2 = V2 + 1)\ncolnames(cscore.DMSO) <- c(\\chr\\, \\start\\, \\end\\, \\cscore_DMSO\\)\n\ncscore.A485 <- as_tibble(fread(here(compDir, \\G1A485_Merged_10kb_cscore_final.bedgraph\\), skip = 1)) %>%\n  dplyr::mutate(V2 = V2 + 1)\ncolnames(cscore.A485) <- c(\\chr\\, \\start\\, \\end\\, \\cscore_A485\\)\n\n\ncscore <- dplyr::full_join(cscore.DMSO, cscore.A485, by = c(\\chr\\, \\start\\, \\end\\))\n\n# FILTER ROWS WITH NA\ncscore <- cscore %>% filter(!if_any(everything(), is.na))\n\n# Annotating how the compartment changed\nthreshold <- 0.1\ncscore <- cscore %>% rowwise() %>% dplyr::mutate(isAB_DMSO = ifelse(cscore_DMSO > 0, \\A\\, \\B\\),\n                                                 isAB_A485 = ifelse(cscore_A485 > 0, \\A\\, \\B\\),\n                                                 changeType = case_when(\n                                                   abs(cscore_DMSO - cscore_A485) < threshold ~ \\Unchanged\\,\n                                                   isAB_DMSO == \\A\\ & isAB_A485 == \\B\\ ~ \\AtoB\\,\n                                                   isAB_DMSO == \\B\\ & isAB_A485 == \\A\\ ~ \\BtoA\\,\n                                                   isAB_DMSO == \\A\\ & isAB_A485 == \\A\\ & abs(cscore_DMSO) > abs(cscore_A485) ~ \\A_weakening\\,\n                                                   isAB_DMSO == \\A\\ & isAB_A485 == \\A\\ & abs(cscore_DMSO) <= abs(cscore_A485) ~ \\A_strengthening\\,\n                                                   isAB_DMSO == \\B\\ & isAB_A485 == \\B\\ & abs(cscore_DMSO) > abs(cscore_A485) ~ \\B_weakening\\,\n                                                   isAB_DMSO == \\B\\ & isAB_A485 == \\B\\ & abs(cscore_DMSO) <= abs(cscore_A485) ~ \\B_strengthening\\                                                 ))\ncscore_summary <- tibble(comparison = rep(\\A485_vs_DMSO\\, 7),\n                         changeType = c(\\AtoB\\, \\BtoA\\, \\A_weakening\\, \\A_strengthening\\, \\B_weakening\\, \\B_strengthening\\, \\Unchanged\\),\n                         value = c(sum(cscore$changeType == \\AtoB\\),\n                                   sum(cscore$changeType == \\BtoA\\),\n                                   sum(cscore$changeType == \\A_weakening\\),\n                                   sum(cscore$changeType == \\A_strengthening\\),\n                                   sum(cscore$changeType == \\B_weakening\\),\n                                   sum(cscore$changeType == \\B_strengthening\\),\n                                   sum(cscore$changeType == \\Unchanged\\)))\ncscore_summary$changeType <- factor(cscore_summary$changeType, levels = c(\\A_weakening\\, \\AtoB\\, \\B_strengthening\\,\n                                                                          \\B_weakening\\, \\BtoA\\, \\A_strengthening\\,\n                                                                          \\Unchanged\\))\nggplot(cscore_summary, aes(x = comparison, y = value, fill = changeType)) + geom_bar(position = \\stack\\, stat = \\identity\\) +\n  theme_bw() +\n  scale_fill_manual(values = c(\\skyblue\\, \\blue\\, \\darkblue\\, \\pink\\, \\red2\\, \\darkred\\ ,\\grey\\))\n  \n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyMjIElNUE9SVElORyBDT01QQVJNVE5FVCBTQ09SRVNcbmNvbXBEaXIgPC0gaGVyZShcXC4uLy4uXFwsIFxccmVzdWx0XFwsIFxcY29tcGFydG1lbnRcXCwgXFxDc2NvcmVUb29sc1xcKVxuXG5jc2NvcmUuRE1TTyA8LSBhc190aWJibGUoZnJlYWQoaGVyZShjb21wRGlyLCBcXEcxRE1TT19NZXJnZWRfMTBrYl9jc2NvcmVfZmluYWwuYmVkZ3JhcGhcXCksIHNraXAgPSAxKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVjIgPSBWMiArIDEpXG5jb2xuYW1lcyhjc2NvcmUuRE1TTykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcY3Njb3JlX0RNU09cXClcblxuY3Njb3JlLkE0ODUgPC0gYXNfdGliYmxlKGZyZWFkKGhlcmUoY29tcERpciwgXFxHMUE0ODVfTWVyZ2VkXzEwa2JfY3Njb3JlX2ZpbmFsLmJlZGdyYXBoXFwpLCBza2lwID0gMSkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFYyID0gVjIgKyAxKVxuY29sbmFtZXMoY3Njb3JlLkE0ODUpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGNzY29yZV9BNDg1XFwpXG5cblxuY3Njb3JlIDwtIGRwbHlyOjpmdWxsX2pvaW4oY3Njb3JlLkRNU08sIGNzY29yZS5BNDg1LCBieSA9IGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKSlcblxuIyBGSUxURVIgUk9XUyBXSVRIIE5BXG5jc2NvcmUgPC0gY3Njb3JlICU+JSBmaWx0ZXIoIWlmX2FueShldmVyeXRoaW5nKCksIGlzLm5hKSlcblxuIyBBbm5vdGF0aW5nIGhvdyB0aGUgY29tcGFydG1lbnQgY2hhbmdlZFxudGhyZXNob2xkIDwtIDAuMVxuY3Njb3JlIDwtIGNzY29yZSAlPiUgcm93d2lzZSgpICU+JSBkcGx5cjo6bXV0YXRlKGlzQUJfRE1TTyA9IGlmZWxzZShjc2NvcmVfRE1TTyA+IDAsIFxcQVxcLCBcXEJcXCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaXNBQl9BNDg1ID0gaWZlbHNlKGNzY29yZV9BNDg1ID4gMCwgXFxBXFwsIFxcQlxcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjaGFuZ2VUeXBlID0gY2FzZV93aGVuKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWJzKGNzY29yZV9ETVNPIC0gY3Njb3JlX0E0ODUpIDwgdGhyZXNob2xkIH4gXFxVbmNoYW5nZWRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlzQUJfRE1TTyA9PSBcXEFcXCAmIGlzQUJfQTQ4NSA9PSBcXEJcXCB+IFxcQXRvQlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaXNBQl9ETVNPID09IFxcQlxcICYgaXNBQl9BNDg1ID09IFxcQVxcIH4gXFxCdG9BXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpc0FCX0RNU08gPT0gXFxBXFwgJiBpc0FCX0E0ODUgPT0gXFxBXFwgJiBhYnMoY3Njb3JlX0RNU08pID4gYWJzKGNzY29yZV9BNDg1KSB+IFxcQV93ZWFrZW5pbmdcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlzQUJfRE1TTyA9PSBcXEFcXCAmIGlzQUJfQTQ4NSA9PSBcXEFcXCAmIGFicyhjc2NvcmVfRE1TTykgPD0gYWJzKGNzY29yZV9BNDg1KSB+IFxcQV9zdHJlbmd0aGVuaW5nXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpc0FCX0RNU08gPT0gXFxCXFwgJiBpc0FCX0E0ODUgPT0gXFxCXFwgJiBhYnMoY3Njb3JlX0RNU08pID4gYWJzKGNzY29yZV9BNDg1KSB+IFxcQl93ZWFrZW5pbmdcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlzQUJfRE1TTyA9PSBcXEJcXCAmIGlzQUJfQTQ4NSA9PSBcXEJcXCAmIGFicyhjc2NvcmVfRE1TTykgPD0gYWJzKGNzY29yZV9BNDg1KSB+IFxcQl9zdHJlbmd0aGVuaW5nXFwgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKSlcbmNzY29yZV9zdW1tYXJ5IDwtIHRpYmJsZShjb21wYXJpc29uID0gcmVwKFxcQTQ4NV92c19ETVNPXFwsIDcpLFxuICAgICAgICAgICAgICAgICAgICAgICAgIGNoYW5nZVR5cGUgPSBjKFxcQXRvQlxcLCBcXEJ0b0FcXCwgXFxBX3dlYWtlbmluZ1xcLCBcXEFfc3RyZW5ndGhlbmluZ1xcLCBcXEJfd2Vha2VuaW5nXFwsIFxcQl9zdHJlbmd0aGVuaW5nXFwsIFxcVW5jaGFuZ2VkXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgIHZhbHVlID0gYyhzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXFxBdG9CXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXFxCdG9BXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXFxBX3dlYWtlbmluZ1xcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3VtKGNzY29yZSRjaGFuZ2VUeXBlID09IFxcQV9zdHJlbmd0aGVuaW5nXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXFxCX3dlYWtlbmluZ1xcKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3VtKGNzY29yZSRjaGFuZ2VUeXBlID09IFxcQl9zdHJlbmd0aGVuaW5nXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdW0oY3Njb3JlJGNoYW5nZVR5cGUgPT0gXFxVbmNoYW5nZWRcXCkpKVxuY3Njb3JlX3N1bW1hcnkkY2hhbmdlVHlwZSA8LSBmYWN0b3IoY3Njb3JlX3N1bW1hcnkkY2hhbmdlVHlwZSwgbGV2ZWxzID0gYyhcXEFfd2Vha2VuaW5nXFwsIFxcQXRvQlxcLCBcXEJfc3RyZW5ndGhlbmluZ1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXEJfd2Vha2VuaW5nXFwsIFxcQnRvQVxcLCBcXEFfc3RyZW5ndGhlbmluZ1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXFVuY2hhbmdlZFxcKSlcbmdncGxvdChjc2NvcmVfc3VtbWFyeSwgYWVzKHggPSBjb21wYXJpc29uLCB5ID0gdmFsdWUsIGZpbGwgPSBjaGFuZ2VUeXBlKSkgKyBnZW9tX2Jhcihwb3NpdGlvbiA9IFxcc3RhY2tcXCwgc3RhdCA9IFxcaWRlbnRpdHlcXCkgK1xuICB0aGVtZV9idygpICtcbiAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcXHNreWJsdWVcXCwgXFxibHVlXFwsIFxcZGFya2JsdWVcXCwgXFxwaW5rXFwsIFxccmVkMlxcLCBcXGRhcmtyZWRcXCAsXFxncmV5XFwpKVxuICBcbmBgYFxuYGBgIn0= -->

```r
```r
### IMPORTING COMPARMTNET SCORES
compDir <- here(\../..\, \result\, \compartment\, \CscoreTools\)

cscore.DMSO <- as_tibble(fread(here(compDir, \G1DMSO_Merged_10kb_cscore_final.bedgraph\), skip = 1)) %>%
  dplyr::mutate(V2 = V2 + 1)
colnames(cscore.DMSO) <- c(\chr\, \start\, \end\, \cscore_DMSO\)

cscore.A485 <- as_tibble(fread(here(compDir, \G1A485_Merged_10kb_cscore_final.bedgraph\), skip = 1)) %>%
  dplyr::mutate(V2 = V2 + 1)
colnames(cscore.A485) <- c(\chr\, \start\, \end\, \cscore_A485\)


cscore <- dplyr::full_join(cscore.DMSO, cscore.A485, by = c(\chr\, \start\, \end\))

# FILTER ROWS WITH NA
cscore <- cscore %>% filter(!if_any(everything(), is.na))

# Annotating how the compartment changed
threshold <- 0.1
cscore <- cscore %>% rowwise() %>% dplyr::mutate(isAB_DMSO = ifelse(cscore_DMSO > 0, \A\, \B\),
                                                 isAB_A485 = ifelse(cscore_A485 > 0, \A\, \B\),
                                                 changeType = case_when(
                                                   abs(cscore_DMSO - cscore_A485) < threshold ~ \Unchanged\,
                                                   isAB_DMSO == \A\ & isAB_A485 == \B\ ~ \AtoB\,
                                                   isAB_DMSO == \B\ & isAB_A485 == \A\ ~ \BtoA\,
                                                   isAB_DMSO == \A\ & isAB_A485 == \A\ & abs(cscore_DMSO) > abs(cscore_A485) ~ \A_weakening\,
                                                   isAB_DMSO == \A\ & isAB_A485 == \A\ & abs(cscore_DMSO) <= abs(cscore_A485) ~ \A_strengthening\,
                                                   isAB_DMSO == \B\ & isAB_A485 == \B\ & abs(cscore_DMSO) > abs(cscore_A485) ~ \B_weakening\,
                                                   isAB_DMSO == \B\ & isAB_A485 == \B\ & abs(cscore_DMSO) <= abs(cscore_A485) ~ \B_strengthening\                                                 ))
cscore_summary <- tibble(comparison = rep(\A485_vs_DMSO\, 7),
                         changeType = c(\AtoB\, \BtoA\, \A_weakening\, \A_strengthening\, \B_weakening\, \B_strengthening\, \Unchanged\),
                         value = c(sum(cscore$changeType == \AtoB\),
                                   sum(cscore$changeType == \BtoA\),
                                   sum(cscore$changeType == \A_weakening\),
                                   sum(cscore$changeType == \A_strengthening\),
                                   sum(cscore$changeType == \B_weakening\),
                                   sum(cscore$changeType == \B_strengthening\),
                                   sum(cscore$changeType == \Unchanged\)))
cscore_summary$changeType <- factor(cscore_summary$changeType, levels = c(\A_weakening\, \AtoB\, \B_strengthening\,
                                                                          \B_weakening\, \BtoA\, \A_strengthening\,
                                                                          \Unchanged\))
ggplot(cscore_summary, aes(x = comparison, y = value, fill = changeType)) + geom_bar(position = \stack\, stat = \identity\) +
  theme_bw() +
  scale_fill_manual(values = c(\skyblue\, \blue\, \darkblue\, \pink\, \red2\, \darkred\ ,\grey\))
  
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



#### Scatterplot & box plot

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcIitcIiwgVjIsIFYzKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTUywgVjYpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFwiY2hyXCIsIFwiVFNTXCIsIFwiZW5zZW1ibFwiKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJkaWZmX0cxLkE0ODUuc2VsZWN0ZWQyX0cxLjJpLkE0ODVfdnNfRzEuMmkuRE1TTy50c3ZcIikpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuZGlmZi5STkEgPC0gZGlmZi5STkEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4oZ2VuZS50YiwgYnkgPSBjKFwiZW5zZW1ibF9nZW5lX2lkXCIgPSBcImVuc2VtYmxcIikpICU+JVxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShUU1MpKVxuXG5hbHBoYSA8LSAwLjA1XG5mY0N1dG9mZiA8LSAwLjVcblxuZGlmZi5STkEgPC0gZGlmZi5STkEgJT4lIGRwbHlyOjptdXRhdGUoZGlmZiA9IGNhc2Vfd2hlbihwYWRqIDwgYWxwaGEgJiBzaHJpbmtlZF9sb2cyRkMgPiBmY0N1dG9mZiB+IFwiVVBcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkaiA8IGFscGhhICYgc2hyaW5rZWRfbG9nMkZDIDwgLWZjQ3V0b2ZmIH4gXCJET1dOXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBcIk5PXCIpKVxuXG5cbmdldENvbXBDaGFuZ2VUeXBlIDwtIGZ1bmN0aW9uKGNocm9tLCBUU1MsIGNzY29yZS50Yil7XG4gIHRlbXAudGIgPC0gY3Njb3JlLnRiICU+JSBkcGx5cjo6ZmlsdGVyKGNociA9PSBjaHJvbSwgc3RhcnQgPCBUU1MsIGVuZCA+IFRTUylcbiAgb3V0IDwtIHRlbXAudGIkY2hhbmdlVHlwZVxuICBpZihsZW5ndGgob3V0KSA8IDEpe1xuICAgIHJldHVybihOQSlcbiAgfWVsc2V7XG4gICAgcmV0dXJuKG91dClcbiAgfVxufVxuXG5jc2NvcmUuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGNzY29yZVsxOjNdKVxudGVtcCA8LWRpZmYuUk5BICU+JSBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gVFNTLCBlbmQgPSBUU1MgKzEpICU+JVxuICBkcGx5cjo6c2VsZWN0KGNociwgc3RhcnQsIGVuZClcbmRpZmYuUk5BLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMoZGlmZi5STkEuZ3IsIGNzY29yZS5ncilcblxuI2NzY29yZS5zZWxlY3RlZCA8LSBjc2NvcmUgJT4lIGRwbHlyOjpzbGljZShzdWJqZWN0SGl0cyhvdmVybGFwKSlcbiMjIFByb2JsZW0gb2YgY2VydGFpbiBnZW5lcyBub3QgZ2V0dGluZyBvdmVybGFwIHdpdGggY3Njb3JlIGR1ZSB0byBzcGFyc2UgY2FsbGluZz9cbmJhdGNoMSA8LSBiaW5kX2NvbHMoZGlmZi5STkFbcXVlcnlIaXRzKG92ZXJsYXApXSxcbiAgICAgICAgICBkYXRhLnRhYmxlKGNzY29yZSlbc3ViamVjdEhpdHMob3ZlcmxhcCldKVxuXG5cbm1pc3NlZCA8LSBkaWZmLlJOQVstcXVlcnlIaXRzKG92ZXJsYXApXVxudGVtcCA8LSBtaXNzZWQgJT4lIGRwbHlyOjptdXRhdGUoVFNTID0gVFNTICsgMTAwMDApICU+JSBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gVFNTLCBlbmQgPSBUU1MgKzEpICU+JVxuICBkcGx5cjo6c2VsZWN0KGNociwgc3RhcnQsIGVuZClcbm1pc3NlZC5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcbm92ZXJsYXAgPC0gZmluZE92ZXJsYXBzKG1pc3NlZC5nciwgY3Njb3JlLmdyKVxuYmF0Y2gyIDwtIGJpbmRfY29scyhtaXNzZWRbcXVlcnlIaXRzKG92ZXJsYXApXSxcbiAgICAgICAgICAgICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxubWlzc2VkMiA8LSBtaXNzZWRbLXF1ZXJ5SGl0cyhvdmVybGFwKV1cbnRlbXAgPC0gbWlzc2VkMiAlPiUgZHBseXI6Om11dGF0ZShUU1MgPSBUU1MgLSAxMDAwMCkgJT4lIGRwbHlyOjptdXRhdGUoc3RhcnQgPSBUU1MsIGVuZCA9IFRTUyArMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoY2hyLCBzdGFydCwgZW5kKVxubWlzc2VkLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMobWlzc2VkLmdyLCBjc2NvcmUuZ3IpXG5iYXRjaDMgPC0gYmluZF9jb2xzKG1pc3NlZDJbcXVlcnlIaXRzKG92ZXJsYXApXSxcbiAgICAgICAgICAgICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxuI21pc3NlZDMgPC0gbWlzc2VkMlstcXVlcnlIaXRzKG92ZXJsYXApXVxuXG5cbmRpZmYuUk5BIDwtIGJpbmRfcm93cyhiYXRjaDEsIGJhdGNoMiwgYmF0Y2gzKVxuXG5cbiMgVklTVUFMSVpFXG5kaWZmLlJOQSRjaGFuZ2VUeXBlIDwtIGZhY3RvcihkaWZmLlJOQSRjaGFuZ2VUeXBlLCBsZXZlbHMgPSBjKFwiQV93ZWFrZW5pbmdcIiwgXCJBdG9CXCIsIFwiQl9zdHJlbmd0aGVuaW5nXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiQl93ZWFrZW5pbmdcIiwgXCJCdG9BXCIsIFwiQV9zdHJlbmd0aGVuaW5nXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwiVW5jaGFuZ2VkXCIpKVxuZ2dwbG90KGRpZmYuUk5BLCBhZXMoeCA9IGRpZmYsIGZpbGwgPSBjaGFuZ2VUeXBlKSkgK1xuICBnZW9tX2Jhcihwb3NpdGlvbiA9IFwiZmlsbFwiKSArXG4gIGxhYnModGl0bGUgPSBcIlN0YWNrZWQgQmFyIFBsb3Qgb2YgQ2hhbmdlIFR5cGUgYnkgRGlmZlwiLFxuICAgICAgIHggPSBcIkRpZmZcIixcbiAgICAgICB5ID0gXCJDb3VudFwiKSArXG4gIHRoZW1lX2J3KCkgKyAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcInNreWJsdWVcIiwgXCJibHVlXCIsIFwiZGFya2JsdWVcIiwgXCJwaW5rXCIsIFwicmVkMlwiLCBcImRhcmtyZWRcIiAsXCJncmV5XCIpKVxuXG5cblxuYGBgIn0= -->\n\n```r\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V1, TSS, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\TSS\\, \\ensembl\\)\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\n\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\n\n\ngetCompChangeType <- function(chrom, TSS, cscore.tb){\n  temp.tb <- cscore.tb %>% dplyr::filter(chr == chrom, start < TSS, end > TSS)\n  out <- temp.tb$changeType\n  if(length(out) < 1){\n    return(NA)\n  }else{\n    return(out)\n  }\n}\n\ncscore.gr <- makeGRangesFromDataFrame(cscore[1:3])\ntemp <-diff.RNA %>% dplyr::mutate(start = TSS, end = TSS +1) %>%\n  dplyr::select(chr, start, end)\ndiff.RNA.gr <- makeGRangesFromDataFrame(temp)\noverlap <- findOverlaps(diff.RNA.gr, cscore.gr)\n\n#cscore.selected <- cscore %>% dplyr::slice(subjectHits(overlap))\n## Problem of certain genes not getting overlap with cscore due to sparse calling?\nbatch1 <- bind_cols(diff.RNA[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\nmissed <- diff.RNA[-queryHits(overlap)]\ntemp <- missed %>% dplyr::mutate(TSS = TSS + 10000) %>% dplyr::mutate(start = TSS, end = TSS +1) %>%\n  dplyr::select(chr, start, end)\nmissed.gr <- makeGRangesFromDataFrame(temp)\noverlap <- findOverlaps(missed.gr, cscore.gr)\nbatch2 <- bind_cols(missed[queryHits(overlap)],\n                    data.table(cscore)[subjectHits(overlap)])\n\nmissed2 <- missed[-queryHits(overlap)]\ntemp <- missed2 %>% dplyr::mutate(TSS = TSS - 10000) %>% dplyr::mutate(start = TSS, end = TSS +1) %>%\n  dplyr::select(chr, start, end)\nmissed.gr <- makeGRangesFromDataFrame(temp)\noverlap <- findOverlaps(missed.gr, cscore.gr)\nbatch3 <- bind_cols(missed2[queryHits(overlap)],\n                    data.table(cscore)[subjectHits(overlap)])\n\n#missed3 <- missed2[-queryHits(overlap)]\n\n\ndiff.RNA <- bind_rows(batch1, batch2, batch3)\n\n\n# VISUALIZE\ndiff.RNA$changeType <- factor(diff.RNA$changeType, levels = c(\\A_weakening\\, \\AtoB\\, \\B_strengthening\\,\n                                                                          \\B_weakening\\, \\BtoA\\, \\A_strengthening\\,\n                                                                          \\Unchanged\\))\nggplot(diff.RNA, aes(x = diff, fill = changeType)) +\n  geom_bar(position = \\fill\\) +\n  labs(title = \\Stacked Bar Plot of Change Type by Diff\\,\n       x = \\Diff\\,\n       y = \\Count\\) +\n  theme_bw() +  scale_fill_manual(values = c(\\skyblue\\, \\blue\\, \\darkblue\\, \\pink\\, \\red2\\, \\darkred\\ ,\\grey\\))\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V1, TSS, V6)
colnames(gene.tb) <- c(\chr\, \TSS\, \ensembl\)

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\ensembl_gene_id\ = \ensembl\)) %>%
  dplyr::filter(!is.na(TSS))

alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                                        TRUE ~ \NO\))


getCompChangeType <- function(chrom, TSS, cscore.tb){
  temp.tb <- cscore.tb %>% dplyr::filter(chr == chrom, start < TSS, end > TSS)
  out <- temp.tb$changeType
  if(length(out) < 1){
    return(NA)
  }else{
    return(out)
  }
}

cscore.gr <- makeGRangesFromDataFrame(cscore[1:3])
temp <-diff.RNA %>% dplyr::mutate(start = TSS, end = TSS +1) %>%
  dplyr::select(chr, start, end)
diff.RNA.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(diff.RNA.gr, cscore.gr)

#cscore.selected <- cscore %>% dplyr::slice(subjectHits(overlap))
## Problem of certain genes not getting overlap with cscore due to sparse calling?
batch1 <- bind_cols(diff.RNA[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


missed <- diff.RNA[-queryHits(overlap)]
temp <- missed %>% dplyr::mutate(TSS = TSS + 10000) %>% dplyr::mutate(start = TSS, end = TSS +1) %>%
  dplyr::select(chr, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch2 <- bind_cols(missed[queryHits(overlap)],
                    data.table(cscore)[subjectHits(overlap)])

missed2 <- missed[-queryHits(overlap)]
temp <- missed2 %>% dplyr::mutate(TSS = TSS - 10000) %>% dplyr::mutate(start = TSS, end = TSS +1) %>%
  dplyr::select(chr, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch3 <- bind_cols(missed2[queryHits(overlap)],
                    data.table(cscore)[subjectHits(overlap)])

#missed3 <- missed2[-queryHits(overlap)]


diff.RNA <- bind_rows(batch1, batch2, batch3)


# VISUALIZE
diff.RNA$changeType <- factor(diff.RNA$changeType, levels = c(\A_weakening\, \AtoB\, \B_strengthening\,
                                                                          \B_weakening\, \BtoA\, \A_strengthening\,
                                                                          \Unchanged\))
ggplot(diff.RNA, aes(x = diff, fill = changeType)) +
  geom_bar(position = \fill\) +
  labs(title = \Stacked Bar Plot of Change Type by Diff\,
       x = \Diff\,
       y = \Count\) +
  theme_bw() +  scale_fill_manual(values = c(\skyblue\, \blue\, \darkblue\, \pink\, \red2\, \darkred\ ,\grey\))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTUywgVjYpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFxcY2hyXFwsIFxcVFNTXFwsIFxcZW5zZW1ibFxcKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLkE0ODUuc2VsZWN0ZWQyX0cxLjJpLkE0ODVfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuZGlmZi5STkEgPC0gZGlmZi5STkEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4oZ2VuZS50YiwgYnkgPSBjKFxcZW5zZW1ibF9nZW5lX2lkXFwgPSBcXGVuc2VtYmxcXCkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShUU1MpKVxuXG5hbHBoYSA8LSAwLjA1XG5mY0N1dG9mZiA8LSAwLjVcblxuZGlmZi5STkEgPC0gZGlmZi5STkEgJT4lIGRwbHlyOjptdXRhdGUoZGlmZiA9IGNhc2Vfd2hlbihwYWRqIDwgYWxwaGEgJiBzaHJpbmtlZF9sb2cyRkMgPiBmY0N1dG9mZiB+IFxcVVBcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkaiA8IGFscGhhICYgc2hyaW5rZWRfbG9nMkZDIDwgLWZjQ3V0b2ZmIH4gXFxET1dOXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBcXE5PXFwpKVxuXG5cbmdldENvbXBDaGFuZ2VUeXBlIDwtIGZ1bmN0aW9uKGNocm9tLCBUU1MsIGNzY29yZS50Yil7XG4gIHRlbXAudGIgPC0gY3Njb3JlLnRiICU+JSBkcGx5cjo6ZmlsdGVyKGNociA9PSBjaHJvbSwgc3RhcnQgPCBUU1MsIGVuZCA+IFRTUylcbiAgb3V0IDwtIHRlbXAudGIkY2hhbmdlVHlwZVxuICBpZihsZW5ndGgob3V0KSA8IDEpe1xuICAgIHJldHVybihOQSlcbiAgfWVsc2V7XG4gICAgcmV0dXJuKG91dClcbiAgfVxufVxuXG5jc2NvcmUuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGNzY29yZVsxOjNdKVxudGVtcCA8LWRpZmYuUk5BICU+JSBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gVFNTLCBlbmQgPSBUU1MgKzEpICU+JVxuICBkcGx5cjo6c2VsZWN0KGNociwgc3RhcnQsIGVuZClcbmRpZmYuUk5BLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMoZGlmZi5STkEuZ3IsIGNzY29yZS5ncilcblxuI2NzY29yZS5zZWxlY3RlZCA8LSBjc2NvcmUgJT4lIGRwbHlyOjpzbGljZShzdWJqZWN0SGl0cyhvdmVybGFwKSlcbiMjIFByb2JsZW0gb2YgY2VydGFpbiBnZW5lcyBub3QgZ2V0dGluZyBvdmVybGFwIHdpdGggY3Njb3JlIGR1ZSB0byBzcGFyc2UgY2FsbGluZz9cbmJhdGNoMSA8LSBiaW5kX2NvbHMoZGlmZi5STkFbcXVlcnlIaXRzKG92ZXJsYXApXSxcbiAgICAgICAgICBkYXRhLnRhYmxlKGNzY29yZSlbc3ViamVjdEhpdHMob3ZlcmxhcCldKVxuXG5cbm1pc3NlZCA8LSBkaWZmLlJOQVstcXVlcnlIaXRzKG92ZXJsYXApXVxudGVtcCA8LSBtaXNzZWQgJT4lIGRwbHlyOjptdXRhdGUoVFNTID0gVFNTICsgMTAwMDApICU+JSBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gVFNTLCBlbmQgPSBUU1MgKzEpICU+JVxuICBkcGx5cjo6c2VsZWN0KGNociwgc3RhcnQsIGVuZClcbm1pc3NlZC5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcbm92ZXJsYXAgPC0gZmluZE92ZXJsYXBzKG1pc3NlZC5nciwgY3Njb3JlLmdyKVxuYmF0Y2gyIDwtIGJpbmRfY29scyhtaXNzZWRbcXVlcnlIaXRzKG92ZXJsYXApXSxcbiAgICAgICAgICAgICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxubWlzc2VkMiA8LSBtaXNzZWRbLXF1ZXJ5SGl0cyhvdmVybGFwKV1cbnRlbXAgPC0gbWlzc2VkMiAlPiUgZHBseXI6Om11dGF0ZShUU1MgPSBUU1MgLSAxMDAwMCkgJT4lIGRwbHlyOjptdXRhdGUoc3RhcnQgPSBUU1MsIGVuZCA9IFRTUyArMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoY2hyLCBzdGFydCwgZW5kKVxubWlzc2VkLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMobWlzc2VkLmdyLCBjc2NvcmUuZ3IpXG5iYXRjaDMgPC0gYmluZF9jb2xzKG1pc3NlZDJbcXVlcnlIaXRzKG92ZXJsYXApXSxcbiAgICAgICAgICAgICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxuI21pc3NlZDMgPC0gbWlzc2VkMlstcXVlcnlIaXRzKG92ZXJsYXApXVxuXG5cbmRpZmYuUk5BIDwtIGJpbmRfcm93cyhiYXRjaDEsIGJhdGNoMiwgYmF0Y2gzKVxuXG5cbiMgVklTVUFMSVpFXG5kaWZmLlJOQSRjaGFuZ2VUeXBlIDwtIGZhY3RvcihkaWZmLlJOQSRjaGFuZ2VUeXBlLCBsZXZlbHMgPSBjKFxcQV93ZWFrZW5pbmdcXCwgXFxBdG9CXFwsIFxcQl9zdHJlbmd0aGVuaW5nXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcQl93ZWFrZW5pbmdcXCwgXFxCdG9BXFwsIFxcQV9zdHJlbmd0aGVuaW5nXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcVW5jaGFuZ2VkXFwpKVxuZ2dwbG90KGRpZmYuUk5BLCBhZXMoeCA9IGRpZmYsIGZpbGwgPSBjaGFuZ2VUeXBlKSkgK1xuICBnZW9tX2Jhcihwb3NpdGlvbiA9IFxcZmlsbFxcKSArXG4gIGxhYnModGl0bGUgPSBcXFN0YWNrZWQgQmFyIFBsb3Qgb2YgQ2hhbmdlIFR5cGUgYnkgRGlmZlxcLFxuICAgICAgIHggPSBcXERpZmZcXCxcbiAgICAgICB5ID0gXFxDb3VudFxcKSArXG4gIHRoZW1lX2J3KCkgKyAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcXHNreWJsdWVcXCwgXFxibHVlXFwsIFxcZGFya2JsdWVcXCwgXFxwaW5rXFwsIFxccmVkMlxcLCBcXGRhcmtyZWRcXCAsXFxncmV5XFwpKVxuXG5cblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V1, TSS, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\TSS\\, \\ensembl\\)\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\ndiff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\\ensembl_gene_id\\ = \\ensembl\\)) %>%\n  dplyr::filter(!is.na(TSS))\n\nalpha <- 0.05\nfcCutoff <- 0.5\n\ndiff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \\UP\\,\n                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \\DOWN\\,\n                                                        TRUE ~ \\NO\\))\n\n\ngetCompChangeType <- function(chrom, TSS, cscore.tb){\n  temp.tb <- cscore.tb %>% dplyr::filter(chr == chrom, start < TSS, end > TSS)\n  out <- temp.tb$changeType\n  if(length(out) < 1){\n    return(NA)\n  }else{\n    return(out)\n  }\n}\n\ncscore.gr <- makeGRangesFromDataFrame(cscore[1:3])\ntemp <-diff.RNA %>% dplyr::mutate(start = TSS, end = TSS +1) %>%\n  dplyr::select(chr, start, end)\ndiff.RNA.gr <- makeGRangesFromDataFrame(temp)\noverlap <- findOverlaps(diff.RNA.gr, cscore.gr)\n\n#cscore.selected <- cscore %>% dplyr::slice(subjectHits(overlap))\n## Problem of certain genes not getting overlap with cscore due to sparse calling?\nbatch1 <- bind_cols(diff.RNA[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\nmissed <- diff.RNA[-queryHits(overlap)]\ntemp <- missed %>% dplyr::mutate(TSS = TSS + 10000) %>% dplyr::mutate(start = TSS, end = TSS +1) %>%\n  dplyr::select(chr, start, end)\nmissed.gr <- makeGRangesFromDataFrame(temp)\noverlap <- findOverlaps(missed.gr, cscore.gr)\nbatch2 <- bind_cols(missed[queryHits(overlap)],\n                    data.table(cscore)[subjectHits(overlap)])\n\nmissed2 <- missed[-queryHits(overlap)]\ntemp <- missed2 %>% dplyr::mutate(TSS = TSS - 10000) %>% dplyr::mutate(start = TSS, end = TSS +1) %>%\n  dplyr::select(chr, start, end)\nmissed.gr <- makeGRangesFromDataFrame(temp)\noverlap <- findOverlaps(missed.gr, cscore.gr)\nbatch3 <- bind_cols(missed2[queryHits(overlap)],\n                    data.table(cscore)[subjectHits(overlap)])\n\n#missed3 <- missed2[-queryHits(overlap)]\n\n\ndiff.RNA <- bind_rows(batch1, batch2, batch3)\n\n\n# VISUALIZE\ndiff.RNA$changeType <- factor(diff.RNA$changeType, levels = c(\\A_weakening\\, \\AtoB\\, \\B_strengthening\\,\n                                                                          \\B_weakening\\, \\BtoA\\, \\A_strengthening\\,\n                                                                          \\Unchanged\\))\nggplot(diff.RNA, aes(x = diff, fill = changeType)) +\n  geom_bar(position = \\fill\\) +\n  labs(title = \\Stacked Bar Plot of Change Type by Diff\\,\n       x = \\Diff\\,\n       y = \\Count\\) +\n  theme_bw() +  scale_fill_manual(values = c(\\skyblue\\, \\blue\\, \\darkblue\\, \\pink\\, \\red2\\, \\darkred\\ ,\\grey\\))\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTUywgVjYpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFxcY2hyXFwsIFxcVFNTXFwsIFxcZW5zZW1ibFxcKVxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLkE0ODUuc2VsZWN0ZWQyX0cxLjJpLkE0ODVfdnNfRzEuMmkuRE1TTy50c3ZcXCkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGVuc2VtYmxfZ2VuZV9pZCwgbG9nMkZvbGRDaGFuZ2UsIHNocmlua2VkX2xvZzJGQywgcGFkaiwgZXh0ZXJuYWxfZ2VuZV9uYW1lKVxuZGlmZi5STkEgPC0gZGlmZi5STkEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4oZ2VuZS50YiwgYnkgPSBjKFxcZW5zZW1ibF9nZW5lX2lkXFwgPSBcXGVuc2VtYmxcXCkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShUU1MpKVxuXG5hbHBoYSA8LSAwLjA1XG5mY0N1dG9mZiA8LSAwLjVcblxuZGlmZi5STkEgPC0gZGlmZi5STkEgJT4lIGRwbHlyOjptdXRhdGUoZGlmZiA9IGNhc2Vfd2hlbihwYWRqIDwgYWxwaGEgJiBzaHJpbmtlZF9sb2cyRkMgPiBmY0N1dG9mZiB+IFxcVVBcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFkaiA8IGFscGhhICYgc2hyaW5rZWRfbG9nMkZDIDwgLWZjQ3V0b2ZmIH4gXFxET1dOXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBcXE5PXFwpKVxuXG5cbmdldENvbXBDaGFuZ2VUeXBlIDwtIGZ1bmN0aW9uKGNocm9tLCBUU1MsIGNzY29yZS50Yil7XG4gIHRlbXAudGIgPC0gY3Njb3JlLnRiICU+JSBkcGx5cjo6ZmlsdGVyKGNociA9PSBjaHJvbSwgc3RhcnQgPCBUU1MsIGVuZCA+IFRTUylcbiAgb3V0IDwtIHRlbXAudGIkY2hhbmdlVHlwZVxuICBpZihsZW5ndGgob3V0KSA8IDEpe1xuICAgIHJldHVybihOQSlcbiAgfWVsc2V7XG4gICAgcmV0dXJuKG91dClcbiAgfVxufVxuXG5jc2NvcmUuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGNzY29yZVsxOjNdKVxudGVtcCA8LWRpZmYuUk5BICU+JSBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gVFNTLCBlbmQgPSBUU1MgKzEpICU+JVxuICBkcGx5cjo6c2VsZWN0KGNociwgc3RhcnQsIGVuZClcbmRpZmYuUk5BLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMoZGlmZi5STkEuZ3IsIGNzY29yZS5ncilcblxuI2NzY29yZS5zZWxlY3RlZCA8LSBjc2NvcmUgJT4lIGRwbHlyOjpzbGljZShzdWJqZWN0SGl0cyhvdmVybGFwKSlcbiMjIFByb2JsZW0gb2YgY2VydGFpbiBnZW5lcyBub3QgZ2V0dGluZyBvdmVybGFwIHdpdGggY3Njb3JlIGR1ZSB0byBzcGFyc2UgY2FsbGluZz9cbmJhdGNoMSA8LSBiaW5kX2NvbHMoZGlmZi5STkFbcXVlcnlIaXRzKG92ZXJsYXApXSxcbiAgICAgICAgICBkYXRhLnRhYmxlKGNzY29yZSlbc3ViamVjdEhpdHMob3ZlcmxhcCldKVxuXG5cbm1pc3NlZCA8LSBkaWZmLlJOQVstcXVlcnlIaXRzKG92ZXJsYXApXVxudGVtcCA8LSBtaXNzZWQgJT4lIGRwbHlyOjptdXRhdGUoVFNTID0gVFNTICsgMTAwMDApICU+JSBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gVFNTLCBlbmQgPSBUU1MgKzEpICU+JVxuICBkcGx5cjo6c2VsZWN0KGNociwgc3RhcnQsIGVuZClcbm1pc3NlZC5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcbm92ZXJsYXAgPC0gZmluZE92ZXJsYXBzKG1pc3NlZC5nciwgY3Njb3JlLmdyKVxuYmF0Y2gyIDwtIGJpbmRfY29scyhtaXNzZWRbcXVlcnlIaXRzKG92ZXJsYXApXSxcbiAgICAgICAgICAgICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxubWlzc2VkMiA8LSBtaXNzZWRbLXF1ZXJ5SGl0cyhvdmVybGFwKV1cbnRlbXAgPC0gbWlzc2VkMiAlPiUgZHBseXI6Om11dGF0ZShUU1MgPSBUU1MgLSAxMDAwMCkgJT4lIGRwbHlyOjptdXRhdGUoc3RhcnQgPSBUU1MsIGVuZCA9IFRTUyArMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoY2hyLCBzdGFydCwgZW5kKVxubWlzc2VkLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMobWlzc2VkLmdyLCBjc2NvcmUuZ3IpXG5iYXRjaDMgPC0gYmluZF9jb2xzKG1pc3NlZDJbcXVlcnlIaXRzKG92ZXJsYXApXSxcbiAgICAgICAgICAgICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxuI21pc3NlZDMgPC0gbWlzc2VkMlstcXVlcnlIaXRzKG92ZXJsYXApXVxuXG5cbmRpZmYuUk5BIDwtIGJpbmRfcm93cyhiYXRjaDEsIGJhdGNoMiwgYmF0Y2gzKVxuXG5cbiMgVklTVUFMSVpFXG5kaWZmLlJOQSRjaGFuZ2VUeXBlIDwtIGZhY3RvcihkaWZmLlJOQSRjaGFuZ2VUeXBlLCBsZXZlbHMgPSBjKFxcQV93ZWFrZW5pbmdcXCwgXFxBdG9CXFwsIFxcQl9zdHJlbmd0aGVuaW5nXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcQl93ZWFrZW5pbmdcXCwgXFxCdG9BXFwsIFxcQV9zdHJlbmd0aGVuaW5nXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxcVW5jaGFuZ2VkXFwpKVxuZ2dwbG90KGRpZmYuUk5BLCBhZXMoeCA9IGRpZmYsIGZpbGwgPSBjaGFuZ2VUeXBlKSkgK1xuICBnZW9tX2Jhcihwb3NpdGlvbiA9IFxcZmlsbFxcKSArXG4gIGxhYnModGl0bGUgPSBcXFN0YWNrZWQgQmFyIFBsb3Qgb2YgQ2hhbmdlIFR5cGUgYnkgRGlmZlxcLFxuICAgICAgIHggPSBcXERpZmZcXCxcbiAgICAgICB5ID0gXFxDb3VudFxcKSArXG4gIHRoZW1lX2J3KCkgKyAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcXHNreWJsdWVcXCwgXFxibHVlXFwsIFxcZGFya2JsdWVcXCwgXFxwaW5rXFwsIFxccmVkMlxcLCBcXGRhcmtyZWRcXCAsXFxncmV5XFwpKVxuXG5cblxuYGBgXG5gYGAifQ== -->

```r
```r
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V1, TSS, V6)
colnames(gene.tb) <- c(\chr\, \TSS\, \ensembl\)

diff.RNA <- fread(here(refDir, \diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c(\ensembl_gene_id\ = \ensembl\)) %>%
  dplyr::filter(!is.na(TSS))

alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ \UP\,
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ \DOWN\,
                                                        TRUE ~ \NO\))


getCompChangeType <- function(chrom, TSS, cscore.tb){
  temp.tb <- cscore.tb %>% dplyr::filter(chr == chrom, start < TSS, end > TSS)
  out <- temp.tb$changeType
  if(length(out) < 1){
    return(NA)
  }else{
    return(out)
  }
}

cscore.gr <- makeGRangesFromDataFrame(cscore[1:3])
temp <-diff.RNA %>% dplyr::mutate(start = TSS, end = TSS +1) %>%
  dplyr::select(chr, start, end)
diff.RNA.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(diff.RNA.gr, cscore.gr)

#cscore.selected <- cscore %>% dplyr::slice(subjectHits(overlap))
## Problem of certain genes not getting overlap with cscore due to sparse calling?
batch1 <- bind_cols(diff.RNA[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


missed <- diff.RNA[-queryHits(overlap)]
temp <- missed %>% dplyr::mutate(TSS = TSS + 10000) %>% dplyr::mutate(start = TSS, end = TSS +1) %>%
  dplyr::select(chr, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch2 <- bind_cols(missed[queryHits(overlap)],
                    data.table(cscore)[subjectHits(overlap)])

missed2 <- missed[-queryHits(overlap)]
temp <- missed2 %>% dplyr::mutate(TSS = TSS - 10000) %>% dplyr::mutate(start = TSS, end = TSS +1) %>%
  dplyr::select(chr, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch3 <- bind_cols(missed2[queryHits(overlap)],
                    data.table(cscore)[subjectHits(overlap)])

#missed3 <- missed2[-queryHits(overlap)]


diff.RNA <- bind_rows(batch1, batch2, batch3)


# VISUALIZE
diff.RNA$changeType <- factor(diff.RNA$changeType, levels = c(\A_weakening\, \AtoB\, \B_strengthening\,
                                                                          \B_weakening\, \BtoA\, \A_strengthening\,
                                                                          \Unchanged\))
ggplot(diff.RNA, aes(x = diff, fill = changeType)) +
  geom_bar(position = \fill\) +
  labs(title = \Stacked Bar Plot of Change Type by Diff\,
       x = \Diff\,
       y = \Count\) +
  theme_bw() +  scale_fill_manual(values = c(\skyblue\, \blue\, \darkblue\, \pink\, \red2\, \darkred\ ,\grey\))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


## [2.29] Compartment analysis
Q. What are the changes in compartment level upon A485 treatment?
#### Compartment change distribution

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuXG4jIFVQIGxvb3Bcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcIikpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG5hbmNob3IudXAudGIgPC0gYXNfdGliYmxlKGFuY2hvci51cCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2VudGVyID0gKHN0YXJ0ICsgZW5kKS8yKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzdGFydCA9IGNlbnRlci0xLCBlbmQgPSBjZW50ZXIrMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQpXG5hbmNob3IudXAgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGFuY2hvci51cC50YilcbiMgTk8gbG9vcFxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fTk9fZGlmZjAuMi5iZWRwZVwiKSlcbmFuY2hvci5ubyA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbmFuY2hvci5uby50YiA8LSBhc190aWJibGUoYW5jaG9yLm5vKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjZW50ZXIgPSAoc3RhcnQgKyBlbmQpLzIpICU+JVxuICBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gY2VudGVyLTEsIGVuZCA9IGNlbnRlcisxKSAlPiVcbiAgZHBseXI6OnNlbGVjdChzZXFuYW1lcywgc3RhcnQsIGVuZClcbmFuY2hvci5ubyA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoYW5jaG9yLm5vLnRiKVxuIyBET1dOIGxvb3Bcbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXCIpKVxuYW5jaG9yLmRvd24gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5kb3duKSlcbmFuY2hvci5kb3duLnRiIDwtIGFzX3RpYmJsZShhbmNob3IuZG93bikgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2VudGVyID0gKHN0YXJ0ICsgZW5kKS8yKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzdGFydCA9IGNlbnRlci0xLCBlbmQgPSBjZW50ZXIrMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQpXG5hbmNob3IuZG93biA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoYW5jaG9yLmRvd24udGIpXG5cblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG4jIyMgT3ZlcmxhcFxuY3Njb3JlLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShjc2NvcmVbMTozXSlcbm92ZXJsYXAgPC0gZmluZE92ZXJsYXBzKGFuY2hvci51cCwgY3Njb3JlLmdyKVxuXG4jIyBQcm9ibGVtIG9mIGNlcnRhaW4gZ2VuZXMgbm90IGdldHRpbmcgb3ZlcmxhcCB3aXRoIGNzY29yZSBkdWUgdG8gc3BhcnNlIGNhbGxpbmc/XG5iYXRjaDEgPC0gYmluZF9jb2xzKGRhdGEudGFibGUoYW5jaG9yLnVwLnRiKVtxdWVyeUhpdHMob3ZlcmxhcCldLFxuICAgICAgICAgIGRhdGEudGFibGUoY3Njb3JlKVtzdWJqZWN0SGl0cyhvdmVybGFwKV0pXG5cblxubWlzc2VkIDwtIGRhdGEudGFibGUoYW5jaG9yLnVwLnRiKVstcXVlcnlIaXRzKG92ZXJsYXApXVxudGVtcCA8LSBtaXNzZWQgJT4lIGRwbHlyOjptdXRhdGUoc3RhcnQgPSBzdGFydCAtIDEwMDAwLCBlbmQgPSBlbmQgLSAxMDAwMCkgJT4lXG4gIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQpXG5taXNzZWQuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRlbXApXG5vdmVybGFwIDwtIGZpbmRPdmVybGFwcyhtaXNzZWQuZ3IsIGNzY29yZS5ncilcbmJhdGNoMiA8LSBiaW5kX2NvbHMoKG1pc3NlZClbcXVlcnlIaXRzKG92ZXJsYXApXSxcbiAgICAgICAgICBkYXRhLnRhYmxlKGNzY29yZSlbc3ViamVjdEhpdHMob3ZlcmxhcCldKVxuXG5cbmRhdGEudXAgPC0gYmluZF9yb3dzKGJhdGNoMSwgYmF0Y2gyKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMjIyBPdmVybGFwXG5jc2NvcmUuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGNzY29yZVsxOjNdKVxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLm5vLCBjc2NvcmUuZ3IpXG5cbiMjIFByb2JsZW0gb2YgY2VydGFpbiBnZW5lcyBub3QgZ2V0dGluZyBvdmVybGFwIHdpdGggY3Njb3JlIGR1ZSB0byBzcGFyc2UgY2FsbGluZz9cbmJhdGNoMSA8LSBiaW5kX2NvbHMoZGF0YS50YWJsZShhbmNob3Iubm8udGIpW3F1ZXJ5SGl0cyhvdmVybGFwKV0sXG4gICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxuXG5taXNzZWQgPC0gZGF0YS50YWJsZShhbmNob3Iubm8udGIpWy1xdWVyeUhpdHMob3ZlcmxhcCldXG50ZW1wIDwtIG1pc3NlZCAlPiUgZHBseXI6Om11dGF0ZShzdGFydCA9IHN0YXJ0IC0gMTAwMDAsIGVuZCA9IGVuZCAtIDEwMDAwKSAlPiVcbiAgZHBseXI6OnNlbGVjdChzZXFuYW1lcywgc3RhcnQsIGVuZClcbm1pc3NlZC5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcbm92ZXJsYXAgPC0gZmluZE92ZXJsYXBzKG1pc3NlZC5nciwgY3Njb3JlLmdyKVxuYmF0Y2gyIDwtIGJpbmRfY29scygobWlzc2VkKVtxdWVyeUhpdHMob3ZlcmxhcCldLFxuICAgICAgICAgIGRhdGEudGFibGUoY3Njb3JlKVtzdWJqZWN0SGl0cyhvdmVybGFwKV0pXG5cblxuZGF0YS5ubyA8LSBiaW5kX3Jvd3MoYmF0Y2gxLCBiYXRjaDIpXG5cbiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyMjIE92ZXJsYXBcbmNzY29yZS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoY3Njb3JlWzE6M10pXG5vdmVybGFwIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuZG93biwgY3Njb3JlLmdyKVxuXG4jIyBQcm9ibGVtIG9mIGNlcnRhaW4gZ2VuZXMgbm90IGdldHRpbmcgb3ZlcmxhcCB3aXRoIGNzY29yZSBkdWUgdG8gc3BhcnNlIGNhbGxpbmc/XG5iYXRjaDEgPC0gYmluZF9jb2xzKGRhdGEudGFibGUoYW5jaG9yLmRvd24udGIpW3F1ZXJ5SGl0cyhvdmVybGFwKV0sXG4gICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxuXG5taXNzZWQgPC0gZGF0YS50YWJsZShhbmNob3IuZG93bi50YilbLXF1ZXJ5SGl0cyhvdmVybGFwKV1cbnRlbXAgPC0gbWlzc2VkICU+JSBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gc3RhcnQgLSAxMDAwMCwgZW5kID0gZW5kIC0gMTAwMDApICU+JVxuICBkcGx5cjo6c2VsZWN0KHNlcW5hbWVzLCBzdGFydCwgZW5kKVxubWlzc2VkLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMobWlzc2VkLmdyLCBjc2NvcmUuZ3IpXG5iYXRjaDIgPC0gYmluZF9jb2xzKChtaXNzZWQpW3F1ZXJ5SGl0cyhvdmVybGFwKV0sXG4gICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxuXG5kYXRhLmRvd24gPC0gYmluZF9yb3dzKGJhdGNoMSwgYmF0Y2gyKVxuXG5uLnVwIDwtIG5yb3coZGF0YS51cClcbm4ubm8gPC0gbnJvdyhkYXRhLm5vKVxubi5kb3duIDwtIG5yb3coZGF0YS5kb3duKVxuXG5kYXRhIDwtIHRpYmJsZShsb29wRGlmZiA9IGMocmVwKFwiVVBcIiwgbi51cCksIHJlcChcIk5PXCIsIG4ubm8pLCByZXAoXCJET1dOXCIsIG4uZG93bikpLFxuICAgICAgICAgICAgICBjaGFuZ2VUeXBlID0gYyhkYXRhLnVwJGNoYW5nZVR5cGUsIGRhdGEubm8kY2hhbmdlVHlwZSwgZGF0YS5kb3duJGNoYW5nZVR5cGUpKVxuXG4jIFZJU1VBTElaRVxuZGF0YSRjaGFuZ2VUeXBlIDwtIGZhY3RvcihkYXRhJGNoYW5nZVR5cGUsIGxldmVscyA9IGMoXCJBX3dlYWtlbmluZ1wiLCBcIkF0b0JcIiwgXCJCX3N0cmVuZ3RoZW5pbmdcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJCX3dlYWtlbmluZ1wiLCBcIkJ0b0FcIiwgXCJBX3N0cmVuZ3RoZW5pbmdcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJVbmNoYW5nZWRcIikpXG5nZ3Bsb3QoZGF0YSwgYWVzKHggPSBsb29wRGlmZiwgZmlsbCA9IGNoYW5nZVR5cGUpKSArXG4gIGdlb21fYmFyKHBvc2l0aW9uID0gXCJmaWxsXCIpICtcbiAgbGFicyh0aXRsZSA9IFwiU3RhY2tlZCBCYXIgUGxvdCBvZiBDaGFuZ2UgVHlwZSBieSBEaWZmXCIsXG4gICAgICAgeCA9IFwiRGlmZlwiLFxuICAgICAgIHkgPSBcIkNvdW50XCIpICtcbiAgdGhlbWVfYncoKSArICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFwic2t5Ymx1ZVwiLCBcImJsdWVcIiwgXCJkYXJrYmx1ZVwiLCBcInBpbmtcIiwgXCJyZWQyXCIsIFwiZGFya3JlZFwiICxcImdyZXlcIikpXG5cblxuXG5cbmBgYCJ9 -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\\))\nanchor.up <- (extractAnchor(loop.up))\nanchor.up.tb <- as_tibble(anchor.up) %>%\n  dplyr::mutate(center = (start + end)/2) %>%\n  dplyr::mutate(start = center-1, end = center+1) %>%\n  dplyr::select(seqnames, start, end)\nanchor.up <- makeGRangesFromDataFrame(anchor.up.tb)\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\\))\nanchor.no <- (extractAnchor(loop.no))\nanchor.no.tb <- as_tibble(anchor.no) %>%\n  dplyr::mutate(center = (start + end)/2) %>%\n  dplyr::mutate(start = center-1, end = center+1) %>%\n  dplyr::select(seqnames, start, end)\nanchor.no <- makeGRangesFromDataFrame(anchor.no.tb)\n# DOWN loop\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- (extractAnchor(loop.down))\nanchor.down.tb <- as_tibble(anchor.down) %>%\n  dplyr::mutate(center = (start + end)/2) %>%\n  dplyr::mutate(start = center-1, end = center+1) %>%\n  dplyr::select(seqnames, start, end)\nanchor.down <- makeGRangesFromDataFrame(anchor.down.tb)\n\n\n########################################################################\n### Overlap\ncscore.gr <- makeGRangesFromDataFrame(cscore[1:3])\noverlap <- findOverlaps(anchor.up, cscore.gr)\n\n## Problem of certain genes not getting overlap with cscore due to sparse calling?\nbatch1 <- bind_cols(data.table(anchor.up.tb)[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\nmissed <- data.table(anchor.up.tb)[-queryHits(overlap)]\ntemp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%\n  dplyr::select(seqnames, start, end)\nmissed.gr <- makeGRangesFromDataFrame(temp)\noverlap <- findOverlaps(missed.gr, cscore.gr)\nbatch2 <- bind_cols((missed)[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\ndata.up <- bind_rows(batch1, batch2)\n\n########################################################################\n### Overlap\ncscore.gr <- makeGRangesFromDataFrame(cscore[1:3])\noverlap <- findOverlaps(anchor.no, cscore.gr)\n\n## Problem of certain genes not getting overlap with cscore due to sparse calling?\nbatch1 <- bind_cols(data.table(anchor.no.tb)[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\nmissed <- data.table(anchor.no.tb)[-queryHits(overlap)]\ntemp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%\n  dplyr::select(seqnames, start, end)\nmissed.gr <- makeGRangesFromDataFrame(temp)\noverlap <- findOverlaps(missed.gr, cscore.gr)\nbatch2 <- bind_cols((missed)[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\ndata.no <- bind_rows(batch1, batch2)\n\n########################################################################\n### Overlap\ncscore.gr <- makeGRangesFromDataFrame(cscore[1:3])\noverlap <- findOverlaps(anchor.down, cscore.gr)\n\n## Problem of certain genes not getting overlap with cscore due to sparse calling?\nbatch1 <- bind_cols(data.table(anchor.down.tb)[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\nmissed <- data.table(anchor.down.tb)[-queryHits(overlap)]\ntemp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%\n  dplyr::select(seqnames, start, end)\nmissed.gr <- makeGRangesFromDataFrame(temp)\noverlap <- findOverlaps(missed.gr, cscore.gr)\nbatch2 <- bind_cols((missed)[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\ndata.down <- bind_rows(batch1, batch2)\n\nn.up <- nrow(data.up)\nn.no <- nrow(data.no)\nn.down <- nrow(data.down)\n\ndata <- tibble(loopDiff = c(rep(\\UP\\, n.up), rep(\\NO\\, n.no), rep(\\DOWN\\, n.down)),\n              changeType = c(data.up$changeType, data.no$changeType, data.down$changeType))\n\n# VISUALIZE\ndata$changeType <- factor(data$changeType, levels = c(\\A_weakening\\, \\AtoB\\, \\B_strengthening\\,\n                                                                          \\B_weakening\\, \\BtoA\\, \\A_strengthening\\,\n                                                                          \\Unchanged\\))\nggplot(data, aes(x = loopDiff, fill = changeType)) +\n  geom_bar(position = \\fill\\) +\n  labs(title = \\Stacked Bar Plot of Change Type by Diff\\,\n       x = \\Diff\\,\n       y = \\Count\\) +\n  theme_bw() +  scale_fill_manual(values = c(\\skyblue\\, \\blue\\, \\darkblue\\, \\pink\\, \\red2\\, \\darkred\\ ,\\grey\\))\n\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\

# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
anchor.up.tb <- as_tibble(anchor.up) %>%
  dplyr::mutate(center = (start + end)/2) %>%
  dplyr::mutate(start = center-1, end = center+1) %>%
  dplyr::select(seqnames, start, end)
anchor.up <- makeGRangesFromDataFrame(anchor.up.tb)
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
anchor.no.tb <- as_tibble(anchor.no) %>%
  dplyr::mutate(center = (start + end)/2) %>%
  dplyr::mutate(start = center-1, end = center+1) %>%
  dplyr::select(seqnames, start, end)
anchor.no <- makeGRangesFromDataFrame(anchor.no.tb)
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))
anchor.down.tb <- as_tibble(anchor.down) %>%
  dplyr::mutate(center = (start + end)/2) %>%
  dplyr::mutate(start = center-1, end = center+1) %>%
  dplyr::select(seqnames, start, end)
anchor.down <- makeGRangesFromDataFrame(anchor.down.tb)


########################################################################
### Overlap
cscore.gr <- makeGRangesFromDataFrame(cscore[1:3])
overlap <- findOverlaps(anchor.up, cscore.gr)

## Problem of certain genes not getting overlap with cscore due to sparse calling?
batch1 <- bind_cols(data.table(anchor.up.tb)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


missed <- data.table(anchor.up.tb)[-queryHits(overlap)]
temp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%
  dplyr::select(seqnames, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch2 <- bind_cols((missed)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


data.up <- bind_rows(batch1, batch2)

########################################################################
### Overlap
cscore.gr <- makeGRangesFromDataFrame(cscore[1:3])
overlap <- findOverlaps(anchor.no, cscore.gr)

## Problem of certain genes not getting overlap with cscore due to sparse calling?
batch1 <- bind_cols(data.table(anchor.no.tb)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


missed <- data.table(anchor.no.tb)[-queryHits(overlap)]
temp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%
  dplyr::select(seqnames, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch2 <- bind_cols((missed)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


data.no <- bind_rows(batch1, batch2)

########################################################################
### Overlap
cscore.gr <- makeGRangesFromDataFrame(cscore[1:3])
overlap <- findOverlaps(anchor.down, cscore.gr)

## Problem of certain genes not getting overlap with cscore due to sparse calling?
batch1 <- bind_cols(data.table(anchor.down.tb)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


missed <- data.table(anchor.down.tb)[-queryHits(overlap)]
temp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%
  dplyr::select(seqnames, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch2 <- bind_cols((missed)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


data.down <- bind_rows(batch1, batch2)

n.up <- nrow(data.up)
n.no <- nrow(data.no)
n.down <- nrow(data.down)

data <- tibble(loopDiff = c(rep(\UP\, n.up), rep(\NO\, n.no), rep(\DOWN\, n.down)),
              changeType = c(data.up$changeType, data.no$changeType, data.down$changeType))

# VISUALIZE
data$changeType <- factor(data$changeType, levels = c(\A_weakening\, \AtoB\, \B_strengthening\,
                                                                          \B_weakening\, \BtoA\, \A_strengthening\,
                                                                          \Unchanged\))
ggplot(data, aes(x = loopDiff, fill = changeType)) +
  geom_bar(position = \fill\) +
  labs(title = \Stacked Bar Plot of Change Type by Diff\,
       x = \Diff\,
       y = \Count\) +
  theme_bw() +  scale_fill_manual(values = c(\skyblue\, \blue\, \darkblue\, \pink\, \red2\, \darkred\ ,\grey\))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG4jIFVQIGxvb3Bcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG5hbmNob3IudXAudGIgPC0gYXNfdGliYmxlKGFuY2hvci51cCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2VudGVyID0gKHN0YXJ0ICsgZW5kKS8yKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzdGFydCA9IGNlbnRlci0xLCBlbmQgPSBjZW50ZXIrMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQpXG5hbmNob3IudXAgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGFuY2hvci51cC50YilcbiMgTk8gbG9vcFxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fTk9fZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci5ubyA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbmFuY2hvci5uby50YiA8LSBhc190aWJibGUoYW5jaG9yLm5vKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjZW50ZXIgPSAoc3RhcnQgKyBlbmQpLzIpICU+JVxuICBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gY2VudGVyLTEsIGVuZCA9IGNlbnRlcisxKSAlPiVcbiAgZHBseXI6OnNlbGVjdChzZXFuYW1lcywgc3RhcnQsIGVuZClcbmFuY2hvci5ubyA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoYW5jaG9yLm5vLnRiKVxuIyBET1dOIGxvb3Bcbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLmRvd24gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5kb3duKSlcbmFuY2hvci5kb3duLnRiIDwtIGFzX3RpYmJsZShhbmNob3IuZG93bikgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2VudGVyID0gKHN0YXJ0ICsgZW5kKS8yKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzdGFydCA9IGNlbnRlci0xLCBlbmQgPSBjZW50ZXIrMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQpXG5hbmNob3IuZG93biA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoYW5jaG9yLmRvd24udGIpXG5cblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG4jIyMgT3ZlcmxhcFxuY3Njb3JlLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShjc2NvcmVbMTozXSlcbm92ZXJsYXAgPC0gZmluZE92ZXJsYXBzKGFuY2hvci51cCwgY3Njb3JlLmdyKVxuXG4jIyBQcm9ibGVtIG9mIGNlcnRhaW4gZ2VuZXMgbm90IGdldHRpbmcgb3ZlcmxhcCB3aXRoIGNzY29yZSBkdWUgdG8gc3BhcnNlIGNhbGxpbmc/XG5iYXRjaDEgPC0gYmluZF9jb2xzKGRhdGEudGFibGUoYW5jaG9yLnVwLnRiKVtxdWVyeUhpdHMob3ZlcmxhcCldLFxuICAgICAgICAgIGRhdGEudGFibGUoY3Njb3JlKVtzdWJqZWN0SGl0cyhvdmVybGFwKV0pXG5cblxubWlzc2VkIDwtIGRhdGEudGFibGUoYW5jaG9yLnVwLnRiKVstcXVlcnlIaXRzKG92ZXJsYXApXVxudGVtcCA8LSBtaXNzZWQgJT4lIGRwbHlyOjptdXRhdGUoc3RhcnQgPSBzdGFydCAtIDEwMDAwLCBlbmQgPSBlbmQgLSAxMDAwMCkgJT4lXG4gIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQpXG5taXNzZWQuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRlbXApXG5vdmVybGFwIDwtIGZpbmRPdmVybGFwcyhtaXNzZWQuZ3IsIGNzY29yZS5ncilcbmJhdGNoMiA8LSBiaW5kX2NvbHMoKG1pc3NlZClbcXVlcnlIaXRzKG92ZXJsYXApXSxcbiAgICAgICAgICBkYXRhLnRhYmxlKGNzY29yZSlbc3ViamVjdEhpdHMob3ZlcmxhcCldKVxuXG5cbmRhdGEudXAgPC0gYmluZF9yb3dzKGJhdGNoMSwgYmF0Y2gyKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMjIyBPdmVybGFwXG5jc2NvcmUuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGNzY29yZVsxOjNdKVxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLm5vLCBjc2NvcmUuZ3IpXG5cbiMjIFByb2JsZW0gb2YgY2VydGFpbiBnZW5lcyBub3QgZ2V0dGluZyBvdmVybGFwIHdpdGggY3Njb3JlIGR1ZSB0byBzcGFyc2UgY2FsbGluZz9cbmJhdGNoMSA8LSBiaW5kX2NvbHMoZGF0YS50YWJsZShhbmNob3Iubm8udGIpW3F1ZXJ5SGl0cyhvdmVybGFwKV0sXG4gICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxuXG5taXNzZWQgPC0gZGF0YS50YWJsZShhbmNob3Iubm8udGIpWy1xdWVyeUhpdHMob3ZlcmxhcCldXG50ZW1wIDwtIG1pc3NlZCAlPiUgZHBseXI6Om11dGF0ZShzdGFydCA9IHN0YXJ0IC0gMTAwMDAsIGVuZCA9IGVuZCAtIDEwMDAwKSAlPiVcbiAgZHBseXI6OnNlbGVjdChzZXFuYW1lcywgc3RhcnQsIGVuZClcbm1pc3NlZC5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcbm92ZXJsYXAgPC0gZmluZE92ZXJsYXBzKG1pc3NlZC5nciwgY3Njb3JlLmdyKVxuYmF0Y2gyIDwtIGJpbmRfY29scygobWlzc2VkKVtxdWVyeUhpdHMob3ZlcmxhcCldLFxuICAgICAgICAgIGRhdGEudGFibGUoY3Njb3JlKVtzdWJqZWN0SGl0cyhvdmVybGFwKV0pXG5cblxuZGF0YS5ubyA8LSBiaW5kX3Jvd3MoYmF0Y2gxLCBiYXRjaDIpXG5cbiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyMjIE92ZXJsYXBcbmNzY29yZS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoY3Njb3JlWzE6M10pXG5vdmVybGFwIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuZG93biwgY3Njb3JlLmdyKVxuXG4jIyBQcm9ibGVtIG9mIGNlcnRhaW4gZ2VuZXMgbm90IGdldHRpbmcgb3ZlcmxhcCB3aXRoIGNzY29yZSBkdWUgdG8gc3BhcnNlIGNhbGxpbmc/XG5iYXRjaDEgPC0gYmluZF9jb2xzKGRhdGEudGFibGUoYW5jaG9yLmRvd24udGIpW3F1ZXJ5SGl0cyhvdmVybGFwKV0sXG4gICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxuXG5taXNzZWQgPC0gZGF0YS50YWJsZShhbmNob3IuZG93bi50YilbLXF1ZXJ5SGl0cyhvdmVybGFwKV1cbnRlbXAgPC0gbWlzc2VkICU+JSBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gc3RhcnQgLSAxMDAwMCwgZW5kID0gZW5kIC0gMTAwMDApICU+JVxuICBkcGx5cjo6c2VsZWN0KHNlcW5hbWVzLCBzdGFydCwgZW5kKVxubWlzc2VkLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMobWlzc2VkLmdyLCBjc2NvcmUuZ3IpXG5iYXRjaDIgPC0gYmluZF9jb2xzKChtaXNzZWQpW3F1ZXJ5SGl0cyhvdmVybGFwKV0sXG4gICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxuXG5kYXRhLmRvd24gPC0gYmluZF9yb3dzKGJhdGNoMSwgYmF0Y2gyKVxuXG5uLnVwIDwtIG5yb3coZGF0YS51cClcbm4ubm8gPC0gbnJvdyhkYXRhLm5vKVxubi5kb3duIDwtIG5yb3coZGF0YS5kb3duKVxuXG5kYXRhIDwtIHRpYmJsZShsb29wRGlmZiA9IGMocmVwKFxcVVBcXCwgbi51cCksIHJlcChcXE5PXFwsIG4ubm8pLCByZXAoXFxET1dOXFwsIG4uZG93bikpLFxuICAgICAgICAgICAgICBjaGFuZ2VUeXBlID0gYyhkYXRhLnVwJGNoYW5nZVR5cGUsIGRhdGEubm8kY2hhbmdlVHlwZSwgZGF0YS5kb3duJGNoYW5nZVR5cGUpKVxuXG4jIFZJU1VBTElaRVxuZGF0YSRjaGFuZ2VUeXBlIDwtIGZhY3RvcihkYXRhJGNoYW5nZVR5cGUsIGxldmVscyA9IGMoXFxBX3dlYWtlbmluZ1xcLCBcXEF0b0JcXCwgXFxCX3N0cmVuZ3RoZW5pbmdcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxCX3dlYWtlbmluZ1xcLCBcXEJ0b0FcXCwgXFxBX3N0cmVuZ3RoZW5pbmdcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxVbmNoYW5nZWRcXCkpXG5nZ3Bsb3QoZGF0YSwgYWVzKHggPSBsb29wRGlmZiwgZmlsbCA9IGNoYW5nZVR5cGUpKSArXG4gIGdlb21fYmFyKHBvc2l0aW9uID0gXFxmaWxsXFwpICtcbiAgbGFicyh0aXRsZSA9IFxcU3RhY2tlZCBCYXIgUGxvdCBvZiBDaGFuZ2UgVHlwZSBieSBEaWZmXFwsXG4gICAgICAgeCA9IFxcRGlmZlxcLFxuICAgICAgIHkgPSBcXENvdW50XFwpICtcbiAgdGhlbWVfYncoKSArICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFxcc2t5Ymx1ZVxcLCBcXGJsdWVcXCwgXFxkYXJrYmx1ZVxcLCBcXHBpbmtcXCwgXFxyZWQyXFwsIFxcZGFya3JlZFxcICxcXGdyZXlcXCkpXG5cblxuXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\\))\nanchor.up <- (extractAnchor(loop.up))\nanchor.up.tb <- as_tibble(anchor.up) %>%\n  dplyr::mutate(center = (start + end)/2) %>%\n  dplyr::mutate(start = center-1, end = center+1) %>%\n  dplyr::select(seqnames, start, end)\nanchor.up <- makeGRangesFromDataFrame(anchor.up.tb)\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\\))\nanchor.no <- (extractAnchor(loop.no))\nanchor.no.tb <- as_tibble(anchor.no) %>%\n  dplyr::mutate(center = (start + end)/2) %>%\n  dplyr::mutate(start = center-1, end = center+1) %>%\n  dplyr::select(seqnames, start, end)\nanchor.no <- makeGRangesFromDataFrame(anchor.no.tb)\n# DOWN loop\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- (extractAnchor(loop.down))\nanchor.down.tb <- as_tibble(anchor.down) %>%\n  dplyr::mutate(center = (start + end)/2) %>%\n  dplyr::mutate(start = center-1, end = center+1) %>%\n  dplyr::select(seqnames, start, end)\nanchor.down <- makeGRangesFromDataFrame(anchor.down.tb)\n\n\n########################################################################\n### Overlap\ncscore.gr <- makeGRangesFromDataFrame(cscore[1:3])\noverlap <- findOverlaps(anchor.up, cscore.gr)\n\n## Problem of certain genes not getting overlap with cscore due to sparse calling?\nbatch1 <- bind_cols(data.table(anchor.up.tb)[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\nmissed <- data.table(anchor.up.tb)[-queryHits(overlap)]\ntemp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%\n  dplyr::select(seqnames, start, end)\nmissed.gr <- makeGRangesFromDataFrame(temp)\noverlap <- findOverlaps(missed.gr, cscore.gr)\nbatch2 <- bind_cols((missed)[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\ndata.up <- bind_rows(batch1, batch2)\n\n########################################################################\n### Overlap\ncscore.gr <- makeGRangesFromDataFrame(cscore[1:3])\noverlap <- findOverlaps(anchor.no, cscore.gr)\n\n## Problem of certain genes not getting overlap with cscore due to sparse calling?\nbatch1 <- bind_cols(data.table(anchor.no.tb)[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\nmissed <- data.table(anchor.no.tb)[-queryHits(overlap)]\ntemp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%\n  dplyr::select(seqnames, start, end)\nmissed.gr <- makeGRangesFromDataFrame(temp)\noverlap <- findOverlaps(missed.gr, cscore.gr)\nbatch2 <- bind_cols((missed)[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\ndata.no <- bind_rows(batch1, batch2)\n\n########################################################################\n### Overlap\ncscore.gr <- makeGRangesFromDataFrame(cscore[1:3])\noverlap <- findOverlaps(anchor.down, cscore.gr)\n\n## Problem of certain genes not getting overlap with cscore due to sparse calling?\nbatch1 <- bind_cols(data.table(anchor.down.tb)[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\nmissed <- data.table(anchor.down.tb)[-queryHits(overlap)]\ntemp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%\n  dplyr::select(seqnames, start, end)\nmissed.gr <- makeGRangesFromDataFrame(temp)\noverlap <- findOverlaps(missed.gr, cscore.gr)\nbatch2 <- bind_cols((missed)[queryHits(overlap)],\n          data.table(cscore)[subjectHits(overlap)])\n\n\ndata.down <- bind_rows(batch1, batch2)\n\nn.up <- nrow(data.up)\nn.no <- nrow(data.no)\nn.down <- nrow(data.down)\n\ndata <- tibble(loopDiff = c(rep(\\UP\\, n.up), rep(\\NO\\, n.no), rep(\\DOWN\\, n.down)),\n              changeType = c(data.up$changeType, data.no$changeType, data.down$changeType))\n\n# VISUALIZE\ndata$changeType <- factor(data$changeType, levels = c(\\A_weakening\\, \\AtoB\\, \\B_strengthening\\,\n                                                                          \\B_weakening\\, \\BtoA\\, \\A_strengthening\\,\n                                                                          \\Unchanged\\))\nggplot(data, aes(x = loopDiff, fill = changeType)) +\n  geom_bar(position = \\fill\\) +\n  labs(title = \\Stacked Bar Plot of Change Type by Diff\\,\n       x = \\Diff\\,\n       y = \\Count\\) +\n  theme_bw() +  scale_fill_manual(values = c(\\skyblue\\, \\blue\\, \\darkblue\\, \\pink\\, \\red2\\, \\darkred\\ ,\\grey\\))\n\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG4jIFVQIGxvb3Bcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9BNDg1dnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXAgPC0gKGV4dHJhY3RBbmNob3IobG9vcC51cCkpXG5hbmNob3IudXAudGIgPC0gYXNfdGliYmxlKGFuY2hvci51cCkgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2VudGVyID0gKHN0YXJ0ICsgZW5kKS8yKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzdGFydCA9IGNlbnRlci0xLCBlbmQgPSBjZW50ZXIrMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQpXG5hbmNob3IudXAgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGFuY2hvci51cC50YilcbiMgTk8gbG9vcFxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fTk9fZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci5ubyA8LSAoZXh0cmFjdEFuY2hvcihsb29wLm5vKSlcbmFuY2hvci5uby50YiA8LSBhc190aWJibGUoYW5jaG9yLm5vKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjZW50ZXIgPSAoc3RhcnQgKyBlbmQpLzIpICU+JVxuICBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gY2VudGVyLTEsIGVuZCA9IGNlbnRlcisxKSAlPiVcbiAgZHBseXI6OnNlbGVjdChzZXFuYW1lcywgc3RhcnQsIGVuZClcbmFuY2hvci5ubyA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoYW5jaG9yLm5vLnRiKVxuIyBET1dOIGxvb3Bcbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX0E0ODV2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLmRvd24gPC0gKGV4dHJhY3RBbmNob3IobG9vcC5kb3duKSlcbmFuY2hvci5kb3duLnRiIDwtIGFzX3RpYmJsZShhbmNob3IuZG93bikgJT4lXG4gIGRwbHlyOjptdXRhdGUoY2VudGVyID0gKHN0YXJ0ICsgZW5kKS8yKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzdGFydCA9IGNlbnRlci0xLCBlbmQgPSBjZW50ZXIrMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQpXG5hbmNob3IuZG93biA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoYW5jaG9yLmRvd24udGIpXG5cblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG4jIyMgT3ZlcmxhcFxuY3Njb3JlLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShjc2NvcmVbMTozXSlcbm92ZXJsYXAgPC0gZmluZE92ZXJsYXBzKGFuY2hvci51cCwgY3Njb3JlLmdyKVxuXG4jIyBQcm9ibGVtIG9mIGNlcnRhaW4gZ2VuZXMgbm90IGdldHRpbmcgb3ZlcmxhcCB3aXRoIGNzY29yZSBkdWUgdG8gc3BhcnNlIGNhbGxpbmc/XG5iYXRjaDEgPC0gYmluZF9jb2xzKGRhdGEudGFibGUoYW5jaG9yLnVwLnRiKVtxdWVyeUhpdHMob3ZlcmxhcCldLFxuICAgICAgICAgIGRhdGEudGFibGUoY3Njb3JlKVtzdWJqZWN0SGl0cyhvdmVybGFwKV0pXG5cblxubWlzc2VkIDwtIGRhdGEudGFibGUoYW5jaG9yLnVwLnRiKVstcXVlcnlIaXRzKG92ZXJsYXApXVxudGVtcCA8LSBtaXNzZWQgJT4lIGRwbHlyOjptdXRhdGUoc3RhcnQgPSBzdGFydCAtIDEwMDAwLCBlbmQgPSBlbmQgLSAxMDAwMCkgJT4lXG4gIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQpXG5taXNzZWQuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRlbXApXG5vdmVybGFwIDwtIGZpbmRPdmVybGFwcyhtaXNzZWQuZ3IsIGNzY29yZS5ncilcbmJhdGNoMiA8LSBiaW5kX2NvbHMoKG1pc3NlZClbcXVlcnlIaXRzKG92ZXJsYXApXSxcbiAgICAgICAgICBkYXRhLnRhYmxlKGNzY29yZSlbc3ViamVjdEhpdHMob3ZlcmxhcCldKVxuXG5cbmRhdGEudXAgPC0gYmluZF9yb3dzKGJhdGNoMSwgYmF0Y2gyKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyNcbiMjIyBPdmVybGFwXG5jc2NvcmUuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGNzY29yZVsxOjNdKVxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLm5vLCBjc2NvcmUuZ3IpXG5cbiMjIFByb2JsZW0gb2YgY2VydGFpbiBnZW5lcyBub3QgZ2V0dGluZyBvdmVybGFwIHdpdGggY3Njb3JlIGR1ZSB0byBzcGFyc2UgY2FsbGluZz9cbmJhdGNoMSA8LSBiaW5kX2NvbHMoZGF0YS50YWJsZShhbmNob3Iubm8udGIpW3F1ZXJ5SGl0cyhvdmVybGFwKV0sXG4gICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxuXG5taXNzZWQgPC0gZGF0YS50YWJsZShhbmNob3Iubm8udGIpWy1xdWVyeUhpdHMob3ZlcmxhcCldXG50ZW1wIDwtIG1pc3NlZCAlPiUgZHBseXI6Om11dGF0ZShzdGFydCA9IHN0YXJ0IC0gMTAwMDAsIGVuZCA9IGVuZCAtIDEwMDAwKSAlPiVcbiAgZHBseXI6OnNlbGVjdChzZXFuYW1lcywgc3RhcnQsIGVuZClcbm1pc3NlZC5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcbm92ZXJsYXAgPC0gZmluZE92ZXJsYXBzKG1pc3NlZC5nciwgY3Njb3JlLmdyKVxuYmF0Y2gyIDwtIGJpbmRfY29scygobWlzc2VkKVtxdWVyeUhpdHMob3ZlcmxhcCldLFxuICAgICAgICAgIGRhdGEudGFibGUoY3Njb3JlKVtzdWJqZWN0SGl0cyhvdmVybGFwKV0pXG5cblxuZGF0YS5ubyA8LSBiaW5kX3Jvd3MoYmF0Y2gxLCBiYXRjaDIpXG5cbiMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyMjIE92ZXJsYXBcbmNzY29yZS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoY3Njb3JlWzE6M10pXG5vdmVybGFwIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuZG93biwgY3Njb3JlLmdyKVxuXG4jIyBQcm9ibGVtIG9mIGNlcnRhaW4gZ2VuZXMgbm90IGdldHRpbmcgb3ZlcmxhcCB3aXRoIGNzY29yZSBkdWUgdG8gc3BhcnNlIGNhbGxpbmc/XG5iYXRjaDEgPC0gYmluZF9jb2xzKGRhdGEudGFibGUoYW5jaG9yLmRvd24udGIpW3F1ZXJ5SGl0cyhvdmVybGFwKV0sXG4gICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxuXG5taXNzZWQgPC0gZGF0YS50YWJsZShhbmNob3IuZG93bi50YilbLXF1ZXJ5SGl0cyhvdmVybGFwKV1cbnRlbXAgPC0gbWlzc2VkICU+JSBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gc3RhcnQgLSAxMDAwMCwgZW5kID0gZW5kIC0gMTAwMDApICU+JVxuICBkcGx5cjo6c2VsZWN0KHNlcW5hbWVzLCBzdGFydCwgZW5kKVxubWlzc2VkLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxub3ZlcmxhcCA8LSBmaW5kT3ZlcmxhcHMobWlzc2VkLmdyLCBjc2NvcmUuZ3IpXG5iYXRjaDIgPC0gYmluZF9jb2xzKChtaXNzZWQpW3F1ZXJ5SGl0cyhvdmVybGFwKV0sXG4gICAgICAgICAgZGF0YS50YWJsZShjc2NvcmUpW3N1YmplY3RIaXRzKG92ZXJsYXApXSlcblxuXG5kYXRhLmRvd24gPC0gYmluZF9yb3dzKGJhdGNoMSwgYmF0Y2gyKVxuXG5uLnVwIDwtIG5yb3coZGF0YS51cClcbm4ubm8gPC0gbnJvdyhkYXRhLm5vKVxubi5kb3duIDwtIG5yb3coZGF0YS5kb3duKVxuXG5kYXRhIDwtIHRpYmJsZShsb29wRGlmZiA9IGMocmVwKFxcVVBcXCwgbi51cCksIHJlcChcXE5PXFwsIG4ubm8pLCByZXAoXFxET1dOXFwsIG4uZG93bikpLFxuICAgICAgICAgICAgICBjaGFuZ2VUeXBlID0gYyhkYXRhLnVwJGNoYW5nZVR5cGUsIGRhdGEubm8kY2hhbmdlVHlwZSwgZGF0YS5kb3duJGNoYW5nZVR5cGUpKVxuXG4jIFZJU1VBTElaRVxuZGF0YSRjaGFuZ2VUeXBlIDwtIGZhY3RvcihkYXRhJGNoYW5nZVR5cGUsIGxldmVscyA9IGMoXFxBX3dlYWtlbmluZ1xcLCBcXEF0b0JcXCwgXFxCX3N0cmVuZ3RoZW5pbmdcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxCX3dlYWtlbmluZ1xcLCBcXEJ0b0FcXCwgXFxBX3N0cmVuZ3RoZW5pbmdcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxVbmNoYW5nZWRcXCkpXG5nZ3Bsb3QoZGF0YSwgYWVzKHggPSBsb29wRGlmZiwgZmlsbCA9IGNoYW5nZVR5cGUpKSArXG4gIGdlb21fYmFyKHBvc2l0aW9uID0gXFxmaWxsXFwpICtcbiAgbGFicyh0aXRsZSA9IFxcU3RhY2tlZCBCYXIgUGxvdCBvZiBDaGFuZ2UgVHlwZSBieSBEaWZmXFwsXG4gICAgICAgeCA9IFxcRGlmZlxcLFxuICAgICAgIHkgPSBcXENvdW50XFwpICtcbiAgdGhlbWVfYncoKSArICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFxcc2t5Ymx1ZVxcLCBcXGJsdWVcXCwgXFxkYXJrYmx1ZVxcLCBcXHBpbmtcXCwgXFxyZWQyXFwsIFxcZGFya3JlZFxcICxcXGdyZXlcXCkpXG5cblxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
name <- \chromo_cons_annoHierarchy\

# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe\))
anchor.up <- (extractAnchor(loop.up))
anchor.up.tb <- as_tibble(anchor.up) %>%
  dplyr::mutate(center = (start + end)/2) %>%
  dplyr::mutate(start = center-1, end = center+1) %>%
  dplyr::select(seqnames, start, end)
anchor.up <- makeGRangesFromDataFrame(anchor.up.tb)
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe\))
anchor.no <- (extractAnchor(loop.no))
anchor.no.tb <- as_tibble(anchor.no) %>%
  dplyr::mutate(center = (start + end)/2) %>%
  dplyr::mutate(start = center-1, end = center+1) %>%
  dplyr::select(seqnames, start, end)
anchor.no <- makeGRangesFromDataFrame(anchor.no.tb)
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- (extractAnchor(loop.down))
anchor.down.tb <- as_tibble(anchor.down) %>%
  dplyr::mutate(center = (start + end)/2) %>%
  dplyr::mutate(start = center-1, end = center+1) %>%
  dplyr::select(seqnames, start, end)
anchor.down <- makeGRangesFromDataFrame(anchor.down.tb)


########################################################################
### Overlap
cscore.gr <- makeGRangesFromDataFrame(cscore[1:3])
overlap <- findOverlaps(anchor.up, cscore.gr)

## Problem of certain genes not getting overlap with cscore due to sparse calling?
batch1 <- bind_cols(data.table(anchor.up.tb)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


missed <- data.table(anchor.up.tb)[-queryHits(overlap)]
temp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%
  dplyr::select(seqnames, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch2 <- bind_cols((missed)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


data.up <- bind_rows(batch1, batch2)

########################################################################
### Overlap
cscore.gr <- makeGRangesFromDataFrame(cscore[1:3])
overlap <- findOverlaps(anchor.no, cscore.gr)

## Problem of certain genes not getting overlap with cscore due to sparse calling?
batch1 <- bind_cols(data.table(anchor.no.tb)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


missed <- data.table(anchor.no.tb)[-queryHits(overlap)]
temp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%
  dplyr::select(seqnames, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch2 <- bind_cols((missed)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


data.no <- bind_rows(batch1, batch2)

########################################################################
### Overlap
cscore.gr <- makeGRangesFromDataFrame(cscore[1:3])
overlap <- findOverlaps(anchor.down, cscore.gr)

## Problem of certain genes not getting overlap with cscore due to sparse calling?
batch1 <- bind_cols(data.table(anchor.down.tb)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


missed <- data.table(anchor.down.tb)[-queryHits(overlap)]
temp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%
  dplyr::select(seqnames, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch2 <- bind_cols((missed)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


data.down <- bind_rows(batch1, batch2)

n.up <- nrow(data.up)
n.no <- nrow(data.no)
n.down <- nrow(data.down)

data <- tibble(loopDiff = c(rep(\UP\, n.up), rep(\NO\, n.no), rep(\DOWN\, n.down)),
              changeType = c(data.up$changeType, data.no$changeType, data.down$changeType))

# VISUALIZE
data$changeType <- factor(data$changeType, levels = c(\A_weakening\, \AtoB\, \B_strengthening\,
                                                                          \B_weakening\, \BtoA\, \A_strengthening\,
                                                                          \Unchanged\))
ggplot(data, aes(x = loopDiff, fill = changeType)) +
  geom_bar(position = \fill\) +
  labs(title = \Stacked Bar Plot of Change Type by Diff\,
       x = \Diff\,
       y = \Count\) +
  theme_bw() +  scale_fill_manual(values = c(\skyblue\, \blue\, \darkblue\, \pink\, \red2\, \darkred\ ,\grey\))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Combining with RNA-seq

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjbVZ6ZFd4MFJHbHlJRHd0SUdobGNtVW9YQ0l1TGk4dUxpOXlaWE4xYkhSY0lpbGNibHh1WkdGMFlTQThMU0JtY21WaFpDaG9aWEpsS0hKbGMzVnNkRVJwY2l3Z1hDSmphSEp2YlVoTlRWd2lMQ0JjSWtFME9EVmZjR1V0Y0dWZllXNWphRzl5YzF3aUxDQmNJbTkyWlhKc1lYQmZaVzV5YVdOb1h6RXdNRjl6ZEdGMFpTNTBlSFJjSWlrcFhHNWpiMnh1WVcxbGN5aGtZWFJoS1NBOExTQmpLRndpYzNSaGRHVmNJaXdnWENKblpXNXZiV1ZjSWl3Z1hDSndaUzF3WlY5Qk5EZzFYMlJ2ZDI1Y0lpd2dYQ0p3WlMxd1pWOUJORGcxWDI1dlhDSXNJRndpY0dVdGNHVmZRVFE0TlY5MWNGd2lLVnh1WkdGMFlTQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZjMlZzWldOMEtDMW5aVzV2YldVcFhHNWNibVJoZEdGZmJXRjBjbWw0SUR3dElHUmhkR0VnSlQ0bFhHNGdJR052YkhWdGJsOTBiMTl5YjNkdVlXMWxjeWgyWVhJZ1BTQmNJbk4wWVhSbFhDSXBJQ1UrSlZ4dUlDQmhjeTV0WVhSeWFYZ29LVnh1WEc1c2FXSnlZWEo1S0dOcGNtTnNhWHBsS1Z4dVhHNWpiMnhmWm5WdUlEd3RJR052Ykc5eVVtRnRjRElvWXlnd0xDQXhMQ0F4TUNrc0lGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdNb1hDSmliSFZsWENJc0lGd2lkMmhwZEdWY0lpd2dYQ0p5WldSY0lpa3BYRzVjYmtobFlYUnRZWEFvWEc0Z0lHUmhkR0ZmYldGMGNtbDRMRnh1SUNCdVlXMWxJRDBnWENKV1lXeDFaVndpTEZ4dUlDQnphRzkzWDNKdmQxOXVZVzFsY3lBOUlGUlNWVVVzWEc0Z0lITm9iM2RmWTI5c2RXMXVYMjVoYldWeklEMGdWRkpWUlN4Y2JpQWdZMngxYzNSbGNsOWpiMngxYlc1eklEMGdSa0ZNVTBVc1hHNGdJR05zZFhOMFpYSmZjbTkzY3lBOUlFWkJURk5GTEZ4dUlDQWdZMjlzSUQwZ1kyOXNYMloxYmx4dUtWeHVYRzRqSXlNakl5TWpYRzVrWVhSaE1pQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZjMlZzWldOMEtHTW9NU3dnTWl3Z05Da3BYRzVrWVhSaE1pQThMU0JrWVhSaE1pQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaGdjR1V0Y0dWZlFUUTROVjlrYjNkdVlDQStJR0J3WlMxd1pWOUJORGcxWDNWd1lDbGNibVJoZEdGZmJXRjBjbWw0SUR3dElHUmhkR0V5SUNVK0pWeHVJQ0JqYjJ4MWJXNWZkRzlmY205M2JtRnRaWE1vZG1GeUlEMGdYQ0p6ZEdGMFpWd2lLU0FsUGlWY2JpQWdZWE11YldGMGNtbDRLQ2xjYmx4dWJHbGljbUZ5ZVNoamFYSmpiR2w2WlNsY2JseHVZMjlzWDJaMWJpQThMU0JqYjJ4dmNsSmhiWEF5S0dNb01Dd2dNU3dnTVRBcExDQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCaktGd2lZbXgxWlZ3aUxDQmNJbmRvYVhSbFhDSXNJRndpY21Wa1hDSXBLVnh1WEc1SVpXRjBiV0Z3S0Z4dUlDQmtZWFJoWDIxaGRISnBlQ3hjYmlBZ2JtRnRaU0E5SUZ3aVZtRnNkV1ZjSWl4Y2JpQWdjMmh2ZDE5eWIzZGZibUZ0WlhNZ1BTQlVVbFZGTEZ4dUlDQnphRzkzWDJOdmJIVnRibDl1WVcxbGN5QTlJRlJTVlVVc1hHNGdJR05zZFhOMFpYSmZZMjlzZFcxdWN5QTlJRVpCVEZORkxGeHVJQ0JqYkhWemRHVnlYM0p2ZDNNZ1BTQkdRVXhUUlN4Y2JpQWdJR052YkNBOUlHTnZiRjltZFc1Y2JpbGNibHh1WEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5yZXN1bHREaXIgPC0gaGVyZShcXC4uLy4uL3Jlc3VsdFxcKVxuXG5kYXRhIDwtIGZyZWFkKGhlcmUocmVzdWx0RGlyLCBcXGNocm9tSE1NXFwsIFxcQTQ4NV9wZS1wZV9hbmNob3JzXFwsIFxcb3ZlcmxhcF9lbnJpY2hfMTAwX3N0YXRlLnR4dFxcKSlcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxzdGF0ZVxcLCBcXGdlbm9tZVxcLCBcXHBlLXBlX0E0ODVfZG93blxcLCBcXHBlLXBlX0E0ODVfbm9cXCwgXFxwZS1wZV9BNDg1X3VwXFwpXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QoLWdlbm9tZSlcblxuZGF0YV9tYXRyaXggPC0gZGF0YSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcc3RhdGVcXCkgJT4lXG4gIGFzLm1hdHJpeCgpXG5cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEsIDEwKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuSGVhdG1hcChcbiAgZGF0YV9tYXRyaXgsXG4gIG5hbWUgPSBcXFZhbHVlXFwsXG4gIHNob3dfcm93X25hbWVzID0gVFJVRSxcbiAgc2hvd19jb2x1bW5fbmFtZXMgPSBUUlVFLFxuICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgY2x1c3Rlcl9yb3dzID0gRkFMU0UsXG4gICBjb2wgPSBjb2xfZnVuXG4pXG5cbiMjIyMjIyNcbmRhdGEyIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCA0KSlcbmRhdGEyIDwtIGRhdGEyICU+JSBkcGx5cjo6ZmlsdGVyKGBwZS1wZV9BNDg1X2Rvd25gID4gYHBlLXBlX0E0ODVfdXBgKVxuZGF0YV9tYXRyaXggPC0gZGF0YTIgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHN0YXRlXFwpICU+JVxuICBhcy5tYXRyaXgoKVxuXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAxMCksIFxuICAgICAgICAgICAgICAgICAgICAgIGMoXFxibHVlXFwsIFxcd2hpdGVcXCwgXFxyZWRcXCkpXG5cbkhlYXRtYXAoXG4gIGRhdGFfbWF0cml4LFxuICBuYW1lID0gXFxWYWx1ZVxcLFxuICBzaG93X3Jvd19uYW1lcyA9IFRSVUUsXG4gIHNob3dfY29sdW1uX25hbWVzID0gVFJVRSxcbiAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsXG4gIGNsdXN0ZXJfcm93cyA9IEZBTFNFLFxuICAgY29sID0gY29sX2Z1blxuKVxuXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
resultDir <- here(\../../result\)

data <- fread(here(resultDir, \chromHMM\, \A485_pe-pe_anchors\, \overlap_enrich_100_state.txt\))
colnames(data) <- c(\state\, \genome\, \pe-pe_A485_down\, \pe-pe_A485_no\, \pe-pe_A485_up\)
data <- data %>% dplyr::select(-genome)

data_matrix <- data %>%
  column_to_rownames(var = \state\) %>%
  as.matrix()

library(circlize)

col_fun <- colorRamp2(c(0, 1, 10), 
                      c(\blue\, \white\, \red\))

Heatmap(
  data_matrix,
  name = \Value\,
  show_row_names = TRUE,
  show_column_names = TRUE,
  cluster_columns = FALSE,
  cluster_rows = FALSE,
   col = col_fun
)

#######
data2 <- data %>% dplyr::select(c(1, 2, 4))
data2 <- data2 %>% dplyr::filter(`pe-pe_A485_down` > `pe-pe_A485_up`)
data_matrix <- data2 %>%
  column_to_rownames(var = \state\) %>%
  as.matrix()

library(circlize)

col_fun <- colorRamp2(c(0, 1, 10), 
                      c(\blue\, \white\, \red\))

Heatmap(
  data_matrix,
  name = \Value\,
  show_row_names = TRUE,
  show_column_names = TRUE,
  cluster_columns = FALSE,
  cluster_rows = FALSE,
   col = col_fun
)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWNtVnpkV3gwUkdseUlEd3RJR2hsY21Vb1hGd3VMaTh1TGk5eVpYTjFiSFJjWENsY2JseHVaR0YwWVNBOExTQm1jbVZoWkNob1pYSmxLSEpsYzNWc2RFUnBjaXdnWEZ4amFISnZiVWhOVFZ4Y0xDQmNYRUUwT0RWZmNHVXRjR1ZmWVc1amFHOXljMXhjTENCY1hHOTJaWEpzWVhCZlpXNXlhV05vWHpFd01GOXpkR0YwWlM1MGVIUmNYQ2twWEc1amIyeHVZVzFsY3loa1lYUmhLU0E4TFNCaktGeGNjM1JoZEdWY1hDd2dYRnhuWlc1dmJXVmNYQ3dnWEZ4d1pTMXdaVjlCTkRnMVgyUnZkMjVjWEN3Z1hGeHdaUzF3WlY5Qk5EZzFYMjV2WEZ3c0lGeGNjR1V0Y0dWZlFUUTROVjkxY0Z4Y0tWeHVaR0YwWVNBOExTQmtZWFJoSUNVK0pTQmtjR3g1Y2pvNmMyVnNaV04wS0MxblpXNXZiV1VwWEc1Y2JtUmhkR0ZmYldGMGNtbDRJRHd0SUdSaGRHRWdKVDRsWEc0Z0lHTnZiSFZ0Ymw5MGIxOXliM2R1WVcxbGN5aDJZWElnUFNCY1hITjBZWFJsWEZ3cElDVStKVnh1SUNCaGN5NXRZWFJ5YVhnb0tWeHVYRzVzYVdKeVlYSjVLR05wY21Oc2FYcGxLVnh1WEc1amIyeGZablZ1SUR3dElHTnZiRzl5VW1GdGNESW9ZeWd3TENBeExDQXhNQ2tzSUZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR01vWEZ4aWJIVmxYRndzSUZ4Y2QyaHBkR1ZjWEN3Z1hGeHlaV1JjWENrcFhHNWNia2hsWVhSdFlYQW9YRzRnSUdSaGRHRmZiV0YwY21sNExGeHVJQ0J1WVcxbElEMGdYRnhXWVd4MVpWeGNMRnh1SUNCemFHOTNYM0p2ZDE5dVlXMWxjeUE5SUZSU1ZVVXNYRzRnSUhOb2IzZGZZMjlzZFcxdVgyNWhiV1Z6SUQwZ1ZGSlZSU3hjYmlBZ1kyeDFjM1JsY2w5amIyeDFiVzV6SUQwZ1JrRk1VMFVzWEc0Z0lHTnNkWE4wWlhKZmNtOTNjeUE5SUVaQlRGTkZMRnh1SUNBZ1kyOXNJRDBnWTI5c1gyWjFibHh1S1Z4dVhHNGpJeU1qSXlNalhHNWtZWFJoTWlBOExTQmtZWFJoSUNVK0pTQmtjR3g1Y2pvNmMyVnNaV04wS0dNb01Td2dNaXdnTkNrcFhHNWtZWFJoTWlBOExTQmtZWFJoTWlBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2loZ2NHVXRjR1ZmUVRRNE5WOWtiM2R1WUNBK0lHQndaUzF3WlY5Qk5EZzFYM1Z3WUNsY2JtUmhkR0ZmYldGMGNtbDRJRHd0SUdSaGRHRXlJQ1UrSlZ4dUlDQmpiMngxYlc1ZmRHOWZjbTkzYm1GdFpYTW9kbUZ5SUQwZ1hGeHpkR0YwWlZ4Y0tTQWxQaVZjYmlBZ1lYTXViV0YwY21sNEtDbGNibHh1YkdsaWNtRnllU2hqYVhKamJHbDZaU2xjYmx4dVkyOXNYMloxYmlBOExTQmpiMnh2Y2xKaGJYQXlLR01vTUN3Z01Td2dNVEFwTENCY2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JqS0Z4Y1lteDFaVnhjTENCY1hIZG9hWFJsWEZ3c0lGeGNjbVZrWEZ3cEtWeHVYRzVJWldGMGJXRndLRnh1SUNCa1lYUmhYMjFoZEhKcGVDeGNiaUFnYm1GdFpTQTlJRnhjVm1Gc2RXVmNYQ3hjYmlBZ2MyaHZkMTl5YjNkZmJtRnRaWE1nUFNCVVVsVkZMRnh1SUNCemFHOTNYMk52YkhWdGJsOXVZVzFsY3lBOUlGUlNWVVVzWEc0Z0lHTnNkWE4wWlhKZlkyOXNkVzF1Y3lBOUlFWkJURk5GTEZ4dUlDQmpiSFZ6ZEdWeVgzSnZkM01nUFNCR1FVeFRSU3hjYmlBZ0lHTnZiQ0E5SUdOdmJGOW1kVzVjYmlsY2JseHVYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG5yZXN1bHREaXIgPC0gaGVyZShcXC4uLy4uL3Jlc3VsdFxcKVxuXG5kYXRhIDwtIGZyZWFkKGhlcmUocmVzdWx0RGlyLCBcXGNocm9tSE1NXFwsIFxcQTQ4NV9wZS1wZV9hbmNob3JzXFwsIFxcb3ZlcmxhcF9lbnJpY2hfMTAwX3N0YXRlLnR4dFxcKSlcbmNvbG5hbWVzKGRhdGEpIDwtIGMoXFxzdGF0ZVxcLCBcXGdlbm9tZVxcLCBcXHBlLXBlX0E0ODVfZG93blxcLCBcXHBlLXBlX0E0ODVfbm9cXCwgXFxwZS1wZV9BNDg1X3VwXFwpXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QoLWdlbm9tZSlcblxuZGF0YV9tYXRyaXggPC0gZGF0YSAlPiVcbiAgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcc3RhdGVcXCkgJT4lXG4gIGFzLm1hdHJpeCgpXG5cbmxpYnJhcnkoY2lyY2xpemUpXG5cbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEsIDEwKSwgXG4gICAgICAgICAgICAgICAgICAgICAgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcblxuSGVhdG1hcChcbiAgZGF0YV9tYXRyaXgsXG4gIG5hbWUgPSBcXFZhbHVlXFwsXG4gIHNob3dfcm93X25hbWVzID0gVFJVRSxcbiAgc2hvd19jb2x1bW5fbmFtZXMgPSBUUlVFLFxuICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgY2x1c3Rlcl9yb3dzID0gRkFMU0UsXG4gICBjb2wgPSBjb2xfZnVuXG4pXG5cbiMjIyMjIyNcbmRhdGEyIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCA0KSlcbmRhdGEyIDwtIGRhdGEyICU+JSBkcGx5cjo6ZmlsdGVyKGBwZS1wZV9BNDg1X2Rvd25gID4gYHBlLXBlX0E0ODVfdXBgKVxuZGF0YV9tYXRyaXggPC0gZGF0YTIgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHN0YXRlXFwpICU+JVxuICBhcy5tYXRyaXgoKVxuXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAxMCksIFxuICAgICAgICAgICAgICAgICAgICAgIGMoXFxibHVlXFwsIFxcd2hpdGVcXCwgXFxyZWRcXCkpXG5cbkhlYXRtYXAoXG4gIGRhdGFfbWF0cml4LFxuICBuYW1lID0gXFxWYWx1ZVxcLFxuICBzaG93X3Jvd19uYW1lcyA9IFRSVUUsXG4gIHNob3dfY29sdW1uX25hbWVzID0gVFJVRSxcbiAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsXG4gIGNsdXN0ZXJfcm93cyA9IEZBTFNFLFxuICAgY29sID0gY29sX2Z1blxuKVxuXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxucmVzdWx0RGlyIDwtIGhlcmUoXFwuLi8uLi9yZXN1bHRcXClcblxuZGF0YSA8LSBmcmVhZChoZXJlKHJlc3VsdERpciwgXFxjaHJvbUhNTVxcLCBcXEE0ODVfcGUtcGVfYW5jaG9yc1xcLCBcXG92ZXJsYXBfZW5yaWNoXzEwMF9zdGF0ZS50eHRcXCkpXG5jb2xuYW1lcyhkYXRhKSA8LSBjKFxcc3RhdGVcXCwgXFxnZW5vbWVcXCwgXFxwZS1wZV9BNDg1X2Rvd25cXCwgXFxwZS1wZV9BNDg1X25vXFwsIFxccGUtcGVfQTQ4NV91cFxcKVxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KC1nZW5vbWUpXG5cbmRhdGFfbWF0cml4IDwtIGRhdGEgJT4lXG4gIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXHN0YXRlXFwpICU+JVxuICBhcy5tYXRyaXgoKVxuXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygwLCAxLCAxMCksIFxuICAgICAgICAgICAgICAgICAgICAgIGMoXFxibHVlXFwsIFxcd2hpdGVcXCwgXFxyZWRcXCkpXG5cbkhlYXRtYXAoXG4gIGRhdGFfbWF0cml4LFxuICBuYW1lID0gXFxWYWx1ZVxcLFxuICBzaG93X3Jvd19uYW1lcyA9IFRSVUUsXG4gIHNob3dfY29sdW1uX25hbWVzID0gVFJVRSxcbiAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsXG4gIGNsdXN0ZXJfcm93cyA9IEZBTFNFLFxuICAgY29sID0gY29sX2Z1blxuKVxuXG4jIyMjIyMjXG5kYXRhMiA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KGMoMSwgMiwgNCkpXG5kYXRhMiA8LSBkYXRhMiAlPiUgZHBseXI6OmZpbHRlcihgcGUtcGVfQTQ4NV9kb3duYCA+IGBwZS1wZV9BNDg1X3VwYClcbmRhdGFfbWF0cml4IDwtIGRhdGEyICU+JVxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFxzdGF0ZVxcKSAlPiVcbiAgYXMubWF0cml4KClcblxubGlicmFyeShjaXJjbGl6ZSlcblxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoMCwgMSwgMTApLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFxcYmx1ZVxcLCBcXHdoaXRlXFwsIFxccmVkXFwpKVxuXG5IZWF0bWFwKFxuICBkYXRhX21hdHJpeCxcbiAgbmFtZSA9IFxcVmFsdWVcXCxcbiAgc2hvd19yb3dfbmFtZXMgPSBUUlVFLFxuICBzaG93X2NvbHVtbl9uYW1lcyA9IFRSVUUsXG4gIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICBjbHVzdGVyX3Jvd3MgPSBGQUxTRSxcbiAgIGNvbCA9IGNvbF9mdW5cbilcblxuXG5gYGBcbmBgYCJ9 -->

```r
```r
resultDir <- here(\../../result\)

data <- fread(here(resultDir, \chromHMM\, \A485_pe-pe_anchors\, \overlap_enrich_100_state.txt\))
colnames(data) <- c(\state\, \genome\, \pe-pe_A485_down\, \pe-pe_A485_no\, \pe-pe_A485_up\)
data <- data %>% dplyr::select(-genome)

data_matrix <- data %>%
  column_to_rownames(var = \state\) %>%
  as.matrix()

library(circlize)

col_fun <- colorRamp2(c(0, 1, 10), 
                      c(\blue\, \white\, \red\))

Heatmap(
  data_matrix,
  name = \Value\,
  show_row_names = TRUE,
  show_column_names = TRUE,
  cluster_columns = FALSE,
  cluster_rows = FALSE,
   col = col_fun
)

#######
data2 <- data %>% dplyr::select(c(1, 2, 4))
data2 <- data2 %>% dplyr::filter(`pe-pe_A485_down` > `pe-pe_A485_up`)
data_matrix <- data2 %>%
  column_to_rownames(var = \state\) %>%
  as.matrix()

library(circlize)

col_fun <- colorRamp2(c(0, 1, 10), 
                      c(\blue\, \white\, \red\))

Heatmap(
  data_matrix,
  name = \Value\,
  show_row_names = TRUE,
  show_column_names = TRUE,
  cluster_columns = FALSE,
  cluster_rows = FALSE,
   col = col_fun
)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Combining with loop

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n### Getting loop ID\ntemp <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe.bedpe\")) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \"_\"))\nregID <- temp$id\n\ntemp <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_structure.bedpe\")) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \"_\"))\nstrID <- temp$id\n\n############## REG\n## Filtering loops to plot\ndata <- fread(here(consensusDir, \"chromo_cons_score.tsv\"))\ntemp <- data %>% dplyr::filter(id %in% regID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\"V1\", \"V2\", \"V3\", \"V4\", \"V5\", \"V6\")\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \"/Volumes/UKJIN_SSD/data_vault_2024summer_microC/hic\"\nwindowSize <- 1*1e6\n\ni = 1\n# for(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \"G1.DMSO.Merged.hic\"))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \"G1.dTAG.Merged.hic\"))\n  #cf.G1dTAG <- HicFile(path = here(hicDir, \"G1.A485.Merged.hic\"))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\"visuzliation_regLoop_dTAG_\", i, \"_10kb_figureVer\"))\n  \n  width <- panelSize(20)*mmToInch\n  height <- panelSize(10)*mmToInch\n  \n  png(paste0(fileName, \".png\"), res = 600, units = \"in\", width = width, height = height)\n  print(cowplot::plot_grid(p1, p2, align = \"h\"))\n  dev.off()\n  svglite(paste0(fileName, \".svg\"), width = width, height = height)\n  print(cowplot::plot_grid(p1, p2, align = \"h\"))\n  dev.off()\n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\"visuzliation_regLoop_dTAG_\", i, \"_25kb\"))\n  png(paste0(fileName, \".png\"), res = 600, units = \"in\", width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \"h\"))\n  dev.off()\n  # svglite(paste0(fileName, \".svg\"), width = 10, height = 5)\n  # print(cowplot::plot_grid(p1, p2, align = \"h\"))\n  # dev.off()\n# }\n\n############## Str\n## Filtering loops to plot\ndata <- fread(here(consensusDir, \"chromo_cons_score.tsv\"))\ntemp <- data %>% dplyr::filter(id %in% strID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\"V1\", \"V2\", \"V3\", \"V4\", \"V5\", \"V6\")\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \"/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\"\nwindowSize <- 2*1e6\n\nfor(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \"G1.DMSO.Merged.hic\"))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \"G1.dTAG.Merged.hic\"))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\"visuzliation_strLoop_dTAG_\", i, \"_10kb\"))\n  png(paste0(fileName, \".png\"), res = 600, units = \"in\", width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \"h\"))\n  dev.off()\n  \n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\"visuzliation_strLoop_dTAG_\", i, \"_25kb\"))\n  png(paste0(fileName, \".png\"), res = 600, units = \"in\", width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \"h\"))\n  dev.off()\n}\n\n############## dTAG called loops\n## Filtering loops to plot\ndata1 <- fread(here(loopDir, \"G1.dTAG.Merged_chromosight_25kb.tsv\"))\ndata2 <- fread(here(loopDir, \"G1.dTAG.Merged_chromosight_10kb.tsv\"))\ndata3 <- fread(here(loopDir, \"G1.dTAG.Merged_chromosight_5kb.tsv\"))\ndata <- bind_rows(data1, data2, data3)\n\ntemp <- data %>% dplyr::arrange(desc(score))\n\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\"V1\", \"V2\", \"V3\", \"V4\", \"V5\", \"V6\")\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \"/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\"\nwindowSize <- 2*1e6\n\nfor(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \"G1.DMSO.Merged.hic\"))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \"G1.dTAG.Merged.hic\"))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\"visuzliation_dTAGcalledLoop_dTAG_\", i, \"_10kb\"))\n  png(paste0(fileName, \".png\"), res = 600, units = \"in\", width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \"h\"))\n  dev.off()\n  \n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\"visuzliation_dTAGcalledLoop_dTAG_\", i, \"_25kb\"))\n  png(paste0(fileName, \".png\"), res = 600, units = \"in\", width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \"h\"))\n  dev.off()\n}\n\nchr = \"chr13\"\nstart = 96900000\nend = 98100000\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \":\", start, \"-\", end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax))\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax))\n    print(cowplot::plot_grid(p1, p2, align = \"h\"))\n\n```"} -->\n\n```r\n### Getting loop ID\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nregID <- temp$id\n\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nstrID <- temp$id\n\n############## REG\n## Filtering loops to plot\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\ntemp <- data %>% dplyr::filter(id %in% regID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \\/Volumes/UKJIN_SSD/data_vault_2024summer_microC/hic\\\nwindowSize <- 1*1e6\n\ni = 1\n# for(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \\G1.DMSO.Merged.hic\\))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.dTAG.Merged.hic\\))\n  #cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.A485.Merged.hic\\))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_regLoop_dTAG_\\, i, \\_10kb_figureVer\\))\n  \n  width <- panelSize(20)*mmToInch\n  height <- panelSize(10)*mmToInch\n  \n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = width, height = height)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_regLoop_dTAG_\\, i, \\_25kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  # svglite(paste0(fileName, \\.svg\\), width = 10, height = 5)\n  # print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  # dev.off()\n# }\n\n############## Str\n## Filtering loops to plot\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\ntemp <- data %>% dplyr::filter(id %in% strID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \\/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\\\nwindowSize <- 2*1e6\n\nfor(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \\G1.DMSO.Merged.hic\\))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.dTAG.Merged.hic\\))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_strLoop_dTAG_\\, i, \\_10kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  \n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_strLoop_dTAG_\\, i, \\_25kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n}\n\n############## dTAG called loops\n## Filtering loops to plot\ndata1 <- fread(here(loopDir, \\G1.dTAG.Merged_chromosight_25kb.tsv\\))\ndata2 <- fread(here(loopDir, \\G1.dTAG.Merged_chromosight_10kb.tsv\\))\ndata3 <- fread(here(loopDir, \\G1.dTAG.Merged_chromosight_5kb.tsv\\))\ndata <- bind_rows(data1, data2, data3)\n\ntemp <- data %>% dplyr::arrange(desc(score))\n\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \\/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\\\nwindowSize <- 2*1e6\n\nfor(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \\G1.DMSO.Merged.hic\\))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.dTAG.Merged.hic\\))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_dTAGcalledLoop_dTAG_\\, i, \\_10kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  \n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_dTAGcalledLoop_dTAG_\\, i, \\_25kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n}\n\nchr = \\chr13\\\nstart = 96900000\nend = 98100000\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax))\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax))\n    print(cowplot::plot_grid(p1, p2, align = \\h\\))\n\n```\n\n<!-- rnb-source-end -->\n"} -->
### Getting loop ID
temp <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\)) %>%
  dplyr::mutate(res = V3 - V2,
                id = paste(V1, res, V2, V5, sep = \_\))
regID <- temp$id

temp <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure.bedpe\)) %>%
  dplyr::mutate(res = V3 - V2,
                id = paste(V1, res, V2, V5, sep = \_\))
strID <- temp$id

############## REG
## Filtering loops to plot
data <- fread(here(consensusDir, \chromo_cons_score.tsv\))
temp <- data %>% dplyr::filter(id %in% regID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))
temp <- temp %>% dplyr::select(seq(1, 6))
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
loops <- importBedpe(temp)

# Visualization
hicDir <- \/Volumes/UKJIN_SSD/data_vault_2024summer_microC/hic\
windowSize <- 1*1e6

i = 1
# for(i in seq(1, 25)){
  ## Loading hic and plotting
  chr <- as_tibble(loops[i])$seqnames1
  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2
  start <- floor(center - 0.5*windowSize)
  end <- floor(center + 0.5*windowSize)
  
  cf.G1DMSO <- HicFile(path = here(hicDir, \G1.DMSO.Merged.hic\))
  cf.G1dTAG <- HicFile(path = here(hicDir, \G1.dTAG.Merged.hic\))
  #cf.G1dTAG <- HicFile(path = here(hicDir, \G1.A485.Merged.hic\))

  res <- 10*1000
  zmax <- 2.5
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0(\visuzliation_regLoop_dTAG_\, i, \_10kb_figureVer\))
  
  width <- panelSize(20)*mmToInch
  height <- panelSize(10)*mmToInch
  
  png(paste0(fileName, \.png\), res = 600, units = \in\, width = width, height = height)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
  svglite(paste0(fileName, \.svg\), width = width, height = height)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
  
  res <- 25*1000
  zmax <- 3
  start <- floor(center - windowSize)
  end <- floor(center + windowSize)
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0(\visuzliation_regLoop_dTAG_\, i, \_25kb\))
  png(paste0(fileName, \.png\), res = 600, units = \in\, width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
  # svglite(paste0(fileName, \.svg\), width = 10, height = 5)
  # print(cowplot::plot_grid(p1, p2, align = \h\))
  # dev.off()
# }

############## Str
## Filtering loops to plot
data <- fread(here(consensusDir, \chromo_cons_score.tsv\))
temp <- data %>% dplyr::filter(id %in% strID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))
temp <- temp %>% dplyr::select(seq(1, 6))
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
loops <- importBedpe(temp)

# Visualization
hicDir <- \/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\
windowSize <- 2*1e6

for(i in seq(1, 25)){
  ## Loading hic and plotting
  chr <- as_tibble(loops[i])$seqnames1
  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2
  start <- floor(center - 0.5*windowSize)
  end <- floor(center + 0.5*windowSize)
  
  cf.G1DMSO <- HicFile(path = here(hicDir, \G1.DMSO.Merged.hic\))
  cf.G1dTAG <- HicFile(path = here(hicDir, \G1.dTAG.Merged.hic\))

  res <- 10*1000
  zmax <- 2.5
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0(\visuzliation_strLoop_dTAG_\, i, \_10kb\))
  png(paste0(fileName, \.png\), res = 600, units = \in\, width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
  
  
  res <- 25*1000
  zmax <- 3
  start <- floor(center - windowSize)
  end <- floor(center + windowSize)
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0(\visuzliation_strLoop_dTAG_\, i, \_25kb\))
  png(paste0(fileName, \.png\), res = 600, units = \in\, width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
}

############## dTAG called loops
## Filtering loops to plot
data1 <- fread(here(loopDir, \G1.dTAG.Merged_chromosight_25kb.tsv\))
data2 <- fread(here(loopDir, \G1.dTAG.Merged_chromosight_10kb.tsv\))
data3 <- fread(here(loopDir, \G1.dTAG.Merged_chromosight_5kb.tsv\))
data <- bind_rows(data1, data2, data3)

temp <- data %>% dplyr::arrange(desc(score))

temp <- temp %>% dplyr::select(seq(1, 6))
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
loops <- importBedpe(temp)

# Visualization
hicDir <- \/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\
windowSize <- 2*1e6

for(i in seq(1, 25)){
  ## Loading hic and plotting
  chr <- as_tibble(loops[i])$seqnames1
  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2
  start <- floor(center - 0.5*windowSize)
  end <- floor(center + 0.5*windowSize)
  
  cf.G1DMSO <- HicFile(path = here(hicDir, \G1.DMSO.Merged.hic\))
  cf.G1dTAG <- HicFile(path = here(hicDir, \G1.dTAG.Merged.hic\))

  res <- 10*1000
  zmax <- 2.5
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0(\visuzliation_dTAGcalledLoop_dTAG_\, i, \_10kb\))
  png(paste0(fileName, \.png\), res = 600, units = \in\, width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
  
  
  res <- 25*1000
  zmax <- 3
  start <- floor(center - windowSize)
  end <- floor(center + windowSize)
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0(\visuzliation_dTAGcalledLoop_dTAG_\, i, \_25kb\))
  png(paste0(fileName, \.png\), res = 600, units = \in\, width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
}

chr = \chr13\
start = 96900000
end = 98100000
  res <- 10*1000
  zmax <- 2.5
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax))
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax))
    print(cowplot::plot_grid(p1, p2, align = \h\))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n### Getting loop ID\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nregID <- temp$id\n\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nstrID <- temp$id\n\n############## REG\n## Filtering loops to plot\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\ntemp <- data %>% dplyr::filter(id %in% regID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \\/Volumes/UKJIN_SSD/data_vault_2024summer_microC/hic\\\nwindowSize <- 1*1e6\n\ni = 1\n# for(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \\G1.DMSO.Merged.hic\\))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.dTAG.Merged.hic\\))\n  #cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.A485.Merged.hic\\))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_regLoop_dTAG_\\, i, \\_10kb_figureVer\\))\n  \n  width <- panelSize(20)*mmToInch\n  height <- panelSize(10)*mmToInch\n  \n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = width, height = height)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_regLoop_dTAG_\\, i, \\_25kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  # svglite(paste0(fileName, \\.svg\\), width = 10, height = 5)\n  # print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  # dev.off()\n# }\n\n############## Str\n## Filtering loops to plot\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\ntemp <- data %>% dplyr::filter(id %in% strID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \\/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\\\nwindowSize <- 2*1e6\n\nfor(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \\G1.DMSO.Merged.hic\\))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.dTAG.Merged.hic\\))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_strLoop_dTAG_\\, i, \\_10kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  \n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_strLoop_dTAG_\\, i, \\_25kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n}\n\n############## dTAG called loops\n## Filtering loops to plot\ndata1 <- fread(here(loopDir, \\G1.dTAG.Merged_chromosight_25kb.tsv\\))\ndata2 <- fread(here(loopDir, \\G1.dTAG.Merged_chromosight_10kb.tsv\\))\ndata3 <- fread(here(loopDir, \\G1.dTAG.Merged_chromosight_5kb.tsv\\))\ndata <- bind_rows(data1, data2, data3)\n\ntemp <- data %>% dplyr::arrange(desc(score))\n\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \\/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\\\nwindowSize <- 2*1e6\n\nfor(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \\G1.DMSO.Merged.hic\\))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.dTAG.Merged.hic\\))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_dTAGcalledLoop_dTAG_\\, i, \\_10kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  \n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_dTAGcalledLoop_dTAG_\\, i, \\_25kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n}\n\nchr = \\chr13\\\nstart = 96900000\nend = 98100000\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax))\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax))\n    print(cowplot::plot_grid(p1, p2, align = \\h\\))\n\n```\n```"} -->\n\n```r\n```r\n### Getting loop ID\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nregID <- temp$id\n\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nstrID <- temp$id\n\n############## REG\n## Filtering loops to plot\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\ntemp <- data %>% dplyr::filter(id %in% regID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \\/Volumes/UKJIN_SSD/data_vault_2024summer_microC/hic\\\nwindowSize <- 1*1e6\n\ni = 1\n# for(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \\G1.DMSO.Merged.hic\\))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.dTAG.Merged.hic\\))\n  #cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.A485.Merged.hic\\))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_regLoop_dTAG_\\, i, \\_10kb_figureVer\\))\n  \n  width <- panelSize(20)*mmToInch\n  height <- panelSize(10)*mmToInch\n  \n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = width, height = height)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_regLoop_dTAG_\\, i, \\_25kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  # svglite(paste0(fileName, \\.svg\\), width = 10, height = 5)\n  # print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  # dev.off()\n# }\n\n############## Str\n## Filtering loops to plot\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\ntemp <- data %>% dplyr::filter(id %in% strID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \\/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\\\nwindowSize <- 2*1e6\n\nfor(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \\G1.DMSO.Merged.hic\\))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.dTAG.Merged.hic\\))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_strLoop_dTAG_\\, i, \\_10kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  \n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_strLoop_dTAG_\\, i, \\_25kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n}\n\n############## dTAG called loops\n## Filtering loops to plot\ndata1 <- fread(here(loopDir, \\G1.dTAG.Merged_chromosight_25kb.tsv\\))\ndata2 <- fread(here(loopDir, \\G1.dTAG.Merged_chromosight_10kb.tsv\\))\ndata3 <- fread(here(loopDir, \\G1.dTAG.Merged_chromosight_5kb.tsv\\))\ndata <- bind_rows(data1, data2, data3)\n\ntemp <- data %>% dplyr::arrange(desc(score))\n\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \\/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\\\nwindowSize <- 2*1e6\n\nfor(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \\G1.DMSO.Merged.hic\\))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.dTAG.Merged.hic\\))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_dTAGcalledLoop_dTAG_\\, i, \\_10kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  \n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_dTAGcalledLoop_dTAG_\\, i, \\_25kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n}\n\nchr = \\chr13\\\nstart = 96900000\nend = 98100000\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax))\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax))\n    print(cowplot::plot_grid(p1, p2, align = \\h\\))\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n### Getting loop ID\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nregID <- temp$id\n\ntemp <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure.bedpe\\)) %>%\n  dplyr::mutate(res = V3 - V2,\n                id = paste(V1, res, V2, V5, sep = \\_\\))\nstrID <- temp$id\n\n############## REG\n## Filtering loops to plot\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\ntemp <- data %>% dplyr::filter(id %in% regID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \\/Volumes/UKJIN_SSD/data_vault_2024summer_microC/hic\\\nwindowSize <- 1*1e6\n\ni = 1\n# for(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \\G1.DMSO.Merged.hic\\))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.dTAG.Merged.hic\\))\n  #cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.A485.Merged.hic\\))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_regLoop_dTAG_\\, i, \\_10kb_figureVer\\))\n  \n  width <- panelSize(20)*mmToInch\n  height <- panelSize(10)*mmToInch\n  \n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = width, height = height)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  svglite(paste0(fileName, \\.svg\\), width = width, height = height)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_regLoop_dTAG_\\, i, \\_25kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  # svglite(paste0(fileName, \\.svg\\), width = 10, height = 5)\n  # print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  # dev.off()\n# }\n\n############## Str\n## Filtering loops to plot\ndata <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\ntemp <- data %>% dplyr::filter(id %in% strID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \\/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\\\nwindowSize <- 2*1e6\n\nfor(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \\G1.DMSO.Merged.hic\\))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.dTAG.Merged.hic\\))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_strLoop_dTAG_\\, i, \\_10kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  \n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_strLoop_dTAG_\\, i, \\_25kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n}\n\n############## dTAG called loops\n## Filtering loops to plot\ndata1 <- fread(here(loopDir, \\G1.dTAG.Merged_chromosight_25kb.tsv\\))\ndata2 <- fread(here(loopDir, \\G1.dTAG.Merged_chromosight_10kb.tsv\\))\ndata3 <- fread(here(loopDir, \\G1.dTAG.Merged_chromosight_5kb.tsv\\))\ndata <- bind_rows(data1, data2, data3)\n\ntemp <- data %>% dplyr::arrange(desc(score))\n\ntemp <- temp %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\nloops <- importBedpe(temp)\n\n# Visualization\nhicDir <- \\/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\\\nwindowSize <- 2*1e6\n\nfor(i in seq(1, 25)){\n  ## Loading hic and plotting\n  chr <- as_tibble(loops[i])$seqnames1\n  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2\n  start <- floor(center - 0.5*windowSize)\n  end <- floor(center + 0.5*windowSize)\n  \n  cf.G1DMSO <- HicFile(path = here(hicDir, \\G1.DMSO.Merged.hic\\))\n  cf.G1dTAG <- HicFile(path = here(hicDir, \\G1.dTAG.Merged.hic\\))\n\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_dTAGcalledLoop_dTAG_\\, i, \\_10kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n  \n  \n  res <- 25*1000\n  zmax <- 3\n  start <- floor(center - windowSize)\n  end <- floor(center + windowSize)\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)\n  \n  fileName <- here(figDir, paste0(\\visuzliation_dTAGcalledLoop_dTAG_\\, i, \\_25kb\\))\n  png(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 10, height = 5)\n  print(cowplot::plot_grid(p1, p2, align = \\h\\))\n  dev.off()\n}\n\nchr = \\chr13\\\nstart = 96900000\nend = 98100000\n  res <- 10*1000\n  zmax <- 2.5\n  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \\:\\, start, \\-\\, end), resolution = res)\n  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax))\n  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax))\n    print(cowplot::plot_grid(p1, p2, align = \\h\\))\n\n```\n```"} -->

```r
```r
### Getting loop ID
temp <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\)) %>%
  dplyr::mutate(res = V3 - V2,
                id = paste(V1, res, V2, V5, sep = \_\))
regID <- temp$id

temp <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure.bedpe\)) %>%
  dplyr::mutate(res = V3 - V2,
                id = paste(V1, res, V2, V5, sep = \_\))
strID <- temp$id

############## REG
## Filtering loops to plot
data <- fread(here(consensusDir, \chromo_cons_score.tsv\))
temp <- data %>% dplyr::filter(id %in% regID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))
temp <- temp %>% dplyr::select(seq(1, 6))
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
loops <- importBedpe(temp)

# Visualization
hicDir <- \/Volumes/UKJIN_SSD/data_vault_2024summer_microC/hic\
windowSize <- 1*1e6

i = 1
# for(i in seq(1, 25)){
  ## Loading hic and plotting
  chr <- as_tibble(loops[i])$seqnames1
  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2
  start <- floor(center - 0.5*windowSize)
  end <- floor(center + 0.5*windowSize)
  
  cf.G1DMSO <- HicFile(path = here(hicDir, \G1.DMSO.Merged.hic\))
  cf.G1dTAG <- HicFile(path = here(hicDir, \G1.dTAG.Merged.hic\))
  #cf.G1dTAG <- HicFile(path = here(hicDir, \G1.A485.Merged.hic\))

  res <- 10*1000
  zmax <- 2.5
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0(\visuzliation_regLoop_dTAG_\, i, \_10kb_figureVer\))
  
  width <- panelSize(20)*mmToInch
  height <- panelSize(10)*mmToInch
  
  png(paste0(fileName, \.png\), res = 600, units = \in\, width = width, height = height)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
  svglite(paste0(fileName, \.svg\), width = width, height = height)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
  
  res <- 25*1000
  zmax <- 3
  start <- floor(center - windowSize)
  end <- floor(center + windowSize)
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0(\visuzliation_regLoop_dTAG_\, i, \_25kb\))
  png(paste0(fileName, \.png\), res = 600, units = \in\, width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
  # svglite(paste0(fileName, \.svg\), width = 10, height = 5)
  # print(cowplot::plot_grid(p1, p2, align = \h\))
  # dev.off()
# }

############## Str
## Filtering loops to plot
data <- fread(here(consensusDir, \chromo_cons_score.tsv\))
temp <- data %>% dplyr::filter(id %in% strID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))
temp <- temp %>% dplyr::select(seq(1, 6))
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
loops <- importBedpe(temp)

# Visualization
hicDir <- \/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\
windowSize <- 2*1e6

for(i in seq(1, 25)){
  ## Loading hic and plotting
  chr <- as_tibble(loops[i])$seqnames1
  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2
  start <- floor(center - 0.5*windowSize)
  end <- floor(center + 0.5*windowSize)
  
  cf.G1DMSO <- HicFile(path = here(hicDir, \G1.DMSO.Merged.hic\))
  cf.G1dTAG <- HicFile(path = here(hicDir, \G1.dTAG.Merged.hic\))

  res <- 10*1000
  zmax <- 2.5
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0(\visuzliation_strLoop_dTAG_\, i, \_10kb\))
  png(paste0(fileName, \.png\), res = 600, units = \in\, width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
  
  
  res <- 25*1000
  zmax <- 3
  start <- floor(center - windowSize)
  end <- floor(center + windowSize)
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0(\visuzliation_strLoop_dTAG_\, i, \_25kb\))
  png(paste0(fileName, \.png\), res = 600, units = \in\, width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
}

############## dTAG called loops
## Filtering loops to plot
data1 <- fread(here(loopDir, \G1.dTAG.Merged_chromosight_25kb.tsv\))
data2 <- fread(here(loopDir, \G1.dTAG.Merged_chromosight_10kb.tsv\))
data3 <- fread(here(loopDir, \G1.dTAG.Merged_chromosight_5kb.tsv\))
data <- bind_rows(data1, data2, data3)

temp <- data %>% dplyr::arrange(desc(score))

temp <- temp %>% dplyr::select(seq(1, 6))
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
loops <- importBedpe(temp)

# Visualization
hicDir <- \/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic\
windowSize <- 2*1e6

for(i in seq(1, 25)){
  ## Loading hic and plotting
  chr <- as_tibble(loops[i])$seqnames1
  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2
  start <- floor(center - 0.5*windowSize)
  end <- floor(center + 0.5*windowSize)
  
  cf.G1DMSO <- HicFile(path = here(hicDir, \G1.DMSO.Merged.hic\))
  cf.G1dTAG <- HicFile(path = here(hicDir, \G1.dTAG.Merged.hic\))

  res <- 10*1000
  zmax <- 2.5
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0(\visuzliation_dTAGcalledLoop_dTAG_\, i, \_10kb\))
  png(paste0(fileName, \.png\), res = 600, units = \in\, width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
  
  
  res <- 25*1000
  zmax <- 3
  start <- floor(center - windowSize)
  end <- floor(center + windowSize)
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0(\visuzliation_dTAGcalledLoop_dTAG_\, i, \_25kb\))
  png(paste0(fileName, \.png\), res = 600, units = \in\, width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
}

chr = \chr13\
start = 96900000
end = 98100000
  res <- 10*1000
  zmax <- 2.5
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, \:\, start, \-\, end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax))
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax))
    print(cowplot::plot_grid(p1, p2, align = \h\))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

## [2.30] ChromHMM

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubGlicmFyeShjaXJjbGl6ZSlcblxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiLnRzdlwiKSkpXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3Qoc2VxKDEsIDYpKVxuY29sbmFtZXModGVtcCkgPC0gYyhcIlYxXCIsIFwiVjJcIiwgXCJWM1wiLCBcIlY0XCIsIFwiVjVcIiwgXCJWNlwiKVxuY29ucy5sb29wIDwtIGltcG9ydEJlZHBlKHRlbXApXG5cbiMgQ2hlY2tpbmcgRE1TT1xubG9vcC4yNWtiIDwtIGltcG9ydEJlZHBlKGZyZWFkKGhlcmUobG9vcERpciwgcGFzdGUwKFwiRzEuRE1TTy5NZXJnZWRfY2hyb21vc2lnaHRfXCIsIDI1LCBcImtiLmJlZHBlXCIpKSkpXG5sb29wLjEwa2IgPC0gaW1wb3J0QmVkcGUoZnJlYWQoaGVyZShsb29wRGlyLCBwYXN0ZTAoXCJHMS5ETVNPLk1lcmdlZF9jaHJvbW9zaWdodF9cIiwgMTAsIFwia2IuYmVkcGVcIikpKSlcbmxvb3AuNWtiIDwtIGltcG9ydEJlZHBlKGZyZWFkKGhlcmUobG9vcERpciwgcGFzdGUwKFwiRzEuRE1TTy5NZXJnZWRfY2hyb21vc2lnaHRfXCIsIDUsIFwia2IuYmVkcGVcIikpKSlcblxuXG5vdmVybGFwLjI1a2IgPC0gZmluZE92ZXJsYXBzKGNvbnMubG9vcCwgbG9vcC4yNWtiKVxub3ZlcmxhcC4xMGtiIDwtIGZpbmRPdmVybGFwcyhjb25zLmxvb3AsIGxvb3AuMTBrYilcbm92ZXJsYXAuNWtiIDwtIGZpbmRPdmVybGFwcyhjb25zLmxvb3AsIGxvb3AuNWtiKVxuXG5pbmRleCA8LSBzb3J0KHVuaXF1ZShjKHF1ZXJ5SGl0cyhvdmVybGFwLjI1a2IpLFxuICAgICAgICAgcXVlcnlIaXRzKG92ZXJsYXAuMTBrYiksXG4gICAgICAgICBxdWVyeUhpdHMob3ZlcmxhcC41a2IpKSkpXG5kYXRhJGNhbGxlZEJ5RE1TTyA8LSAwXG5kYXRhJGNhbGxlZEJ5RE1TT1tpbmRleF0gPC0gMVxuXG4jIENoZWNraW5nIGRUQUdcbmxvb3AuMjVrYiA8LSBpbXBvcnRCZWRwZShmcmVhZChoZXJlKGxvb3BEaXIsIHBhc3RlMChcIkcxLmRUQUcuTWVyZ2VkX2Nocm9tb3NpZ2h0X1wiLCAyNSwgXCJrYi5iZWRwZVwiKSkpKVxubG9vcC4xMGtiIDwtIGltcG9ydEJlZHBlKGZyZWFkKGhlcmUobG9vcERpciwgcGFzdGUwKFwiRzEuZFRBRy5NZXJnZWRfY2hyb21vc2lnaHRfXCIsIDEwLCBcImtiLmJlZHBlXCIpKSkpXG5sb29wLjVrYiA8LSBpbXBvcnRCZWRwZShmcmVhZChoZXJlKGxvb3BEaXIsIHBhc3RlMChcIkcxLmRUQUcuTWVyZ2VkX2Nocm9tb3NpZ2h0X1wiLCA1LCBcImtiLmJlZHBlXCIpKSkpXG5cblxub3ZlcmxhcC4yNWtiIDwtIGZpbmRPdmVybGFwcyhjb25zLmxvb3AsIGxvb3AuMjVrYilcbm92ZXJsYXAuMTBrYiA8LSBmaW5kT3ZlcmxhcHMoY29ucy5sb29wLCBsb29wLjEwa2IpXG5vdmVybGFwLjVrYiA8LSBmaW5kT3ZlcmxhcHMoY29ucy5sb29wLCBsb29wLjVrYilcblxuaW5kZXggPC0gc29ydCh1bmlxdWUoYyhxdWVyeUhpdHMob3ZlcmxhcC4yNWtiKSxcbiAgICAgICAgIHF1ZXJ5SGl0cyhvdmVybGFwLjEwa2IpLFxuICAgICAgICAgcXVlcnlIaXRzKG92ZXJsYXAuNWtiKSkpKVxuZGF0YSRjYWxsZWRCeWRUQUcgPC0gMFxuZGF0YSRjYWxsZWRCeWRUQUdbaW5kZXhdIDwtIDFcblxuIyBDaGVja2luZyBBNDg1XG5sb29wLjI1a2IgPC0gaW1wb3J0QmVkcGUoZnJlYWQoaGVyZShsb29wRGlyLCBwYXN0ZTAoXCJHMS5BNDg1Lk1lcmdlZF9jaHJvbW9zaWdodF9cIiwgMjUsIFwia2IuYmVkcGVcIikpKSlcbmxvb3AuMTBrYiA8LSBpbXBvcnRCZWRwZShmcmVhZChoZXJlKGxvb3BEaXIsIHBhc3RlMChcIkcxLkE0ODUuTWVyZ2VkX2Nocm9tb3NpZ2h0X1wiLCAxMCwgXCJrYi5iZWRwZVwiKSkpKVxubG9vcC41a2IgPC0gaW1wb3J0QmVkcGUoZnJlYWQoaGVyZShsb29wRGlyLCBwYXN0ZTAoXCJHMS5BNDg1Lk1lcmdlZF9jaHJvbW9zaWdodF9cIiwgNSwgXCJrYi5iZWRwZVwiKSkpKVxuXG5cbm92ZXJsYXAuMjVrYiA8LSBmaW5kT3ZlcmxhcHMoY29ucy5sb29wLCBsb29wLjI1a2IpXG5vdmVybGFwLjEwa2IgPC0gZmluZE92ZXJsYXBzKGNvbnMubG9vcCwgbG9vcC4xMGtiKVxub3ZlcmxhcC41a2IgPC0gZmluZE92ZXJsYXBzKGNvbnMubG9vcCwgbG9vcC41a2IpXG5cbmluZGV4IDwtIHNvcnQodW5pcXVlKGMocXVlcnlIaXRzKG92ZXJsYXAuMjVrYiksXG4gICAgICAgICBxdWVyeUhpdHMob3ZlcmxhcC4xMGtiKSxcbiAgICAgICAgIHF1ZXJ5SGl0cyhvdmVybGFwLjVrYikpKSlcbmRhdGEkY2FsbGVkQnlBNDg1IDwtIDBcbmRhdGEkY2FsbGVkQnlBNDg1W2luZGV4XSA8LSAxXG5cblxuIyBIZWF0bWFwIChjaGVja2luZyB3aGV0aGVyIGNlcnRhaW4gcGVhayBpcyBjYWxsZWQgYnkgc3BlY2lmaWMgc2FtcGxlKVxuZGF0YVRvUGxvdCA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KGlkLCBjYWxsZWRCeURNU08sIGNhbGxlZEJ5ZFRBRywgY2FsbGVkQnlBNDg1KVxuZGF0YVRvUGxvdCA8LSBkYXRhVG9QbG90ICU+JSBkcGx5cjo6bXV0YXRlKGZsYWcgPSA0KmNhbGxlZEJ5RE1TTyArIDIqY2FsbGVkQnlkVEFHICsgY2FsbGVkQnlBNDg1KSAlPiVcbiAgZHBseXI6OmFycmFuZ2UoZGVzYyhmbGFnKSlcblxucm93X2dyb3VwcyA8LSBkYXRhVG9QbG90JGZsYWdcbmRhdGFfbWF0cml4IDwtIGRhdGFUb1Bsb3QgJT4lIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcImlkXCIpICU+JSBkcGx5cjo6c2VsZWN0KC1mbGFnKSAlPiUgYXMubWF0cml4KClcbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEpLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFwid2hpdGVcIiwgXCJncmVlblwiKSlcbmgxIDwtIEhlYXRtYXAoZGF0YV9tYXRyaXgsIG5hbWUgPSBcImNhbGxlZEJ5XCIsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBGQUxTRSxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBib3JkZXIgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19uYW1lcyA9IEZBTFNFLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICByb3dfc3BsaXQgPSByb3dfZ3JvdXBzKVxuXG5cbiMgUHJlcGFyZSBkYXRhIGZvciB0aGUgc2Vjb25kIGhlYXRtYXBcbmRhdGFUb1Bsb3QyIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QoaWQsIERNU08sIGRUQUcsIEE0ODUpICU+JVxuICBhcnJhbmdlKG1hdGNoKGlkLCBkYXRhVG9QbG90JGlkKSlcblxuZGF0YV9tYXRyaXgyIDwtIGRhdGFUb1Bsb3QyICU+JSBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXCJpZFwiKSAlPiUgYXMubWF0cml4KClcblxuXG5jb2xfZnVuMiA8LSBjb2xvclJhbXAyKGMoLTAuNSwgMCwgMSksIGMoXCJibHVlXCIsIFwid2hpdGVcIiwgXCJyZWRcIikpXG5cbmgyIDwtIEhlYXRtYXAoZGF0YV9tYXRyaXgyLCBuYW1lID0gXCJzY29yZVwiLFxuICAgICAgICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgICAgICAgY2x1c3Rlcl9yb3dzID0gVFJVRSxcbiAgICAgICAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICAgICAgICBib3JkZXIgPSBUUlVFLFxuICAgICAgICAgICAgICBzaG93X3Jvd19uYW1lcyA9IEZBTFNFLFxuICAgICAgICAgICAgICBjb2wgPSBjb2xfZnVuMixcbiAgICAgICAgICAgICAgcm93X3NwbGl0ID0gcm93X2dyb3VwcylcblxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgcGFzdGUwKFwiaGVhdG1hcF9jaGVja2luZ1NhbXBsZUNhbGxlZExvb3BzXCIpKVxucG5nKHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpLCByZXMgPSA2MDAsIHVuaXRzID0gXCJpblwiLCB3aWR0aCA9IDMsIGhlaWdodCA9IDEwKVxucHJpbnQoaDEgKyBoMilcbmRldi5vZmYoKVxuXG5gYGAifQ== -->\n\n```r\nlibrary(circlize)\n\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ntemp <- data %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\ncons.loop <- importBedpe(temp)\n\n# Checking DMSO\nloop.25kb <- importBedpe(fread(here(loopDir, paste0(\\G1.DMSO.Merged_chromosight_\\, 25, \\kb.bedpe\\))))\nloop.10kb <- importBedpe(fread(here(loopDir, paste0(\\G1.DMSO.Merged_chromosight_\\, 10, \\kb.bedpe\\))))\nloop.5kb <- importBedpe(fread(here(loopDir, paste0(\\G1.DMSO.Merged_chromosight_\\, 5, \\kb.bedpe\\))))\n\n\noverlap.25kb <- findOverlaps(cons.loop, loop.25kb)\noverlap.10kb <- findOverlaps(cons.loop, loop.10kb)\noverlap.5kb <- findOverlaps(cons.loop, loop.5kb)\n\nindex <- sort(unique(c(queryHits(overlap.25kb),\n         queryHits(overlap.10kb),\n         queryHits(overlap.5kb))))\ndata$calledByDMSO <- 0\ndata$calledByDMSO[index] <- 1\n\n# Checking dTAG\nloop.25kb <- importBedpe(fread(here(loopDir, paste0(\\G1.dTAG.Merged_chromosight_\\, 25, \\kb.bedpe\\))))\nloop.10kb <- importBedpe(fread(here(loopDir, paste0(\\G1.dTAG.Merged_chromosight_\\, 10, \\kb.bedpe\\))))\nloop.5kb <- importBedpe(fread(here(loopDir, paste0(\\G1.dTAG.Merged_chromosight_\\, 5, \\kb.bedpe\\))))\n\n\noverlap.25kb <- findOverlaps(cons.loop, loop.25kb)\noverlap.10kb <- findOverlaps(cons.loop, loop.10kb)\noverlap.5kb <- findOverlaps(cons.loop, loop.5kb)\n\nindex <- sort(unique(c(queryHits(overlap.25kb),\n         queryHits(overlap.10kb),\n         queryHits(overlap.5kb))))\ndata$calledBydTAG <- 0\ndata$calledBydTAG[index] <- 1\n\n# Checking A485\nloop.25kb <- importBedpe(fread(here(loopDir, paste0(\\G1.A485.Merged_chromosight_\\, 25, \\kb.bedpe\\))))\nloop.10kb <- importBedpe(fread(here(loopDir, paste0(\\G1.A485.Merged_chromosight_\\, 10, \\kb.bedpe\\))))\nloop.5kb <- importBedpe(fread(here(loopDir, paste0(\\G1.A485.Merged_chromosight_\\, 5, \\kb.bedpe\\))))\n\n\noverlap.25kb <- findOverlaps(cons.loop, loop.25kb)\noverlap.10kb <- findOverlaps(cons.loop, loop.10kb)\noverlap.5kb <- findOverlaps(cons.loop, loop.5kb)\n\nindex <- sort(unique(c(queryHits(overlap.25kb),\n         queryHits(overlap.10kb),\n         queryHits(overlap.5kb))))\ndata$calledByA485 <- 0\ndata$calledByA485[index] <- 1\n\n\n# Heatmap (checking whether certain peak is called by specific sample)\ndataToPlot <- data %>% dplyr::select(id, calledByDMSO, calledBydTAG, calledByA485)\ndataToPlot <- dataToPlot %>% dplyr::mutate(flag = 4*calledByDMSO + 2*calledBydTAG + calledByA485) %>%\n  dplyr::arrange(desc(flag))\n\nrow_groups <- dataToPlot$flag\ndata_matrix <- dataToPlot %>% column_to_rownames(var = \\id\\) %>% dplyr::select(-flag) %>% as.matrix()\ncol_fun <- colorRamp2(c(0, 1), \n                      c(\\white\\, \\green\\))\nh1 <- Heatmap(data_matrix, name = \\calledBy\\,\n        cluster_columns = FALSE,\n        cluster_rows = FALSE,\n        show_row_dend = FALSE,\n        border = TRUE,\n        show_row_names = FALSE,\n        col = col_fun,\n        row_split = row_groups)\n\n\n# Prepare data for the second heatmap\ndataToPlot2 <- data %>% dplyr::select(id, DMSO, dTAG, A485) %>%\n  arrange(match(id, dataToPlot$id))\n\ndata_matrix2 <- dataToPlot2 %>% column_to_rownames(var = \\id\\) %>% as.matrix()\n\n\ncol_fun2 <- colorRamp2(c(-0.5, 0, 1), c(\\blue\\, \\white\\, \\red\\))\n\nh2 <- Heatmap(data_matrix2, name = \\score\\,\n              cluster_columns = FALSE,\n              cluster_rows = TRUE,\n              show_row_dend = FALSE,\n              border = TRUE,\n              show_row_names = FALSE,\n              col = col_fun2,\n              row_split = row_groups)\n\n\nfileName <- here(figDir, paste0(\\heatmap_checkingSampleCalledLoops\\))\npng(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 3, height = 10)\nprint(h1 + h2)\ndev.off()\n\n```\n\n<!-- rnb-source-end -->\n"} -->
library(circlize)

name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
temp <- data %>% dplyr::select(seq(1, 6))
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
cons.loop <- importBedpe(temp)

# Checking DMSO
loop.25kb <- importBedpe(fread(here(loopDir, paste0(\G1.DMSO.Merged_chromosight_\, 25, \kb.bedpe\))))
loop.10kb <- importBedpe(fread(here(loopDir, paste0(\G1.DMSO.Merged_chromosight_\, 10, \kb.bedpe\))))
loop.5kb <- importBedpe(fread(here(loopDir, paste0(\G1.DMSO.Merged_chromosight_\, 5, \kb.bedpe\))))


overlap.25kb <- findOverlaps(cons.loop, loop.25kb)
overlap.10kb <- findOverlaps(cons.loop, loop.10kb)
overlap.5kb <- findOverlaps(cons.loop, loop.5kb)

index <- sort(unique(c(queryHits(overlap.25kb),
         queryHits(overlap.10kb),
         queryHits(overlap.5kb))))
data$calledByDMSO <- 0
data$calledByDMSO[index] <- 1

# Checking dTAG
loop.25kb <- importBedpe(fread(here(loopDir, paste0(\G1.dTAG.Merged_chromosight_\, 25, \kb.bedpe\))))
loop.10kb <- importBedpe(fread(here(loopDir, paste0(\G1.dTAG.Merged_chromosight_\, 10, \kb.bedpe\))))
loop.5kb <- importBedpe(fread(here(loopDir, paste0(\G1.dTAG.Merged_chromosight_\, 5, \kb.bedpe\))))


overlap.25kb <- findOverlaps(cons.loop, loop.25kb)
overlap.10kb <- findOverlaps(cons.loop, loop.10kb)
overlap.5kb <- findOverlaps(cons.loop, loop.5kb)

index <- sort(unique(c(queryHits(overlap.25kb),
         queryHits(overlap.10kb),
         queryHits(overlap.5kb))))
data$calledBydTAG <- 0
data$calledBydTAG[index] <- 1

# Checking A485
loop.25kb <- importBedpe(fread(here(loopDir, paste0(\G1.A485.Merged_chromosight_\, 25, \kb.bedpe\))))
loop.10kb <- importBedpe(fread(here(loopDir, paste0(\G1.A485.Merged_chromosight_\, 10, \kb.bedpe\))))
loop.5kb <- importBedpe(fread(here(loopDir, paste0(\G1.A485.Merged_chromosight_\, 5, \kb.bedpe\))))


overlap.25kb <- findOverlaps(cons.loop, loop.25kb)
overlap.10kb <- findOverlaps(cons.loop, loop.10kb)
overlap.5kb <- findOverlaps(cons.loop, loop.5kb)

index <- sort(unique(c(queryHits(overlap.25kb),
         queryHits(overlap.10kb),
         queryHits(overlap.5kb))))
data$calledByA485 <- 0
data$calledByA485[index] <- 1


# Heatmap (checking whether certain peak is called by specific sample)
dataToPlot <- data %>% dplyr::select(id, calledByDMSO, calledBydTAG, calledByA485)
dataToPlot <- dataToPlot %>% dplyr::mutate(flag = 4*calledByDMSO + 2*calledBydTAG + calledByA485) %>%
  dplyr::arrange(desc(flag))

row_groups <- dataToPlot$flag
data_matrix <- dataToPlot %>% column_to_rownames(var = \id\) %>% dplyr::select(-flag) %>% as.matrix()
col_fun <- colorRamp2(c(0, 1), 
                      c(\white\, \green\))
h1 <- Heatmap(data_matrix, name = \calledBy\,
        cluster_columns = FALSE,
        cluster_rows = FALSE,
        show_row_dend = FALSE,
        border = TRUE,
        show_row_names = FALSE,
        col = col_fun,
        row_split = row_groups)


# Prepare data for the second heatmap
dataToPlot2 <- data %>% dplyr::select(id, DMSO, dTAG, A485) %>%
  arrange(match(id, dataToPlot$id))

data_matrix2 <- dataToPlot2 %>% column_to_rownames(var = \id\) %>% as.matrix()


col_fun2 <- colorRamp2(c(-0.5, 0, 1), c(\blue\, \white\, \red\))

h2 <- Heatmap(data_matrix2, name = \score\,
              cluster_columns = FALSE,
              cluster_rows = TRUE,
              show_row_dend = FALSE,
              border = TRUE,
              show_row_names = FALSE,
              col = col_fun2,
              row_split = row_groups)


fileName <- here(figDir, paste0(\heatmap_checkingSampleCalledLoops\))
png(paste0(fileName, \.png\), res = 600, units = \in\, width = 3, height = 10)
print(h1 + h2)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubGlicmFyeShjaXJjbGl6ZSlcblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3Qoc2VxKDEsIDYpKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXFYxXFwsIFxcVjJcXCwgXFxWM1xcLCBcXFY0XFwsIFxcVjVcXCwgXFxWNlxcKVxuY29ucy5sb29wIDwtIGltcG9ydEJlZHBlKHRlbXApXG5cbiMgQ2hlY2tpbmcgRE1TT1xubG9vcC4yNWtiIDwtIGltcG9ydEJlZHBlKGZyZWFkKGhlcmUobG9vcERpciwgcGFzdGUwKFxcRzEuRE1TTy5NZXJnZWRfY2hyb21vc2lnaHRfXFwsIDI1LCBcXGtiLmJlZHBlXFwpKSkpXG5sb29wLjEwa2IgPC0gaW1wb3J0QmVkcGUoZnJlYWQoaGVyZShsb29wRGlyLCBwYXN0ZTAoXFxHMS5ETVNPLk1lcmdlZF9jaHJvbW9zaWdodF9cXCwgMTAsIFxca2IuYmVkcGVcXCkpKSlcbmxvb3AuNWtiIDwtIGltcG9ydEJlZHBlKGZyZWFkKGhlcmUobG9vcERpciwgcGFzdGUwKFxcRzEuRE1TTy5NZXJnZWRfY2hyb21vc2lnaHRfXFwsIDUsIFxca2IuYmVkcGVcXCkpKSlcblxuXG5vdmVybGFwLjI1a2IgPC0gZmluZE92ZXJsYXBzKGNvbnMubG9vcCwgbG9vcC4yNWtiKVxub3ZlcmxhcC4xMGtiIDwtIGZpbmRPdmVybGFwcyhjb25zLmxvb3AsIGxvb3AuMTBrYilcbm92ZXJsYXAuNWtiIDwtIGZpbmRPdmVybGFwcyhjb25zLmxvb3AsIGxvb3AuNWtiKVxuXG5pbmRleCA8LSBzb3J0KHVuaXF1ZShjKHF1ZXJ5SGl0cyhvdmVybGFwLjI1a2IpLFxuICAgICAgICAgcXVlcnlIaXRzKG92ZXJsYXAuMTBrYiksXG4gICAgICAgICBxdWVyeUhpdHMob3ZlcmxhcC41a2IpKSkpXG5kYXRhJGNhbGxlZEJ5RE1TTyA8LSAwXG5kYXRhJGNhbGxlZEJ5RE1TT1tpbmRleF0gPC0gMVxuXG4jIENoZWNraW5nIGRUQUdcbmxvb3AuMjVrYiA8LSBpbXBvcnRCZWRwZShmcmVhZChoZXJlKGxvb3BEaXIsIHBhc3RlMChcXEcxLmRUQUcuTWVyZ2VkX2Nocm9tb3NpZ2h0X1xcLCAyNSwgXFxrYi5iZWRwZVxcKSkpKVxubG9vcC4xMGtiIDwtIGltcG9ydEJlZHBlKGZyZWFkKGhlcmUobG9vcERpciwgcGFzdGUwKFxcRzEuZFRBRy5NZXJnZWRfY2hyb21vc2lnaHRfXFwsIDEwLCBcXGtiLmJlZHBlXFwpKSkpXG5sb29wLjVrYiA8LSBpbXBvcnRCZWRwZShmcmVhZChoZXJlKGxvb3BEaXIsIHBhc3RlMChcXEcxLmRUQUcuTWVyZ2VkX2Nocm9tb3NpZ2h0X1xcLCA1LCBcXGtiLmJlZHBlXFwpKSkpXG5cblxub3ZlcmxhcC4yNWtiIDwtIGZpbmRPdmVybGFwcyhjb25zLmxvb3AsIGxvb3AuMjVrYilcbm92ZXJsYXAuMTBrYiA8LSBmaW5kT3ZlcmxhcHMoY29ucy5sb29wLCBsb29wLjEwa2IpXG5vdmVybGFwLjVrYiA8LSBmaW5kT3ZlcmxhcHMoY29ucy5sb29wLCBsb29wLjVrYilcblxuaW5kZXggPC0gc29ydCh1bmlxdWUoYyhxdWVyeUhpdHMob3ZlcmxhcC4yNWtiKSxcbiAgICAgICAgIHF1ZXJ5SGl0cyhvdmVybGFwLjEwa2IpLFxuICAgICAgICAgcXVlcnlIaXRzKG92ZXJsYXAuNWtiKSkpKVxuZGF0YSRjYWxsZWRCeWRUQUcgPC0gMFxuZGF0YSRjYWxsZWRCeWRUQUdbaW5kZXhdIDwtIDFcblxuIyBDaGVja2luZyBBNDg1XG5sb29wLjI1a2IgPC0gaW1wb3J0QmVkcGUoZnJlYWQoaGVyZShsb29wRGlyLCBwYXN0ZTAoXFxHMS5BNDg1Lk1lcmdlZF9jaHJvbW9zaWdodF9cXCwgMjUsIFxca2IuYmVkcGVcXCkpKSlcbmxvb3AuMTBrYiA8LSBpbXBvcnRCZWRwZShmcmVhZChoZXJlKGxvb3BEaXIsIHBhc3RlMChcXEcxLkE0ODUuTWVyZ2VkX2Nocm9tb3NpZ2h0X1xcLCAxMCwgXFxrYi5iZWRwZVxcKSkpKVxubG9vcC41a2IgPC0gaW1wb3J0QmVkcGUoZnJlYWQoaGVyZShsb29wRGlyLCBwYXN0ZTAoXFxHMS5BNDg1Lk1lcmdlZF9jaHJvbW9zaWdodF9cXCwgNSwgXFxrYi5iZWRwZVxcKSkpKVxuXG5cbm92ZXJsYXAuMjVrYiA8LSBmaW5kT3ZlcmxhcHMoY29ucy5sb29wLCBsb29wLjI1a2IpXG5vdmVybGFwLjEwa2IgPC0gZmluZE92ZXJsYXBzKGNvbnMubG9vcCwgbG9vcC4xMGtiKVxub3ZlcmxhcC41a2IgPC0gZmluZE92ZXJsYXBzKGNvbnMubG9vcCwgbG9vcC41a2IpXG5cbmluZGV4IDwtIHNvcnQodW5pcXVlKGMocXVlcnlIaXRzKG92ZXJsYXAuMjVrYiksXG4gICAgICAgICBxdWVyeUhpdHMob3ZlcmxhcC4xMGtiKSxcbiAgICAgICAgIHF1ZXJ5SGl0cyhvdmVybGFwLjVrYikpKSlcbmRhdGEkY2FsbGVkQnlBNDg1IDwtIDBcbmRhdGEkY2FsbGVkQnlBNDg1W2luZGV4XSA8LSAxXG5cblxuIyBIZWF0bWFwIChjaGVja2luZyB3aGV0aGVyIGNlcnRhaW4gcGVhayBpcyBjYWxsZWQgYnkgc3BlY2lmaWMgc2FtcGxlKVxuZGF0YVRvUGxvdCA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KGlkLCBjYWxsZWRCeURNU08sIGNhbGxlZEJ5ZFRBRywgY2FsbGVkQnlBNDg1KVxuZGF0YVRvUGxvdCA8LSBkYXRhVG9QbG90ICU+JSBkcGx5cjo6bXV0YXRlKGZsYWcgPSA0KmNhbGxlZEJ5RE1TTyArIDIqY2FsbGVkQnlkVEFHICsgY2FsbGVkQnlBNDg1KSAlPiVcbiAgZHBseXI6OmFycmFuZ2UoZGVzYyhmbGFnKSlcblxucm93X2dyb3VwcyA8LSBkYXRhVG9QbG90JGZsYWdcbmRhdGFfbWF0cml4IDwtIGRhdGFUb1Bsb3QgJT4lIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXGlkXFwpICU+JSBkcGx5cjo6c2VsZWN0KC1mbGFnKSAlPiUgYXMubWF0cml4KClcbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEpLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFxcd2hpdGVcXCwgXFxncmVlblxcKSlcbmgxIDwtIEhlYXRtYXAoZGF0YV9tYXRyaXgsIG5hbWUgPSBcXGNhbGxlZEJ5XFwsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBGQUxTRSxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBib3JkZXIgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19uYW1lcyA9IEZBTFNFLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICByb3dfc3BsaXQgPSByb3dfZ3JvdXBzKVxuXG5cbiMgUHJlcGFyZSBkYXRhIGZvciB0aGUgc2Vjb25kIGhlYXRtYXBcbmRhdGFUb1Bsb3QyIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QoaWQsIERNU08sIGRUQUcsIEE0ODUpICU+JVxuICBhcnJhbmdlKG1hdGNoKGlkLCBkYXRhVG9QbG90JGlkKSlcblxuZGF0YV9tYXRyaXgyIDwtIGRhdGFUb1Bsb3QyICU+JSBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFxpZFxcKSAlPiUgYXMubWF0cml4KClcblxuXG5jb2xfZnVuMiA8LSBjb2xvclJhbXAyKGMoLTAuNSwgMCwgMSksIGMoXFxibHVlXFwsIFxcd2hpdGVcXCwgXFxyZWRcXCkpXG5cbmgyIDwtIEhlYXRtYXAoZGF0YV9tYXRyaXgyLCBuYW1lID0gXFxzY29yZVxcLFxuICAgICAgICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgICAgICAgY2x1c3Rlcl9yb3dzID0gVFJVRSxcbiAgICAgICAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICAgICAgICBib3JkZXIgPSBUUlVFLFxuICAgICAgICAgICAgICBzaG93X3Jvd19uYW1lcyA9IEZBTFNFLFxuICAgICAgICAgICAgICBjb2wgPSBjb2xfZnVuMixcbiAgICAgICAgICAgICAgcm93X3NwbGl0ID0gcm93X2dyb3VwcylcblxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgcGFzdGUwKFxcaGVhdG1hcF9jaGVja2luZ1NhbXBsZUNhbGxlZExvb3BzXFwpKVxucG5nKHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpLCByZXMgPSA2MDAsIHVuaXRzID0gXFxpblxcLCB3aWR0aCA9IDMsIGhlaWdodCA9IDEwKVxucHJpbnQoaDEgKyBoMilcbmRldi5vZmYoKVxuXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\nlibrary(circlize)\n\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\ntemp <- data %>% dplyr::select(seq(1, 6))\ncolnames(temp) <- c(\\V1\\, \\V2\\, \\V3\\, \\V4\\, \\V5\\, \\V6\\)\ncons.loop <- importBedpe(temp)\n\n# Checking DMSO\nloop.25kb <- importBedpe(fread(here(loopDir, paste0(\\G1.DMSO.Merged_chromosight_\\, 25, \\kb.bedpe\\))))\nloop.10kb <- importBedpe(fread(here(loopDir, paste0(\\G1.DMSO.Merged_chromosight_\\, 10, \\kb.bedpe\\))))\nloop.5kb <- importBedpe(fread(here(loopDir, paste0(\\G1.DMSO.Merged_chromosight_\\, 5, \\kb.bedpe\\))))\n\n\noverlap.25kb <- findOverlaps(cons.loop, loop.25kb)\noverlap.10kb <- findOverlaps(cons.loop, loop.10kb)\noverlap.5kb <- findOverlaps(cons.loop, loop.5kb)\n\nindex <- sort(unique(c(queryHits(overlap.25kb),\n         queryHits(overlap.10kb),\n         queryHits(overlap.5kb))))\ndata$calledByDMSO <- 0\ndata$calledByDMSO[index] <- 1\n\n# Checking dTAG\nloop.25kb <- importBedpe(fread(here(loopDir, paste0(\\G1.dTAG.Merged_chromosight_\\, 25, \\kb.bedpe\\))))\nloop.10kb <- importBedpe(fread(here(loopDir, paste0(\\G1.dTAG.Merged_chromosight_\\, 10, \\kb.bedpe\\))))\nloop.5kb <- importBedpe(fread(here(loopDir, paste0(\\G1.dTAG.Merged_chromosight_\\, 5, \\kb.bedpe\\))))\n\n\noverlap.25kb <- findOverlaps(cons.loop, loop.25kb)\noverlap.10kb <- findOverlaps(cons.loop, loop.10kb)\noverlap.5kb <- findOverlaps(cons.loop, loop.5kb)\n\nindex <- sort(unique(c(queryHits(overlap.25kb),\n         queryHits(overlap.10kb),\n         queryHits(overlap.5kb))))\ndata$calledBydTAG <- 0\ndata$calledBydTAG[index] <- 1\n\n# Checking A485\nloop.25kb <- importBedpe(fread(here(loopDir, paste0(\\G1.A485.Merged_chromosight_\\, 25, \\kb.bedpe\\))))\nloop.10kb <- importBedpe(fread(here(loopDir, paste0(\\G1.A485.Merged_chromosight_\\, 10, \\kb.bedpe\\))))\nloop.5kb <- importBedpe(fread(here(loopDir, paste0(\\G1.A485.Merged_chromosight_\\, 5, \\kb.bedpe\\))))\n\n\noverlap.25kb <- findOverlaps(cons.loop, loop.25kb)\noverlap.10kb <- findOverlaps(cons.loop, loop.10kb)\noverlap.5kb <- findOverlaps(cons.loop, loop.5kb)\n\nindex <- sort(unique(c(queryHits(overlap.25kb),\n         queryHits(overlap.10kb),\n         queryHits(overlap.5kb))))\ndata$calledByA485 <- 0\ndata$calledByA485[index] <- 1\n\n\n# Heatmap (checking whether certain peak is called by specific sample)\ndataToPlot <- data %>% dplyr::select(id, calledByDMSO, calledBydTAG, calledByA485)\ndataToPlot <- dataToPlot %>% dplyr::mutate(flag = 4*calledByDMSO + 2*calledBydTAG + calledByA485) %>%\n  dplyr::arrange(desc(flag))\n\nrow_groups <- dataToPlot$flag\ndata_matrix <- dataToPlot %>% column_to_rownames(var = \\id\\) %>% dplyr::select(-flag) %>% as.matrix()\ncol_fun <- colorRamp2(c(0, 1), \n                      c(\\white\\, \\green\\))\nh1 <- Heatmap(data_matrix, name = \\calledBy\\,\n        cluster_columns = FALSE,\n        cluster_rows = FALSE,\n        show_row_dend = FALSE,\n        border = TRUE,\n        show_row_names = FALSE,\n        col = col_fun,\n        row_split = row_groups)\n\n\n# Prepare data for the second heatmap\ndataToPlot2 <- data %>% dplyr::select(id, DMSO, dTAG, A485) %>%\n  arrange(match(id, dataToPlot$id))\n\ndata_matrix2 <- dataToPlot2 %>% column_to_rownames(var = \\id\\) %>% as.matrix()\n\n\ncol_fun2 <- colorRamp2(c(-0.5, 0, 1), c(\\blue\\, \\white\\, \\red\\))\n\nh2 <- Heatmap(data_matrix2, name = \\score\\,\n              cluster_columns = FALSE,\n              cluster_rows = TRUE,\n              show_row_dend = FALSE,\n              border = TRUE,\n              show_row_names = FALSE,\n              col = col_fun2,\n              row_split = row_groups)\n\n\nfileName <- here(figDir, paste0(\\heatmap_checkingSampleCalledLoops\\))\npng(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 3, height = 10)\nprint(h1 + h2)\ndev.off()\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubGlicmFyeShjaXJjbGl6ZSlcblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3Qoc2VxKDEsIDYpKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXFYxXFwsIFxcVjJcXCwgXFxWM1xcLCBcXFY0XFwsIFxcVjVcXCwgXFxWNlxcKVxuY29ucy5sb29wIDwtIGltcG9ydEJlZHBlKHRlbXApXG5cbiMgQ2hlY2tpbmcgRE1TT1xubG9vcC4yNWtiIDwtIGltcG9ydEJlZHBlKGZyZWFkKGhlcmUobG9vcERpciwgcGFzdGUwKFxcRzEuRE1TTy5NZXJnZWRfY2hyb21vc2lnaHRfXFwsIDI1LCBcXGtiLmJlZHBlXFwpKSkpXG5sb29wLjEwa2IgPC0gaW1wb3J0QmVkcGUoZnJlYWQoaGVyZShsb29wRGlyLCBwYXN0ZTAoXFxHMS5ETVNPLk1lcmdlZF9jaHJvbW9zaWdodF9cXCwgMTAsIFxca2IuYmVkcGVcXCkpKSlcbmxvb3AuNWtiIDwtIGltcG9ydEJlZHBlKGZyZWFkKGhlcmUobG9vcERpciwgcGFzdGUwKFxcRzEuRE1TTy5NZXJnZWRfY2hyb21vc2lnaHRfXFwsIDUsIFxca2IuYmVkcGVcXCkpKSlcblxuXG5vdmVybGFwLjI1a2IgPC0gZmluZE92ZXJsYXBzKGNvbnMubG9vcCwgbG9vcC4yNWtiKVxub3ZlcmxhcC4xMGtiIDwtIGZpbmRPdmVybGFwcyhjb25zLmxvb3AsIGxvb3AuMTBrYilcbm92ZXJsYXAuNWtiIDwtIGZpbmRPdmVybGFwcyhjb25zLmxvb3AsIGxvb3AuNWtiKVxuXG5pbmRleCA8LSBzb3J0KHVuaXF1ZShjKHF1ZXJ5SGl0cyhvdmVybGFwLjI1a2IpLFxuICAgICAgICAgcXVlcnlIaXRzKG92ZXJsYXAuMTBrYiksXG4gICAgICAgICBxdWVyeUhpdHMob3ZlcmxhcC41a2IpKSkpXG5kYXRhJGNhbGxlZEJ5RE1TTyA8LSAwXG5kYXRhJGNhbGxlZEJ5RE1TT1tpbmRleF0gPC0gMVxuXG4jIENoZWNraW5nIGRUQUdcbmxvb3AuMjVrYiA8LSBpbXBvcnRCZWRwZShmcmVhZChoZXJlKGxvb3BEaXIsIHBhc3RlMChcXEcxLmRUQUcuTWVyZ2VkX2Nocm9tb3NpZ2h0X1xcLCAyNSwgXFxrYi5iZWRwZVxcKSkpKVxubG9vcC4xMGtiIDwtIGltcG9ydEJlZHBlKGZyZWFkKGhlcmUobG9vcERpciwgcGFzdGUwKFxcRzEuZFRBRy5NZXJnZWRfY2hyb21vc2lnaHRfXFwsIDEwLCBcXGtiLmJlZHBlXFwpKSkpXG5sb29wLjVrYiA8LSBpbXBvcnRCZWRwZShmcmVhZChoZXJlKGxvb3BEaXIsIHBhc3RlMChcXEcxLmRUQUcuTWVyZ2VkX2Nocm9tb3NpZ2h0X1xcLCA1LCBcXGtiLmJlZHBlXFwpKSkpXG5cblxub3ZlcmxhcC4yNWtiIDwtIGZpbmRPdmVybGFwcyhjb25zLmxvb3AsIGxvb3AuMjVrYilcbm92ZXJsYXAuMTBrYiA8LSBmaW5kT3ZlcmxhcHMoY29ucy5sb29wLCBsb29wLjEwa2IpXG5vdmVybGFwLjVrYiA8LSBmaW5kT3ZlcmxhcHMoY29ucy5sb29wLCBsb29wLjVrYilcblxuaW5kZXggPC0gc29ydCh1bmlxdWUoYyhxdWVyeUhpdHMob3ZlcmxhcC4yNWtiKSxcbiAgICAgICAgIHF1ZXJ5SGl0cyhvdmVybGFwLjEwa2IpLFxuICAgICAgICAgcXVlcnlIaXRzKG92ZXJsYXAuNWtiKSkpKVxuZGF0YSRjYWxsZWRCeWRUQUcgPC0gMFxuZGF0YSRjYWxsZWRCeWRUQUdbaW5kZXhdIDwtIDFcblxuIyBDaGVja2luZyBBNDg1XG5sb29wLjI1a2IgPC0gaW1wb3J0QmVkcGUoZnJlYWQoaGVyZShsb29wRGlyLCBwYXN0ZTAoXFxHMS5BNDg1Lk1lcmdlZF9jaHJvbW9zaWdodF9cXCwgMjUsIFxca2IuYmVkcGVcXCkpKSlcbmxvb3AuMTBrYiA8LSBpbXBvcnRCZWRwZShmcmVhZChoZXJlKGxvb3BEaXIsIHBhc3RlMChcXEcxLkE0ODUuTWVyZ2VkX2Nocm9tb3NpZ2h0X1xcLCAxMCwgXFxrYi5iZWRwZVxcKSkpKVxubG9vcC41a2IgPC0gaW1wb3J0QmVkcGUoZnJlYWQoaGVyZShsb29wRGlyLCBwYXN0ZTAoXFxHMS5BNDg1Lk1lcmdlZF9jaHJvbW9zaWdodF9cXCwgNSwgXFxrYi5iZWRwZVxcKSkpKVxuXG5cbm92ZXJsYXAuMjVrYiA8LSBmaW5kT3ZlcmxhcHMoY29ucy5sb29wLCBsb29wLjI1a2IpXG5vdmVybGFwLjEwa2IgPC0gZmluZE92ZXJsYXBzKGNvbnMubG9vcCwgbG9vcC4xMGtiKVxub3ZlcmxhcC41a2IgPC0gZmluZE92ZXJsYXBzKGNvbnMubG9vcCwgbG9vcC41a2IpXG5cbmluZGV4IDwtIHNvcnQodW5pcXVlKGMocXVlcnlIaXRzKG92ZXJsYXAuMjVrYiksXG4gICAgICAgICBxdWVyeUhpdHMob3ZlcmxhcC4xMGtiKSxcbiAgICAgICAgIHF1ZXJ5SGl0cyhvdmVybGFwLjVrYikpKSlcbmRhdGEkY2FsbGVkQnlBNDg1IDwtIDBcbmRhdGEkY2FsbGVkQnlBNDg1W2luZGV4XSA8LSAxXG5cblxuIyBIZWF0bWFwIChjaGVja2luZyB3aGV0aGVyIGNlcnRhaW4gcGVhayBpcyBjYWxsZWQgYnkgc3BlY2lmaWMgc2FtcGxlKVxuZGF0YVRvUGxvdCA8LSBkYXRhICU+JSBkcGx5cjo6c2VsZWN0KGlkLCBjYWxsZWRCeURNU08sIGNhbGxlZEJ5ZFRBRywgY2FsbGVkQnlBNDg1KVxuZGF0YVRvUGxvdCA8LSBkYXRhVG9QbG90ICU+JSBkcGx5cjo6bXV0YXRlKGZsYWcgPSA0KmNhbGxlZEJ5RE1TTyArIDIqY2FsbGVkQnlkVEFHICsgY2FsbGVkQnlBNDg1KSAlPiVcbiAgZHBseXI6OmFycmFuZ2UoZGVzYyhmbGFnKSlcblxucm93X2dyb3VwcyA8LSBkYXRhVG9QbG90JGZsYWdcbmRhdGFfbWF0cml4IDwtIGRhdGFUb1Bsb3QgJT4lIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXGlkXFwpICU+JSBkcGx5cjo6c2VsZWN0KC1mbGFnKSAlPiUgYXMubWF0cml4KClcbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKDAsIDEpLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFxcd2hpdGVcXCwgXFxncmVlblxcKSlcbmgxIDwtIEhlYXRtYXAoZGF0YV9tYXRyaXgsIG5hbWUgPSBcXGNhbGxlZEJ5XFwsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBGQUxTRSxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBib3JkZXIgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19uYW1lcyA9IEZBTFNFLFxuICAgICAgICBjb2wgPSBjb2xfZnVuLFxuICAgICAgICByb3dfc3BsaXQgPSByb3dfZ3JvdXBzKVxuXG5cbiMgUHJlcGFyZSBkYXRhIGZvciB0aGUgc2Vjb25kIGhlYXRtYXBcbmRhdGFUb1Bsb3QyIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QoaWQsIERNU08sIGRUQUcsIEE0ODUpICU+JVxuICBhcnJhbmdlKG1hdGNoKGlkLCBkYXRhVG9QbG90JGlkKSlcblxuZGF0YV9tYXRyaXgyIDwtIGRhdGFUb1Bsb3QyICU+JSBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFxpZFxcKSAlPiUgYXMubWF0cml4KClcblxuXG5jb2xfZnVuMiA8LSBjb2xvclJhbXAyKGMoLTAuNSwgMCwgMSksIGMoXFxibHVlXFwsIFxcd2hpdGVcXCwgXFxyZWRcXCkpXG5cbmgyIDwtIEhlYXRtYXAoZGF0YV9tYXRyaXgyLCBuYW1lID0gXFxzY29yZVxcLFxuICAgICAgICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgICAgICAgY2x1c3Rlcl9yb3dzID0gVFJVRSxcbiAgICAgICAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICAgICAgICBib3JkZXIgPSBUUlVFLFxuICAgICAgICAgICAgICBzaG93X3Jvd19uYW1lcyA9IEZBTFNFLFxuICAgICAgICAgICAgICBjb2wgPSBjb2xfZnVuMixcbiAgICAgICAgICAgICAgcm93X3NwbGl0ID0gcm93X2dyb3VwcylcblxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgcGFzdGUwKFxcaGVhdG1hcF9jaGVja2luZ1NhbXBsZUNhbGxlZExvb3BzXFwpKVxucG5nKHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpLCByZXMgPSA2MDAsIHVuaXRzID0gXFxpblxcLCB3aWR0aCA9IDMsIGhlaWdodCA9IDEwKVxucHJpbnQoaDEgKyBoMilcbmRldi5vZmYoKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
library(circlize)

name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
temp <- data %>% dplyr::select(seq(1, 6))
colnames(temp) <- c(\V1\, \V2\, \V3\, \V4\, \V5\, \V6\)
cons.loop <- importBedpe(temp)

# Checking DMSO
loop.25kb <- importBedpe(fread(here(loopDir, paste0(\G1.DMSO.Merged_chromosight_\, 25, \kb.bedpe\))))
loop.10kb <- importBedpe(fread(here(loopDir, paste0(\G1.DMSO.Merged_chromosight_\, 10, \kb.bedpe\))))
loop.5kb <- importBedpe(fread(here(loopDir, paste0(\G1.DMSO.Merged_chromosight_\, 5, \kb.bedpe\))))


overlap.25kb <- findOverlaps(cons.loop, loop.25kb)
overlap.10kb <- findOverlaps(cons.loop, loop.10kb)
overlap.5kb <- findOverlaps(cons.loop, loop.5kb)

index <- sort(unique(c(queryHits(overlap.25kb),
         queryHits(overlap.10kb),
         queryHits(overlap.5kb))))
data$calledByDMSO <- 0
data$calledByDMSO[index] <- 1

# Checking dTAG
loop.25kb <- importBedpe(fread(here(loopDir, paste0(\G1.dTAG.Merged_chromosight_\, 25, \kb.bedpe\))))
loop.10kb <- importBedpe(fread(here(loopDir, paste0(\G1.dTAG.Merged_chromosight_\, 10, \kb.bedpe\))))
loop.5kb <- importBedpe(fread(here(loopDir, paste0(\G1.dTAG.Merged_chromosight_\, 5, \kb.bedpe\))))


overlap.25kb <- findOverlaps(cons.loop, loop.25kb)
overlap.10kb <- findOverlaps(cons.loop, loop.10kb)
overlap.5kb <- findOverlaps(cons.loop, loop.5kb)

index <- sort(unique(c(queryHits(overlap.25kb),
         queryHits(overlap.10kb),
         queryHits(overlap.5kb))))
data$calledBydTAG <- 0
data$calledBydTAG[index] <- 1

# Checking A485
loop.25kb <- importBedpe(fread(here(loopDir, paste0(\G1.A485.Merged_chromosight_\, 25, \kb.bedpe\))))
loop.10kb <- importBedpe(fread(here(loopDir, paste0(\G1.A485.Merged_chromosight_\, 10, \kb.bedpe\))))
loop.5kb <- importBedpe(fread(here(loopDir, paste0(\G1.A485.Merged_chromosight_\, 5, \kb.bedpe\))))


overlap.25kb <- findOverlaps(cons.loop, loop.25kb)
overlap.10kb <- findOverlaps(cons.loop, loop.10kb)
overlap.5kb <- findOverlaps(cons.loop, loop.5kb)

index <- sort(unique(c(queryHits(overlap.25kb),
         queryHits(overlap.10kb),
         queryHits(overlap.5kb))))
data$calledByA485 <- 0
data$calledByA485[index] <- 1


# Heatmap (checking whether certain peak is called by specific sample)
dataToPlot <- data %>% dplyr::select(id, calledByDMSO, calledBydTAG, calledByA485)
dataToPlot <- dataToPlot %>% dplyr::mutate(flag = 4*calledByDMSO + 2*calledBydTAG + calledByA485) %>%
  dplyr::arrange(desc(flag))

row_groups <- dataToPlot$flag
data_matrix <- dataToPlot %>% column_to_rownames(var = \id\) %>% dplyr::select(-flag) %>% as.matrix()
col_fun <- colorRamp2(c(0, 1), 
                      c(\white\, \green\))
h1 <- Heatmap(data_matrix, name = \calledBy\,
        cluster_columns = FALSE,
        cluster_rows = FALSE,
        show_row_dend = FALSE,
        border = TRUE,
        show_row_names = FALSE,
        col = col_fun,
        row_split = row_groups)


# Prepare data for the second heatmap
dataToPlot2 <- data %>% dplyr::select(id, DMSO, dTAG, A485) %>%
  arrange(match(id, dataToPlot$id))

data_matrix2 <- dataToPlot2 %>% column_to_rownames(var = \id\) %>% as.matrix()


col_fun2 <- colorRamp2(c(-0.5, 0, 1), c(\blue\, \white\, \red\))

h2 <- Heatmap(data_matrix2, name = \score\,
              cluster_columns = FALSE,
              cluster_rows = TRUE,
              show_row_dend = FALSE,
              border = TRUE,
              show_row_names = FALSE,
              col = col_fun2,
              row_split = row_groups)


fileName <- here(figDir, paste0(\heatmap_checkingSampleCalledLoops\))
png(paste0(fileName, \.png\), res = 600, units = \in\, width = 3, height = 10)
print(h1 + h2)
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


## [2.31] Making Visualization Easy
https://bioconductor.org/books/devel/OHCA/pages/visualization.html

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJJWldGMGJXRndYRzVzYVdKeVlYSjVLR05wY21Oc2FYcGxLVnh1WEc0aklFaGxZWFJ0WVhBZ01seHVjMlYwTG5ObFpXUW9NVEl6S1Z4dVhHNWthV1ptUTNWMGIyWm1JRHd0SURBdU1seHVaR0YwWVZSdlVHeHZkQ0E4TFNCa1lYUmhJQ1UrSlNCa2NHeDVjam82YlhWMFlYUmxLR2x6WkdsbVpsOWtWRUZIWDBSTlUwOGdQU0JjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHTmhjMlZmZDJobGJpaGthV1ptWDJSVVFVZGZSRTFUVHlBK1BTQmthV1ptUTNWMGIyWm1JSDRnTVN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JoWW5Nb1pHbG1abDlrVkVGSFgwUk5VMDhwSUR3Z1pHbG1aa04xZEc5bVppQitJREFzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdaR2xtWmw5a1ZFRkhYMFJOVTA4Z1BEMGdMV1JwWm1aRGRYUnZabVlnZmlBdE1TeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCVVVsVkZJSDRnVGtFcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2x6WkdsbVpsOUJORGcxWDBSTlUwOGdQU0JjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHTmhjMlZmZDJobGJpaGthV1ptWDBFME9EVmZSRTFUVHlBK1BTQmthV1ptUTNWMGIyWm1JSDRnTVN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JoWW5Nb1pHbG1abDlCTkRnMVgwUk5VMDhwSUR3Z1pHbG1aa04xZEc5bVppQitJREFzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdaR2xtWmw5Qk5EZzFYMFJOVTA4Z1BEMGdMV1JwWm1aRGRYUnZabVlnZmlBdE1TeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCVVVsVkZJSDRnVGtFcEtTQWxQaVZjYmlBZ1pIQnNlWEk2T25ObGJHVmpkQ2hwWkN3Z2FYTmthV1ptWDJSVVFVZGZSRTFUVHl3Z2FYTmthV1ptWDBFME9EVmZSRTFUVHlsY2JtUmhkR0ZmYldGMGNtbDRJRHd0SUdSaGRHRlViMUJzYjNRZ0pUNGxJR052YkhWdGJsOTBiMTl5YjNkdVlXMWxjeWgyWVhJZ1BTQmNJbWxrWENJcEpUNGxJR0Z6TG0xaGRISnBlQ2dwWEc1amIyeGZablZ1SUR3dElHTnZiRzl5VW1GdGNESW9ZeWd0TVN3Z01Dd2dNU2tzSUdNb1hDSmliSFZsWENJc0lGd2laM0psZVZ3aUxDQmNJbkpsWkZ3aUtTbGNibWd4SUR3dElFaGxZWFJ0WVhBb1pHRjBZVjl0WVhSeWFYZ3NJRzVoYldVZ1BTQmNJbXh2YjNBZ2MyTnZjbVZjSWl4Y2JpQWdJQ0FnSUNBZ1kyeDFjM1JsY2w5amIyeDFiVzV6SUQwZ1JrRk1VMFVzWEc0Z0lDQWdJQ0FnSUdOc2RYTjBaWEpmY205M2N5QTlJRVpCVEZORkxGeHVJQ0FnSUNBZ0lDQnliM2RmYTIwZ1BTQTVMRnh1SUNBZ0lDQWdJQ0J6YUc5M1gzSnZkMTlrWlc1a0lEMGdSa0ZNVTBVc1hHNGdJQ0FnSUNBZ0lHSnZjbVJsY2lBOUlFWkJURk5GTEZ4dUlDQWdJQ0FnSUNCemFHOTNYM0p2ZDE5dVlXMWxjeUE5SUVaQlRGTkZMRnh1SUNBZ0lDQWdJQ0JqYjJ3Z1BTQmpiMnhmWm5WdUtWeHVYRzVtYVd4bFRtRnRaU0E4TFNCb1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tGd2lhR1ZoZEcxaGNGOWphR1ZqYTJsdVowUmxiSFJoUVdOeWIzTnpRMjl1WkdsMGFXOXVYQ0lwS1Z4dWNHNW5LSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYQ0l1Y0c1blhDSXBMQ0J5WlhNZ1BTQTJNREFzSUhWdWFYUnpJRDBnWENKcGJsd2lMQ0IzYVdSMGFDQTlJRElzSUdobGFXZG9kQ0E5SURFd0tWeHVjSEpwYm5Rb2FERXBYRzVrWlhZdWIyWm1LQ2xjYmx4dWMyVjBMbk5sWldRb01USXpLVnh1WEc1b2JWOWtjbUYzYmlBOExTQmtjbUYzS0dneEtWeHVjbTkzWDJOc2RYTjBaWEp6SUR3dElISnZkMTl2Y21SbGNpaG9iVjlrY21GM2JpbGNibHh1Ykc5dmNDNWpiSFZ6ZEdWeU1TQThMU0IwWlcxd1czSnZkMTlqYkhWemRHVnljMXRiTVYxZFhWeHViRzl2Y0M1amJIVnpkR1Z5TWlBOExTQjBaVzF3VzNKdmQxOWpiSFZ6ZEdWeWMxdGJNbDFkWFZ4dWJHOXZjQzVqYkhWemRHVnlNeUE4TFNCMFpXMXdXM0p2ZDE5amJIVnpkR1Z5YzF0Yk0xMWRYVnh1Ykc5dmNDNWpiSFZ6ZEdWeU5DQThMU0IwWlcxd1czSnZkMTlqYkhWemRHVnljMXRiTkYxZFhWeHViRzl2Y0M1amJIVnpkR1Z5TlNBOExTQjBaVzF3VzNKdmQxOWpiSFZ6ZEdWeWMxdGJOVjFkWFZ4dWJHOXZjQzVqYkhWemRHVnlOaUE4TFNCMFpXMXdXM0p2ZDE5amJIVnpkR1Z5YzF0Yk5sMWRYVnh1Ykc5dmNDNWpiSFZ6ZEdWeU55QThMU0IwWlcxd1czSnZkMTlqYkhWemRHVnljMXRiTjExZFhWeHViRzl2Y0M1amJIVnpkR1Z5T0NBOExTQjBaVzF3VzNKdmQxOWpiSFZ6ZEdWeWMxdGJPRjFkWFZ4dWJHOXZjQzVqYkhWemRHVnlPU0E4TFNCMFpXMXdXM0p2ZDE5amJIVnpkR1Z5YzF0Yk9WMWRYVnh1WEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG4jIEhlYXRtYXBcbmxpYnJhcnkoY2lyY2xpemUpXG5cbiMgSGVhdG1hcCAyXG5zZXQuc2VlZCgxMjMpXG5cbmRpZmZDdXRvZmYgPC0gMC4yXG5kYXRhVG9QbG90IDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoaXNkaWZmX2RUQUdfRE1TTyA9IFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2FzZV93aGVuKGRpZmZfZFRBR19ETVNPID49IGRpZmZDdXRvZmYgfiAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFicyhkaWZmX2RUQUdfRE1TTykgPCBkaWZmQ3V0b2ZmIH4gMCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmX2RUQUdfRE1TTyA8PSAtZGlmZkN1dG9mZiB+IC0xLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaXNkaWZmX0E0ODVfRE1TTyA9IFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2FzZV93aGVuKGRpZmZfQTQ4NV9ETVNPID49IGRpZmZDdXRvZmYgfiAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFicyhkaWZmX0E0ODVfRE1TTykgPCBkaWZmQ3V0b2ZmIH4gMCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmX0E0ODVfRE1TTyA8PSAtZGlmZkN1dG9mZiB+IC0xLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBpc2RpZmZfZFRBR19ETVNPLCBpc2RpZmZfQTQ4NV9ETVNPKVxuZGF0YV9tYXRyaXggPC0gZGF0YVRvUGxvdCAlPiUgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcaWRcXCklPiUgYXMubWF0cml4KClcbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKC0xLCAwLCAxKSwgYyhcXGJsdWVcXCwgXFxncmV5XFwsIFxccmVkXFwpKVxuaDEgPC0gSGVhdG1hcChkYXRhX21hdHJpeCwgbmFtZSA9IFxcbG9vcCBzY29yZVxcLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY2x1c3Rlcl9yb3dzID0gRkFMU0UsXG4gICAgICAgIHJvd19rbSA9IDksXG4gICAgICAgIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgICAgICAgYm9yZGVyID0gRkFMU0UsXG4gICAgICAgIHNob3dfcm93X25hbWVzID0gRkFMU0UsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4pXG5cbmZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBwYXN0ZTAoXFxoZWF0bWFwX2NoZWNraW5nRGVsdGFBY3Jvc3NDb25kaXRpb25cXCkpXG5wbmcocGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCksIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gMiwgaGVpZ2h0ID0gMTApXG5wcmludChoMSlcbmRldi5vZmYoKVxuXG5zZXQuc2VlZCgxMjMpXG5cbmhtX2RyYXduIDwtIGRyYXcoaDEpXG5yb3dfY2x1c3RlcnMgPC0gcm93X29yZGVyKGhtX2RyYXduKVxuXG5sb29wLmNsdXN0ZXIxIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1sxXV1dXG5sb29wLmNsdXN0ZXIyIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1syXV1dXG5sb29wLmNsdXN0ZXIzIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1szXV1dXG5sb29wLmNsdXN0ZXI0IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s0XV1dXG5sb29wLmNsdXN0ZXI1IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s1XV1dXG5sb29wLmNsdXN0ZXI2IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s2XV1dXG5sb29wLmNsdXN0ZXI3IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s3XV1dXG5sb29wLmNsdXN0ZXI4IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s4XV1dXG5sb29wLmNsdXN0ZXI5IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s5XV1dXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
# Heatmap
library(circlize)

# Heatmap 2
set.seed(123)

diffCutoff <- 0.2
dataToPlot <- data %>% dplyr::mutate(isdiff_dTAG_DMSO = 
                                       case_when(diff_dTAG_DMSO >= diffCutoff ~ 1,
                                                 abs(diff_dTAG_DMSO) < diffCutoff ~ 0,
                                                 diff_dTAG_DMSO <= -diffCutoff ~ -1,
                                                 TRUE ~ NA),
                                     isdiff_A485_DMSO = 
                                       case_when(diff_A485_DMSO >= diffCutoff ~ 1,
                                                 abs(diff_A485_DMSO) < diffCutoff ~ 0,
                                                 diff_A485_DMSO <= -diffCutoff ~ -1,
                                                 TRUE ~ NA)) %>%
  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)
data_matrix <- dataToPlot %>% column_to_rownames(var = \id\)%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c(\blue\, \grey\, \red\))
h1 <- Heatmap(data_matrix, name = \loop score\,
        cluster_columns = FALSE,
        cluster_rows = FALSE,
        row_km = 9,
        show_row_dend = FALSE,
        border = FALSE,
        show_row_names = FALSE,
        col = col_fun)

fileName <- here(figDir, paste0(\heatmap_checkingDeltaAcrossCondition\))
png(paste0(fileName, \.png\), res = 600, units = \in\, width = 2, height = 10)
print(h1)
dev.off()

set.seed(123)

hm_drawn <- draw(h1)
row_clusters <- row_order(hm_drawn)

loop.cluster1 <- temp[row_clusters[[1]]]
loop.cluster2 <- temp[row_clusters[[2]]]
loop.cluster3 <- temp[row_clusters[[3]]]
loop.cluster4 <- temp[row_clusters[[4]]]
loop.cluster5 <- temp[row_clusters[[5]]]
loop.cluster6 <- temp[row_clusters[[6]]]
loop.cluster7 <- temp[row_clusters[[7]]]
loop.cluster8 <- temp[row_clusters[[8]]]
loop.cluster9 <- temp[row_clusters[[9]]]



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QklaV0YwYldGd1hHNXNhV0p5WVhKNUtHTnBjbU5zYVhwbEtWeHVYRzRqSUVobFlYUnRZWEFnTWx4dWMyVjBMbk5sWldRb01USXpLVnh1WEc1a2FXWm1RM1YwYjJabUlEd3RJREF1TWx4dVpHRjBZVlJ2VUd4dmRDQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZiWFYwWVhSbEtHbHpaR2xtWmw5a1ZFRkhYMFJOVTA4Z1BTQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdOaGMyVmZkMmhsYmloa2FXWm1YMlJVUVVkZlJFMVRUeUErUFNCa2FXWm1RM1YwYjJabUlINGdNU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmhZbk1vWkdsbVpsOWtWRUZIWDBSTlUwOHBJRHdnWkdsbVprTjFkRzltWmlCK0lEQXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1pHbG1abDlrVkVGSFgwUk5VMDhnUEQwZ0xXUnBabVpEZFhSdlptWWdmaUF0TVN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JVVWxWRklINGdUa0VwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbHpaR2xtWmw5Qk5EZzFYMFJOVTA4Z1BTQmNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdOaGMyVmZkMmhsYmloa2FXWm1YMEUwT0RWZlJFMVRUeUErUFNCa2FXWm1RM1YwYjJabUlINGdNU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmhZbk1vWkdsbVpsOUJORGcxWDBSTlUwOHBJRHdnWkdsbVprTjFkRzltWmlCK0lEQXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1pHbG1abDlCTkRnMVgwUk5VMDhnUEQwZ0xXUnBabVpEZFhSdlptWWdmaUF0TVN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JVVWxWRklINGdUa0VwS1NBbFBpVmNiaUFnWkhCc2VYSTZPbk5sYkdWamRDaHBaQ3dnYVhOa2FXWm1YMlJVUVVkZlJFMVRUeXdnYVhOa2FXWm1YMEUwT0RWZlJFMVRUeWxjYm1SaGRHRmZiV0YwY21sNElEd3RJR1JoZEdGVWIxQnNiM1FnSlQ0bElHTnZiSFZ0Ymw5MGIxOXliM2R1WVcxbGN5aDJZWElnUFNCY1hHbGtYRndwSlQ0bElHRnpMbTFoZEhKcGVDZ3BYRzVqYjJ4ZlpuVnVJRHd0SUdOdmJHOXlVbUZ0Y0RJb1l5Z3RNU3dnTUN3Z01Ta3NJR01vWEZ4aWJIVmxYRndzSUZ4Y1ozSmxlVnhjTENCY1hISmxaRnhjS1NsY2JtZ3hJRHd0SUVobFlYUnRZWEFvWkdGMFlWOXRZWFJ5YVhnc0lHNWhiV1VnUFNCY1hHeHZiM0FnYzJOdmNtVmNYQ3hjYmlBZ0lDQWdJQ0FnWTJ4MWMzUmxjbDlqYjJ4MWJXNXpJRDBnUmtGTVUwVXNYRzRnSUNBZ0lDQWdJR05zZFhOMFpYSmZjbTkzY3lBOUlFWkJURk5GTEZ4dUlDQWdJQ0FnSUNCeWIzZGZhMjBnUFNBNUxGeHVJQ0FnSUNBZ0lDQnphRzkzWDNKdmQxOWtaVzVrSUQwZ1JrRk1VMFVzWEc0Z0lDQWdJQ0FnSUdKdmNtUmxjaUE5SUVaQlRGTkZMRnh1SUNBZ0lDQWdJQ0J6YUc5M1gzSnZkMTl1WVcxbGN5QTlJRVpCVEZORkxGeHVJQ0FnSUNBZ0lDQmpiMndnUFNCamIyeGZablZ1S1Z4dVhHNW1hV3hsVG1GdFpTQThMU0JvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0Z4Y2FHVmhkRzFoY0Y5amFHVmphMmx1WjBSbGJIUmhRV055YjNOelEyOXVaR2wwYVc5dVhGd3BLVnh1Y0c1bktIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hGd3VjRzVuWEZ3cExDQnlaWE1nUFNBMk1EQXNJSFZ1YVhSeklEMGdYRnhwYmx4Y0xDQjNhV1IwYUNBOUlESXNJR2hsYVdkb2RDQTlJREV3S1Z4dWNISnBiblFvYURFcFhHNWtaWFl1YjJabUtDbGNibHh1YzJWMExuTmxaV1FvTVRJektWeHVYRzVvYlY5a2NtRjNiaUE4TFNCa2NtRjNLR2d4S1Z4dWNtOTNYMk5zZFhOMFpYSnpJRHd0SUhKdmQxOXZjbVJsY2lob2JWOWtjbUYzYmlsY2JseHViRzl2Y0M1amJIVnpkR1Z5TVNBOExTQjBaVzF3VzNKdmQxOWpiSFZ6ZEdWeWMxdGJNVjFkWFZ4dWJHOXZjQzVqYkhWemRHVnlNaUE4TFNCMFpXMXdXM0p2ZDE5amJIVnpkR1Z5YzF0Yk1sMWRYVnh1Ykc5dmNDNWpiSFZ6ZEdWeU15QThMU0IwWlcxd1czSnZkMTlqYkhWemRHVnljMXRiTTExZFhWeHViRzl2Y0M1amJIVnpkR1Z5TkNBOExTQjBaVzF3VzNKdmQxOWpiSFZ6ZEdWeWMxdGJORjFkWFZ4dWJHOXZjQzVqYkhWemRHVnlOU0E4TFNCMFpXMXdXM0p2ZDE5amJIVnpkR1Z5YzF0Yk5WMWRYVnh1Ykc5dmNDNWpiSFZ6ZEdWeU5pQThMU0IwWlcxd1czSnZkMTlqYkhWemRHVnljMXRiTmwxZFhWeHViRzl2Y0M1amJIVnpkR1Z5TnlBOExTQjBaVzF3VzNKdmQxOWpiSFZ6ZEdWeWMxdGJOMTFkWFZ4dWJHOXZjQzVqYkhWemRHVnlPQ0E4TFNCMFpXMXdXM0p2ZDE5amJIVnpkR1Z5YzF0Yk9GMWRYVnh1Ykc5dmNDNWpiSFZ6ZEdWeU9TQThMU0IwWlcxd1czSnZkMTlqYkhWemRHVnljMXRiT1YxZFhWeHVYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG4jIEhlYXRtYXBcbmxpYnJhcnkoY2lyY2xpemUpXG5cbiMgSGVhdG1hcCAyXG5zZXQuc2VlZCgxMjMpXG5cbmRpZmZDdXRvZmYgPC0gMC4yXG5kYXRhVG9QbG90IDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoaXNkaWZmX2RUQUdfRE1TTyA9IFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2FzZV93aGVuKGRpZmZfZFRBR19ETVNPID49IGRpZmZDdXRvZmYgfiAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFicyhkaWZmX2RUQUdfRE1TTykgPCBkaWZmQ3V0b2ZmIH4gMCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmX2RUQUdfRE1TTyA8PSAtZGlmZkN1dG9mZiB+IC0xLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaXNkaWZmX0E0ODVfRE1TTyA9IFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2FzZV93aGVuKGRpZmZfQTQ4NV9ETVNPID49IGRpZmZDdXRvZmYgfiAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFicyhkaWZmX0E0ODVfRE1TTykgPCBkaWZmQ3V0b2ZmIH4gMCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmX0E0ODVfRE1TTyA8PSAtZGlmZkN1dG9mZiB+IC0xLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBpc2RpZmZfZFRBR19ETVNPLCBpc2RpZmZfQTQ4NV9ETVNPKVxuZGF0YV9tYXRyaXggPC0gZGF0YVRvUGxvdCAlPiUgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcaWRcXCklPiUgYXMubWF0cml4KClcbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKC0xLCAwLCAxKSwgYyhcXGJsdWVcXCwgXFxncmV5XFwsIFxccmVkXFwpKVxuaDEgPC0gSGVhdG1hcChkYXRhX21hdHJpeCwgbmFtZSA9IFxcbG9vcCBzY29yZVxcLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY2x1c3Rlcl9yb3dzID0gRkFMU0UsXG4gICAgICAgIHJvd19rbSA9IDksXG4gICAgICAgIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgICAgICAgYm9yZGVyID0gRkFMU0UsXG4gICAgICAgIHNob3dfcm93X25hbWVzID0gRkFMU0UsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4pXG5cbmZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBwYXN0ZTAoXFxoZWF0bWFwX2NoZWNraW5nRGVsdGFBY3Jvc3NDb25kaXRpb25cXCkpXG5wbmcocGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCksIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gMiwgaGVpZ2h0ID0gMTApXG5wcmludChoMSlcbmRldi5vZmYoKVxuXG5zZXQuc2VlZCgxMjMpXG5cbmhtX2RyYXduIDwtIGRyYXcoaDEpXG5yb3dfY2x1c3RlcnMgPC0gcm93X29yZGVyKGhtX2RyYXduKVxuXG5sb29wLmNsdXN0ZXIxIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1sxXV1dXG5sb29wLmNsdXN0ZXIyIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1syXV1dXG5sb29wLmNsdXN0ZXIzIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1szXV1dXG5sb29wLmNsdXN0ZXI0IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s0XV1dXG5sb29wLmNsdXN0ZXI1IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s1XV1dXG5sb29wLmNsdXN0ZXI2IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s2XV1dXG5sb29wLmNsdXN0ZXI3IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s3XV1dXG5sb29wLmNsdXN0ZXI4IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s4XV1dXG5sb29wLmNsdXN0ZXI5IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s5XV1dXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBIZWF0bWFwXG5saWJyYXJ5KGNpcmNsaXplKVxuXG4jIEhlYXRtYXAgMlxuc2V0LnNlZWQoMTIzKVxuXG5kaWZmQ3V0b2ZmIDwtIDAuMlxuZGF0YVRvUGxvdCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGlzZGlmZl9kVEFHX0RNU08gPSBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNhc2Vfd2hlbihkaWZmX2RUQUdfRE1TTyA+PSBkaWZmQ3V0b2ZmIH4gMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhYnMoZGlmZl9kVEFHX0RNU08pIDwgZGlmZkN1dG9mZiB+IDAsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZl9kVEFHX0RNU08gPD0gLWRpZmZDdXRvZmYgfiAtMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlzZGlmZl9BNDg1X0RNU08gPSBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNhc2Vfd2hlbihkaWZmX0E0ODVfRE1TTyA+PSBkaWZmQ3V0b2ZmIH4gMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhYnMoZGlmZl9BNDg1X0RNU08pIDwgZGlmZkN1dG9mZiB+IDAsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZl9BNDg1X0RNU08gPD0gLWRpZmZDdXRvZmYgfiAtMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChpZCwgaXNkaWZmX2RUQUdfRE1TTywgaXNkaWZmX0E0ODVfRE1TTylcbmRhdGFfbWF0cml4IDwtIGRhdGFUb1Bsb3QgJT4lIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXGlkXFwpJT4lIGFzLm1hdHJpeCgpXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygtMSwgMCwgMSksIGMoXFxibHVlXFwsIFxcZ3JleVxcLCBcXHJlZFxcKSlcbmgxIDwtIEhlYXRtYXAoZGF0YV9tYXRyaXgsIG5hbWUgPSBcXGxvb3Agc2NvcmVcXCxcbiAgICAgICAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsXG4gICAgICAgIGNsdXN0ZXJfcm93cyA9IEZBTFNFLFxuICAgICAgICByb3dfa20gPSA5LFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGJvcmRlciA9IEZBTFNFLFxuICAgICAgICBzaG93X3Jvd19uYW1lcyA9IEZBTFNFLFxuICAgICAgICBjb2wgPSBjb2xfZnVuKVxuXG5maWxlTmFtZSA8LSBoZXJlKGZpZ0RpciwgcGFzdGUwKFxcaGVhdG1hcF9jaGVja2luZ0RlbHRhQWNyb3NzQ29uZGl0aW9uXFwpKVxucG5nKHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpLCByZXMgPSA2MDAsIHVuaXRzID0gXFxpblxcLCB3aWR0aCA9IDIsIGhlaWdodCA9IDEwKVxucHJpbnQoaDEpXG5kZXYub2ZmKClcblxuc2V0LnNlZWQoMTIzKVxuXG5obV9kcmF3biA8LSBkcmF3KGgxKVxucm93X2NsdXN0ZXJzIDwtIHJvd19vcmRlcihobV9kcmF3bilcblxubG9vcC5jbHVzdGVyMSA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbMV1dXVxubG9vcC5jbHVzdGVyMiA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbMl1dXVxubG9vcC5jbHVzdGVyMyA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbM11dXVxubG9vcC5jbHVzdGVyNCA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbNF1dXVxubG9vcC5jbHVzdGVyNSA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbNV1dXVxubG9vcC5jbHVzdGVyNiA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbNl1dXVxubG9vcC5jbHVzdGVyNyA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbN11dXVxubG9vcC5jbHVzdGVyOCA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbOF1dXVxubG9vcC5jbHVzdGVyOSA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbOV1dXVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
# Heatmap
library(circlize)

# Heatmap 2
set.seed(123)

diffCutoff <- 0.2
dataToPlot <- data %>% dplyr::mutate(isdiff_dTAG_DMSO = 
                                       case_when(diff_dTAG_DMSO >= diffCutoff ~ 1,
                                                 abs(diff_dTAG_DMSO) < diffCutoff ~ 0,
                                                 diff_dTAG_DMSO <= -diffCutoff ~ -1,
                                                 TRUE ~ NA),
                                     isdiff_A485_DMSO = 
                                       case_when(diff_A485_DMSO >= diffCutoff ~ 1,
                                                 abs(diff_A485_DMSO) < diffCutoff ~ 0,
                                                 diff_A485_DMSO <= -diffCutoff ~ -1,
                                                 TRUE ~ NA)) %>%
  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)
data_matrix <- dataToPlot %>% column_to_rownames(var = \id\)%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c(\blue\, \grey\, \red\))
h1 <- Heatmap(data_matrix, name = \loop score\,
        cluster_columns = FALSE,
        cluster_rows = FALSE,
        row_km = 9,
        show_row_dend = FALSE,
        border = FALSE,
        show_row_names = FALSE,
        col = col_fun)

fileName <- here(figDir, paste0(\heatmap_checkingDeltaAcrossCondition\))
png(paste0(fileName, \.png\), res = 600, units = \in\, width = 2, height = 10)
print(h1)
dev.off()

set.seed(123)

hm_drawn <- draw(h1)
row_clusters <- row_order(hm_drawn)

loop.cluster1 <- temp[row_clusters[[1]]]
loop.cluster2 <- temp[row_clusters[[2]]]
loop.cluster3 <- temp[row_clusters[[3]]]
loop.cluster4 <- temp[row_clusters[[4]]]
loop.cluster5 <- temp[row_clusters[[5]]]
loop.cluster6 <- temp[row_clusters[[6]]]
loop.cluster7 <- temp[row_clusters[[7]]]
loop.cluster8 <- temp[row_clusters[[8]]]
loop.cluster9 <- temp[row_clusters[[9]]]

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


## [2.32] Heatmap of loops
Strategy: check overlap of the union loops to the loops called at each condition
#### Check sample specific called loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJJWldGMGJXRndYRzVzYVdKeVlYSjVLR05wY21Oc2FYcGxLVnh1WEc0aklFaGxZWFJ0WVhBZ01seHVjMlYwTG5ObFpXUW9NVEl6S1Z4dVhHNWthV1ptUTNWMGIyWm1JRHd0SURBdU1seHVaR0YwWVZSdlVHeHZkQ0E4TFNCa1lYUmhJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRUZ1Ym04eUlDVnBiaVVnWXloY0lsQXRVRndpTENCY0lsQXRSVndpTENCY0lrVXRSVndpS1NrZ0pUNGxYRzRnSUdSd2JIbHlPanB0ZFhSaGRHVW9hWE5rYVdabVgyUlVRVWRmUkUxVFR5QTlJRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWTJGelpWOTNhR1Z1S0dScFptWmZaRlJCUjE5RVRWTlBJRDQ5SUdScFptWkRkWFJ2Wm1ZZ2ZpQXhMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdGaWN5aGthV1ptWDJSVVFVZGZSRTFUVHlrZ1BDQmthV1ptUTNWMGIyWm1JSDRnTUN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmthV1ptWDJSVVFVZGZSRTFUVHlBOFBTQXRaR2xtWmtOMWRHOW1aaUIrSUMweExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRlJTVlVVZ2ZpQk9RU2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYVhOa2FXWm1YMEUwT0RWZlJFMVRUeUE5SUZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1kyRnpaVjkzYUdWdUtHUnBabVpmUVRRNE5WOUVUVk5QSUQ0OUlHUnBabVpEZFhSdlptWWdmaUF4TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHRmljeWhrYVdabVgwRTBPRFZmUkUxVFR5a2dQQ0JrYVdabVEzVjBiMlptSUg0Z01DeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JrYVdabVgwRTBPRFZmUkUxVFR5QThQU0F0WkdsbVprTjFkRzltWmlCK0lDMHhMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZSU1ZVVWdmaUJPUVNrcElDVStKVnh1SUNCa2NHeDVjam82YzJWc1pXTjBLR2xrTENCcGMyUnBabVpmWkZSQlIxOUVUVk5QTENCcGMyUnBabVpmUVRRNE5WOUVUVk5QS1Z4dVpHRjBZVjl0WVhSeWFYZ2dQQzBnWkdGMFlWUnZVR3h2ZENBbFBpVWdZMjlzZFcxdVgzUnZYM0p2ZDI1aGJXVnpLSFpoY2lBOUlGd2lhV1JjSWlrbFBpVWdZWE11YldGMGNtbDRLQ2xjYm1OdmJGOW1kVzRnUEMwZ1kyOXNiM0pTWVcxd01paGpLQzB4TENBd0xDQXhLU3dnWXloY0ltSnNkV1ZjSWl3Z1hDSm5jbVY1WENJc0lGd2ljbVZrWENJcEtWeHVhREVnUEMwZ1NHVmhkRzFoY0Noa1lYUmhYMjFoZEhKcGVDd2dibUZ0WlNBOUlGd2liRzl2Y0NCelkyOXlaVndpTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0JqYkhWemRHVnlYMk52YkhWdGJuTWdQU0JHUVV4VFJTeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ1kyeDFjM1JsY2w5eWIzZHpJRDBnUmtGTVUwVXNYRzRnSUNBZ0lDQWdJSEp2ZDE5cmJTQTlJRGdzWEc0Z0lDQWdJQ0FnSUhOb2IzZGZjbTkzWDJSbGJtUWdQU0JHUVV4VFJTeGNiaUFnSUNBZ0lDQWdZbTl5WkdWeUlEMGdSa0ZNVTBVc1hHNGdJQ0FnSUNBZ0lITm9iM2RmY205M1gyNWhiV1Z6SUQwZ1JrRk1VMFVzWEc0Z0lDQWdJQ0FnSUdOdmJDQTlJR052YkY5bWRXNHBYRzVjYm1acGJHVk9ZVzFsSUR3dElHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9YQ0pvWldGMGJXRndYMk5vWldOcmFXNW5SR1ZzZEdGQlkzSnZjM05EYjI1a2FYUnBiMjVmY21WblhDSXBLVnh1Y0c1bktIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hDSXVjRzVuWENJcExDQnlaWE1nUFNBMk1EQXNJSFZ1YVhSeklEMGdYQ0pwYmx3aUxDQjNhV1IwYUNBOUlESXNJR2hsYVdkb2RDQTlJREV3S1Z4dWNISnBiblFvYURFcFhHNWtaWFl1YjJabUtDbGNibHh1YzJWMExuTmxaV1FvTVRJektWeHVYRzVvYlY5a2NtRjNiaUE4TFNCa2NtRjNLR2d4S1Z4dWNtOTNYMk5zZFhOMFpYSnpJRHd0SUhKdmQxOXZjbVJsY2lob2JWOWtjbUYzYmlsY2JseHViRzl2Y0M1amJIVnpkR1Z5TVNBOExTQjBaVzF3VzNKdmQxOWpiSFZ6ZEdWeWMxdGJNVjFkWFZ4dWJHOXZjQzVqYkhWemRHVnlNaUE4TFNCMFpXMXdXM0p2ZDE5amJIVnpkR1Z5YzF0Yk1sMWRYVnh1Ykc5dmNDNWpiSFZ6ZEdWeU15QThMU0IwWlcxd1czSnZkMTlqYkhWemRHVnljMXRiTTExZFhWeHViRzl2Y0M1amJIVnpkR1Z5TkNBOExTQjBaVzF3VzNKdmQxOWpiSFZ6ZEdWeWMxdGJORjFkWFZ4dWJHOXZjQzVqYkhWemRHVnlOU0E4TFNCMFpXMXdXM0p2ZDE5amJIVnpkR1Z5YzF0Yk5WMWRYVnh1Ykc5dmNDNWpiSFZ6ZEdWeU5pQThMU0IwWlcxd1czSnZkMTlqYkhWemRHVnljMXRiTmwxZFhWeHViRzl2Y0M1amJIVnpkR1Z5TnlBOExTQjBaVzF3VzNKdmQxOWpiSFZ6ZEdWeWMxdGJOMTFkWFZ4dWJHOXZjQzVqYkhWemRHVnlPQ0E4TFNCMFpXMXdXM0p2ZDE5amJIVnpkR1Z5YzF0Yk9GMWRYVnh1WEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG4jIEhlYXRtYXBcbmxpYnJhcnkoY2lyY2xpemUpXG5cbiMgSGVhdG1hcCAyXG5zZXQuc2VlZCgxMjMpXG5cbmRpZmZDdXRvZmYgPC0gMC4yXG5kYXRhVG9QbG90IDwtIGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShpc2RpZmZfZFRBR19ETVNPID0gXG4gICAgICAgICAgICAgICAgICBjYXNlX3doZW4oZGlmZl9kVEFHX0RNU08gPj0gZGlmZkN1dG9mZiB+IDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYWJzKGRpZmZfZFRBR19ETVNPKSA8IGRpZmZDdXRvZmYgfiAwLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZfZFRBR19ETVNPIDw9IC1kaWZmQ3V0b2ZmIH4gLTEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BKSxcbiAgICAgICAgICAgICAgICBpc2RpZmZfQTQ4NV9ETVNPID0gXG4gICAgICAgICAgICAgICAgICBjYXNlX3doZW4oZGlmZl9BNDg1X0RNU08gPj0gZGlmZkN1dG9mZiB+IDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYWJzKGRpZmZfQTQ4NV9ETVNPKSA8IGRpZmZDdXRvZmYgfiAwLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZfQTQ4NV9ETVNPIDw9IC1kaWZmQ3V0b2ZmIH4gLTEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIGlzZGlmZl9kVEFHX0RNU08sIGlzZGlmZl9BNDg1X0RNU08pXG5kYXRhX21hdHJpeCA8LSBkYXRhVG9QbG90ICU+JSBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFxpZFxcKSU+JSBhcy5tYXRyaXgoKVxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoLTEsIDAsIDEpLCBjKFxcYmx1ZVxcLCBcXGdyZXlcXCwgXFxyZWRcXCkpXG5oMSA8LSBIZWF0bWFwKGRhdGFfbWF0cml4LCBuYW1lID0gXFxsb29wIHNjb3JlXFwsXG4gICAgICAgICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICAgICAgICBjbHVzdGVyX3Jvd3MgPSBGQUxTRSxcbiAgICAgICAgcm93X2ttID0gOCxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBib3JkZXIgPSBGQUxTRSxcbiAgICAgICAgc2hvd19yb3dfbmFtZXMgPSBGQUxTRSxcbiAgICAgICAgY29sID0gY29sX2Z1bilcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIHBhc3RlMChcXGhlYXRtYXBfY2hlY2tpbmdEZWx0YUFjcm9zc0NvbmRpdGlvbl9yZWdcXCkpXG5wbmcocGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCksIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gMiwgaGVpZ2h0ID0gMTApXG5wcmludChoMSlcbmRldi5vZmYoKVxuXG5zZXQuc2VlZCgxMjMpXG5cbmhtX2RyYXduIDwtIGRyYXcoaDEpXG5yb3dfY2x1c3RlcnMgPC0gcm93X29yZGVyKGhtX2RyYXduKVxuXG5sb29wLmNsdXN0ZXIxIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1sxXV1dXG5sb29wLmNsdXN0ZXIyIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1syXV1dXG5sb29wLmNsdXN0ZXIzIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1szXV1dXG5sb29wLmNsdXN0ZXI0IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s0XV1dXG5sb29wLmNsdXN0ZXI1IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s1XV1dXG5sb29wLmNsdXN0ZXI2IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s2XV1dXG5sb29wLmNsdXN0ZXI3IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s3XV1dXG5sb29wLmNsdXN0ZXI4IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s4XV1dXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
# Heatmap
library(circlize)

# Heatmap 2
set.seed(123)

diffCutoff <- 0.2
dataToPlot <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\)) %>%
  dplyr::mutate(isdiff_dTAG_DMSO = 
                  case_when(diff_dTAG_DMSO >= diffCutoff ~ 1,
                            abs(diff_dTAG_DMSO) < diffCutoff ~ 0,
                            diff_dTAG_DMSO <= -diffCutoff ~ -1,
                            TRUE ~ NA),
                isdiff_A485_DMSO = 
                  case_when(diff_A485_DMSO >= diffCutoff ~ 1,
                            abs(diff_A485_DMSO) < diffCutoff ~ 0,
                            diff_A485_DMSO <= -diffCutoff ~ -1,
                            TRUE ~ NA)) %>%
  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)
data_matrix <- dataToPlot %>% column_to_rownames(var = \id\)%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c(\blue\, \grey\, \red\))
h1 <- Heatmap(data_matrix, name = \loop score\,
              cluster_columns = FALSE,
              cluster_rows = FALSE,
        row_km = 8,
        show_row_dend = FALSE,
        border = FALSE,
        show_row_names = FALSE,
        col = col_fun)

fileName <- here(figDir, paste0(\heatmap_checkingDeltaAcrossCondition_reg\))
png(paste0(fileName, \.png\), res = 600, units = \in\, width = 2, height = 10)
print(h1)
dev.off()

set.seed(123)

hm_drawn <- draw(h1)
row_clusters <- row_order(hm_drawn)

loop.cluster1 <- temp[row_clusters[[1]]]
loop.cluster2 <- temp[row_clusters[[2]]]
loop.cluster3 <- temp[row_clusters[[3]]]
loop.cluster4 <- temp[row_clusters[[4]]]
loop.cluster5 <- temp[row_clusters[[5]]]
loop.cluster6 <- temp[row_clusters[[6]]]
loop.cluster7 <- temp[row_clusters[[7]]]
loop.cluster8 <- temp[row_clusters[[8]]]



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QklaV0YwYldGd1hHNXNhV0p5WVhKNUtHTnBjbU5zYVhwbEtWeHVYRzRqSUVobFlYUnRZWEFnTWx4dWMyVjBMbk5sWldRb01USXpLVnh1WEc1a2FXWm1RM1YwYjJabUlEd3RJREF1TWx4dVpHRjBZVlJ2VUd4dmRDQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtFRnVibTh5SUNWcGJpVWdZeWhjWEZBdFVGeGNMQ0JjWEZBdFJWeGNMQ0JjWEVVdFJWeGNLU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHRkWFJoZEdVb2FYTmthV1ptWDJSVVFVZGZSRTFUVHlBOUlGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdZMkZ6WlY5M2FHVnVLR1JwWm1aZlpGUkJSMTlFVFZOUElENDlJR1JwWm1aRGRYUnZabVlnZmlBeExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR0ZpY3loa2FXWm1YMlJVUVVkZlJFMVRUeWtnUENCa2FXWm1RM1YwYjJabUlINGdNQ3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCa2FXWm1YMlJVUVVkZlJFMVRUeUE4UFNBdFpHbG1aa04xZEc5bVppQitJQzB4TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGUlNWVVVnZmlCT1FTa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhWE5rYVdabVgwRTBPRFZmUkUxVFR5QTlJRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWTJGelpWOTNhR1Z1S0dScFptWmZRVFE0TlY5RVRWTlBJRDQ5SUdScFptWkRkWFJ2Wm1ZZ2ZpQXhMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdGaWN5aGthV1ptWDBFME9EVmZSRTFUVHlrZ1BDQmthV1ptUTNWMGIyWm1JSDRnTUN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmthV1ptWDBFME9EVmZSRTFUVHlBOFBTQXRaR2xtWmtOMWRHOW1aaUIrSUMweExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJRlJTVlVVZ2ZpQk9RU2twSUNVK0pWeHVJQ0JrY0d4NWNqbzZjMlZzWldOMEtHbGtMQ0JwYzJScFptWmZaRlJCUjE5RVRWTlBMQ0JwYzJScFptWmZRVFE0TlY5RVRWTlBLVnh1WkdGMFlWOXRZWFJ5YVhnZ1BDMGdaR0YwWVZSdlVHeHZkQ0FsUGlVZ1kyOXNkVzF1WDNSdlgzSnZkMjVoYldWektIWmhjaUE5SUZ4Y2FXUmNYQ2tsUGlVZ1lYTXViV0YwY21sNEtDbGNibU52YkY5bWRXNGdQQzBnWTI5c2IzSlNZVzF3TWloaktDMHhMQ0F3TENBeEtTd2dZeWhjWEdKc2RXVmNYQ3dnWEZ4bmNtVjVYRndzSUZ4Y2NtVmtYRndwS1Z4dWFERWdQQzBnU0dWaGRHMWhjQ2hrWVhSaFgyMWhkSEpwZUN3Z2JtRnRaU0E5SUZ4Y2JHOXZjQ0J6WTI5eVpWeGNMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQmpiSFZ6ZEdWeVgyTnZiSFZ0Ym5NZ1BTQkdRVXhUUlN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnWTJ4MWMzUmxjbDl5YjNkeklEMGdSa0ZNVTBVc1hHNGdJQ0FnSUNBZ0lISnZkMTlyYlNBOUlEZ3NYRzRnSUNBZ0lDQWdJSE5vYjNkZmNtOTNYMlJsYm1RZ1BTQkdRVXhUUlN4Y2JpQWdJQ0FnSUNBZ1ltOXlaR1Z5SUQwZ1JrRk1VMFVzWEc0Z0lDQWdJQ0FnSUhOb2IzZGZjbTkzWDI1aGJXVnpJRDBnUmtGTVUwVXNYRzRnSUNBZ0lDQWdJR052YkNBOUlHTnZiRjltZFc0cFhHNWNibVpwYkdWT1lXMWxJRHd0SUdobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1hGeG9aV0YwYldGd1gyTm9aV05yYVc1blJHVnNkR0ZCWTNKdmMzTkRiMjVrYVhScGIyNWZjbVZuWEZ3cEtWeHVjRzVuS0hCaGMzUmxNQ2htYVd4bFRtRnRaU3dnWEZ3dWNHNW5YRndwTENCeVpYTWdQU0EyTURBc0lIVnVhWFJ6SUQwZ1hGeHBibHhjTENCM2FXUjBhQ0E5SURJc0lHaGxhV2RvZENBOUlERXdLVnh1Y0hKcGJuUW9hREVwWEc1a1pYWXViMlptS0NsY2JseHVjMlYwTG5ObFpXUW9NVEl6S1Z4dVhHNW9iVjlrY21GM2JpQThMU0JrY21GM0tHZ3hLVnh1Y205M1gyTnNkWE4wWlhKeklEd3RJSEp2ZDE5dmNtUmxjaWhvYlY5a2NtRjNiaWxjYmx4dWJHOXZjQzVqYkhWemRHVnlNU0E4TFNCMFpXMXdXM0p2ZDE5amJIVnpkR1Z5YzF0Yk1WMWRYVnh1Ykc5dmNDNWpiSFZ6ZEdWeU1pQThMU0IwWlcxd1czSnZkMTlqYkhWemRHVnljMXRiTWwxZFhWeHViRzl2Y0M1amJIVnpkR1Z5TXlBOExTQjBaVzF3VzNKdmQxOWpiSFZ6ZEdWeWMxdGJNMTFkWFZ4dWJHOXZjQzVqYkhWemRHVnlOQ0E4TFNCMFpXMXdXM0p2ZDE5amJIVnpkR1Z5YzF0Yk5GMWRYVnh1Ykc5dmNDNWpiSFZ6ZEdWeU5TQThMU0IwWlcxd1czSnZkMTlqYkhWemRHVnljMXRiTlYxZFhWeHViRzl2Y0M1amJIVnpkR1Z5TmlBOExTQjBaVzF3VzNKdmQxOWpiSFZ6ZEdWeWMxdGJObDFkWFZ4dWJHOXZjQzVqYkhWemRHVnlOeUE4TFNCMFpXMXdXM0p2ZDE5amJIVnpkR1Z5YzF0Yk4xMWRYVnh1Ykc5dmNDNWpiSFZ6ZEdWeU9DQThMU0IwWlcxd1czSnZkMTlqYkhWemRHVnljMXRiT0YxZFhWeHVYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG4jIEhlYXRtYXBcbmxpYnJhcnkoY2lyY2xpemUpXG5cbiMgSGVhdG1hcCAyXG5zZXQuc2VlZCgxMjMpXG5cbmRpZmZDdXRvZmYgPC0gMC4yXG5kYXRhVG9QbG90IDwtIGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShpc2RpZmZfZFRBR19ETVNPID0gXG4gICAgICAgICAgICAgICAgICBjYXNlX3doZW4oZGlmZl9kVEFHX0RNU08gPj0gZGlmZkN1dG9mZiB+IDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYWJzKGRpZmZfZFRBR19ETVNPKSA8IGRpZmZDdXRvZmYgfiAwLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZfZFRBR19ETVNPIDw9IC1kaWZmQ3V0b2ZmIH4gLTEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BKSxcbiAgICAgICAgICAgICAgICBpc2RpZmZfQTQ4NV9ETVNPID0gXG4gICAgICAgICAgICAgICAgICBjYXNlX3doZW4oZGlmZl9BNDg1X0RNU08gPj0gZGlmZkN1dG9mZiB+IDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYWJzKGRpZmZfQTQ4NV9ETVNPKSA8IGRpZmZDdXRvZmYgfiAwLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZfQTQ4NV9ETVNPIDw9IC1kaWZmQ3V0b2ZmIH4gLTEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIGlzZGlmZl9kVEFHX0RNU08sIGlzZGlmZl9BNDg1X0RNU08pXG5kYXRhX21hdHJpeCA8LSBkYXRhVG9QbG90ICU+JSBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFxpZFxcKSU+JSBhcy5tYXRyaXgoKVxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoLTEsIDAsIDEpLCBjKFxcYmx1ZVxcLCBcXGdyZXlcXCwgXFxyZWRcXCkpXG5oMSA8LSBIZWF0bWFwKGRhdGFfbWF0cml4LCBuYW1lID0gXFxsb29wIHNjb3JlXFwsXG4gICAgICAgICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICAgICAgICBjbHVzdGVyX3Jvd3MgPSBGQUxTRSxcbiAgICAgICAgcm93X2ttID0gOCxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBib3JkZXIgPSBGQUxTRSxcbiAgICAgICAgc2hvd19yb3dfbmFtZXMgPSBGQUxTRSxcbiAgICAgICAgY29sID0gY29sX2Z1bilcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIHBhc3RlMChcXGhlYXRtYXBfY2hlY2tpbmdEZWx0YUFjcm9zc0NvbmRpdGlvbl9yZWdcXCkpXG5wbmcocGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCksIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gMiwgaGVpZ2h0ID0gMTApXG5wcmludChoMSlcbmRldi5vZmYoKVxuXG5zZXQuc2VlZCgxMjMpXG5cbmhtX2RyYXduIDwtIGRyYXcoaDEpXG5yb3dfY2x1c3RlcnMgPC0gcm93X29yZGVyKGhtX2RyYXduKVxuXG5sb29wLmNsdXN0ZXIxIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1sxXV1dXG5sb29wLmNsdXN0ZXIyIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1syXV1dXG5sb29wLmNsdXN0ZXIzIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1szXV1dXG5sb29wLmNsdXN0ZXI0IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s0XV1dXG5sb29wLmNsdXN0ZXI1IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s1XV1dXG5sb29wLmNsdXN0ZXI2IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s2XV1dXG5sb29wLmNsdXN0ZXI3IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s3XV1dXG5sb29wLmNsdXN0ZXI4IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s4XV1dXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBIZWF0bWFwXG5saWJyYXJ5KGNpcmNsaXplKVxuXG4jIEhlYXRtYXAgMlxuc2V0LnNlZWQoMTIzKVxuXG5kaWZmQ3V0b2ZmIDwtIDAuMlxuZGF0YVRvUGxvdCA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoaXNkaWZmX2RUQUdfRE1TTyA9IFxuICAgICAgICAgICAgICAgICAgY2FzZV93aGVuKGRpZmZfZFRBR19ETVNPID49IGRpZmZDdXRvZmYgfiAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFicyhkaWZmX2RUQUdfRE1TTykgPCBkaWZmQ3V0b2ZmIH4gMCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmX2RUQUdfRE1TTyA8PSAtZGlmZkN1dG9mZiB+IC0xLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSksXG4gICAgICAgICAgICAgICAgaXNkaWZmX0E0ODVfRE1TTyA9IFxuICAgICAgICAgICAgICAgICAgY2FzZV93aGVuKGRpZmZfQTQ4NV9ETVNPID49IGRpZmZDdXRvZmYgfiAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFicyhkaWZmX0E0ODVfRE1TTykgPCBkaWZmQ3V0b2ZmIH4gMCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmX0E0ODVfRE1TTyA8PSAtZGlmZkN1dG9mZiB+IC0xLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBpc2RpZmZfZFRBR19ETVNPLCBpc2RpZmZfQTQ4NV9ETVNPKVxuZGF0YV9tYXRyaXggPC0gZGF0YVRvUGxvdCAlPiUgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcaWRcXCklPiUgYXMubWF0cml4KClcbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKC0xLCAwLCAxKSwgYyhcXGJsdWVcXCwgXFxncmV5XFwsIFxccmVkXFwpKVxuaDEgPC0gSGVhdG1hcChkYXRhX21hdHJpeCwgbmFtZSA9IFxcbG9vcCBzY29yZVxcLFxuICAgICAgICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgICAgICAgY2x1c3Rlcl9yb3dzID0gRkFMU0UsXG4gICAgICAgIHJvd19rbSA9IDgsXG4gICAgICAgIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgICAgICAgYm9yZGVyID0gRkFMU0UsXG4gICAgICAgIHNob3dfcm93X25hbWVzID0gRkFMU0UsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4pXG5cbmZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBwYXN0ZTAoXFxoZWF0bWFwX2NoZWNraW5nRGVsdGFBY3Jvc3NDb25kaXRpb25fcmVnXFwpKVxucG5nKHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpLCByZXMgPSA2MDAsIHVuaXRzID0gXFxpblxcLCB3aWR0aCA9IDIsIGhlaWdodCA9IDEwKVxucHJpbnQoaDEpXG5kZXYub2ZmKClcblxuc2V0LnNlZWQoMTIzKVxuXG5obV9kcmF3biA8LSBkcmF3KGgxKVxucm93X2NsdXN0ZXJzIDwtIHJvd19vcmRlcihobV9kcmF3bilcblxubG9vcC5jbHVzdGVyMSA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbMV1dXVxubG9vcC5jbHVzdGVyMiA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbMl1dXVxubG9vcC5jbHVzdGVyMyA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbM11dXVxubG9vcC5jbHVzdGVyNCA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbNF1dXVxubG9vcC5jbHVzdGVyNSA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbNV1dXVxubG9vcC5jbHVzdGVyNiA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbNl1dXVxubG9vcC5jbHVzdGVyNyA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbN11dXVxubG9vcC5jbHVzdGVyOCA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbOF1dXVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
# Heatmap
library(circlize)

# Heatmap 2
set.seed(123)

diffCutoff <- 0.2
dataToPlot <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\)) %>%
  dplyr::mutate(isdiff_dTAG_DMSO = 
                  case_when(diff_dTAG_DMSO >= diffCutoff ~ 1,
                            abs(diff_dTAG_DMSO) < diffCutoff ~ 0,
                            diff_dTAG_DMSO <= -diffCutoff ~ -1,
                            TRUE ~ NA),
                isdiff_A485_DMSO = 
                  case_when(diff_A485_DMSO >= diffCutoff ~ 1,
                            abs(diff_A485_DMSO) < diffCutoff ~ 0,
                            diff_A485_DMSO <= -diffCutoff ~ -1,
                            TRUE ~ NA)) %>%
  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)
data_matrix <- dataToPlot %>% column_to_rownames(var = \id\)%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c(\blue\, \grey\, \red\))
h1 <- Heatmap(data_matrix, name = \loop score\,
              cluster_columns = FALSE,
              cluster_rows = FALSE,
        row_km = 8,
        show_row_dend = FALSE,
        border = FALSE,
        show_row_names = FALSE,
        col = col_fun)

fileName <- here(figDir, paste0(\heatmap_checkingDeltaAcrossCondition_reg\))
png(paste0(fileName, \.png\), res = 600, units = \in\, width = 2, height = 10)
print(h1)
dev.off()

set.seed(123)

hm_drawn <- draw(h1)
row_clusters <- row_order(hm_drawn)

loop.cluster1 <- temp[row_clusters[[1]]]
loop.cluster2 <- temp[row_clusters[[2]]]
loop.cluster3 <- temp[row_clusters[[3]]]
loop.cluster4 <- temp[row_clusters[[4]]]
loop.cluster5 <- temp[row_clusters[[5]]]
loop.cluster6 <- temp[row_clusters[[6]]]
loop.cluster7 <- temp[row_clusters[[7]]]
loop.cluster8 <- temp[row_clusters[[8]]]

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Checking updown
##### All loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHViR2xpY21GeWVTaGphWEpqYkdsNlpTbGNibHh1YzJWMExuTmxaV1FvTVRJektWeHVaR0YwWVZSdlVHeHZkQ0E4TFNCa1lYUmhJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRUZ1Ym04eUlDVnBiaVVnWXloY0lsQXRVRndpTENCY0lsQXRSVndpTENCY0lrVXRSVndpS1NrZ0pUNGxYRzRnSUdSd2JIbHlPanB6Wld4bFkzUW9hV1FzSUdScFptWmZaRlJCUjE5RVRWTlBMQ0JrYVdabVgwRTBPRFZmUkUxVFR5bGNibVJoZEdGZmJXRjBjbWw0SUR3dElHUmhkR0ZVYjFCc2IzUWdKVDRsSUdOdmJIVnRibDkwYjE5eWIzZHVZVzFsY3loMllYSWdQU0JjSW1sa1hDSXBKVDRsSUdGekxtMWhkSEpwZUNncFhHNWpiMnhmWm5WdUlEd3RJR052Ykc5eVVtRnRjRElvWXlndE1Td2dNQ3dnTVNrc0lHTW9YQ0ppYkhWbFhDSXNJRndpZDJocGRHVmNJaXdnWENKeVpXUmNJaWtwWEc1b01TQThMU0JJWldGMGJXRndLR1JoZEdGZmJXRjBjbWw0TENCdVlXMWxJRDBnWENKc2IyOXdJSE5qYjNKbFhDSXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lHTnNkWE4wWlhKZlkyOXNkVzF1Y3lBOUlFWkJURk5GTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0JqYkhWemRHVnlYM0p2ZDNNZ1BTQkdRVXhUUlN4Y2JpQWdJQ0FnSUNBZ2NtOTNYMnR0SUQwZ05DeGNiaUFnSUNBZ0lDQWdjMmh2ZDE5eWIzZGZaR1Z1WkNBOUlFWkJURk5GTEZ4dUlDQWdJQ0FnSUNCaWIzSmtaWElnUFNCVVVsVkZMRnh1SUNBZ0lDQWdJQ0J6YUc5M1gzSnZkMTl1WVcxbGN5QTlJRVpCVEZORkxGeHVJQ0FnSUNBZ0lDQmpiMndnUFNCamIyeGZablZ1S1Z4dVhHNWNibVpwYkdWT1lXMWxJRHd0SUdobGNtVW9abWxuUkdseUxDQndZWE4wWlRBb1hDSm9aV0YwYldGd1gyUnBabVpUWTI5eVpWOXlaV2RmYXpSY0lpa3BYRzV3Ym1jb2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY0lpNXdibWRjSWlrc0lISmxjeUE5SURZd01Dd2dkVzVwZEhNZ1BTQmNJbWx1WENJc0lIZHBaSFJvSUQwZ01pd2dhR1ZwWjJoMElEMGdOaWxjYm5CeWFXNTBLR2d4S1Z4dVpHVjJMbTltWmlncFhHNWNibWh0WDJSeVlYZHVJRHd0SUdSeVlYY29hREVwWEc1eWIzZGZZMngxYzNSbGNuTWdQQzBnY205M1gyOXlaR1Z5S0dodFgyUnlZWGR1S1Z4dVhHNXNiMjl3TG1Oc2RYTjBaWEl4SUR3dElIUmxiWEJiY205M1gyTnNkWE4wWlhKelcxc3hYVjFkWEc1c2IyOXdMbU5zZFhOMFpYSXlJRHd0SUhSbGJYQmJjbTkzWDJOc2RYTjBaWEp6VzFzeVhWMWRYRzVzYjI5d0xtTnNkWE4wWlhJeklEd3RJSFJsYlhCYmNtOTNYMk5zZFhOMFpYSnpXMXN6WFYxZFhHNXNiMjl3TG1Oc2RYTjBaWEkwSUR3dElIUmxiWEJiY205M1gyTnNkWE4wWlhKelcxczBYVjFkWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5zZXQuc2VlZCgxMjMpXG5kYXRhVG9QbG90IDwtIGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChpZCwgZGlmZl9kVEFHX0RNU08sIGRpZmZfQTQ4NV9ETVNPKVxuZGF0YV9tYXRyaXggPC0gZGF0YVRvUGxvdCAlPiUgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcaWRcXCklPiUgYXMubWF0cml4KClcbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKC0xLCAwLCAxKSwgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcbmgxIDwtIEhlYXRtYXAoZGF0YV9tYXRyaXgsIG5hbWUgPSBcXGxvb3Agc2NvcmVcXCxcbiAgICAgICAgICAgICAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsXG4gICAgICAgICAgICAgIGNsdXN0ZXJfcm93cyA9IEZBTFNFLFxuICAgICAgICByb3dfa20gPSA0LFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGJvcmRlciA9IFRSVUUsXG4gICAgICAgIHNob3dfcm93X25hbWVzID0gRkFMU0UsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4pXG5cblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIHBhc3RlMChcXGhlYXRtYXBfZGlmZlNjb3JlX3JlZ19rNFxcKSlcbnBuZyhwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSwgcmVzID0gNjAwLCB1bml0cyA9IFxcaW5cXCwgd2lkdGggPSAyLCBoZWlnaHQgPSA2KVxucHJpbnQoaDEpXG5kZXYub2ZmKClcblxuaG1fZHJhd24gPC0gZHJhdyhoMSlcbnJvd19jbHVzdGVycyA8LSByb3dfb3JkZXIoaG1fZHJhd24pXG5cbmxvb3AuY2x1c3RlcjEgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzFdXV1cbmxvb3AuY2x1c3RlcjIgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzJdXV1cbmxvb3AuY2x1c3RlcjMgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzNdXV1cbmxvb3AuY2x1c3RlcjQgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzRdXV1cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
library(circlize)

set.seed(123)
dataToPlot <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\)) %>%
  dplyr::select(id, diff_dTAG_DMSO, diff_A485_DMSO)
data_matrix <- dataToPlot %>% column_to_rownames(var = \id\)%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c(\blue\, \white\, \red\))
h1 <- Heatmap(data_matrix, name = \loop score\,
              cluster_columns = FALSE,
              cluster_rows = FALSE,
        row_km = 4,
        show_row_dend = FALSE,
        border = TRUE,
        show_row_names = FALSE,
        col = col_fun)


fileName <- here(figDir, paste0(\heatmap_diffScore_reg_k4\))
png(paste0(fileName, \.png\), res = 600, units = \in\, width = 2, height = 6)
print(h1)
dev.off()

hm_drawn <- draw(h1)
row_clusters <- row_order(hm_drawn)

loop.cluster1 <- temp[row_clusters[[1]]]
loop.cluster2 <- temp[row_clusters[[2]]]
loop.cluster3 <- temp[row_clusters[[3]]]
loop.cluster4 <- temp[row_clusters[[4]]]



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJHbGljbUZ5ZVNoamFYSmpiR2w2WlNsY2JseHVjMlYwTG5ObFpXUW9NVEl6S1Z4dVpHRjBZVlJ2VUd4dmRDQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtFRnVibTh5SUNWcGJpVWdZeWhjWEZBdFVGeGNMQ0JjWEZBdFJWeGNMQ0JjWEVVdFJWeGNLU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHpaV3hsWTNRb2FXUXNJR1JwWm1aZlpGUkJSMTlFVFZOUExDQmthV1ptWDBFME9EVmZSRTFUVHlsY2JtUmhkR0ZmYldGMGNtbDRJRHd0SUdSaGRHRlViMUJzYjNRZ0pUNGxJR052YkhWdGJsOTBiMTl5YjNkdVlXMWxjeWgyWVhJZ1BTQmNYR2xrWEZ3cEpUNGxJR0Z6TG0xaGRISnBlQ2dwWEc1amIyeGZablZ1SUR3dElHTnZiRzl5VW1GdGNESW9ZeWd0TVN3Z01Dd2dNU2tzSUdNb1hGeGliSFZsWEZ3c0lGeGNkMmhwZEdWY1hDd2dYRnh5WldSY1hDa3BYRzVvTVNBOExTQklaV0YwYldGd0tHUmhkR0ZmYldGMGNtbDRMQ0J1WVcxbElEMGdYRnhzYjI5d0lITmpiM0psWEZ3c1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUdOc2RYTjBaWEpmWTI5c2RXMXVjeUE5SUVaQlRGTkZMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQmpiSFZ6ZEdWeVgzSnZkM01nUFNCR1FVeFRSU3hjYmlBZ0lDQWdJQ0FnY205M1gydHRJRDBnTkN4Y2JpQWdJQ0FnSUNBZ2MyaHZkMTl5YjNkZlpHVnVaQ0E5SUVaQlRGTkZMRnh1SUNBZ0lDQWdJQ0JpYjNKa1pYSWdQU0JVVWxWRkxGeHVJQ0FnSUNBZ0lDQnphRzkzWDNKdmQxOXVZVzFsY3lBOUlFWkJURk5GTEZ4dUlDQWdJQ0FnSUNCamIyd2dQU0JqYjJ4ZlpuVnVLVnh1WEc1Y2JtWnBiR1ZPWVcxbElEd3RJR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWEZ4b1pXRjBiV0Z3WDJScFptWlRZMjl5WlY5eVpXZGZhelJjWENrcFhHNXdibWNvY0dGemRHVXdLR1pwYkdWT1lXMWxMQ0JjWEM1d2JtZGNYQ2tzSUhKbGN5QTlJRFl3TUN3Z2RXNXBkSE1nUFNCY1hHbHVYRndzSUhkcFpIUm9JRDBnTWl3Z2FHVnBaMmgwSUQwZ05pbGNibkJ5YVc1MEtHZ3hLVnh1WkdWMkxtOW1aaWdwWEc1Y2JtaHRYMlJ5WVhkdUlEd3RJR1J5WVhjb2FERXBYRzV5YjNkZlkyeDFjM1JsY25NZ1BDMGdjbTkzWDI5eVpHVnlLR2h0WDJSeVlYZHVLVnh1WEc1c2IyOXdMbU5zZFhOMFpYSXhJRHd0SUhSbGJYQmJjbTkzWDJOc2RYTjBaWEp6VzFzeFhWMWRYRzVzYjI5d0xtTnNkWE4wWlhJeUlEd3RJSFJsYlhCYmNtOTNYMk5zZFhOMFpYSnpXMXN5WFYxZFhHNXNiMjl3TG1Oc2RYTjBaWEl6SUR3dElIUmxiWEJiY205M1gyTnNkWE4wWlhKelcxc3pYVjFkWEc1c2IyOXdMbU5zZFhOMFpYSTBJRHd0SUhSbGJYQmJjbTkzWDJOc2RYTjBaWEp6VzFzMFhWMWRYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5zZXQuc2VlZCgxMjMpXG5kYXRhVG9QbG90IDwtIGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpKSAlPiVcbiAgZHBseXI6OnNlbGVjdChpZCwgZGlmZl9kVEFHX0RNU08sIGRpZmZfQTQ4NV9ETVNPKVxuZGF0YV9tYXRyaXggPC0gZGF0YVRvUGxvdCAlPiUgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcaWRcXCklPiUgYXMubWF0cml4KClcbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKC0xLCAwLCAxKSwgYyhcXGJsdWVcXCwgXFx3aGl0ZVxcLCBcXHJlZFxcKSlcbmgxIDwtIEhlYXRtYXAoZGF0YV9tYXRyaXgsIG5hbWUgPSBcXGxvb3Agc2NvcmVcXCxcbiAgICAgICAgICAgICAgY2x1c3Rlcl9jb2x1bW5zID0gRkFMU0UsXG4gICAgICAgICAgICAgIGNsdXN0ZXJfcm93cyA9IEZBTFNFLFxuICAgICAgICByb3dfa20gPSA0LFxuICAgICAgICBzaG93X3Jvd19kZW5kID0gRkFMU0UsXG4gICAgICAgIGJvcmRlciA9IFRSVUUsXG4gICAgICAgIHNob3dfcm93X25hbWVzID0gRkFMU0UsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4pXG5cblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIHBhc3RlMChcXGhlYXRtYXBfZGlmZlNjb3JlX3JlZ19rNFxcKSlcbnBuZyhwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSwgcmVzID0gNjAwLCB1bml0cyA9IFxcaW5cXCwgd2lkdGggPSAyLCBoZWlnaHQgPSA2KVxucHJpbnQoaDEpXG5kZXYub2ZmKClcblxuaG1fZHJhd24gPC0gZHJhdyhoMSlcbnJvd19jbHVzdGVycyA8LSByb3dfb3JkZXIoaG1fZHJhd24pXG5cbmxvb3AuY2x1c3RlcjEgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzFdXV1cbmxvb3AuY2x1c3RlcjIgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzJdXV1cbmxvb3AuY2x1c3RlcjMgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzNdXV1cbmxvb3AuY2x1c3RlcjQgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzRdXV1cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubGlicmFyeShjaXJjbGl6ZSlcblxuc2V0LnNlZWQoMTIzKVxuZGF0YVRvUGxvdCA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIGRpZmZfZFRBR19ETVNPLCBkaWZmX0E0ODVfRE1TTylcbmRhdGFfbWF0cml4IDwtIGRhdGFUb1Bsb3QgJT4lIGNvbHVtbl90b19yb3duYW1lcyh2YXIgPSBcXGlkXFwpJT4lIGFzLm1hdHJpeCgpXG5jb2xfZnVuIDwtIGNvbG9yUmFtcDIoYygtMSwgMCwgMSksIGMoXFxibHVlXFwsIFxcd2hpdGVcXCwgXFxyZWRcXCkpXG5oMSA8LSBIZWF0bWFwKGRhdGFfbWF0cml4LCBuYW1lID0gXFxsb29wIHNjb3JlXFwsXG4gICAgICAgICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICAgICAgICBjbHVzdGVyX3Jvd3MgPSBGQUxTRSxcbiAgICAgICAgcm93X2ttID0gNCxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBib3JkZXIgPSBUUlVFLFxuICAgICAgICBzaG93X3Jvd19uYW1lcyA9IEZBTFNFLFxuICAgICAgICBjb2wgPSBjb2xfZnVuKVxuXG5cbmZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBwYXN0ZTAoXFxoZWF0bWFwX2RpZmZTY29yZV9yZWdfazRcXCkpXG5wbmcocGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCksIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gMiwgaGVpZ2h0ID0gNilcbnByaW50KGgxKVxuZGV2Lm9mZigpXG5cbmhtX2RyYXduIDwtIGRyYXcoaDEpXG5yb3dfY2x1c3RlcnMgPC0gcm93X29yZGVyKGhtX2RyYXduKVxuXG5sb29wLmNsdXN0ZXIxIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1sxXV1dXG5sb29wLmNsdXN0ZXIyIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1syXV1dXG5sb29wLmNsdXN0ZXIzIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1szXV1dXG5sb29wLmNsdXN0ZXI0IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s0XV1dXG5gYGBcbmBgYCJ9 -->

```r
```r
library(circlize)

set.seed(123)
dataToPlot <- data %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\)) %>%
  dplyr::select(id, diff_dTAG_DMSO, diff_A485_DMSO)
data_matrix <- dataToPlot %>% column_to_rownames(var = \id\)%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c(\blue\, \white\, \red\))
h1 <- Heatmap(data_matrix, name = \loop score\,
              cluster_columns = FALSE,
              cluster_rows = FALSE,
        row_km = 4,
        show_row_dend = FALSE,
        border = TRUE,
        show_row_names = FALSE,
        col = col_fun)


fileName <- here(figDir, paste0(\heatmap_diffScore_reg_k4\))
png(paste0(fileName, \.png\), res = 600, units = \in\, width = 2, height = 6)
print(h1)
dev.off()

hm_drawn <- draw(h1)
row_clusters <- row_order(hm_drawn)

loop.cluster1 <- temp[row_clusters[[1]]]
loop.cluster2 <- temp[row_clusters[[2]]]
loop.cluster3 <- temp[row_clusters[[3]]]
loop.cluster4 <- temp[row_clusters[[4]]]
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### Reg loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBIZWF0bWFwXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5uYW1lIDwtIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVwiXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXCIudHN2XCIpKSlcbiMgSGVhdG1hcCAyXG5zZXQuc2VlZCgxMjMpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbmRpZmZDdXRvZmYgPC0gMC41XG5vYnNleHAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcImxvb3BTY29yZV9jb25zX29ic2V4cC50c3ZcIikpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0RNU08pKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZFRBRyA9IGlmX2Vsc2Uob2JzZXhwX2RUQUcgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX2RUQUcpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfQTQ4NSA9IGlmX2Vsc2Uob2JzZXhwX0E0ODUgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0E0ODUpKSlcblxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGFUb1Bsb3QgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcImlkXCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPID0gbG9nX29ic2V4cF9kVEFHIC0gbG9nX29ic2V4cF9ETVNPLFxuICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZGlmZl9BNDg1X0RNU08gPSBsb2dfb2JzZXhwX0E0ODUgLSBsb2dfb2JzZXhwX0RNU08sXG4gICAgICAgICAgICAgICAgaXNkaWZmX2RUQUdfRE1TTyA9IGNhc2Vfd2hlbihsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPID49IGRpZmZDdXRvZmYgfiAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWJzKGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08pIDwgZGlmZkN1dG9mZiB+IDAsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPIDw9IGRpZmZDdXRvZmYgfiAtMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSApLFxuICAgICAgICAgICAgICAgIGlzZGlmZl9BNDg1X0RNU08gPSBjYXNlX3doZW4obG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA+PSBkaWZmQ3V0b2ZmIH4gMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFicyhsb2dfb2JzZXhwX2RpZmZfQTQ4NV9ETVNPKSA8IGRpZmZDdXRvZmYgfiAwLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA8PSBkaWZmQ3V0b2ZmIH4gLTEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKSU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBpc2RpZmZfZFRBR19ETVNPLCBpc2RpZmZfQTQ4NV9ETVNPKVxuXG5cblxuZGF0YV9tYXRyaXggPC0gZGF0YVRvUGxvdCAlPiUgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFwiaWRcIiklPiUgYXMubWF0cml4KClcbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKC0xLCAwLCAxKSwgYyhcImJsdWVcIiwgXCJncmV5XCIsIFwicmVkXCIpKVxuaDEgPC0gSGVhdG1hcChkYXRhX21hdHJpeCwgbmFtZSA9IFwibG9vcCBzY29yZVwiLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY2x1c3Rlcl9yb3dzID0gRkFMU0UsXG4gICAgICAgIHJvd19rbSA9IDksXG4gICAgICAgIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgICAgICAgYm9yZGVyID0gRkFMU0UsXG4gICAgICAgIHNob3dfcm93X25hbWVzID0gRkFMU0UsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4pXG5cbmZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBwYXN0ZTAoXCJoZWF0bWFwX2NoZWNraW5nRGVsdGFBY3Jvc3NDb25kaXRpb25fT0VcIikpXG5wbmcocGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIiksIHJlcyA9IDYwMCwgdW5pdHMgPSBcImluXCIsIHdpZHRoID0gMiwgaGVpZ2h0ID0gMTApXG5wcmludChoMSlcbmRldi5vZmYoKVxuIyBcbiMgc2V0LnNlZWQoMTIzKVxuIyBcbiMgaG1fZHJhd24gPC0gZHJhdyhoMSlcbiMgcm93X2NsdXN0ZXJzIDwtIHJvd19vcmRlcihobV9kcmF3bilcbiMgXG4jIGxvb3AuY2x1c3RlcjEgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzFdXV1cbiMgbG9vcC5jbHVzdGVyMiA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbMl1dXVxuIyBsb29wLmNsdXN0ZXIzIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1szXV1dXG4jIGxvb3AuY2x1c3RlcjQgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzRdXV1cbiMgbG9vcC5jbHVzdGVyNSA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbNV1dXVxuIyBsb29wLmNsdXN0ZXI2IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s2XV1dXG4jIGxvb3AuY2x1c3RlcjcgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzddXV1cbiMgbG9vcC5jbHVzdGVyOCA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbOF1dXVxuIyBsb29wLmNsdXN0ZXI5IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s5XV1dXG5cbmBgYCJ9 -->\n\n```r\n# Heatmap\nlibrary(circlize)\n\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\n# Heatmap 2\nset.seed(123)\n\n# Import obs/exp scores and merge to the dataset\nminValue <- -4\ndiffCutoff <- 0.5\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))\n\n\n# Merge dataset\ndataToPlot <- data %>% dplyr::left_join(obsexp, by = c(\\id\\)) %>%\n  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO,\n                isdiff_dTAG_DMSO = case_when(log_obsexp_diff_dTAG_DMSO >= diffCutoff ~ 1,\n                                             abs(log_obsexp_diff_dTAG_DMSO) < diffCutoff ~ 0,\n                                             log_obsexp_diff_dTAG_DMSO <= diffCutoff ~ -1,\n                                             TRUE ~ NA ),\n                isdiff_A485_DMSO = case_when(log_obsexp_diff_A485_DMSO >= diffCutoff ~ 1,\n                                             abs(log_obsexp_diff_A485_DMSO) < diffCutoff ~ 0,\n                                             log_obsexp_diff_A485_DMSO <= diffCutoff ~ -1,\n                                             TRUE ~ NA))%>%\n  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)\n\n\n\ndata_matrix <- dataToPlot %>% column_to_rownames(var = \\id\\)%>% as.matrix()\ncol_fun <- colorRamp2(c(-1, 0, 1), c(\\blue\\, \\grey\\, \\red\\))\nh1 <- Heatmap(data_matrix, name = \\loop score\\,\n        cluster_columns = FALSE,\n        cluster_rows = FALSE,\n        row_km = 9,\n        show_row_dend = FALSE,\n        border = FALSE,\n        show_row_names = FALSE,\n        col = col_fun)\n\nfileName <- here(figDir, paste0(\\heatmap_checkingDeltaAcrossCondition_OE\\))\npng(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 2, height = 10)\nprint(h1)\ndev.off()\n# \n# set.seed(123)\n# \n# hm_drawn <- draw(h1)\n# row_clusters <- row_order(hm_drawn)\n# \n# loop.cluster1 <- temp[row_clusters[[1]]]\n# loop.cluster2 <- temp[row_clusters[[2]]]\n# loop.cluster3 <- temp[row_clusters[[3]]]\n# loop.cluster4 <- temp[row_clusters[[4]]]\n# loop.cluster5 <- temp[row_clusters[[5]]]\n# loop.cluster6 <- temp[row_clusters[[6]]]\n# loop.cluster7 <- temp[row_clusters[[7]]]\n# loop.cluster8 <- temp[row_clusters[[8]]]\n# loop.cluster9 <- temp[row_clusters[[9]]]\n\n```\n\n<!-- rnb-source-end -->\n"} -->
# Heatmap
library(circlize)

name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
# Heatmap 2
set.seed(123)

# Import obs/exp scores and merge to the dataset
minValue <- -4
diffCutoff <- 0.5
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))


# Merge dataset
dataToPlot <- data %>% dplyr::left_join(obsexp, by = c(\id\)) %>%
  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO,
                isdiff_dTAG_DMSO = case_when(log_obsexp_diff_dTAG_DMSO >= diffCutoff ~ 1,
                                             abs(log_obsexp_diff_dTAG_DMSO) < diffCutoff ~ 0,
                                             log_obsexp_diff_dTAG_DMSO <= diffCutoff ~ -1,
                                             TRUE ~ NA ),
                isdiff_A485_DMSO = case_when(log_obsexp_diff_A485_DMSO >= diffCutoff ~ 1,
                                             abs(log_obsexp_diff_A485_DMSO) < diffCutoff ~ 0,
                                             log_obsexp_diff_A485_DMSO <= diffCutoff ~ -1,
                                             TRUE ~ NA))%>%
  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)



data_matrix <- dataToPlot %>% column_to_rownames(var = \id\)%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c(\blue\, \grey\, \red\))
h1 <- Heatmap(data_matrix, name = \loop score\,
        cluster_columns = FALSE,
        cluster_rows = FALSE,
        row_km = 9,
        show_row_dend = FALSE,
        border = FALSE,
        show_row_names = FALSE,
        col = col_fun)

fileName <- here(figDir, paste0(\heatmap_checkingDeltaAcrossCondition_OE\))
png(paste0(fileName, \.png\), res = 600, units = \in\, width = 2, height = 10)
print(h1)
dev.off()
# 
# set.seed(123)
# 
# hm_drawn <- draw(h1)
# row_clusters <- row_order(hm_drawn)
# 
# loop.cluster1 <- temp[row_clusters[[1]]]
# loop.cluster2 <- temp[row_clusters[[2]]]
# loop.cluster3 <- temp[row_clusters[[3]]]
# loop.cluster4 <- temp[row_clusters[[4]]]
# loop.cluster5 <- temp[row_clusters[[5]]]
# loop.cluster6 <- temp[row_clusters[[6]]]
# loop.cluster7 <- temp[row_clusters[[7]]]
# loop.cluster8 <- temp[row_clusters[[8]]]
# loop.cluster9 <- temp[row_clusters[[9]]]



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBIZWF0bWFwXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcbiMgSGVhdG1hcCAyXG5zZXQuc2VlZCgxMjMpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbmRpZmZDdXRvZmYgPC0gMC41XG5vYnNleHAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9jb25zX29ic2V4cC50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0RNU08pKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZFRBRyA9IGlmX2Vsc2Uob2JzZXhwX2RUQUcgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX2RUQUcpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfQTQ4NSA9IGlmX2Vsc2Uob2JzZXhwX0E0ODUgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0E0ODUpKSlcblxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGFUb1Bsb3QgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcXGlkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPID0gbG9nX29ic2V4cF9kVEFHIC0gbG9nX29ic2V4cF9ETVNPLFxuICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZGlmZl9BNDg1X0RNU08gPSBsb2dfb2JzZXhwX0E0ODUgLSBsb2dfb2JzZXhwX0RNU08sXG4gICAgICAgICAgICAgICAgaXNkaWZmX2RUQUdfRE1TTyA9IGNhc2Vfd2hlbihsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPID49IGRpZmZDdXRvZmYgfiAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWJzKGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08pIDwgZGlmZkN1dG9mZiB+IDAsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPIDw9IGRpZmZDdXRvZmYgfiAtMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSApLFxuICAgICAgICAgICAgICAgIGlzZGlmZl9BNDg1X0RNU08gPSBjYXNlX3doZW4obG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA+PSBkaWZmQ3V0b2ZmIH4gMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFicyhsb2dfb2JzZXhwX2RpZmZfQTQ4NV9ETVNPKSA8IGRpZmZDdXRvZmYgfiAwLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA8PSBkaWZmQ3V0b2ZmIH4gLTEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKSU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBpc2RpZmZfZFRBR19ETVNPLCBpc2RpZmZfQTQ4NV9ETVNPKVxuXG5cblxuZGF0YV9tYXRyaXggPC0gZGF0YVRvUGxvdCAlPiUgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcaWRcXCklPiUgYXMubWF0cml4KClcbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKC0xLCAwLCAxKSwgYyhcXGJsdWVcXCwgXFxncmV5XFwsIFxccmVkXFwpKVxuaDEgPC0gSGVhdG1hcChkYXRhX21hdHJpeCwgbmFtZSA9IFxcbG9vcCBzY29yZVxcLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY2x1c3Rlcl9yb3dzID0gRkFMU0UsXG4gICAgICAgIHJvd19rbSA9IDksXG4gICAgICAgIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgICAgICAgYm9yZGVyID0gRkFMU0UsXG4gICAgICAgIHNob3dfcm93X25hbWVzID0gRkFMU0UsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4pXG5cbmZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBwYXN0ZTAoXFxoZWF0bWFwX2NoZWNraW5nRGVsdGFBY3Jvc3NDb25kaXRpb25fT0VcXCkpXG5wbmcocGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCksIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gMiwgaGVpZ2h0ID0gMTApXG5wcmludChoMSlcbmRldi5vZmYoKVxuIyBcbiMgc2V0LnNlZWQoMTIzKVxuIyBcbiMgaG1fZHJhd24gPC0gZHJhdyhoMSlcbiMgcm93X2NsdXN0ZXJzIDwtIHJvd19vcmRlcihobV9kcmF3bilcbiMgXG4jIGxvb3AuY2x1c3RlcjEgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzFdXV1cbiMgbG9vcC5jbHVzdGVyMiA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbMl1dXVxuIyBsb29wLmNsdXN0ZXIzIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1szXV1dXG4jIGxvb3AuY2x1c3RlcjQgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzRdXV1cbiMgbG9vcC5jbHVzdGVyNSA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbNV1dXVxuIyBsb29wLmNsdXN0ZXI2IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s2XV1dXG4jIGxvb3AuY2x1c3RlcjcgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzddXV1cbiMgbG9vcC5jbHVzdGVyOCA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbOF1dXVxuIyBsb29wLmNsdXN0ZXI5IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s5XV1dXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\n# Heatmap\nlibrary(circlize)\n\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\n# Heatmap 2\nset.seed(123)\n\n# Import obs/exp scores and merge to the dataset\nminValue <- -4\ndiffCutoff <- 0.5\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))\n\n\n# Merge dataset\ndataToPlot <- data %>% dplyr::left_join(obsexp, by = c(\\id\\)) %>%\n  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO,\n                isdiff_dTAG_DMSO = case_when(log_obsexp_diff_dTAG_DMSO >= diffCutoff ~ 1,\n                                             abs(log_obsexp_diff_dTAG_DMSO) < diffCutoff ~ 0,\n                                             log_obsexp_diff_dTAG_DMSO <= diffCutoff ~ -1,\n                                             TRUE ~ NA ),\n                isdiff_A485_DMSO = case_when(log_obsexp_diff_A485_DMSO >= diffCutoff ~ 1,\n                                             abs(log_obsexp_diff_A485_DMSO) < diffCutoff ~ 0,\n                                             log_obsexp_diff_A485_DMSO <= diffCutoff ~ -1,\n                                             TRUE ~ NA))%>%\n  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)\n\n\n\ndata_matrix <- dataToPlot %>% column_to_rownames(var = \\id\\)%>% as.matrix()\ncol_fun <- colorRamp2(c(-1, 0, 1), c(\\blue\\, \\grey\\, \\red\\))\nh1 <- Heatmap(data_matrix, name = \\loop score\\,\n        cluster_columns = FALSE,\n        cluster_rows = FALSE,\n        row_km = 9,\n        show_row_dend = FALSE,\n        border = FALSE,\n        show_row_names = FALSE,\n        col = col_fun)\n\nfileName <- here(figDir, paste0(\\heatmap_checkingDeltaAcrossCondition_OE\\))\npng(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 2, height = 10)\nprint(h1)\ndev.off()\n# \n# set.seed(123)\n# \n# hm_drawn <- draw(h1)\n# row_clusters <- row_order(hm_drawn)\n# \n# loop.cluster1 <- temp[row_clusters[[1]]]\n# loop.cluster2 <- temp[row_clusters[[2]]]\n# loop.cluster3 <- temp[row_clusters[[3]]]\n# loop.cluster4 <- temp[row_clusters[[4]]]\n# loop.cluster5 <- temp[row_clusters[[5]]]\n# loop.cluster6 <- temp[row_clusters[[6]]]\n# loop.cluster7 <- temp[row_clusters[[7]]]\n# loop.cluster8 <- temp[row_clusters[[8]]]\n# loop.cluster9 <- temp[row_clusters[[9]]]\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBIZWF0bWFwXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcbiMgSGVhdG1hcCAyXG5zZXQuc2VlZCgxMjMpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbmRpZmZDdXRvZmYgPC0gMC41XG5vYnNleHAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9jb25zX29ic2V4cC50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0RNU08pKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZFRBRyA9IGlmX2Vsc2Uob2JzZXhwX2RUQUcgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX2RUQUcpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfQTQ4NSA9IGlmX2Vsc2Uob2JzZXhwX0E0ODUgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0E0ODUpKSlcblxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGFUb1Bsb3QgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcXGlkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPID0gbG9nX29ic2V4cF9kVEFHIC0gbG9nX29ic2V4cF9ETVNPLFxuICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZGlmZl9BNDg1X0RNU08gPSBsb2dfb2JzZXhwX0E0ODUgLSBsb2dfb2JzZXhwX0RNU08sXG4gICAgICAgICAgICAgICAgaXNkaWZmX2RUQUdfRE1TTyA9IGNhc2Vfd2hlbihsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPID49IGRpZmZDdXRvZmYgfiAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWJzKGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08pIDwgZGlmZkN1dG9mZiB+IDAsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPIDw9IGRpZmZDdXRvZmYgfiAtMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSApLFxuICAgICAgICAgICAgICAgIGlzZGlmZl9BNDg1X0RNU08gPSBjYXNlX3doZW4obG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA+PSBkaWZmQ3V0b2ZmIH4gMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFicyhsb2dfb2JzZXhwX2RpZmZfQTQ4NV9ETVNPKSA8IGRpZmZDdXRvZmYgfiAwLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA8PSBkaWZmQ3V0b2ZmIH4gLTEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKSU+JVxuICBkcGx5cjo6c2VsZWN0KGlkLCBpc2RpZmZfZFRBR19ETVNPLCBpc2RpZmZfQTQ4NV9ETVNPKVxuXG5cblxuZGF0YV9tYXRyaXggPC0gZGF0YVRvUGxvdCAlPiUgY29sdW1uX3RvX3Jvd25hbWVzKHZhciA9IFxcaWRcXCklPiUgYXMubWF0cml4KClcbmNvbF9mdW4gPC0gY29sb3JSYW1wMihjKC0xLCAwLCAxKSwgYyhcXGJsdWVcXCwgXFxncmV5XFwsIFxccmVkXFwpKVxuaDEgPC0gSGVhdG1hcChkYXRhX21hdHJpeCwgbmFtZSA9IFxcbG9vcCBzY29yZVxcLFxuICAgICAgICBjbHVzdGVyX2NvbHVtbnMgPSBGQUxTRSxcbiAgICAgICAgY2x1c3Rlcl9yb3dzID0gRkFMU0UsXG4gICAgICAgIHJvd19rbSA9IDksXG4gICAgICAgIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgICAgICAgYm9yZGVyID0gRkFMU0UsXG4gICAgICAgIHNob3dfcm93X25hbWVzID0gRkFMU0UsXG4gICAgICAgIGNvbCA9IGNvbF9mdW4pXG5cbmZpbGVOYW1lIDwtIGhlcmUoZmlnRGlyLCBwYXN0ZTAoXFxoZWF0bWFwX2NoZWNraW5nRGVsdGFBY3Jvc3NDb25kaXRpb25fT0VcXCkpXG5wbmcocGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCksIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gMiwgaGVpZ2h0ID0gMTApXG5wcmludChoMSlcbmRldi5vZmYoKVxuIyBcbiMgc2V0LnNlZWQoMTIzKVxuIyBcbiMgaG1fZHJhd24gPC0gZHJhdyhoMSlcbiMgcm93X2NsdXN0ZXJzIDwtIHJvd19vcmRlcihobV9kcmF3bilcbiMgXG4jIGxvb3AuY2x1c3RlcjEgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzFdXV1cbiMgbG9vcC5jbHVzdGVyMiA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbMl1dXVxuIyBsb29wLmNsdXN0ZXIzIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1szXV1dXG4jIGxvb3AuY2x1c3RlcjQgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzRdXV1cbiMgbG9vcC5jbHVzdGVyNSA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbNV1dXVxuIyBsb29wLmNsdXN0ZXI2IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s2XV1dXG4jIGxvb3AuY2x1c3RlcjcgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzddXV1cbiMgbG9vcC5jbHVzdGVyOCA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbOF1dXVxuIyBsb29wLmNsdXN0ZXI5IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s5XV1dXG5cbmBgYFxuYGBgIn0= -->

```r
```r
# Heatmap
library(circlize)

name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
# Heatmap 2
set.seed(123)

# Import obs/exp scores and merge to the dataset
minValue <- -4
diffCutoff <- 0.5
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))


# Merge dataset
dataToPlot <- data %>% dplyr::left_join(obsexp, by = c(\id\)) %>%
  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO,
                isdiff_dTAG_DMSO = case_when(log_obsexp_diff_dTAG_DMSO >= diffCutoff ~ 1,
                                             abs(log_obsexp_diff_dTAG_DMSO) < diffCutoff ~ 0,
                                             log_obsexp_diff_dTAG_DMSO <= diffCutoff ~ -1,
                                             TRUE ~ NA ),
                isdiff_A485_DMSO = case_when(log_obsexp_diff_A485_DMSO >= diffCutoff ~ 1,
                                             abs(log_obsexp_diff_A485_DMSO) < diffCutoff ~ 0,
                                             log_obsexp_diff_A485_DMSO <= diffCutoff ~ -1,
                                             TRUE ~ NA))%>%
  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)



data_matrix <- dataToPlot %>% column_to_rownames(var = \id\)%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c(\blue\, \grey\, \red\))
h1 <- Heatmap(data_matrix, name = \loop score\,
        cluster_columns = FALSE,
        cluster_rows = FALSE,
        row_km = 9,
        show_row_dend = FALSE,
        border = FALSE,
        show_row_names = FALSE,
        col = col_fun)

fileName <- here(figDir, paste0(\heatmap_checkingDeltaAcrossCondition_OE\))
png(paste0(fileName, \.png\), res = 600, units = \in\, width = 2, height = 10)
print(h1)
dev.off()
# 
# set.seed(123)
# 
# hm_drawn <- draw(h1)
# row_clusters <- row_order(hm_drawn)
# 
# loop.cluster1 <- temp[row_clusters[[1]]]
# loop.cluster2 <- temp[row_clusters[[2]]]
# loop.cluster3 <- temp[row_clusters[[3]]]
# loop.cluster4 <- temp[row_clusters[[4]]]
# loop.cluster5 <- temp[row_clusters[[5]]]
# loop.cluster6 <- temp[row_clusters[[6]]]
# loop.cluster7 <- temp[row_clusters[[7]]]
# loop.cluster8 <- temp[row_clusters[[8]]]
# loop.cluster9 <- temp[row_clusters[[9]]]

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBIZWF0bWFwXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5uYW1lIDwtIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVwiXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXCIudHN2XCIpKSlcbiMgSGVhdG1hcCAyXG5zZXQuc2VlZCgxMjMpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbmRpZmZDdXRvZmYgPC0gMC41XG5vYnNleHAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcImxvb3BTY29yZV9jb25zX29ic2V4cC50c3ZcIikpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0RNU08pKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZFRBRyA9IGlmX2Vsc2Uob2JzZXhwX2RUQUcgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX2RUQUcpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfQTQ4NSA9IGlmX2Vsc2Uob2JzZXhwX0E0ODUgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0E0ODUpKSlcblxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGFUb1Bsb3QgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcImlkXCIpKSAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXCJQLVBcIiwgXCJQLUVcIiwgXCJFLUVcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08gPSBsb2dfb2JzZXhwX2RUQUcgLSBsb2dfb2JzZXhwX0RNU08sXG4gICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA9IGxvZ19vYnNleHBfQTQ4NSAtIGxvZ19vYnNleHBfRE1TTyxcbiAgICAgICAgICAgICAgICBpc2RpZmZfZFRBR19ETVNPID0gY2FzZV93aGVuKGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08gPj0gZGlmZkN1dG9mZiB+IDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhYnMobG9nX29ic2V4cF9kaWZmX2RUQUdfRE1TTykgPCBkaWZmQ3V0b2ZmIH4gMCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08gPD0gZGlmZkN1dG9mZiB+IC0xLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BICksXG4gICAgICAgICAgICAgICAgaXNkaWZmX0E0ODVfRE1TTyA9IGNhc2Vfd2hlbihsb2dfb2JzZXhwX2RpZmZfQTQ4NV9ETVNPID49IGRpZmZDdXRvZmYgfiAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWJzKGxvZ19vYnNleHBfZGlmZl9BNDg1X0RNU08pIDwgZGlmZkN1dG9mZiB+IDAsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX2RpZmZfQTQ4NV9ETVNPIDw9IGRpZmZDdXRvZmYgfiAtMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIGlzZGlmZl9kVEFHX0RNU08sIGlzZGlmZl9BNDg1X0RNU08pXG5cblxuXG5kYXRhX21hdHJpeCA8LSBkYXRhVG9QbG90ICU+JSBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXCJpZFwiKSU+JSBhcy5tYXRyaXgoKVxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoLTEsIDAsIDEpLCBjKFwiYmx1ZVwiLCBcImdyZXlcIiwgXCJyZWRcIikpXG5oMSA8LSBIZWF0bWFwKGRhdGFfbWF0cml4LCBuYW1lID0gXCJsb29wIHNjb3JlXCIsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBGQUxTRSxcbiAgICAgICAgcm93X2ttID0gOSxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBib3JkZXIgPSBGQUxTRSxcbiAgICAgICAgc2hvd19yb3dfbmFtZXMgPSBGQUxTRSxcbiAgICAgICAgY29sID0gY29sX2Z1bilcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIHBhc3RlMChcImhlYXRtYXBfY2hlY2tpbmdEZWx0YUFjcm9zc0NvbmRpdGlvbl9yZWdfT0VcIikpXG5wbmcocGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIiksIHJlcyA9IDYwMCwgdW5pdHMgPSBcImluXCIsIHdpZHRoID0gMiwgaGVpZ2h0ID0gMTApXG5wcmludChoMSlcbmRldi5vZmYoKVxuIyBcbiMgc2V0LnNlZWQoMTIzKVxuIyBcbiMgaG1fZHJhd24gPC0gZHJhdyhoMSlcbiMgcm93X2NsdXN0ZXJzIDwtIHJvd19vcmRlcihobV9kcmF3bilcbiMgXG4jIGxvb3AuY2x1c3RlcjEgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzFdXV1cbiMgbG9vcC5jbHVzdGVyMiA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbMl1dXVxuIyBsb29wLmNsdXN0ZXIzIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1szXV1dXG4jIGxvb3AuY2x1c3RlcjQgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzRdXV1cbiMgbG9vcC5jbHVzdGVyNSA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbNV1dXVxuIyBsb29wLmNsdXN0ZXI2IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s2XV1dXG4jIGxvb3AuY2x1c3RlcjcgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzddXV1cbiMgbG9vcC5jbHVzdGVyOCA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbOF1dXVxuIyBsb29wLmNsdXN0ZXI5IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s5XV1dXG5cbmBgYCJ9 -->\n\n```r\n# Heatmap\nlibrary(circlize)\n\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\n# Heatmap 2\nset.seed(123)\n\n# Import obs/exp scores and merge to the dataset\nminValue <- -4\ndiffCutoff <- 0.5\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))\n\n\n# Merge dataset\ndataToPlot <- data %>% dplyr::left_join(obsexp, by = c(\\id\\)) %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\)) %>%\n  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO,\n                isdiff_dTAG_DMSO = case_when(log_obsexp_diff_dTAG_DMSO >= diffCutoff ~ 1,\n                                             abs(log_obsexp_diff_dTAG_DMSO) < diffCutoff ~ 0,\n                                             log_obsexp_diff_dTAG_DMSO <= diffCutoff ~ -1,\n                                             TRUE ~ NA ),\n                isdiff_A485_DMSO = case_when(log_obsexp_diff_A485_DMSO >= diffCutoff ~ 1,\n                                             abs(log_obsexp_diff_A485_DMSO) < diffCutoff ~ 0,\n                                             log_obsexp_diff_A485_DMSO <= diffCutoff ~ -1,\n                                             TRUE ~ NA))%>%\n  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)\n\n\n\ndata_matrix <- dataToPlot %>% column_to_rownames(var = \\id\\)%>% as.matrix()\ncol_fun <- colorRamp2(c(-1, 0, 1), c(\\blue\\, \\grey\\, \\red\\))\nh1 <- Heatmap(data_matrix, name = \\loop score\\,\n        cluster_columns = FALSE,\n        cluster_rows = FALSE,\n        row_km = 9,\n        show_row_dend = FALSE,\n        border = FALSE,\n        show_row_names = FALSE,\n        col = col_fun)\n\nfileName <- here(figDir, paste0(\\heatmap_checkingDeltaAcrossCondition_reg_OE\\))\npng(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 2, height = 10)\nprint(h1)\ndev.off()\n# \n# set.seed(123)\n# \n# hm_drawn <- draw(h1)\n# row_clusters <- row_order(hm_drawn)\n# \n# loop.cluster1 <- temp[row_clusters[[1]]]\n# loop.cluster2 <- temp[row_clusters[[2]]]\n# loop.cluster3 <- temp[row_clusters[[3]]]\n# loop.cluster4 <- temp[row_clusters[[4]]]\n# loop.cluster5 <- temp[row_clusters[[5]]]\n# loop.cluster6 <- temp[row_clusters[[6]]]\n# loop.cluster7 <- temp[row_clusters[[7]]]\n# loop.cluster8 <- temp[row_clusters[[8]]]\n# loop.cluster9 <- temp[row_clusters[[9]]]\n\n```\n\n<!-- rnb-source-end -->\n"} -->
# Heatmap
library(circlize)

name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
# Heatmap 2
set.seed(123)

# Import obs/exp scores and merge to the dataset
minValue <- -4
diffCutoff <- 0.5
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))


# Merge dataset
dataToPlot <- data %>% dplyr::left_join(obsexp, by = c(\id\)) %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\)) %>%
  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO,
                isdiff_dTAG_DMSO = case_when(log_obsexp_diff_dTAG_DMSO >= diffCutoff ~ 1,
                                             abs(log_obsexp_diff_dTAG_DMSO) < diffCutoff ~ 0,
                                             log_obsexp_diff_dTAG_DMSO <= diffCutoff ~ -1,
                                             TRUE ~ NA ),
                isdiff_A485_DMSO = case_when(log_obsexp_diff_A485_DMSO >= diffCutoff ~ 1,
                                             abs(log_obsexp_diff_A485_DMSO) < diffCutoff ~ 0,
                                             log_obsexp_diff_A485_DMSO <= diffCutoff ~ -1,
                                             TRUE ~ NA))%>%
  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)



data_matrix <- dataToPlot %>% column_to_rownames(var = \id\)%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c(\blue\, \grey\, \red\))
h1 <- Heatmap(data_matrix, name = \loop score\,
        cluster_columns = FALSE,
        cluster_rows = FALSE,
        row_km = 9,
        show_row_dend = FALSE,
        border = FALSE,
        show_row_names = FALSE,
        col = col_fun)

fileName <- here(figDir, paste0(\heatmap_checkingDeltaAcrossCondition_reg_OE\))
png(paste0(fileName, \.png\), res = 600, units = \in\, width = 2, height = 10)
print(h1)
dev.off()
# 
# set.seed(123)
# 
# hm_drawn <- draw(h1)
# row_clusters <- row_order(hm_drawn)
# 
# loop.cluster1 <- temp[row_clusters[[1]]]
# loop.cluster2 <- temp[row_clusters[[2]]]
# loop.cluster3 <- temp[row_clusters[[3]]]
# loop.cluster4 <- temp[row_clusters[[4]]]
# loop.cluster5 <- temp[row_clusters[[5]]]
# loop.cluster6 <- temp[row_clusters[[6]]]
# loop.cluster7 <- temp[row_clusters[[7]]]
# loop.cluster8 <- temp[row_clusters[[8]]]
# loop.cluster9 <- temp[row_clusters[[9]]]



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBIZWF0bWFwXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcbiMgSGVhdG1hcCAyXG5zZXQuc2VlZCgxMjMpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbmRpZmZDdXRvZmYgPC0gMC41XG5vYnNleHAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9jb25zX29ic2V4cC50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0RNU08pKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZFRBRyA9IGlmX2Vsc2Uob2JzZXhwX2RUQUcgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX2RUQUcpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfQTQ4NSA9IGlmX2Vsc2Uob2JzZXhwX0E0ODUgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0E0ODUpKSlcblxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGFUb1Bsb3QgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcXGlkXFwpKSAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08gPSBsb2dfb2JzZXhwX2RUQUcgLSBsb2dfb2JzZXhwX0RNU08sXG4gICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA9IGxvZ19vYnNleHBfQTQ4NSAtIGxvZ19vYnNleHBfRE1TTyxcbiAgICAgICAgICAgICAgICBpc2RpZmZfZFRBR19ETVNPID0gY2FzZV93aGVuKGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08gPj0gZGlmZkN1dG9mZiB+IDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhYnMobG9nX29ic2V4cF9kaWZmX2RUQUdfRE1TTykgPCBkaWZmQ3V0b2ZmIH4gMCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08gPD0gZGlmZkN1dG9mZiB+IC0xLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BICksXG4gICAgICAgICAgICAgICAgaXNkaWZmX0E0ODVfRE1TTyA9IGNhc2Vfd2hlbihsb2dfb2JzZXhwX2RpZmZfQTQ4NV9ETVNPID49IGRpZmZDdXRvZmYgfiAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWJzKGxvZ19vYnNleHBfZGlmZl9BNDg1X0RNU08pIDwgZGlmZkN1dG9mZiB+IDAsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX2RpZmZfQTQ4NV9ETVNPIDw9IGRpZmZDdXRvZmYgfiAtMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIGlzZGlmZl9kVEFHX0RNU08sIGlzZGlmZl9BNDg1X0RNU08pXG5cblxuXG5kYXRhX21hdHJpeCA8LSBkYXRhVG9QbG90ICU+JSBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFxpZFxcKSU+JSBhcy5tYXRyaXgoKVxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoLTEsIDAsIDEpLCBjKFxcYmx1ZVxcLCBcXGdyZXlcXCwgXFxyZWRcXCkpXG5oMSA8LSBIZWF0bWFwKGRhdGFfbWF0cml4LCBuYW1lID0gXFxsb29wIHNjb3JlXFwsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBGQUxTRSxcbiAgICAgICAgcm93X2ttID0gOSxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBib3JkZXIgPSBGQUxTRSxcbiAgICAgICAgc2hvd19yb3dfbmFtZXMgPSBGQUxTRSxcbiAgICAgICAgY29sID0gY29sX2Z1bilcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIHBhc3RlMChcXGhlYXRtYXBfY2hlY2tpbmdEZWx0YUFjcm9zc0NvbmRpdGlvbl9yZWdfT0VcXCkpXG5wbmcocGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCksIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gMiwgaGVpZ2h0ID0gMTApXG5wcmludChoMSlcbmRldi5vZmYoKVxuIyBcbiMgc2V0LnNlZWQoMTIzKVxuIyBcbiMgaG1fZHJhd24gPC0gZHJhdyhoMSlcbiMgcm93X2NsdXN0ZXJzIDwtIHJvd19vcmRlcihobV9kcmF3bilcbiMgXG4jIGxvb3AuY2x1c3RlcjEgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzFdXV1cbiMgbG9vcC5jbHVzdGVyMiA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbMl1dXVxuIyBsb29wLmNsdXN0ZXIzIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1szXV1dXG4jIGxvb3AuY2x1c3RlcjQgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzRdXV1cbiMgbG9vcC5jbHVzdGVyNSA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbNV1dXVxuIyBsb29wLmNsdXN0ZXI2IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s2XV1dXG4jIGxvb3AuY2x1c3RlcjcgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzddXV1cbiMgbG9vcC5jbHVzdGVyOCA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbOF1dXVxuIyBsb29wLmNsdXN0ZXI5IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s5XV1dXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\n# Heatmap\nlibrary(circlize)\n\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\n# Heatmap 2\nset.seed(123)\n\n# Import obs/exp scores and merge to the dataset\nminValue <- -4\ndiffCutoff <- 0.5\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))\n\n\n# Merge dataset\ndataToPlot <- data %>% dplyr::left_join(obsexp, by = c(\\id\\)) %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\)) %>%\n  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO,\n                isdiff_dTAG_DMSO = case_when(log_obsexp_diff_dTAG_DMSO >= diffCutoff ~ 1,\n                                             abs(log_obsexp_diff_dTAG_DMSO) < diffCutoff ~ 0,\n                                             log_obsexp_diff_dTAG_DMSO <= diffCutoff ~ -1,\n                                             TRUE ~ NA ),\n                isdiff_A485_DMSO = case_when(log_obsexp_diff_A485_DMSO >= diffCutoff ~ 1,\n                                             abs(log_obsexp_diff_A485_DMSO) < diffCutoff ~ 0,\n                                             log_obsexp_diff_A485_DMSO <= diffCutoff ~ -1,\n                                             TRUE ~ NA))%>%\n  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)\n\n\n\ndata_matrix <- dataToPlot %>% column_to_rownames(var = \\id\\)%>% as.matrix()\ncol_fun <- colorRamp2(c(-1, 0, 1), c(\\blue\\, \\grey\\, \\red\\))\nh1 <- Heatmap(data_matrix, name = \\loop score\\,\n        cluster_columns = FALSE,\n        cluster_rows = FALSE,\n        row_km = 9,\n        show_row_dend = FALSE,\n        border = FALSE,\n        show_row_names = FALSE,\n        col = col_fun)\n\nfileName <- here(figDir, paste0(\\heatmap_checkingDeltaAcrossCondition_reg_OE\\))\npng(paste0(fileName, \\.png\\), res = 600, units = \\in\\, width = 2, height = 10)\nprint(h1)\ndev.off()\n# \n# set.seed(123)\n# \n# hm_drawn <- draw(h1)\n# row_clusters <- row_order(hm_drawn)\n# \n# loop.cluster1 <- temp[row_clusters[[1]]]\n# loop.cluster2 <- temp[row_clusters[[2]]]\n# loop.cluster3 <- temp[row_clusters[[3]]]\n# loop.cluster4 <- temp[row_clusters[[4]]]\n# loop.cluster5 <- temp[row_clusters[[5]]]\n# loop.cluster6 <- temp[row_clusters[[6]]]\n# loop.cluster7 <- temp[row_clusters[[7]]]\n# loop.cluster8 <- temp[row_clusters[[8]]]\n# loop.cluster9 <- temp[row_clusters[[9]]]\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBIZWF0bWFwXG5saWJyYXJ5KGNpcmNsaXplKVxuXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcbiMgSGVhdG1hcCAyXG5zZXQuc2VlZCgxMjMpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbmRpZmZDdXRvZmYgPC0gMC41XG5vYnNleHAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9jb25zX29ic2V4cC50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0RNU08pKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZFRBRyA9IGlmX2Vsc2Uob2JzZXhwX2RUQUcgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX2RUQUcpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfQTQ4NSA9IGlmX2Vsc2Uob2JzZXhwX0E0ODUgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0E0ODUpKSlcblxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGFUb1Bsb3QgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcXGlkXFwpKSAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08gPSBsb2dfb2JzZXhwX2RUQUcgLSBsb2dfb2JzZXhwX0RNU08sXG4gICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA9IGxvZ19vYnNleHBfQTQ4NSAtIGxvZ19vYnNleHBfRE1TTyxcbiAgICAgICAgICAgICAgICBpc2RpZmZfZFRBR19ETVNPID0gY2FzZV93aGVuKGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08gPj0gZGlmZkN1dG9mZiB+IDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhYnMobG9nX29ic2V4cF9kaWZmX2RUQUdfRE1TTykgPCBkaWZmQ3V0b2ZmIH4gMCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08gPD0gZGlmZkN1dG9mZiB+IC0xLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BICksXG4gICAgICAgICAgICAgICAgaXNkaWZmX0E0ODVfRE1TTyA9IGNhc2Vfd2hlbihsb2dfb2JzZXhwX2RpZmZfQTQ4NV9ETVNPID49IGRpZmZDdXRvZmYgfiAxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWJzKGxvZ19vYnNleHBfZGlmZl9BNDg1X0RNU08pIDwgZGlmZkN1dG9mZiB+IDAsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX2RpZmZfQTQ4NV9ETVNPIDw9IGRpZmZDdXRvZmYgfiAtMSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIGlzZGlmZl9kVEFHX0RNU08sIGlzZGlmZl9BNDg1X0RNU08pXG5cblxuXG5kYXRhX21hdHJpeCA8LSBkYXRhVG9QbG90ICU+JSBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFxpZFxcKSU+JSBhcy5tYXRyaXgoKVxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoLTEsIDAsIDEpLCBjKFxcYmx1ZVxcLCBcXGdyZXlcXCwgXFxyZWRcXCkpXG5oMSA8LSBIZWF0bWFwKGRhdGFfbWF0cml4LCBuYW1lID0gXFxsb29wIHNjb3JlXFwsXG4gICAgICAgIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLFxuICAgICAgICBjbHVzdGVyX3Jvd3MgPSBGQUxTRSxcbiAgICAgICAgcm93X2ttID0gOSxcbiAgICAgICAgc2hvd19yb3dfZGVuZCA9IEZBTFNFLFxuICAgICAgICBib3JkZXIgPSBGQUxTRSxcbiAgICAgICAgc2hvd19yb3dfbmFtZXMgPSBGQUxTRSxcbiAgICAgICAgY29sID0gY29sX2Z1bilcblxuZmlsZU5hbWUgPC0gaGVyZShmaWdEaXIsIHBhc3RlMChcXGhlYXRtYXBfY2hlY2tpbmdEZWx0YUFjcm9zc0NvbmRpdGlvbl9yZWdfT0VcXCkpXG5wbmcocGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCksIHJlcyA9IDYwMCwgdW5pdHMgPSBcXGluXFwsIHdpZHRoID0gMiwgaGVpZ2h0ID0gMTApXG5wcmludChoMSlcbmRldi5vZmYoKVxuIyBcbiMgc2V0LnNlZWQoMTIzKVxuIyBcbiMgaG1fZHJhd24gPC0gZHJhdyhoMSlcbiMgcm93X2NsdXN0ZXJzIDwtIHJvd19vcmRlcihobV9kcmF3bilcbiMgXG4jIGxvb3AuY2x1c3RlcjEgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzFdXV1cbiMgbG9vcC5jbHVzdGVyMiA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbMl1dXVxuIyBsb29wLmNsdXN0ZXIzIDwtIHRlbXBbcm93X2NsdXN0ZXJzW1szXV1dXG4jIGxvb3AuY2x1c3RlcjQgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzRdXV1cbiMgbG9vcC5jbHVzdGVyNSA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbNV1dXVxuIyBsb29wLmNsdXN0ZXI2IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s2XV1dXG4jIGxvb3AuY2x1c3RlcjcgPC0gdGVtcFtyb3dfY2x1c3RlcnNbWzddXV1cbiMgbG9vcC5jbHVzdGVyOCA8LSB0ZW1wW3Jvd19jbHVzdGVyc1tbOF1dXVxuIyBsb29wLmNsdXN0ZXI5IDwtIHRlbXBbcm93X2NsdXN0ZXJzW1s5XV1dXG5cbmBgYFxuYGBgIn0= -->

```r
```r
# Heatmap
library(circlize)

name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))
# Heatmap 2
set.seed(123)

# Import obs/exp scores and merge to the dataset
minValue <- -4
diffCutoff <- 0.5
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))


# Merge dataset
dataToPlot <- data %>% dplyr::left_join(obsexp, by = c(\id\)) %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\)) %>%
  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO,
                isdiff_dTAG_DMSO = case_when(log_obsexp_diff_dTAG_DMSO >= diffCutoff ~ 1,
                                             abs(log_obsexp_diff_dTAG_DMSO) < diffCutoff ~ 0,
                                             log_obsexp_diff_dTAG_DMSO <= diffCutoff ~ -1,
                                             TRUE ~ NA ),
                isdiff_A485_DMSO = case_when(log_obsexp_diff_A485_DMSO >= diffCutoff ~ 1,
                                             abs(log_obsexp_diff_A485_DMSO) < diffCutoff ~ 0,
                                             log_obsexp_diff_A485_DMSO <= diffCutoff ~ -1,
                                             TRUE ~ NA))%>%
  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)



data_matrix <- dataToPlot %>% column_to_rownames(var = \id\)%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c(\blue\, \grey\, \red\))
h1 <- Heatmap(data_matrix, name = \loop score\,
        cluster_columns = FALSE,
        cluster_rows = FALSE,
        row_km = 9,
        show_row_dend = FALSE,
        border = FALSE,
        show_row_names = FALSE,
        col = col_fun)

fileName <- here(figDir, paste0(\heatmap_checkingDeltaAcrossCondition_reg_OE\))
png(paste0(fileName, \.png\), res = 600, units = \in\, width = 2, height = 10)
print(h1)
dev.off()
# 
# set.seed(123)
# 
# hm_drawn <- draw(h1)
# row_clusters <- row_order(hm_drawn)
# 
# loop.cluster1 <- temp[row_clusters[[1]]]
# loop.cluster2 <- temp[row_clusters[[2]]]
# loop.cluster3 <- temp[row_clusters[[3]]]
# loop.cluster4 <- temp[row_clusters[[4]]]
# loop.cluster5 <- temp[row_clusters[[5]]]
# loop.cluster6 <- temp[row_clusters[[6]]]
# loop.cluster7 <- temp[row_clusters[[7]]]
# loop.cluster8 <- temp[row_clusters[[8]]]
# loop.cluster9 <- temp[row_clusters[[9]]]

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### All loops _OE

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubWFyZ2luRXJyb3IgPC0gZnVuY3Rpb24obXlMaXN0KSB7XG4gIHNhbXBsZS5uID0gbGVuZ3RoKG15TGlzdClcbiAgc2FtcGxlLnNkID0gc2QobXlMaXN0KVxuICBzYW1wbGUuc2UgPSBzYW1wbGUuc2Qvc3FydChzYW1wbGUubilcbiAgYWxwaGEgPSAwLjA1XG4gIGRlZ3JlZXMuZnJlZWRvbSA9IHNhbXBsZS5uIC0gMVxuICB0LnNjb3JlID0gcXQocCA9IGFscGhhLzIsIGRmID0gZGVncmVlcy5mcmVlZG9tLCBsb3dlci50YWlsID0gRilcbiAgbWFyZ2luLmVycm9yID0gdC5zY29yZSpzYW1wbGUuc2VcbiAgcmV0dXJuKG1hcmdpbi5lcnJvcilcbn1cblxuUFJPc2VxLmJvYmJpZSA8LSBhc190aWJibGUoZnJlYWQoaGVyZShyZWZEaXIsIFwiYm9iYmllX2dlbmVfY2xhc3NpZmljYXRpb24uY3N2XCIpKSlcblxuZ2VuZUxpc3QuRXBpLmRUQUcudXAgPC0gKGZyZWFkKGhlcmUocmVmRGlyLCBcImRpZmZfRzEuZFRBR19HMS5FcGkuZFRBR192c19HMS5FcGkuRE1TTy50c3ZcIikpICU+JSBkcGx5cjo6ZmlsdGVyKHBhZGogPCAwLjA1LCBsb2cyRm9sZENoYW5nZSA+IDApKSRlbnNlbWJsX2dlbmVfaWRcblxuZ2VuZUxpc3QuRXBpLmRUQUcuZG93biA8LSAoZnJlYWQoaGVyZShyZWZEaXIsIFwiZGlmZl9HMS5kVEFHX0cxLkVwaS5kVEFHX3ZzX0cxLkVwaS5ETVNPLnRzdlwiKSkgJT4lIGRwbHlyOjpmaWx0ZXIocGFkaiA8IDAuMDUsIGxvZzJGb2xkQ2hhbmdlIDwgMCkpJGVuc2VtYmxfZ2VuZV9pZFxuXG4jIyBDb252ZXJ0aW5nIHRyYW5zY3JpcHQgSUQgdG8gZ2VuZSBJRFxuaWRQYWlyX3RnIDwtIGdldEJNKGF0dHJpYnV0ZXMgPSBjKFwiZW5zZW1ibF90cmFuc2NyaXB0X2lkXCIsIFwiZW5zZW1ibF9nZW5lX2lkXCIpLFxuICAgICAgICAgICAgICAgICBmaWx0ZXJzID0gXCJlbnNlbWJsX3RyYW5zY3JpcHRfaWRcIixcbiAgICAgICAgICAgICAgICAgdmFsdWVzID0gUFJPc2VxLmJvYmJpZSRlbnN0LFxuICAgICAgICAgICAgICAgICBtYXJ0ID0gZW5zZW1ibC52MTAyKVxuUFJPc2VxLmJvYmJpZSA8LSBQUk9zZXEuYm9iYmllICU+JSBkcGx5cjo6bGVmdF9qb2luKGlkUGFpcl90ZywgYnkgPSBjKFwiZW5zdFwiID0gXCJlbnNlbWJsX3RyYW5zY3JpcHRfaWRcIikpXG5cbiMjIEJhciBQbG90XG50ZW1wIDwtIFBST3NlcS5ib2JiaWUgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibF9nZW5lX2lkICVpbiUgZ2VuZUxpc3QuRXBpLmRUQUcuZG93bilcblxuZ3JvdXAgPC0gYyhyZXAoXCJFcGlMQ19kVEFHdnNETVNPX0RPV05cIiwgNCkpXG5jbHVzdGVyIDwtIHJlcChjKFwiRWFybHlcIiwgXCJNaWRkbGVcIiwgXCJMYXRlXCIsIFwiVHJhbnNpZW50XCIpLCAxKVxuY2x1c3RlciA8LSBmYWN0b3IoY2x1c3RlciwgbGV2ZWxzID0gYyhcIkVhcmx5XCIsIFwiTWlkZGxlXCIsIFwiTGF0ZVwiLCBcIlRyYW5zaWVudFwiKSlcbnZhbHVlIDwtIGMoc3VtKHRlbXAkQ2x1c3RlciA9PSBcIkVhcmx5XCIpLFxuICAgICAgICAgICBzdW0odGVtcCRDbHVzdGVyID09IFwiTWlkZGxlXCIpLFxuICAgICAgICAgICBzdW0odGVtcCRDbHVzdGVyID09IFwiTGF0ZVwiKSxcbiAgICAgICAgICAgc3VtKHRlbXAkQ2x1c3RlciA9PSBcIlRyYW5zaWVudFwiKSlcbmRhdGEgPC0gZGF0YS5mcmFtZShncm91cCwgY2x1c3RlciwgdmFsdWUpXG5nZ3Bsb3QoZGF0YSwgYWVzKGZpbGw9Y2x1c3RlciwgeT12YWx1ZSwgeD1ncm91cCkpICsgXG4gICAgZ2VvbV9iYXIocG9zaXRpb249XCJmaWxsXCIsIHN0YXQ9XCJpZGVudGl0eVwiKSArIHRoZW1lX2NsYXNzaWMoKVxuXG4jIyBMaW5lIHBsb3RcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OnNlbGVjdChjKDQsIDUsIDYsIDcsIDgsIDkpKVxudGVtcC50YWxsID0gdGVtcCAlPiUgcGl2b3RfbG9uZ2VyKC1jKDEsIDIpLCBuYW1lc190byA9IFwidGltZXBvaW50c1wiLCB2YWx1ZXNfdG8gPSBcInZhbHVlXCIpXG5cbmdnMSA9IGdncGxvdCh0ZW1wLnRhbGwsXG4gICAgICAgYWVzKCB4ID0gZmFjdG9yKHRpbWVwb2ludHMsIGxldmVsID0gYyhcIk1JVFwiLCBcIkVHMVwiLCBcIkxHMVwiLCBcIkFTWU5cIikpLFxuICAgICAgICAgICAgeSA9IHZhbHVlLFxuICAgICAgICAgICAgZ3JvdXAgPSBlbnN0LCBjb2wgPSBlbnN0KSkgK1xuICBnZW9tX2xpbmUoKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdndGl0bGUoXCJCb2JiaWUsIFBSTy1zZXFcIiwgc3VidGl0bGUgPSBcInNlbGVjdGVkIGdlbmVzXCIpICtcbiAgeGxhYiAoXCJ0aW1lcG9pbnRzXCIpICsgeWxhYihcInZhbHVlXCIpICtcbiAgdGhlbWUocGxvdC50aXRsZSA9IGVsZW1lbnRfdGV4dChoanVzdCA9IDAuNSksXG4gICAgICAgIHBsb3Quc3VidGl0bGUgPSBlbGVtZW50X3RleHQoaGp1c3QgPSAwLjUpLFxuICAgICAgICBsZWdlbmQucG9zaXRpb24gPSBcIm5vbmVcIixcbiAgICAgICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoYW5nbGUgPSA5MCwgdmp1c3QgPSAwLjUsIGhqdXN0ID0gMSkpXG5cbmdnc2F2ZShmaWxlbmFtZSA9IGhlcmUoZmlnRGlyLCBcImJvYmJpZV9nZW5lX0VwaUxDX2RUQUd2c0RNU09fRE9XTi5wbmdcIiksIGdnMSwgd2lkdGggPSA0LCBoZWlnaHQgPSA0LCBkcGkgPSAzMDAsIHVuaXRzID0gXCJpblwiLCBkZXZpY2UgPSBcInBuZ1wiKVxuXG5cbiMgRFJBVyBSSUJCT05cblxuXG50ZW1wLnJpYmJvbiA9IHRpYmJsZShcInRpbWVwb2ludHNcIiA9IGMoXCJNSVRcIiwgXCJFRzFcIiwgXCJMRzFcIiwgXCJBU1lOXCIpLFxuICAgICAgICAgICAgICAgICAgICAgIFwidmFsdWVcIiA9IGMobWVhbih0ZW1wJE1JVCksIG1lYW4odGVtcCRFRzEpLCBtZWFuKHRlbXAkTEcxKSwgbWVhbih0ZW1wJEFTWU4pKSxcbiAgICAgICAgICAgICAgICAgICAgICBcImxvd2VyXCIgPSBjKG1lYW4odGVtcCRNSVQpIC0gbWFyZ2luRXJyb3IodGVtcCRNSVQpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBtZWFuKHRlbXAkRUcxKSAtIG1hcmdpbkVycm9yKHRlbXAkRUcxKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbWVhbih0ZW1wJExHMSkgLSBtYXJnaW5FcnJvcih0ZW1wJExHMSksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG1lYW4odGVtcCRBU1lOKSAtIG1hcmdpbkVycm9yKHRlbXAkQVNZTikpLFxuICAgICAgICAgICAgICAgICAgICAgIFwidXBwZXJcIiA9IGMobWVhbih0ZW1wJE1JVCkgKyBtYXJnaW5FcnJvcih0ZW1wJE1JVCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG1lYW4odGVtcCRFRzEpICsgbWFyZ2luRXJyb3IodGVtcCRFRzEpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBtZWFuKHRlbXAkTEcxKSArIG1hcmdpbkVycm9yKHRlbXAkTEcxKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbWVhbih0ZW1wJEFTWU4pICsgbWFyZ2luRXJyb3IodGVtcCRBU1lOKSkpXG5nZzEgPSBnZ3Bsb3QodGVtcC5yaWJib24sIGFlcyh4ID0gZmFjdG9yKHRpbWVwb2ludHMsIGxldmVsID0gYyhcIk1JVFwiLCBcIkVHMVwiLCBcIkxHMVwiLCBcIkFTWU5cIikpLCBcbiAgICAgICAgICAgICAgICAgICAgICAgIHkgPSB2YWx1ZSwgZ3JvdXAgPSAxKSkgK1xuICBnZW9tX2xpbmUoY29sb3IgPSBcImJsYWNrXCIpICtcbiAgZ2VvbV9yaWJib24oYWVzKHltaW4gPSBsb3dlciwgeW1heCA9IHVwcGVyKSwgZmlsbCA9IFwiZ3JleTcwXCIsIGFscGhhID0gMC4zKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdndGl0bGUoXCJCb2JiaWUsIFBSTy1zZXFcIiwgc3VidGl0bGUgPSBcInNlbGVjdGVkIGdlbmVzXCIpICtcbiAgeGxhYiAoXCJ0aW1lcG9pbnRzXCIpICsgeWxhYihcInZhbHVlXCIpICsgeWxpbSgwLCA2NSkgK1xuICB0aGVtZShwbG90LnRpdGxlID0gZWxlbWVudF90ZXh0KGhqdXN0ID0gMC41KSxcbiAgICAgICAgcGxvdC5zdWJ0aXRsZSA9IGVsZW1lbnRfdGV4dChoanVzdCA9IDAuNSksXG4gICAgICAgIGxlZ2VuZC5wb3NpdGlvbiA9IFwibm9uZVwiLFxuICAgICAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChhbmdsZSA9IDkwLCB2anVzdCA9IDAuNSwgaGp1c3QgPSAxKSlcblxuZ2dzYXZlKGZpbGVuYW1lID0gaGVyZShmaWdEaXIsIFwiYm9iYmllX2dlbmVfRXBpTENfZFRBR3ZzRE1TT19ET1dOXzk1Q0kucG5nXCIpLCBnZzEsIHdpZHRoID0gNCwgaGVpZ2h0ID0gNCwgZHBpID0gMzAwLCB1bml0cyA9IFwiaW5cIiwgZGV2aWNlID0gXCJwbmdcIilcblxuXG5gYGAifQ== -->\n\n```r\nmarginError <- function(myList) {\n  sample.n = length(myList)\n  sample.sd = sd(myList)\n  sample.se = sample.sd/sqrt(sample.n)\n  alpha = 0.05\n  degrees.freedom = sample.n - 1\n  t.score = qt(p = alpha/2, df = degrees.freedom, lower.tail = F)\n  margin.error = t.score*sample.se\n  return(margin.error)\n}\n\nPROseq.bobbie <- as_tibble(fread(here(refDir, \\bobbie_gene_classification.csv\\)))\n\ngeneList.Epi.dTAG.up <- (fread(here(refDir, \\diff_G1.dTAG_G1.Epi.dTAG_vs_G1.Epi.DMSO.tsv\\)) %>% dplyr::filter(padj < 0.05, log2FoldChange > 0))$ensembl_gene_id\n\ngeneList.Epi.dTAG.down <- (fread(here(refDir, \\diff_G1.dTAG_G1.Epi.dTAG_vs_G1.Epi.DMSO.tsv\\)) %>% dplyr::filter(padj < 0.05, log2FoldChange < 0))$ensembl_gene_id\n\n## Converting transcript ID to gene ID\nidPair_tg <- getBM(attributes = c(\\ensembl_transcript_id\\, \\ensembl_gene_id\\),\n                 filters = \\ensembl_transcript_id\\,\n                 values = PROseq.bobbie$enst,\n                 mart = ensembl.v102)\nPROseq.bobbie <- PROseq.bobbie %>% dplyr::left_join(idPair_tg, by = c(\\enst\\ = \\ensembl_transcript_id\\))\n\n## Bar Plot\ntemp <- PROseq.bobbie %>% dplyr::filter(ensembl_gene_id %in% geneList.Epi.dTAG.down)\n\ngroup <- c(rep(\\EpiLC_dTAGvsDMSO_DOWN\\, 4))\ncluster <- rep(c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\), 1)\ncluster <- factor(cluster, levels = c(\\Early\\, \\Middle\\, \\Late\\, \\Transient\\))\nvalue <- c(sum(temp$Cluster == \\Early\\),\n           sum(temp$Cluster == \\Middle\\),\n           sum(temp$Cluster == \\Late\\),\n           sum(temp$Cluster == \\Transient\\))\ndata <- data.frame(group, cluster, value)\nggplot(data, aes(fill=cluster, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n## Line plot\ntemp <- temp %>% dplyr::select(c(4, 5, 6, 7, 8, 9))\ntemp.tall = temp %>% pivot_longer(-c(1, 2), names_to = \\timepoints\\, values_to = \\value\\)\n\ngg1 = ggplot(temp.tall,\n       aes( x = factor(timepoints, level = c(\\MIT\\, \\EG1\\, \\LG1\\, \\ASYN\\)),\n            y = value,\n            group = enst, col = enst)) +\n  geom_line() +\n  theme_classic() +\n  ggtitle(\\Bobbie\n"} -->
marginError <- function(myList) {
  sample.n = length(myList)
  sample.sd = sd(myList)
  sample.se = sample.sd/sqrt(sample.n)
  alpha = 0.05
  degrees.freedom = sample.n - 1
  t.score = qt(p = alpha/2, df = degrees.freedom, lower.tail = F)
  margin.error = t.score*sample.se
  return(margin.error)
}

PROseq.bobbie <- as_tibble(fread(here(refDir, \bobbie_gene_classification.csv\)))

geneList.Epi.dTAG.up <- (fread(here(refDir, \diff_G1.dTAG_G1.Epi.dTAG_vs_G1.Epi.DMSO.tsv\)) %>% dplyr::filter(padj < 0.05, log2FoldChange > 0))$ensembl_gene_id

geneList.Epi.dTAG.down <- (fread(here(refDir, \diff_G1.dTAG_G1.Epi.dTAG_vs_G1.Epi.DMSO.tsv\)) %>% dplyr::filter(padj < 0.05, log2FoldChange < 0))$ensembl_gene_id

## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c(\ensembl_transcript_id\, \ensembl_gene_id\),
                 filters = \ensembl_transcript_id\,
                 values = PROseq.bobbie$enst,
                 mart = ensembl.v102)
PROseq.bobbie <- PROseq.bobbie %>% dplyr::left_join(idPair_tg, by = c(\enst\ = \ensembl_transcript_id\))

## Bar Plot
temp <- PROseq.bobbie %>% dplyr::filter(ensembl_gene_id %in% geneList.Epi.dTAG.down)

group <- c(rep(\EpiLC_dTAGvsDMSO_DOWN\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 1)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(sum(temp$Cluster == \Early\),
           sum(temp$Cluster == \Middle\),
           sum(temp$Cluster == \Late\),
           sum(temp$Cluster == \Transient\))
data <- data.frame(group, cluster, value)
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()

## Line plot
temp <- temp %>% dplyr::select(c(4, 5, 6, 7, 8, 9))
temp.tall = temp %>% pivot_longer(-c(1, 2), names_to = \timepoints\, values_to = \value\)

gg1 = ggplot(temp.tall,
       aes( x = factor(timepoints, level = c(\MIT\, \EG1\, \LG1\, \ASYN\)),
            y = value,
            group = enst, col = enst)) +
  geom_line() +
  theme_classic() +
  ggtitle(\Bobbie
```r
marginError <- function(myList) {
  sample.n = length(myList)
  sample.sd = sd(myList)
  sample.se = sample.sd/sqrt(sample.n)
  alpha = 0.05
  degrees.freedom = sample.n - 1
  t.score = qt(p = alpha/2, df = degrees.freedom, lower.tail = F)
  margin.error = t.score*sample.se
  return(margin.error)
}

PROseq.bobbie <- as_tibble(fread(here(refDir, \bobbie_gene_classification.csv\)))

geneList.Epi.dTAG.up <- (fread(here(refDir, \diff_G1.dTAG_G1.Epi.dTAG_vs_G1.Epi.DMSO.tsv\)) %>% dplyr::filter(padj < 0.05, log2FoldChange > 0))$ensembl_gene_id

geneList.Epi.dTAG.down <- (fread(here(refDir, \diff_G1.dTAG_G1.Epi.dTAG_vs_G1.Epi.DMSO.tsv\)) %>% dplyr::filter(padj < 0.05, log2FoldChange < 0))$ensembl_gene_id

## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c(\ensembl_transcript_id\, \ensembl_gene_id\),
                 filters = \ensembl_transcript_id\,
                 values = PROseq.bobbie$enst,
                 mart = ensembl.v102)
PROseq.bobbie <- PROseq.bobbie %>% dplyr::left_join(idPair_tg, by = c(\enst\ = \ensembl_transcript_id\))

## Bar Plot
temp <- PROseq.bobbie %>% dplyr::filter(ensembl_gene_id %in% geneList.Epi.dTAG.down)

group <- c(rep(\EpiLC_dTAGvsDMSO_DOWN\, 4))
cluster <- rep(c(\Early\, \Middle\, \Late\, \Transient\), 1)
cluster <- factor(cluster, levels = c(\Early\, \Middle\, \Late\, \Transient\))
value <- c(sum(temp$Cluster == \Early\),
           sum(temp$Cluster == \Middle\),
           sum(temp$Cluster == \Late\),
           sum(temp$Cluster == \Transient\))
data <- data.frame(group, cluster, value)
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()

## Line plot
temp <- temp %>% dplyr::select(c(4, 5, 6, 7, 8, 9))
temp.tall = temp %>% pivot_longer(-c(1, 2), names_to = \timepoints\, values_to = \value\)

gg1 = ggplot(temp.tall,
       aes( x = factor(timepoints, level = c(\MIT\, \EG1\, \LG1\, \ASYN\)),
            y = value,
            group = enst, col = enst)) +
  geom_line() +
  theme_classic() +
  ggtitle(\Bobbie
Reg loops _OE

<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcIitcIiwgVjIsIFYzKSwgZW5zZW1ibCA9IFY2LCBjaHIgPSBWMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibCwgY2hyLCBUU1MpXG5cbmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlwiKSkkZ2VuZVxuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XCIpKSRnZW5lXG5cblxuZ2VuZS50YiA8LSBnZW5lLnRiICU+JSBkcGx5cjo6ZmlsdGVyKGVuc2VtYmwgJWluJSBjKGdyb3VwMSwgZ3JvdXAyKSlcbmdlbmVzLmdyIDwtIEdSYW5nZXMoXG4gIHNlcW5hbWVzID0gZ2VuZS50YiRjaHIsXG4gIHJhbmdlcyA9IElSYW5nZXMoc3RhcnQgPSBnZW5lLnRiJFRTUywgZW5kID0gZ2VuZS50YiRUU1MpLFxuICBlbnNlbWJsID0gZ2VuZS50YiRlbnNlbWJsXG4pXG5cbmdlbmVib2R5LnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcIm1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFwiKSkgJT4lIGRwbHlyOjpzZWxlY3QoVjEsIFYyLCBWMylcbmNvbG5hbWVzKGdlbmVib2R5LnRiKSA8LSBjKFwiY2hyXCIsIFwic3RhcnRcIiwgXCJlbmRcIilcbmdlbmVib2R5LmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShnZW5lYm9keS50YilcblxuXG5wZWFrLkgzSzI3YWMgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXCJHU00yNDM4NDc2X0VDLURHLTM0NTgtSDNLMjdBQ19BU1lOXzEubmFycm93UGVhay5iZWRcIikpXG5wZWFrLkgzSzI3YWM8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZnJlYWQoaGVyZShyZWZEaXIsIFwiR1NNMjQzODQ3Nl9FQy1ERy0zNDU4LUgzSzI3QUNfQVNZTl8xLm5hcnJvd1BlYWsuYmVkXCIpKSAlPiUgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkcGx5cjo6bXV0YXRlKGNociA9IFYxLCBzdGFydCA9IChWMiArIFYzKS8yLCBlbmQgPSAoVjIgKyBWMykvMikgJT4lXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkcGx5cjo6c2VsZWN0KGNociwgc3RhcnQsIGVuZCkpXG5cbiMjIyMjIyMgRmlsdGVyaW5nIG91dCBwZWFrcyBvdmVybGFwcGluZyB3aXRoIHRoZSBnZW5lIGJvZHlcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhnZW5lYm9keS5nciwgcGVhay5IM0syN2FjKVxuXG4jIEluZGljZXMgb2YgcGVha3MgdGhhdCBvdmVybGFwIHRoZSBUU1Ncbm92ZXJsYXBwaW5nX3BlYWtfaW5kaWNlcyA8LSB1bmlxdWUoc3ViamVjdEhpdHMob3ZlcmxhcHMpKVxuXG4jIEV4Y2x1ZGUgb3ZlcmxhcHBpbmcgcGVha3Ncbm5vbl9vdmVybGFwcGluZ19wZWFrcyA8LSBwZWFrLkgzSzI3YWNbLW92ZXJsYXBwaW5nX3BlYWtfaW5kaWNlc11cblxuXG4jIyMjIyMjIENhbGN1bGF0aW5nIGRpc3RhbmNlIHRvIG5lYXJlc3QgcGVha1xubmVhcmVzdF9wZWFrX2luZGljZXMgPC0gbmVhcmVzdChnZW5lcy5nciwgbm9uX292ZXJsYXBwaW5nX3BlYWtzKVxubmVhcmVzdF9wZWFrcyA8LSBub25fb3ZlcmxhcHBpbmdfcGVha3NbbmVhcmVzdF9wZWFrX2luZGljZXNdXG5kaXN0YW5jZXMgPC0gZGlzdGFuY2UoZ2VuZXMuZ3IsIG5lYXJlc3RfcGVha3MpXG5cblxucmVzdWx0cyA8LSBkYXRhLmZyYW1lKFxuICBlbnNlbWJsID0gbWNvbHMoZ2VuZXMuZ3IpJGVuc2VtYmwsXG4gIGdlbmVfY2hyID0gYXMuY2hhcmFjdGVyKHNlcW5hbWVzKGdlbmVzLmdyKSksXG4gIGdlbmVfVFNTID0gc3RhcnQoZ2VuZXMuZ3IpLFxuICBwZWFrX2NociA9IGFzLmNoYXJhY3RlcihzZXFuYW1lcyhuZWFyZXN0X3BlYWtzKSksXG4gIHBlYWtfc3RhcnQgPSBzdGFydChuZWFyZXN0X3BlYWtzKSxcbiAgcGVha19lbmQgPSBlbmQobmVhcmVzdF9wZWFrcyksXG4gIGRpc3RhbmNlID0gZGlzdGFuY2VzXG4pXG5cbnJlc3VsdHMgPC0gcmVzdWx0cyAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihlbnNlbWJsICVpbiUgZ3JvdXAxIH4gXCJncm91cDFcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZW5zZW1ibCAlaW4lIGdyb3VwMiB+IFwiZ3JvdXAyXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpXG5cbmdncGxvdChyZXN1bHRzLCBhZXMoeCA9IGdyb3VwLCB5ID0gZGlzdGFuY2UsIGZpbGwgPSBncm91cCkpICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdChvdXRsaWVyLnNoYXBlID0gTkEsIHdpZHRoID0gMC4xLCBmaWxsID0gXCJ3aGl0ZVwiKSArIHRoZW1lX2J3KCkgKyBnZ3RpdGxlKFwiZGlzdGFuY2UgdG8gbmVhcmVzdCBIM0syN2FjIHBlYWsgZXhjbHVkaW5nIGdlbmUgYm9keVwiKSArIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgKyBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgMjUwKjEwMDApKVxuXG4gIFxuYGBgIn0= -->

```r
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS)

group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.tb <- gene.tb %>% dplyr::filter(ensembl %in% c(group1, group2))
genes.gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),
  ensembl = gene.tb$ensembl
)

genebody.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(genebody.tb) <- c(\chr\, \start\, \end\)
genebody.gr <- makeGRangesFromDataFrame(genebody.tb)


peak.H3K27ac <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
peak.H3K27ac<- makeGRangesFromDataFrame(fread(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\)) %>% 
                                          dplyr::mutate(chr = V1, start = (V2 + V3)/2, end = (V2 + V3)/2) %>%
                                          dplyr::select(chr, start, end))

####### Filtering out peaks overlapping with the gene body
overlaps <- findOverlaps(genebody.gr, peak.H3K27ac)

# Indices of peaks that overlap the TSS
overlapping_peak_indices <- unique(subjectHits(overlaps))

# Exclude overlapping peaks
non_overlapping_peaks <- peak.H3K27ac[-overlapping_peak_indices]


####### Calculating distance to nearest peak
nearest_peak_indices <- nearest(genes.gr, non_overlapping_peaks)
nearest_peaks <- non_overlapping_peaks[nearest_peak_indices]
distances <- distance(genes.gr, nearest_peaks)


results <- data.frame(
  ensembl = mcols(genes.gr)$ensembl,
  gene_chr = as.character(seqnames(genes.gr)),
  gene_TSS = start(genes.gr),
  peak_chr = as.character(seqnames(nearest_peaks)),
  peak_start = start(nearest_peaks),
  peak_end = end(nearest_peaks),
  distance = distances
)

results <- results %>% dplyr::mutate(group = case_when(ensembl %in% group1 ~ \group1\,
                                            ensembl %in% group2 ~ \group2\,
                                            TRUE ~ NA))

ggplot(results, aes(x = group, y = distance, fill = group)) + geom_violin() + geom_boxplot(outlier.shape = NA, width = 0.1, fill = \white\) + theme_bw() + ggtitle(\distance to nearest H3K27ac peak excluding gene body\) + scale_y_continuous(labels = label_kb_mb) + coord_cartesian(ylim = c(0, 250*1000))

  
```

<!-- rnb-source-end -->
```r
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS)

group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.tb <- gene.tb %>% dplyr::filter(ensembl %in% c(group1, group2))
genes.gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),
  ensembl = gene.tb$ensembl
)

genebody.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(genebody.tb) <- c(\chr\, \start\, \end\)
genebody.gr <- makeGRangesFromDataFrame(genebody.tb)


peak.H3K27ac <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
peak.H3K27ac<- makeGRangesFromDataFrame(fread(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\)) %>% 
                                          dplyr::mutate(chr = V1, start = (V2 + V3)/2, end = (V2 + V3)/2) %>%
                                          dplyr::select(chr, start, end))

####### Filtering out peaks overlapping with the gene body
overlaps <- findOverlaps(genebody.gr, peak.H3K27ac)

# Indices of peaks that overlap the TSS
overlapping_peak_indices <- unique(subjectHits(overlaps))

# Exclude overlapping peaks
non_overlapping_peaks <- peak.H3K27ac[-overlapping_peak_indices]


####### Calculating distance to nearest peak
nearest_peak_indices <- nearest(genes.gr, non_overlapping_peaks)
nearest_peaks <- non_overlapping_peaks[nearest_peak_indices]
distances <- distance(genes.gr, nearest_peaks)


results <- data.frame(
  ensembl = mcols(genes.gr)$ensembl,
  gene_chr = as.character(seqnames(genes.gr)),
  gene_TSS = start(genes.gr),
  peak_chr = as.character(seqnames(nearest_peaks)),
  peak_start = start(nearest_peaks),
  peak_end = end(nearest_peaks),
  distance = distances
)

results <- results %>% dplyr::mutate(group = case_when(ensembl %in% group1 ~ \group1\,
                                            ensembl %in% group2 ~ \group2\,
                                            TRUE ~ NA))

ggplot(results, aes(x = group, y = distance, fill = group)) + geom_violin() + geom_boxplot(outlier.shape = NA, width = 0.1, fill = \white\) + theme_bw() + ggtitle(\distance to nearest H3K27ac peak excluding gene body\) + scale_y_continuous(labels = label_kb_mb) + coord_cartesian(ylim = c(0, 250*1000))

  

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

### [2.32] Comparing with Bobbie's data
Where does differentiated related genes fall into?

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XCIpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcIikpJGdlbmVcblxuXG5nZW5lLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcIm1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFwiK1wiLCBWMiwgVjMpLCBlbnNlbWJsID0gVjYsIGNociA9IFYxKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsLCBjaHIsIFRTUykgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGMoZ3JvdXAxLCBncm91cDIpKVxuZ2VuZXMuZ3IgPC0gR1JhbmdlcyhcbiAgc2VxbmFtZXMgPSBnZW5lLnRiJGNocixcbiAgcmFuZ2VzID0gSVJhbmdlcyhzdGFydCA9IGdlbmUudGIkVFNTLCBlbmQgPSBnZW5lLnRiJFRTUyksXG4gIGVuc2VtYmwgPSBnZW5lLnRiJGVuc2VtYmxcbilcblxuZ2VuZWJvZHkudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwibW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXCIpKSAlPiUgZHBseXI6OmZpbHRlcihWNiAlaW4lIGMoZ3JvdXAxLCBncm91cDIpKSU+JSBkcGx5cjo6c2VsZWN0KFYxLCBWMiwgVjMpXG5jb2xuYW1lcyhnZW5lYm9keS50YikgPC0gYyhcImNoclwiLCBcInN0YXJ0XCIsIFwiZW5kXCIpXG5nZW5lYm9keS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZWJvZHkudGIpXG5cblxuIyBTdGVwIDE6IEZpbmQgb3ZlcmxhcHMgYmV0d2VlbiBnZW5lIGJvZGllcyBhbmQgcGVha3Ncbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhnZW5lYm9keS5nciwgcGVhay5IM0syN2FjKVxuXG4jIENyZWF0ZSBhIGxpc3QgbWFwcGluZyBlYWNoIGdlbmUgdG8gdGhlIGluZGljZXMgb2YgcGVha3Mgb3ZlcmxhcHBpbmcgd2l0aCBpdHMgZ2VuZSBib2R5XG5vdmVybGFwcGluZ19wZWFrc19wZXJfZ2VuZSA8LSBzcGxpdChzdWJqZWN0SGl0cyhvdmVybGFwcyksIHF1ZXJ5SGl0cyhvdmVybGFwcykpXG5cbiMgSW5pdGlhbGl6ZSBhbiBlbXB0eSBsaXN0IHRvIHN0b3JlIHJlc3VsdHNcbnJlc3VsdHNfbGlzdCA8LSB2ZWN0b3IoXCJsaXN0XCIsIGxlbmd0aChnZW5lcy5ncikpXG5cbiMgU3RlcCAyOiBGb3IgZWFjaCBnZW5lLCBleGNsdWRlIG92ZXJsYXBwaW5nIHBlYWtzIGFuZCBmaW5kIHRoZSBuZWFyZXN0IHBlYWsgdG8gaXRzIFRTU1xuZm9yIChpIGluIHNlcV9hbG9uZyhnZW5lcy5ncikpIHtcbiAgZ2VuZSA8LSBnZW5lcy5ncltpXVxuICBcbiAgIyBHZXQgaW5kaWNlcyBvZiBwZWFrcyBvdmVybGFwcGluZyB3aXRoIHRoaXMgZ2VuZSdzIGJvZHlcbiAgb3ZlcmxhcHBpbmdfcGVha19pbmRpY2VzIDwtIG92ZXJsYXBwaW5nX3BlYWtzX3Blcl9nZW5lW1thcy5jaGFyYWN0ZXIoaSldXVxuICBcbiAgIyBFeGNsdWRlIG92ZXJsYXBwaW5nIHBlYWtzIGZvciB0aGlzIGdlbmVcbiAgaWYgKCFpcy5udWxsKG92ZXJsYXBwaW5nX3BlYWtfaW5kaWNlcykpIHtcbiAgICBwZWFrc190b19jb25zaWRlciA8LSBwZWFrLkgzSzI3YWNbLW92ZXJsYXBwaW5nX3BlYWtfaW5kaWNlc11cbiAgfSBlbHNlIHtcbiAgICBwZWFrc190b19jb25zaWRlciA8LSBwZWFrLkgzSzI3YWNcbiAgfVxuICBcbiAgIyBGaW5kIHRoZSBuZWFyZXN0IHBlYWsgdG8gdGhlIFRTUyBvZiB0aGlzIGdlbmVcbiAgbmVhcmVzdF9wZWFrX2luZGV4IDwtIG5lYXJlc3QoZ2VuZSwgcGVha3NfdG9fY29uc2lkZXIpXG4gIFxuICBpZiAoaXMubmEobmVhcmVzdF9wZWFrX2luZGV4KSkge1xuICAgICMgTm8gcGVha3MgZm91bmQ7IHNldCBOQSB2YWx1ZXNcbiAgICByZXN1bHRzX2xpc3RbW2ldXSA8LSBkYXRhLmZyYW1lKFxuICAgICAgZW5zZW1ibCA9IG1jb2xzKGdlbmUpJGVuc2VtYmwsXG4gICAgICBnZW5lX2NociA9IGFzLmNoYXJhY3RlcihzZXFuYW1lcyhnZW5lKSksXG4gICAgICBnZW5lX1RTUyA9IHN0YXJ0KGdlbmUpLFxuICAgICAgcGVha19jaHIgPSBOQSxcbiAgICAgIHBlYWtfc3RhcnQgPSBOQSxcbiAgICAgIHBlYWtfZW5kID0gTkEsXG4gICAgICBkaXN0YW5jZSA9IE5BXG4gICAgKVxuICB9IGVsc2Uge1xuICAgIG5lYXJlc3RfcGVhayA8LSBwZWFrc190b19jb25zaWRlcltuZWFyZXN0X3BlYWtfaW5kZXhdXG4gICAgZGlzdCA8LSBkaXN0YW5jZShnZW5lLCBuZWFyZXN0X3BlYWspXG4gICAgXG4gICAgcmVzdWx0c19saXN0W1tpXV0gPC0gZGF0YS5mcmFtZShcbiAgICAgIGVuc2VtYmwgPSBtY29scyhnZW5lKSRlbnNlbWJsLFxuICAgICAgZ2VuZV9jaHIgPSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMoZ2VuZSkpLFxuICAgICAgZ2VuZV9UU1MgPSBzdGFydChnZW5lKSxcbiAgICAgIHBlYWtfY2hyID0gYXMuY2hhcmFjdGVyKHNlcW5hbWVzKG5lYXJlc3RfcGVhaykpLFxuICAgICAgcGVha19zdGFydCA9IHN0YXJ0KG5lYXJlc3RfcGVhayksXG4gICAgICBwZWFrX2VuZCA9IGVuZChuZWFyZXN0X3BlYWspLFxuICAgICAgZGlzdGFuY2UgPSBkaXN0XG4gICAgKVxuICB9XG59XG5cbiMgQ29tYmluZSByZXN1bHRzIGludG8gYSBzaW5nbGUgZGF0YSBmcmFtZVxucmVzdWx0cyA8LSBkby5jYWxsKHJiaW5kLCByZXN1bHRzX2xpc3QpXG5cbiMgQWRkIGdyb3VwIGluZm9ybWF0aW9uXG5yZXN1bHRzIDwtIHJlc3VsdHMgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBjYXNlX3doZW4oXG4gIGVuc2VtYmwgJWluJSBncm91cDEgfiBcImdyb3VwMVwiLFxuICBlbnNlbWJsICVpbiUgZ3JvdXAyIH4gXCJncm91cDJcIixcbiAgVFJVRSB+IE5BX2NoYXJhY3Rlcl9cbikpXG5cbiMgUGxvdHRpbmdcbmdncGxvdChyZXN1bHRzLCBhZXMoeCA9IGdyb3VwLCB5ID0gZGlzdGFuY2UsIGZpbGwgPSBncm91cCkpICtcbiAgZ2VvbV92aW9saW4oKSArXG4gIGdlb21fYm94cGxvdChvdXRsaWVyLnNoYXBlID0gTkEsIHdpZHRoID0gMC4xLCBmaWxsID0gXCJ3aGl0ZVwiKSArXG4gIHRoZW1lX2J3KCkgK1xuICBnZ3RpdGxlKFwiRGlzdGFuY2UgdG8gTmVhcmVzdCBIM0syN2FjIFBlYWsgRXhjbHVkaW5nIEdlbmUgQm9keSBPdmVybGFwc1wiKSArXG4gIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgNTAgKiAxMDAwKSlcbmBgYCJ9 -->\n\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3), ensembl = V6, chr = V1) %>%\n  dplyr::select(ensembl, chr, TSS) %>% dplyr::filter(ensembl %in% c(group1, group2))\ngenes.gr <- GRanges(\n  seqnames = gene.tb$chr,\n  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),\n  ensembl = gene.tb$ensembl\n)\n\ngenebody.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>% dplyr::filter(V6 %in% c(group1, group2))%>% dplyr::select(V1, V2, V3)\ncolnames(genebody.tb) <- c(\\chr\\, \\start\\, \\end\\)\ngenebody.gr <- makeGRangesFromDataFrame(genebody.tb)\n\n\n# Step 1: Find overlaps between gene bodies and peaks\noverlaps <- findOverlaps(genebody.gr, peak.H3K27ac)\n\n# Create a list mapping each gene to the indices of peaks overlapping with its gene body\noverlapping_peaks_per_gene <- split(subjectHits(overlaps), queryHits(overlaps))\n\n# Initialize an empty list to store results\nresults_list <- vector(\\list\\, length(genes.gr))\n\n# Step 2: For each gene, exclude overlapping peaks and find the nearest peak to its TSS\nfor (i in seq_along(genes.gr)) {\n  gene <- genes.gr[i]\n  \n  # Get indices of peaks overlapping with this gene's body\n  overlapping_peak_indices <- overlapping_peaks_per_gene[[as.character(i)]]\n  \n  # Exclude overlapping peaks for this gene\n  if (!is.null(overlapping_peak_indices)) {\n    peaks_to_consider <- peak.H3K27ac[-overlapping_peak_indices]\n  } else {\n    peaks_to_consider <- peak.H3K27ac\n  }\n  \n  # Find the nearest peak to the TSS of this gene\n  nearest_peak_index <- nearest(gene, peaks_to_consider)\n  \n  if (is.na(nearest_peak_index)) {\n    # No peaks found; set NA values\n    results_list[[i]] <- data.frame(\n      ensembl = mcols(gene)$ensembl,\n      gene_chr = as.character(seqnames(gene)),\n      gene_TSS = start(gene),\n      peak_chr = NA,\n      peak_start = NA,\n      peak_end = NA,\n      distance = NA\n    )\n  } else {\n    nearest_peak <- peaks_to_consider[nearest_peak_index]\n    dist <- distance(gene, nearest_peak)\n    \n    results_list[[i]] <- data.frame(\n      ensembl = mcols(gene)$ensembl,\n      gene_chr = as.character(seqnames(gene)),\n      gene_TSS = start(gene),\n      peak_chr = as.character(seqnames(nearest_peak)),\n      peak_start = start(nearest_peak),\n      peak_end = end(nearest_peak),\n      distance = dist\n    )\n  }\n}\n\n# Combine results into a single data frame\nresults <- do.call(rbind, results_list)\n\n# Add group information\nresults <- results %>% dplyr::mutate(group = case_when(\n  ensembl %in% group1 ~ \\group1\\,\n  ensembl %in% group2 ~ \\group2\\,\n  TRUE ~ NA_character_\n))\n\n# Plotting\nggplot(results, aes(x = group, y = distance, fill = group)) +\n  geom_violin() +\n  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \\white\\) +\n  theme_bw() +\n  ggtitle(\\Distance to Nearest H3K27ac Peak Excluding Gene Body Overlaps\\) +\n  scale_y_continuous(labels = label_kb_mb) +\n  coord_cartesian(ylim = c(0, 50 * 1000))\n```\n\n<!-- rnb-source-end -->\n"} -->
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS) %>% dplyr::filter(ensembl %in% c(group1, group2))
genes.gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),
  ensembl = gene.tb$ensembl
)

genebody.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>% dplyr::filter(V6 %in% c(group1, group2))%>% dplyr::select(V1, V2, V3)
colnames(genebody.tb) <- c(\chr\, \start\, \end\)
genebody.gr <- makeGRangesFromDataFrame(genebody.tb)


# Step 1: Find overlaps between gene bodies and peaks
overlaps <- findOverlaps(genebody.gr, peak.H3K27ac)

# Create a list mapping each gene to the indices of peaks overlapping with its gene body
overlapping_peaks_per_gene <- split(subjectHits(overlaps), queryHits(overlaps))

# Initialize an empty list to store results
results_list <- vector(\list\, length(genes.gr))

# Step 2: For each gene, exclude overlapping peaks and find the nearest peak to its TSS
for (i in seq_along(genes.gr)) {
  gene <- genes.gr[i]
  
  # Get indices of peaks overlapping with this gene's body
  overlapping_peak_indices <- overlapping_peaks_per_gene[[as.character(i)]]
  
  # Exclude overlapping peaks for this gene
  if (!is.null(overlapping_peak_indices)) {
    peaks_to_consider <- peak.H3K27ac[-overlapping_peak_indices]
  } else {
    peaks_to_consider <- peak.H3K27ac
  }
  
  # Find the nearest peak to the TSS of this gene
  nearest_peak_index <- nearest(gene, peaks_to_consider)
  
  if (is.na(nearest_peak_index)) {
    # No peaks found; set NA values
    results_list[[i]] <- data.frame(
      ensembl = mcols(gene)$ensembl,
      gene_chr = as.character(seqnames(gene)),
      gene_TSS = start(gene),
      peak_chr = NA,
      peak_start = NA,
      peak_end = NA,
      distance = NA
    )
  } else {
    nearest_peak <- peaks_to_consider[nearest_peak_index]
    dist <- distance(gene, nearest_peak)
    
    results_list[[i]] <- data.frame(
      ensembl = mcols(gene)$ensembl,
      gene_chr = as.character(seqnames(gene)),
      gene_TSS = start(gene),
      peak_chr = as.character(seqnames(nearest_peak)),
      peak_start = start(nearest_peak),
      peak_end = end(nearest_peak),
      distance = dist
    )
  }
}

# Combine results into a single data frame
results <- do.call(rbind, results_list)

# Add group information
results <- results %>% dplyr::mutate(group = case_when(
  ensembl %in% group1 ~ \group1\,
  ensembl %in% group2 ~ \group2\,
  TRUE ~ NA_character_
))

# Plotting
ggplot(results, aes(x = group, y = distance, fill = group)) +
  geom_violin() +
  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \white\) +
  theme_bw() +
  ggtitle(\Distance to Nearest H3K27ac Peak Excluding Gene Body Overlaps\) +
  scale_y_continuous(labels = label_kb_mb) +
  coord_cartesian(ylim = c(0, 50 * 1000))



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuXG5nZW5lLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpLCBlbnNlbWJsID0gVjYsIGNociA9IFYxKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsLCBjaHIsIFRTUykgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGMoZ3JvdXAxLCBncm91cDIpKVxuZ2VuZXMuZ3IgPC0gR1JhbmdlcyhcbiAgc2VxbmFtZXMgPSBnZW5lLnRiJGNocixcbiAgcmFuZ2VzID0gSVJhbmdlcyhzdGFydCA9IGdlbmUudGIkVFNTLCBlbmQgPSBnZW5lLnRiJFRTUyksXG4gIGVuc2VtYmwgPSBnZW5lLnRiJGVuc2VtYmxcbilcblxuZ2VuZWJvZHkudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiUgZHBseXI6OmZpbHRlcihWNiAlaW4lIGMoZ3JvdXAxLCBncm91cDIpKSU+JSBkcGx5cjo6c2VsZWN0KFYxLCBWMiwgVjMpXG5jb2xuYW1lcyhnZW5lYm9keS50YikgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5nZW5lYm9keS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZWJvZHkudGIpXG5cblxuIyBTdGVwIDE6IEZpbmQgb3ZlcmxhcHMgYmV0d2VlbiBnZW5lIGJvZGllcyBhbmQgcGVha3Ncbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhnZW5lYm9keS5nciwgcGVhay5IM0syN2FjKVxuXG4jIENyZWF0ZSBhIGxpc3QgbWFwcGluZyBlYWNoIGdlbmUgdG8gdGhlIGluZGljZXMgb2YgcGVha3Mgb3ZlcmxhcHBpbmcgd2l0aCBpdHMgZ2VuZSBib2R5XG5vdmVybGFwcGluZ19wZWFrc19wZXJfZ2VuZSA8LSBzcGxpdChzdWJqZWN0SGl0cyhvdmVybGFwcyksIHF1ZXJ5SGl0cyhvdmVybGFwcykpXG5cbiMgSW5pdGlhbGl6ZSBhbiBlbXB0eSBsaXN0IHRvIHN0b3JlIHJlc3VsdHNcbnJlc3VsdHNfbGlzdCA8LSB2ZWN0b3IoXFxsaXN0XFwsIGxlbmd0aChnZW5lcy5ncikpXG5cbiMgU3RlcCAyOiBGb3IgZWFjaCBnZW5lLCBleGNsdWRlIG92ZXJsYXBwaW5nIHBlYWtzIGFuZCBmaW5kIHRoZSBuZWFyZXN0IHBlYWsgdG8gaXRzIFRTU1xuZm9yIChpIGluIHNlcV9hbG9uZyhnZW5lcy5ncikpIHtcbiAgZ2VuZSA8LSBnZW5lcy5ncltpXVxuICBcbiAgIyBHZXQgaW5kaWNlcyBvZiBwZWFrcyBvdmVybGFwcGluZyB3aXRoIHRoaXMgZ2VuZSdzIGJvZHlcbiAgb3ZlcmxhcHBpbmdfcGVha19pbmRpY2VzIDwtIG92ZXJsYXBwaW5nX3BlYWtzX3Blcl9nZW5lW1thcy5jaGFyYWN0ZXIoaSldXVxuICBcbiAgIyBFeGNsdWRlIG92ZXJsYXBwaW5nIHBlYWtzIGZvciB0aGlzIGdlbmVcbiAgaWYgKCFpcy5udWxsKG92ZXJsYXBwaW5nX3BlYWtfaW5kaWNlcykpIHtcbiAgICBwZWFrc190b19jb25zaWRlciA8LSBwZWFrLkgzSzI3YWNbLW92ZXJsYXBwaW5nX3BlYWtfaW5kaWNlc11cbiAgfSBlbHNlIHtcbiAgICBwZWFrc190b19jb25zaWRlciA8LSBwZWFrLkgzSzI3YWNcbiAgfVxuICBcbiAgIyBGaW5kIHRoZSBuZWFyZXN0IHBlYWsgdG8gdGhlIFRTUyBvZiB0aGlzIGdlbmVcbiAgbmVhcmVzdF9wZWFrX2luZGV4IDwtIG5lYXJlc3QoZ2VuZSwgcGVha3NfdG9fY29uc2lkZXIpXG4gIFxuICBpZiAoaXMubmEobmVhcmVzdF9wZWFrX2luZGV4KSkge1xuICAgICMgTm8gcGVha3MgZm91bmQ7IHNldCBOQSB2YWx1ZXNcbiAgICByZXN1bHRzX2xpc3RbW2ldXSA8LSBkYXRhLmZyYW1lKFxuICAgICAgZW5zZW1ibCA9IG1jb2xzKGdlbmUpJGVuc2VtYmwsXG4gICAgICBnZW5lX2NociA9IGFzLmNoYXJhY3RlcihzZXFuYW1lcyhnZW5lKSksXG4gICAgICBnZW5lX1RTUyA9IHN0YXJ0KGdlbmUpLFxuICAgICAgcGVha19jaHIgPSBOQSxcbiAgICAgIHBlYWtfc3RhcnQgPSBOQSxcbiAgICAgIHBlYWtfZW5kID0gTkEsXG4gICAgICBkaXN0YW5jZSA9IE5BXG4gICAgKVxuICB9IGVsc2Uge1xuICAgIG5lYXJlc3RfcGVhayA8LSBwZWFrc190b19jb25zaWRlcltuZWFyZXN0X3BlYWtfaW5kZXhdXG4gICAgZGlzdCA8LSBkaXN0YW5jZShnZW5lLCBuZWFyZXN0X3BlYWspXG4gICAgXG4gICAgcmVzdWx0c19saXN0W1tpXV0gPC0gZGF0YS5mcmFtZShcbiAgICAgIGVuc2VtYmwgPSBtY29scyhnZW5lKSRlbnNlbWJsLFxuICAgICAgZ2VuZV9jaHIgPSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMoZ2VuZSkpLFxuICAgICAgZ2VuZV9UU1MgPSBzdGFydChnZW5lKSxcbiAgICAgIHBlYWtfY2hyID0gYXMuY2hhcmFjdGVyKHNlcW5hbWVzKG5lYXJlc3RfcGVhaykpLFxuICAgICAgcGVha19zdGFydCA9IHN0YXJ0KG5lYXJlc3RfcGVhayksXG4gICAgICBwZWFrX2VuZCA9IGVuZChuZWFyZXN0X3BlYWspLFxuICAgICAgZGlzdGFuY2UgPSBkaXN0XG4gICAgKVxuICB9XG59XG5cbiMgQ29tYmluZSByZXN1bHRzIGludG8gYSBzaW5nbGUgZGF0YSBmcmFtZVxucmVzdWx0cyA8LSBkby5jYWxsKHJiaW5kLCByZXN1bHRzX2xpc3QpXG5cbiMgQWRkIGdyb3VwIGluZm9ybWF0aW9uXG5yZXN1bHRzIDwtIHJlc3VsdHMgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBjYXNlX3doZW4oXG4gIGVuc2VtYmwgJWluJSBncm91cDEgfiBcXGdyb3VwMVxcLFxuICBlbnNlbWJsICVpbiUgZ3JvdXAyIH4gXFxncm91cDJcXCxcbiAgVFJVRSB+IE5BX2NoYXJhY3Rlcl9cbikpXG5cbiMgUGxvdHRpbmdcbmdncGxvdChyZXN1bHRzLCBhZXMoeCA9IGdyb3VwLCB5ID0gZGlzdGFuY2UsIGZpbGwgPSBncm91cCkpICtcbiAgZ2VvbV92aW9saW4oKSArXG4gIGdlb21fYm94cGxvdChvdXRsaWVyLnNoYXBlID0gTkEsIHdpZHRoID0gMC4xLCBmaWxsID0gXFx3aGl0ZVxcKSArXG4gIHRoZW1lX2J3KCkgK1xuICBnZ3RpdGxlKFxcRGlzdGFuY2UgdG8gTmVhcmVzdCBIM0syN2FjIFBlYWsgRXhjbHVkaW5nIEdlbmUgQm9keSBPdmVybGFwc1xcKSArXG4gIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgNTAgKiAxMDAwKSlcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3), ensembl = V6, chr = V1) %>%\n  dplyr::select(ensembl, chr, TSS) %>% dplyr::filter(ensembl %in% c(group1, group2))\ngenes.gr <- GRanges(\n  seqnames = gene.tb$chr,\n  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),\n  ensembl = gene.tb$ensembl\n)\n\ngenebody.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>% dplyr::filter(V6 %in% c(group1, group2))%>% dplyr::select(V1, V2, V3)\ncolnames(genebody.tb) <- c(\\chr\\, \\start\\, \\end\\)\ngenebody.gr <- makeGRangesFromDataFrame(genebody.tb)\n\n\n# Step 1: Find overlaps between gene bodies and peaks\noverlaps <- findOverlaps(genebody.gr, peak.H3K27ac)\n\n# Create a list mapping each gene to the indices of peaks overlapping with its gene body\noverlapping_peaks_per_gene <- split(subjectHits(overlaps), queryHits(overlaps))\n\n# Initialize an empty list to store results\nresults_list <- vector(\\list\\, length(genes.gr))\n\n# Step 2: For each gene, exclude overlapping peaks and find the nearest peak to its TSS\nfor (i in seq_along(genes.gr)) {\n  gene <- genes.gr[i]\n  \n  # Get indices of peaks overlapping with this gene's body\n  overlapping_peak_indices <- overlapping_peaks_per_gene[[as.character(i)]]\n  \n  # Exclude overlapping peaks for this gene\n  if (!is.null(overlapping_peak_indices)) {\n    peaks_to_consider <- peak.H3K27ac[-overlapping_peak_indices]\n  } else {\n    peaks_to_consider <- peak.H3K27ac\n  }\n  \n  # Find the nearest peak to the TSS of this gene\n  nearest_peak_index <- nearest(gene, peaks_to_consider)\n  \n  if (is.na(nearest_peak_index)) {\n    # No peaks found; set NA values\n    results_list[[i]] <- data.frame(\n      ensembl = mcols(gene)$ensembl,\n      gene_chr = as.character(seqnames(gene)),\n      gene_TSS = start(gene),\n      peak_chr = NA,\n      peak_start = NA,\n      peak_end = NA,\n      distance = NA\n    )\n  } else {\n    nearest_peak <- peaks_to_consider[nearest_peak_index]\n    dist <- distance(gene, nearest_peak)\n    \n    results_list[[i]] <- data.frame(\n      ensembl = mcols(gene)$ensembl,\n      gene_chr = as.character(seqnames(gene)),\n      gene_TSS = start(gene),\n      peak_chr = as.character(seqnames(nearest_peak)),\n      peak_start = start(nearest_peak),\n      peak_end = end(nearest_peak),\n      distance = dist\n    )\n  }\n}\n\n# Combine results into a single data frame\nresults <- do.call(rbind, results_list)\n\n# Add group information\nresults <- results %>% dplyr::mutate(group = case_when(\n  ensembl %in% group1 ~ \\group1\\,\n  ensembl %in% group2 ~ \\group2\\,\n  TRUE ~ NA_character_\n))\n\n# Plotting\nggplot(results, aes(x = group, y = distance, fill = group)) +\n  geom_violin() +\n  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \\white\\) +\n  theme_bw() +\n  ggtitle(\\Distance to Nearest H3K27ac Peak Excluding Gene Body Overlaps\\) +\n  scale_y_continuous(labels = label_kb_mb) +\n  coord_cartesian(ylim = c(0, 50 * 1000))\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuXG5nZW5lLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpLCBlbnNlbWJsID0gVjYsIGNociA9IFYxKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsLCBjaHIsIFRTUykgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGMoZ3JvdXAxLCBncm91cDIpKVxuZ2VuZXMuZ3IgPC0gR1JhbmdlcyhcbiAgc2VxbmFtZXMgPSBnZW5lLnRiJGNocixcbiAgcmFuZ2VzID0gSVJhbmdlcyhzdGFydCA9IGdlbmUudGIkVFNTLCBlbmQgPSBnZW5lLnRiJFRTUyksXG4gIGVuc2VtYmwgPSBnZW5lLnRiJGVuc2VtYmxcbilcblxuZ2VuZWJvZHkudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiUgZHBseXI6OmZpbHRlcihWNiAlaW4lIGMoZ3JvdXAxLCBncm91cDIpKSU+JSBkcGx5cjo6c2VsZWN0KFYxLCBWMiwgVjMpXG5jb2xuYW1lcyhnZW5lYm9keS50YikgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5nZW5lYm9keS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZWJvZHkudGIpXG5cblxuIyBTdGVwIDE6IEZpbmQgb3ZlcmxhcHMgYmV0d2VlbiBnZW5lIGJvZGllcyBhbmQgcGVha3Ncbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhnZW5lYm9keS5nciwgcGVhay5IM0syN2FjKVxuXG4jIENyZWF0ZSBhIGxpc3QgbWFwcGluZyBlYWNoIGdlbmUgdG8gdGhlIGluZGljZXMgb2YgcGVha3Mgb3ZlcmxhcHBpbmcgd2l0aCBpdHMgZ2VuZSBib2R5XG5vdmVybGFwcGluZ19wZWFrc19wZXJfZ2VuZSA8LSBzcGxpdChzdWJqZWN0SGl0cyhvdmVybGFwcyksIHF1ZXJ5SGl0cyhvdmVybGFwcykpXG5cbiMgSW5pdGlhbGl6ZSBhbiBlbXB0eSBsaXN0IHRvIHN0b3JlIHJlc3VsdHNcbnJlc3VsdHNfbGlzdCA8LSB2ZWN0b3IoXFxsaXN0XFwsIGxlbmd0aChnZW5lcy5ncikpXG5cbiMgU3RlcCAyOiBGb3IgZWFjaCBnZW5lLCBleGNsdWRlIG92ZXJsYXBwaW5nIHBlYWtzIGFuZCBmaW5kIHRoZSBuZWFyZXN0IHBlYWsgdG8gaXRzIFRTU1xuZm9yIChpIGluIHNlcV9hbG9uZyhnZW5lcy5ncikpIHtcbiAgZ2VuZSA8LSBnZW5lcy5ncltpXVxuICBcbiAgIyBHZXQgaW5kaWNlcyBvZiBwZWFrcyBvdmVybGFwcGluZyB3aXRoIHRoaXMgZ2VuZSdzIGJvZHlcbiAgb3ZlcmxhcHBpbmdfcGVha19pbmRpY2VzIDwtIG92ZXJsYXBwaW5nX3BlYWtzX3Blcl9nZW5lW1thcy5jaGFyYWN0ZXIoaSldXVxuICBcbiAgIyBFeGNsdWRlIG92ZXJsYXBwaW5nIHBlYWtzIGZvciB0aGlzIGdlbmVcbiAgaWYgKCFpcy5udWxsKG92ZXJsYXBwaW5nX3BlYWtfaW5kaWNlcykpIHtcbiAgICBwZWFrc190b19jb25zaWRlciA8LSBwZWFrLkgzSzI3YWNbLW92ZXJsYXBwaW5nX3BlYWtfaW5kaWNlc11cbiAgfSBlbHNlIHtcbiAgICBwZWFrc190b19jb25zaWRlciA8LSBwZWFrLkgzSzI3YWNcbiAgfVxuICBcbiAgIyBGaW5kIHRoZSBuZWFyZXN0IHBlYWsgdG8gdGhlIFRTUyBvZiB0aGlzIGdlbmVcbiAgbmVhcmVzdF9wZWFrX2luZGV4IDwtIG5lYXJlc3QoZ2VuZSwgcGVha3NfdG9fY29uc2lkZXIpXG4gIFxuICBpZiAoaXMubmEobmVhcmVzdF9wZWFrX2luZGV4KSkge1xuICAgICMgTm8gcGVha3MgZm91bmQ7IHNldCBOQSB2YWx1ZXNcbiAgICByZXN1bHRzX2xpc3RbW2ldXSA8LSBkYXRhLmZyYW1lKFxuICAgICAgZW5zZW1ibCA9IG1jb2xzKGdlbmUpJGVuc2VtYmwsXG4gICAgICBnZW5lX2NociA9IGFzLmNoYXJhY3RlcihzZXFuYW1lcyhnZW5lKSksXG4gICAgICBnZW5lX1RTUyA9IHN0YXJ0KGdlbmUpLFxuICAgICAgcGVha19jaHIgPSBOQSxcbiAgICAgIHBlYWtfc3RhcnQgPSBOQSxcbiAgICAgIHBlYWtfZW5kID0gTkEsXG4gICAgICBkaXN0YW5jZSA9IE5BXG4gICAgKVxuICB9IGVsc2Uge1xuICAgIG5lYXJlc3RfcGVhayA8LSBwZWFrc190b19jb25zaWRlcltuZWFyZXN0X3BlYWtfaW5kZXhdXG4gICAgZGlzdCA8LSBkaXN0YW5jZShnZW5lLCBuZWFyZXN0X3BlYWspXG4gICAgXG4gICAgcmVzdWx0c19saXN0W1tpXV0gPC0gZGF0YS5mcmFtZShcbiAgICAgIGVuc2VtYmwgPSBtY29scyhnZW5lKSRlbnNlbWJsLFxuICAgICAgZ2VuZV9jaHIgPSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMoZ2VuZSkpLFxuICAgICAgZ2VuZV9UU1MgPSBzdGFydChnZW5lKSxcbiAgICAgIHBlYWtfY2hyID0gYXMuY2hhcmFjdGVyKHNlcW5hbWVzKG5lYXJlc3RfcGVhaykpLFxuICAgICAgcGVha19zdGFydCA9IHN0YXJ0KG5lYXJlc3RfcGVhayksXG4gICAgICBwZWFrX2VuZCA9IGVuZChuZWFyZXN0X3BlYWspLFxuICAgICAgZGlzdGFuY2UgPSBkaXN0XG4gICAgKVxuICB9XG59XG5cbiMgQ29tYmluZSByZXN1bHRzIGludG8gYSBzaW5nbGUgZGF0YSBmcmFtZVxucmVzdWx0cyA8LSBkby5jYWxsKHJiaW5kLCByZXN1bHRzX2xpc3QpXG5cbiMgQWRkIGdyb3VwIGluZm9ybWF0aW9uXG5yZXN1bHRzIDwtIHJlc3VsdHMgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBjYXNlX3doZW4oXG4gIGVuc2VtYmwgJWluJSBncm91cDEgfiBcXGdyb3VwMVxcLFxuICBlbnNlbWJsICVpbiUgZ3JvdXAyIH4gXFxncm91cDJcXCxcbiAgVFJVRSB+IE5BX2NoYXJhY3Rlcl9cbikpXG5cbiMgUGxvdHRpbmdcbmdncGxvdChyZXN1bHRzLCBhZXMoeCA9IGdyb3VwLCB5ID0gZGlzdGFuY2UsIGZpbGwgPSBncm91cCkpICtcbiAgZ2VvbV92aW9saW4oKSArXG4gIGdlb21fYm94cGxvdChvdXRsaWVyLnNoYXBlID0gTkEsIHdpZHRoID0gMC4xLCBmaWxsID0gXFx3aGl0ZVxcKSArXG4gIHRoZW1lX2J3KCkgK1xuICBnZ3RpdGxlKFxcRGlzdGFuY2UgdG8gTmVhcmVzdCBIM0syN2FjIFBlYWsgRXhjbHVkaW5nIEdlbmUgQm9keSBPdmVybGFwc1xcKSArXG4gIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgNTAgKiAxMDAwKSlcbmBgYFxuYGBgIn0= -->

```r
```r
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS) %>% dplyr::filter(ensembl %in% c(group1, group2))
genes.gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),
  ensembl = gene.tb$ensembl
)

genebody.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>% dplyr::filter(V6 %in% c(group1, group2))%>% dplyr::select(V1, V2, V3)
colnames(genebody.tb) <- c(\chr\, \start\, \end\)
genebody.gr <- makeGRangesFromDataFrame(genebody.tb)


# Step 1: Find overlaps between gene bodies and peaks
overlaps <- findOverlaps(genebody.gr, peak.H3K27ac)

# Create a list mapping each gene to the indices of peaks overlapping with its gene body
overlapping_peaks_per_gene <- split(subjectHits(overlaps), queryHits(overlaps))

# Initialize an empty list to store results
results_list <- vector(\list\, length(genes.gr))

# Step 2: For each gene, exclude overlapping peaks and find the nearest peak to its TSS
for (i in seq_along(genes.gr)) {
  gene <- genes.gr[i]
  
  # Get indices of peaks overlapping with this gene's body
  overlapping_peak_indices <- overlapping_peaks_per_gene[[as.character(i)]]
  
  # Exclude overlapping peaks for this gene
  if (!is.null(overlapping_peak_indices)) {
    peaks_to_consider <- peak.H3K27ac[-overlapping_peak_indices]
  } else {
    peaks_to_consider <- peak.H3K27ac
  }
  
  # Find the nearest peak to the TSS of this gene
  nearest_peak_index <- nearest(gene, peaks_to_consider)
  
  if (is.na(nearest_peak_index)) {
    # No peaks found; set NA values
    results_list[[i]] <- data.frame(
      ensembl = mcols(gene)$ensembl,
      gene_chr = as.character(seqnames(gene)),
      gene_TSS = start(gene),
      peak_chr = NA,
      peak_start = NA,
      peak_end = NA,
      distance = NA
    )
  } else {
    nearest_peak <- peaks_to_consider[nearest_peak_index]
    dist <- distance(gene, nearest_peak)
    
    results_list[[i]] <- data.frame(
      ensembl = mcols(gene)$ensembl,
      gene_chr = as.character(seqnames(gene)),
      gene_TSS = start(gene),
      peak_chr = as.character(seqnames(nearest_peak)),
      peak_start = start(nearest_peak),
      peak_end = end(nearest_peak),
      distance = dist
    )
  }
}

# Combine results into a single data frame
results <- do.call(rbind, results_list)

# Add group information
results <- results %>% dplyr::mutate(group = case_when(
  ensembl %in% group1 ~ \group1\,
  ensembl %in% group2 ~ \group2\,
  TRUE ~ NA_character_
))

# Plotting
ggplot(results, aes(x = group, y = distance, fill = group)) +
  geom_violin() +
  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \white\) +
  theme_bw() +
  ggtitle(\Distance to Nearest H3K27ac Peak Excluding Gene Body Overlaps\) +
  scale_y_continuous(labels = label_kb_mb) +
  coord_cartesian(ylim = c(0, 50 * 1000))
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


###[2.33] Finding closest enhancer
Here, enhancer will be defined by H3K27ac peak
It makes more sence to include the enhancer peak on gene body
(strategy 1) exclude +-10kb region from TSS only
(strategy 2) only check the E-P loops called in Micro-C
##### binary group - excluding all gene body

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcIitcIiwgVjIsIFYzKSwgZW5zZW1ibCA9IFY2LCBjaHIgPSBWMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibCwgY2hyLCBUU1MpXG5cbmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlwiKSkkZ2VuZVxuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XCIpKSRnZW5lXG5cblxuZ2VuZS50YiA8LSBnZW5lLnRiICU+JSBkcGx5cjo6ZmlsdGVyKGVuc2VtYmwgJWluJSBjKGdyb3VwMSwgZ3JvdXAyKSlcbmdlbmVzLmdyIDwtIEdSYW5nZXMoXG4gIHNlcW5hbWVzID0gZ2VuZS50YiRjaHIsXG4gIHJhbmdlcyA9IElSYW5nZXMoc3RhcnQgPSBnZW5lLnRiJFRTUywgZW5kID0gZ2VuZS50YiRUU1MpLFxuICBlbnNlbWJsID0gZ2VuZS50YiRlbnNlbWJsXG4pXG5cbmdlbmVib2R5LnRiIDwtIGdlbmUudGIgJT4lIGRwbHlyOjptdXRhdGUoc3RhcnQgPSBUU1MtMTAqMTAwMCwgZW5kID0gVFNTICsgMTAqMTAwMCkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoY2hyLCBzdGFydCwgZW5kKVxuXG5nZW5lYm9keS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZWJvZHkudGIpXG5cblxucGVhay5IM0syN2FjIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFwiR1NNMjQzODQ3Nl9FQy1ERy0zNDU4LUgzSzI3QUNfQVNZTl8xLm5hcnJvd1BlYWsuYmVkXCIpKVxuIyBwZWFrLkgzSzI3YWM8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZnJlYWQoaGVyZShyZWZEaXIsIFwiR1NNMjQzODQ3Nl9FQy1ERy0zNDU4LUgzSzI3QUNfQVNZTl8xLm5hcnJvd1BlYWsuYmVkXCIpKSAlPiUgXG4jICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRwbHlyOjptdXRhdGUoY2hyID0gVjEsIHN0YXJ0ID0gKFYyICsgVjMpLzIsIGVuZCA9IChWMiArIFYzKS8yKSAlPiVcbiMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZHBseXI6OnNlbGVjdChjaHIsIHN0YXJ0LCBlbmQpKVxuXG4jIyMjIyMjIEZpbHRlcmluZyBvdXQgcGVha3Mgb3ZlcmxhcHBpbmcgd2l0aCB0aGUgZ2VuZSBib2R5XG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoZ2VuZWJvZHkuZ3IsIHBlYWsuSDNLMjdhYylcblxuIyBJbmRpY2VzIG9mIHBlYWtzIHRoYXQgb3ZlcmxhcCB0aGUgVFNTXG5vdmVybGFwcGluZ19wZWFrX2luZGljZXMgPC0gdW5pcXVlKHN1YmplY3RIaXRzKG92ZXJsYXBzKSlcblxuIyBFeGNsdWRlIG92ZXJsYXBwaW5nIHBlYWtzXG5ub25fb3ZlcmxhcHBpbmdfcGVha3MgPC0gcGVhay5IM0syN2FjWy1vdmVybGFwcGluZ19wZWFrX2luZGljZXNdXG5cblxuIyMjIyMjIyBDYWxjdWxhdGluZyBkaXN0YW5jZSB0byBuZWFyZXN0IHBlYWtcbm5lYXJlc3RfcGVha19pbmRpY2VzIDwtIG5lYXJlc3QoZ2VuZXMuZ3IsIG5vbl9vdmVybGFwcGluZ19wZWFrcylcbm5lYXJlc3RfcGVha3MgPC0gbm9uX292ZXJsYXBwaW5nX3BlYWtzW25lYXJlc3RfcGVha19pbmRpY2VzXVxuZGlzdGFuY2VzIDwtIGRpc3RhbmNlKGdlbmVzLmdyLCBuZWFyZXN0X3BlYWtzKVxuXG5cbnJlc3VsdHMgPC0gZGF0YS5mcmFtZShcbiAgZW5zZW1ibCA9IG1jb2xzKGdlbmVzLmdyKSRlbnNlbWJsLFxuICBnZW5lX2NociA9IGFzLmNoYXJhY3RlcihzZXFuYW1lcyhnZW5lcy5ncikpLFxuICBnZW5lX1RTUyA9IHN0YXJ0KGdlbmVzLmdyKSxcbiAgcGVha19jaHIgPSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMobmVhcmVzdF9wZWFrcykpLFxuICBwZWFrX3N0YXJ0ID0gc3RhcnQobmVhcmVzdF9wZWFrcyksXG4gIHBlYWtfZW5kID0gZW5kKG5lYXJlc3RfcGVha3MpLFxuICBkaXN0YW5jZSA9IGRpc3RhbmNlc1xuKVxuXG5yZXN1bHRzIDwtIHJlc3VsdHMgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBjYXNlX3doZW4oZW5zZW1ibCAlaW4lIGdyb3VwMSB+IFwiZ3JvdXAxXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuc2VtYmwgJWluJSBncm91cDIgfiBcImdyb3VwMlwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKVxuXG5nZ3Bsb3QocmVzdWx0cywgYWVzKHggPSBncm91cCwgeSA9IGRpc3RhbmNlLCBmaWxsID0gZ3JvdXApKSArIGdlb21fdmlvbGluKCkgKyBnZW9tX2JveHBsb3Qob3V0bGllci5zaGFwZSA9IE5BLCB3aWR0aCA9IDAuMSwgZmlsbCA9IFwid2hpdGVcIikgKyB0aGVtZV9idygpICsgZ2d0aXRsZShcImRpc3RhbmNlIHRvIG5lYXJlc3QgSDNLMjdhYyBwZWFrIGV4Y2x1ZGluZyBnZW5lIGJvZHlcIikgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIDI1MCoxMDAwKSlcblxuICBcbmBgYCJ9 -->\n\n```r\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3), ensembl = V6, chr = V1) %>%\n  dplyr::select(ensembl, chr, TSS)\n\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\ngene.tb <- gene.tb %>% dplyr::filter(ensembl %in% c(group1, group2))\ngenes.gr <- GRanges(\n  seqnames = gene.tb$chr,\n  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),\n  ensembl = gene.tb$ensembl\n)\n\ngenebody.tb <- gene.tb %>% dplyr::mutate(start = TSS-10*1000, end = TSS + 10*1000) %>%\n  dplyr::select(chr, start, end)\n\ngenebody.gr <- makeGRangesFromDataFrame(genebody.tb)\n\n\npeak.H3K27ac <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\n# peak.H3K27ac<- makeGRangesFromDataFrame(fread(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\)) %>% \n#                                           dplyr::mutate(chr = V1, start = (V2 + V3)/2, end = (V2 + V3)/2) %>%\n#                                           dplyr::select(chr, start, end))\n\n####### Filtering out peaks overlapping with the gene body\noverlaps <- findOverlaps(genebody.gr, peak.H3K27ac)\n\n# Indices of peaks that overlap the TSS\noverlapping_peak_indices <- unique(subjectHits(overlaps))\n\n# Exclude overlapping peaks\nnon_overlapping_peaks <- peak.H3K27ac[-overlapping_peak_indices]\n\n\n####### Calculating distance to nearest peak\nnearest_peak_indices <- nearest(genes.gr, non_overlapping_peaks)\nnearest_peaks <- non_overlapping_peaks[nearest_peak_indices]\ndistances <- distance(genes.gr, nearest_peaks)\n\n\nresults <- data.frame(\n  ensembl = mcols(genes.gr)$ensembl,\n  gene_chr = as.character(seqnames(genes.gr)),\n  gene_TSS = start(genes.gr),\n  peak_chr = as.character(seqnames(nearest_peaks)),\n  peak_start = start(nearest_peaks),\n  peak_end = end(nearest_peaks),\n  distance = distances\n)\n\nresults <- results %>% dplyr::mutate(group = case_when(ensembl %in% group1 ~ \\group1\\,\n                                            ensembl %in% group2 ~ \\group2\\,\n                                            TRUE ~ NA))\n\nggplot(results, aes(x = group, y = distance, fill = group)) + geom_violin() + geom_boxplot(outlier.shape = NA, width = 0.1, fill = \\white\\) + theme_bw() + ggtitle(\\distance to nearest H3K27ac peak excluding gene body\\) + scale_y_continuous(labels = label_kb_mb) + coord_cartesian(ylim = c(0, 250*1000))\n\n  \n```\n\n<!-- rnb-source-end -->\n"} -->
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS)

group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.tb <- gene.tb %>% dplyr::filter(ensembl %in% c(group1, group2))
genes.gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),
  ensembl = gene.tb$ensembl
)

genebody.tb <- gene.tb %>% dplyr::mutate(start = TSS-10*1000, end = TSS + 10*1000) %>%
  dplyr::select(chr, start, end)

genebody.gr <- makeGRangesFromDataFrame(genebody.tb)


peak.H3K27ac <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
# peak.H3K27ac<- makeGRangesFromDataFrame(fread(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\)) %>% 
#                                           dplyr::mutate(chr = V1, start = (V2 + V3)/2, end = (V2 + V3)/2) %>%
#                                           dplyr::select(chr, start, end))

####### Filtering out peaks overlapping with the gene body
overlaps <- findOverlaps(genebody.gr, peak.H3K27ac)

# Indices of peaks that overlap the TSS
overlapping_peak_indices <- unique(subjectHits(overlaps))

# Exclude overlapping peaks
non_overlapping_peaks <- peak.H3K27ac[-overlapping_peak_indices]


####### Calculating distance to nearest peak
nearest_peak_indices <- nearest(genes.gr, non_overlapping_peaks)
nearest_peaks <- non_overlapping_peaks[nearest_peak_indices]
distances <- distance(genes.gr, nearest_peaks)


results <- data.frame(
  ensembl = mcols(genes.gr)$ensembl,
  gene_chr = as.character(seqnames(genes.gr)),
  gene_TSS = start(genes.gr),
  peak_chr = as.character(seqnames(nearest_peaks)),
  peak_start = start(nearest_peaks),
  peak_end = end(nearest_peaks),
  distance = distances
)

results <- results %>% dplyr::mutate(group = case_when(ensembl %in% group1 ~ \group1\,
                                            ensembl %in% group2 ~ \group2\,
                                            TRUE ~ NA))

ggplot(results, aes(x = group, y = distance, fill = group)) + geom_violin() + geom_boxplot(outlier.shape = NA, width = 0.1, fill = \white\) + theme_bw() + ggtitle(\distance to nearest H3K27ac peak excluding gene body\) + scale_y_continuous(labels = label_kb_mb) + coord_cartesian(ylim = c(0, 250*1000))

  



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSwgZW5zZW1ibCA9IFY2LCBjaHIgPSBWMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibCwgY2hyLCBUU1MpXG5cbmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlxcKSkkZ2VuZVxuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XFwpKSRnZW5lXG5cblxuZ2VuZS50YiA8LSBnZW5lLnRiICU+JSBkcGx5cjo6ZmlsdGVyKGVuc2VtYmwgJWluJSBjKGdyb3VwMSwgZ3JvdXAyKSlcbmdlbmVzLmdyIDwtIEdSYW5nZXMoXG4gIHNlcW5hbWVzID0gZ2VuZS50YiRjaHIsXG4gIHJhbmdlcyA9IElSYW5nZXMoc3RhcnQgPSBnZW5lLnRiJFRTUywgZW5kID0gZ2VuZS50YiRUU1MpLFxuICBlbnNlbWJsID0gZ2VuZS50YiRlbnNlbWJsXG4pXG5cbmdlbmVib2R5LnRiIDwtIGdlbmUudGIgJT4lIGRwbHlyOjptdXRhdGUoc3RhcnQgPSBUU1MtMTAqMTAwMCwgZW5kID0gVFNTICsgMTAqMTAwMCkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoY2hyLCBzdGFydCwgZW5kKVxuXG5nZW5lYm9keS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZWJvZHkudGIpXG5cblxucGVhay5IM0syN2FjIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcR1NNMjQzODQ3Nl9FQy1ERy0zNDU4LUgzSzI3QUNfQVNZTl8xLm5hcnJvd1BlYWsuYmVkXFwpKVxuIyBwZWFrLkgzSzI3YWM8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZnJlYWQoaGVyZShyZWZEaXIsIFxcR1NNMjQzODQ3Nl9FQy1ERy0zNDU4LUgzSzI3QUNfQVNZTl8xLm5hcnJvd1BlYWsuYmVkXFwpKSAlPiUgXG4jICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRwbHlyOjptdXRhdGUoY2hyID0gVjEsIHN0YXJ0ID0gKFYyICsgVjMpLzIsIGVuZCA9IChWMiArIFYzKS8yKSAlPiVcbiMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZHBseXI6OnNlbGVjdChjaHIsIHN0YXJ0LCBlbmQpKVxuXG4jIyMjIyMjIEZpbHRlcmluZyBvdXQgcGVha3Mgb3ZlcmxhcHBpbmcgd2l0aCB0aGUgZ2VuZSBib2R5XG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoZ2VuZWJvZHkuZ3IsIHBlYWsuSDNLMjdhYylcblxuIyBJbmRpY2VzIG9mIHBlYWtzIHRoYXQgb3ZlcmxhcCB0aGUgVFNTXG5vdmVybGFwcGluZ19wZWFrX2luZGljZXMgPC0gdW5pcXVlKHN1YmplY3RIaXRzKG92ZXJsYXBzKSlcblxuIyBFeGNsdWRlIG92ZXJsYXBwaW5nIHBlYWtzXG5ub25fb3ZlcmxhcHBpbmdfcGVha3MgPC0gcGVhay5IM0syN2FjWy1vdmVybGFwcGluZ19wZWFrX2luZGljZXNdXG5cblxuIyMjIyMjIyBDYWxjdWxhdGluZyBkaXN0YW5jZSB0byBuZWFyZXN0IHBlYWtcbm5lYXJlc3RfcGVha19pbmRpY2VzIDwtIG5lYXJlc3QoZ2VuZXMuZ3IsIG5vbl9vdmVybGFwcGluZ19wZWFrcylcbm5lYXJlc3RfcGVha3MgPC0gbm9uX292ZXJsYXBwaW5nX3BlYWtzW25lYXJlc3RfcGVha19pbmRpY2VzXVxuZGlzdGFuY2VzIDwtIGRpc3RhbmNlKGdlbmVzLmdyLCBuZWFyZXN0X3BlYWtzKVxuXG5cbnJlc3VsdHMgPC0gZGF0YS5mcmFtZShcbiAgZW5zZW1ibCA9IG1jb2xzKGdlbmVzLmdyKSRlbnNlbWJsLFxuICBnZW5lX2NociA9IGFzLmNoYXJhY3RlcihzZXFuYW1lcyhnZW5lcy5ncikpLFxuICBnZW5lX1RTUyA9IHN0YXJ0KGdlbmVzLmdyKSxcbiAgcGVha19jaHIgPSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMobmVhcmVzdF9wZWFrcykpLFxuICBwZWFrX3N0YXJ0ID0gc3RhcnQobmVhcmVzdF9wZWFrcyksXG4gIHBlYWtfZW5kID0gZW5kKG5lYXJlc3RfcGVha3MpLFxuICBkaXN0YW5jZSA9IGRpc3RhbmNlc1xuKVxuXG5yZXN1bHRzIDwtIHJlc3VsdHMgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBjYXNlX3doZW4oZW5zZW1ibCAlaW4lIGdyb3VwMSB+IFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuc2VtYmwgJWluJSBncm91cDIgfiBcXGdyb3VwMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKVxuXG5nZ3Bsb3QocmVzdWx0cywgYWVzKHggPSBncm91cCwgeSA9IGRpc3RhbmNlLCBmaWxsID0gZ3JvdXApKSArIGdlb21fdmlvbGluKCkgKyBnZW9tX2JveHBsb3Qob3V0bGllci5zaGFwZSA9IE5BLCB3aWR0aCA9IDAuMSwgZmlsbCA9IFxcd2hpdGVcXCkgKyB0aGVtZV9idygpICsgZ2d0aXRsZShcXGRpc3RhbmNlIHRvIG5lYXJlc3QgSDNLMjdhYyBwZWFrIGV4Y2x1ZGluZyBnZW5lIGJvZHlcXCkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIDI1MCoxMDAwKSlcblxuICBcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3), ensembl = V6, chr = V1) %>%\n  dplyr::select(ensembl, chr, TSS)\n\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\ngene.tb <- gene.tb %>% dplyr::filter(ensembl %in% c(group1, group2))\ngenes.gr <- GRanges(\n  seqnames = gene.tb$chr,\n  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),\n  ensembl = gene.tb$ensembl\n)\n\ngenebody.tb <- gene.tb %>% dplyr::mutate(start = TSS-10*1000, end = TSS + 10*1000) %>%\n  dplyr::select(chr, start, end)\n\ngenebody.gr <- makeGRangesFromDataFrame(genebody.tb)\n\n\npeak.H3K27ac <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\n# peak.H3K27ac<- makeGRangesFromDataFrame(fread(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\)) %>% \n#                                           dplyr::mutate(chr = V1, start = (V2 + V3)/2, end = (V2 + V3)/2) %>%\n#                                           dplyr::select(chr, start, end))\n\n####### Filtering out peaks overlapping with the gene body\noverlaps <- findOverlaps(genebody.gr, peak.H3K27ac)\n\n# Indices of peaks that overlap the TSS\noverlapping_peak_indices <- unique(subjectHits(overlaps))\n\n# Exclude overlapping peaks\nnon_overlapping_peaks <- peak.H3K27ac[-overlapping_peak_indices]\n\n\n####### Calculating distance to nearest peak\nnearest_peak_indices <- nearest(genes.gr, non_overlapping_peaks)\nnearest_peaks <- non_overlapping_peaks[nearest_peak_indices]\ndistances <- distance(genes.gr, nearest_peaks)\n\n\nresults <- data.frame(\n  ensembl = mcols(genes.gr)$ensembl,\n  gene_chr = as.character(seqnames(genes.gr)),\n  gene_TSS = start(genes.gr),\n  peak_chr = as.character(seqnames(nearest_peaks)),\n  peak_start = start(nearest_peaks),\n  peak_end = end(nearest_peaks),\n  distance = distances\n)\n\nresults <- results %>% dplyr::mutate(group = case_when(ensembl %in% group1 ~ \\group1\\,\n                                            ensembl %in% group2 ~ \\group2\\,\n                                            TRUE ~ NA))\n\nggplot(results, aes(x = group, y = distance, fill = group)) + geom_violin() + geom_boxplot(outlier.shape = NA, width = 0.1, fill = \\white\\) + theme_bw() + ggtitle(\\distance to nearest H3K27ac peak excluding gene body\\) + scale_y_continuous(labels = label_kb_mb) + coord_cartesian(ylim = c(0, 250*1000))\n\n  \n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSwgZW5zZW1ibCA9IFY2LCBjaHIgPSBWMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibCwgY2hyLCBUU1MpXG5cbmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlxcKSkkZ2VuZVxuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XFwpKSRnZW5lXG5cblxuZ2VuZS50YiA8LSBnZW5lLnRiICU+JSBkcGx5cjo6ZmlsdGVyKGVuc2VtYmwgJWluJSBjKGdyb3VwMSwgZ3JvdXAyKSlcbmdlbmVzLmdyIDwtIEdSYW5nZXMoXG4gIHNlcW5hbWVzID0gZ2VuZS50YiRjaHIsXG4gIHJhbmdlcyA9IElSYW5nZXMoc3RhcnQgPSBnZW5lLnRiJFRTUywgZW5kID0gZ2VuZS50YiRUU1MpLFxuICBlbnNlbWJsID0gZ2VuZS50YiRlbnNlbWJsXG4pXG5cbmdlbmVib2R5LnRiIDwtIGdlbmUudGIgJT4lIGRwbHlyOjptdXRhdGUoc3RhcnQgPSBUU1MtMTAqMTAwMCwgZW5kID0gVFNTICsgMTAqMTAwMCkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoY2hyLCBzdGFydCwgZW5kKVxuXG5nZW5lYm9keS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZWJvZHkudGIpXG5cblxucGVhay5IM0syN2FjIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcR1NNMjQzODQ3Nl9FQy1ERy0zNDU4LUgzSzI3QUNfQVNZTl8xLm5hcnJvd1BlYWsuYmVkXFwpKVxuIyBwZWFrLkgzSzI3YWM8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZnJlYWQoaGVyZShyZWZEaXIsIFxcR1NNMjQzODQ3Nl9FQy1ERy0zNDU4LUgzSzI3QUNfQVNZTl8xLm5hcnJvd1BlYWsuYmVkXFwpKSAlPiUgXG4jICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRwbHlyOjptdXRhdGUoY2hyID0gVjEsIHN0YXJ0ID0gKFYyICsgVjMpLzIsIGVuZCA9IChWMiArIFYzKS8yKSAlPiVcbiMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZHBseXI6OnNlbGVjdChjaHIsIHN0YXJ0LCBlbmQpKVxuXG4jIyMjIyMjIEZpbHRlcmluZyBvdXQgcGVha3Mgb3ZlcmxhcHBpbmcgd2l0aCB0aGUgZ2VuZSBib2R5XG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoZ2VuZWJvZHkuZ3IsIHBlYWsuSDNLMjdhYylcblxuIyBJbmRpY2VzIG9mIHBlYWtzIHRoYXQgb3ZlcmxhcCB0aGUgVFNTXG5vdmVybGFwcGluZ19wZWFrX2luZGljZXMgPC0gdW5pcXVlKHN1YmplY3RIaXRzKG92ZXJsYXBzKSlcblxuIyBFeGNsdWRlIG92ZXJsYXBwaW5nIHBlYWtzXG5ub25fb3ZlcmxhcHBpbmdfcGVha3MgPC0gcGVhay5IM0syN2FjWy1vdmVybGFwcGluZ19wZWFrX2luZGljZXNdXG5cblxuIyMjIyMjIyBDYWxjdWxhdGluZyBkaXN0YW5jZSB0byBuZWFyZXN0IHBlYWtcbm5lYXJlc3RfcGVha19pbmRpY2VzIDwtIG5lYXJlc3QoZ2VuZXMuZ3IsIG5vbl9vdmVybGFwcGluZ19wZWFrcylcbm5lYXJlc3RfcGVha3MgPC0gbm9uX292ZXJsYXBwaW5nX3BlYWtzW25lYXJlc3RfcGVha19pbmRpY2VzXVxuZGlzdGFuY2VzIDwtIGRpc3RhbmNlKGdlbmVzLmdyLCBuZWFyZXN0X3BlYWtzKVxuXG5cbnJlc3VsdHMgPC0gZGF0YS5mcmFtZShcbiAgZW5zZW1ibCA9IG1jb2xzKGdlbmVzLmdyKSRlbnNlbWJsLFxuICBnZW5lX2NociA9IGFzLmNoYXJhY3RlcihzZXFuYW1lcyhnZW5lcy5ncikpLFxuICBnZW5lX1RTUyA9IHN0YXJ0KGdlbmVzLmdyKSxcbiAgcGVha19jaHIgPSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMobmVhcmVzdF9wZWFrcykpLFxuICBwZWFrX3N0YXJ0ID0gc3RhcnQobmVhcmVzdF9wZWFrcyksXG4gIHBlYWtfZW5kID0gZW5kKG5lYXJlc3RfcGVha3MpLFxuICBkaXN0YW5jZSA9IGRpc3RhbmNlc1xuKVxuXG5yZXN1bHRzIDwtIHJlc3VsdHMgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBjYXNlX3doZW4oZW5zZW1ibCAlaW4lIGdyb3VwMSB+IFxcZ3JvdXAxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuc2VtYmwgJWluJSBncm91cDIgfiBcXGdyb3VwMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKVxuXG5nZ3Bsb3QocmVzdWx0cywgYWVzKHggPSBncm91cCwgeSA9IGRpc3RhbmNlLCBmaWxsID0gZ3JvdXApKSArIGdlb21fdmlvbGluKCkgKyBnZW9tX2JveHBsb3Qob3V0bGllci5zaGFwZSA9IE5BLCB3aWR0aCA9IDAuMSwgZmlsbCA9IFxcd2hpdGVcXCkgKyB0aGVtZV9idygpICsgZ2d0aXRsZShcXGRpc3RhbmNlIHRvIG5lYXJlc3QgSDNLMjdhYyBwZWFrIGV4Y2x1ZGluZyBnZW5lIGJvZHlcXCkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gbGFiZWxfa2JfbWIpICsgY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKDAsIDI1MCoxMDAwKSlcblxuICBcbmBgYFxuYGBgIn0= -->

```r
```r
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS)

group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.tb <- gene.tb %>% dplyr::filter(ensembl %in% c(group1, group2))
genes.gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),
  ensembl = gene.tb$ensembl
)

genebody.tb <- gene.tb %>% dplyr::mutate(start = TSS-10*1000, end = TSS + 10*1000) %>%
  dplyr::select(chr, start, end)

genebody.gr <- makeGRangesFromDataFrame(genebody.tb)


peak.H3K27ac <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
# peak.H3K27ac<- makeGRangesFromDataFrame(fread(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\)) %>% 
#                                           dplyr::mutate(chr = V1, start = (V2 + V3)/2, end = (V2 + V3)/2) %>%
#                                           dplyr::select(chr, start, end))

####### Filtering out peaks overlapping with the gene body
overlaps <- findOverlaps(genebody.gr, peak.H3K27ac)

# Indices of peaks that overlap the TSS
overlapping_peak_indices <- unique(subjectHits(overlaps))

# Exclude overlapping peaks
non_overlapping_peaks <- peak.H3K27ac[-overlapping_peak_indices]


####### Calculating distance to nearest peak
nearest_peak_indices <- nearest(genes.gr, non_overlapping_peaks)
nearest_peaks <- non_overlapping_peaks[nearest_peak_indices]
distances <- distance(genes.gr, nearest_peaks)


results <- data.frame(
  ensembl = mcols(genes.gr)$ensembl,
  gene_chr = as.character(seqnames(genes.gr)),
  gene_TSS = start(genes.gr),
  peak_chr = as.character(seqnames(nearest_peaks)),
  peak_start = start(nearest_peaks),
  peak_end = end(nearest_peaks),
  distance = distances
)

results <- results %>% dplyr::mutate(group = case_when(ensembl %in% group1 ~ \group1\,
                                            ensembl %in% group2 ~ \group2\,
                                            TRUE ~ NA))

ggplot(results, aes(x = group, y = distance, fill = group)) + geom_violin() + geom_boxplot(outlier.shape = NA, width = 0.1, fill = \white\) + theme_bw() + ggtitle(\distance to nearest H3K27ac peak excluding gene body\) + scale_y_continuous(labels = label_kb_mb) + coord_cartesian(ylim = c(0, 250*1000))

  
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

##### binary group - excluding specific gene body

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XCIpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcIikpJGdlbmVcblxuXG5nZW5lLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcIm1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFwiK1wiLCBWMiwgVjMpLCBlbnNlbWJsID0gVjYsIGNociA9IFYxKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsLCBjaHIsIFRTUykgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGMoZ3JvdXAxLCBncm91cDIpKVxuZ2VuZXMuZ3IgPC0gR1JhbmdlcyhcbiAgc2VxbmFtZXMgPSBnZW5lLnRiJGNocixcbiAgcmFuZ2VzID0gSVJhbmdlcyhzdGFydCA9IGdlbmUudGIkVFNTLCBlbmQgPSBnZW5lLnRiJFRTUyksXG4gIGVuc2VtYmwgPSBnZW5lLnRiJGVuc2VtYmxcbilcblxuZ2VuZWJvZHkudGIgPC0gZ2VuZS50YiAlPiUgZHBseXI6Om11dGF0ZShzdGFydCA9IFRTUy0xMCoxMDAwLCBlbmQgPSBUU1MgKyAxMCoxMDAwKSAlPiVcbiAgZHBseXI6OnNlbGVjdChjaHIsIHN0YXJ0LCBlbmQpXG5nZW5lYm9keS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZWJvZHkudGIpXG5cbnBlYWsuSDNLMjdhYyA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcIkdTTTI0Mzg0NzZfRUMtREctMzQ1OC1IM0syN0FDX0FTWU5fMS5uYXJyb3dQZWFrLmJlZFwiKSlcblxuXG4jIFN0ZXAgMTogRmluZCBvdmVybGFwcyBiZXR3ZWVuIGdlbmUgYm9kaWVzIGFuZCBwZWFrc1xub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGdlbmVib2R5LmdyLCBwZWFrLkgzSzI3YWMpXG5cbiMgQ3JlYXRlIGEgbGlzdCBtYXBwaW5nIGVhY2ggZ2VuZSB0byB0aGUgaW5kaWNlcyBvZiBwZWFrcyBvdmVybGFwcGluZyB3aXRoIGl0cyBnZW5lIGJvZHlcbm92ZXJsYXBwaW5nX3BlYWtzX3Blcl9nZW5lIDwtIHNwbGl0KHN1YmplY3RIaXRzKG92ZXJsYXBzKSwgcXVlcnlIaXRzKG92ZXJsYXBzKSlcblxuIyBJbml0aWFsaXplIGFuIGVtcHR5IGxpc3QgdG8gc3RvcmUgcmVzdWx0c1xucmVzdWx0c19saXN0IDwtIHZlY3RvcihcImxpc3RcIiwgbGVuZ3RoKGdlbmVzLmdyKSlcblxuIyBTdGVwIDI6IEZvciBlYWNoIGdlbmUsIGV4Y2x1ZGUgb3ZlcmxhcHBpbmcgcGVha3MgYW5kIGZpbmQgdGhlIG5lYXJlc3QgcGVhayB0byBpdHMgVFNTXG5mb3IgKGkgaW4gc2VxX2Fsb25nKGdlbmVzLmdyKSkge1xuICBnZW5lIDwtIGdlbmVzLmdyW2ldXG4gIFxuICAjIEdldCBpbmRpY2VzIG9mIHBlYWtzIG92ZXJsYXBwaW5nIHdpdGggdGhpcyBnZW5lJ3MgYm9keVxuICBvdmVybGFwcGluZ19wZWFrX2luZGljZXMgPC0gb3ZlcmxhcHBpbmdfcGVha3NfcGVyX2dlbmVbW2FzLmNoYXJhY3RlcihpKV1dXG4gIFxuICAjIEV4Y2x1ZGUgb3ZlcmxhcHBpbmcgcGVha3MgZm9yIHRoaXMgZ2VuZVxuICBpZiAoIWlzLm51bGwob3ZlcmxhcHBpbmdfcGVha19pbmRpY2VzKSkge1xuICAgIHBlYWtzX3RvX2NvbnNpZGVyIDwtIHBlYWsuSDNLMjdhY1stb3ZlcmxhcHBpbmdfcGVha19pbmRpY2VzXVxuICB9IGVsc2Uge1xuICAgIHBlYWtzX3RvX2NvbnNpZGVyIDwtIHBlYWsuSDNLMjdhY1xuICB9XG4gIFxuICAjIEZpbmQgdGhlIG5lYXJlc3QgcGVhayB0byB0aGUgVFNTIG9mIHRoaXMgZ2VuZVxuICBuZWFyZXN0X3BlYWtfaW5kZXggPC0gbmVhcmVzdChnZW5lLCBwZWFrc190b19jb25zaWRlcilcbiAgXG4gIGlmIChpcy5uYShuZWFyZXN0X3BlYWtfaW5kZXgpKSB7XG4gICAgIyBObyBwZWFrcyBmb3VuZDsgc2V0IE5BIHZhbHVlc1xuICAgIHJlc3VsdHNfbGlzdFtbaV1dIDwtIGRhdGEuZnJhbWUoXG4gICAgICBlbnNlbWJsID0gbWNvbHMoZ2VuZSkkZW5zZW1ibCxcbiAgICAgIGdlbmVfY2hyID0gYXMuY2hhcmFjdGVyKHNlcW5hbWVzKGdlbmUpKSxcbiAgICAgIGdlbmVfVFNTID0gc3RhcnQoZ2VuZSksXG4gICAgICBwZWFrX2NociA9IE5BLFxuICAgICAgcGVha19zdGFydCA9IE5BLFxuICAgICAgcGVha19lbmQgPSBOQSxcbiAgICAgIGRpc3RhbmNlID0gTkFcbiAgICApXG4gIH0gZWxzZSB7XG4gICAgbmVhcmVzdF9wZWFrIDwtIHBlYWtzX3RvX2NvbnNpZGVyW25lYXJlc3RfcGVha19pbmRleF1cbiAgICBkaXN0IDwtIGRpc3RhbmNlKGdlbmUsIG5lYXJlc3RfcGVhaylcbiAgICBcbiAgICByZXN1bHRzX2xpc3RbW2ldXSA8LSBkYXRhLmZyYW1lKFxuICAgICAgZW5zZW1ibCA9IG1jb2xzKGdlbmUpJGVuc2VtYmwsXG4gICAgICBnZW5lX2NociA9IGFzLmNoYXJhY3RlcihzZXFuYW1lcyhnZW5lKSksXG4gICAgICBnZW5lX1RTUyA9IHN0YXJ0KGdlbmUpLFxuICAgICAgcGVha19jaHIgPSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMobmVhcmVzdF9wZWFrKSksXG4gICAgICBwZWFrX3N0YXJ0ID0gc3RhcnQobmVhcmVzdF9wZWFrKSxcbiAgICAgIHBlYWtfZW5kID0gZW5kKG5lYXJlc3RfcGVhayksXG4gICAgICBkaXN0YW5jZSA9IGRpc3RcbiAgICApXG4gIH1cbn1cblxuIyBDb21iaW5lIHJlc3VsdHMgaW50byBhIHNpbmdsZSBkYXRhIGZyYW1lXG5yZXN1bHRzIDwtIGRvLmNhbGwocmJpbmQsIHJlc3VsdHNfbGlzdClcblxuIyBBZGQgZ3JvdXAgaW5mb3JtYXRpb25cbnJlc3VsdHMgPC0gcmVzdWx0cyAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihcbiAgZW5zZW1ibCAlaW4lIGdyb3VwMSB+IFwiZ3JvdXAxXCIsXG4gIGVuc2VtYmwgJWluJSBncm91cDIgfiBcImdyb3VwMlwiLFxuICBUUlVFIH4gTkFfY2hhcmFjdGVyX1xuKSlcblxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZGlzdGFuY2VcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRkaXN0YW5jZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuZ2V0UHZhbFdpbGNveChyZXN1bHRzLCBcImdyb3VwMVwiLCBcImdyb3VwMlwiKVxuIyBQbG90dGluZ1xuZ2dwbG90KHJlc3VsdHMsIGFlcyh4ID0gZ3JvdXAsIHkgPSBkaXN0YW5jZSwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX3Zpb2xpbigpICtcbiAgZ2VvbV9ib3hwbG90KG91dGxpZXIuc2hhcGUgPSBOQSwgd2lkdGggPSAwLjEsIGZpbGwgPSBcIndoaXRlXCIpICtcbiAgdGhlbWVfYncoKSArXG4gIGdndGl0bGUoXCJEaXN0YW5jZSB0byBOZWFyZXN0IEgzSzI3YWMgUGVhayBFeGNsdWRpbmcgR2VuZSBCb2R5IE92ZXJsYXBzXCIpICtcbiAgc2NhbGVfeV9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iKSArXG4gIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygwLCA1MCAqIDEwMDApKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcInBvaW50XCIsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCIpIFxuYGBgIn0= -->\n\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3), ensembl = V6, chr = V1) %>%\n  dplyr::select(ensembl, chr, TSS) %>% dplyr::filter(ensembl %in% c(group1, group2))\ngenes.gr <- GRanges(\n  seqnames = gene.tb$chr,\n  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),\n  ensembl = gene.tb$ensembl\n)\n\ngenebody.tb <- gene.tb %>% dplyr::mutate(start = TSS-10*1000, end = TSS + 10*1000) %>%\n  dplyr::select(chr, start, end)\ngenebody.gr <- makeGRangesFromDataFrame(genebody.tb)\n\npeak.H3K27ac <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\n\n\n# Step 1: Find overlaps between gene bodies and peaks\noverlaps <- findOverlaps(genebody.gr, peak.H3K27ac)\n\n# Create a list mapping each gene to the indices of peaks overlapping with its gene body\noverlapping_peaks_per_gene <- split(subjectHits(overlaps), queryHits(overlaps))\n\n# Initialize an empty list to store results\nresults_list <- vector(\\list\\, length(genes.gr))\n\n# Step 2: For each gene, exclude overlapping peaks and find the nearest peak to its TSS\nfor (i in seq_along(genes.gr)) {\n  gene <- genes.gr[i]\n  \n  # Get indices of peaks overlapping with this gene's body\n  overlapping_peak_indices <- overlapping_peaks_per_gene[[as.character(i)]]\n  \n  # Exclude overlapping peaks for this gene\n  if (!is.null(overlapping_peak_indices)) {\n    peaks_to_consider <- peak.H3K27ac[-overlapping_peak_indices]\n  } else {\n    peaks_to_consider <- peak.H3K27ac\n  }\n  \n  # Find the nearest peak to the TSS of this gene\n  nearest_peak_index <- nearest(gene, peaks_to_consider)\n  \n  if (is.na(nearest_peak_index)) {\n    # No peaks found; set NA values\n    results_list[[i]] <- data.frame(\n      ensembl = mcols(gene)$ensembl,\n      gene_chr = as.character(seqnames(gene)),\n      gene_TSS = start(gene),\n      peak_chr = NA,\n      peak_start = NA,\n      peak_end = NA,\n      distance = NA\n    )\n  } else {\n    nearest_peak <- peaks_to_consider[nearest_peak_index]\n    dist <- distance(gene, nearest_peak)\n    \n    results_list[[i]] <- data.frame(\n      ensembl = mcols(gene)$ensembl,\n      gene_chr = as.character(seqnames(gene)),\n      gene_TSS = start(gene),\n      peak_chr = as.character(seqnames(nearest_peak)),\n      peak_start = start(nearest_peak),\n      peak_end = end(nearest_peak),\n      distance = dist\n    )\n  }\n}\n\n# Combine results into a single data frame\nresults <- do.call(rbind, results_list)\n\n# Add group information\nresults <- results %>% dplyr::mutate(group = case_when(\n  ensembl %in% group1 ~ \\group1\\,\n  ensembl %in% group2 ~ \\group2\\,\n  TRUE ~ NA_character_\n))\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$distance\n  distance2 <- (data %>% dplyr::filter(group == group2) )$distance\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ngetPvalWilcox(results, \\group1\\, \\group2\\)\n# Plotting\nggplot(results, aes(x = group, y = distance, fill = group)) +\n  geom_violin() +\n  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \\white\\) +\n  theme_bw() +\n  ggtitle(\\Distance to Nearest H3K27ac Peak Excluding Gene Body Overlaps\\) +\n  scale_y_continuous(labels = label_kb_mb) +\n  coord_cartesian(ylim = c(0, 50 * 1000)) +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) \n```\n\n<!-- rnb-source-end -->\n"} -->
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS) %>% dplyr::filter(ensembl %in% c(group1, group2))
genes.gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),
  ensembl = gene.tb$ensembl
)

genebody.tb <- gene.tb %>% dplyr::mutate(start = TSS-10*1000, end = TSS + 10*1000) %>%
  dplyr::select(chr, start, end)
genebody.gr <- makeGRangesFromDataFrame(genebody.tb)

peak.H3K27ac <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))


# Step 1: Find overlaps between gene bodies and peaks
overlaps <- findOverlaps(genebody.gr, peak.H3K27ac)

# Create a list mapping each gene to the indices of peaks overlapping with its gene body
overlapping_peaks_per_gene <- split(subjectHits(overlaps), queryHits(overlaps))

# Initialize an empty list to store results
results_list <- vector(\list\, length(genes.gr))

# Step 2: For each gene, exclude overlapping peaks and find the nearest peak to its TSS
for (i in seq_along(genes.gr)) {
  gene <- genes.gr[i]
  
  # Get indices of peaks overlapping with this gene's body
  overlapping_peak_indices <- overlapping_peaks_per_gene[[as.character(i)]]
  
  # Exclude overlapping peaks for this gene
  if (!is.null(overlapping_peak_indices)) {
    peaks_to_consider <- peak.H3K27ac[-overlapping_peak_indices]
  } else {
    peaks_to_consider <- peak.H3K27ac
  }
  
  # Find the nearest peak to the TSS of this gene
  nearest_peak_index <- nearest(gene, peaks_to_consider)
  
  if (is.na(nearest_peak_index)) {
    # No peaks found; set NA values
    results_list[[i]] <- data.frame(
      ensembl = mcols(gene)$ensembl,
      gene_chr = as.character(seqnames(gene)),
      gene_TSS = start(gene),
      peak_chr = NA,
      peak_start = NA,
      peak_end = NA,
      distance = NA
    )
  } else {
    nearest_peak <- peaks_to_consider[nearest_peak_index]
    dist <- distance(gene, nearest_peak)
    
    results_list[[i]] <- data.frame(
      ensembl = mcols(gene)$ensembl,
      gene_chr = as.character(seqnames(gene)),
      gene_TSS = start(gene),
      peak_chr = as.character(seqnames(nearest_peak)),
      peak_start = start(nearest_peak),
      peak_end = end(nearest_peak),
      distance = dist
    )
  }
}

# Combine results into a single data frame
results <- do.call(rbind, results_list)

# Add group information
results <- results %>% dplyr::mutate(group = case_when(
  ensembl %in% group1 ~ \group1\,
  ensembl %in% group2 ~ \group2\,
  TRUE ~ NA_character_
))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$distance
  distance2 <- (data %>% dplyr::filter(group == group2) )$distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

getPvalWilcox(results, \group1\, \group2\)
# Plotting
ggplot(results, aes(x = group, y = distance, fill = group)) +
  geom_violin() +
  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \white\) +
  theme_bw() +
  ggtitle(\Distance to Nearest H3K27ac Peak Excluding Gene Body Overlaps\) +
  scale_y_continuous(labels = label_kb_mb) +
  coord_cartesian(ylim = c(0, 50 * 1000)) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) 



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuXG5nZW5lLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpLCBlbnNlbWJsID0gVjYsIGNociA9IFYxKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsLCBjaHIsIFRTUykgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGMoZ3JvdXAxLCBncm91cDIpKVxuZ2VuZXMuZ3IgPC0gR1JhbmdlcyhcbiAgc2VxbmFtZXMgPSBnZW5lLnRiJGNocixcbiAgcmFuZ2VzID0gSVJhbmdlcyhzdGFydCA9IGdlbmUudGIkVFNTLCBlbmQgPSBnZW5lLnRiJFRTUyksXG4gIGVuc2VtYmwgPSBnZW5lLnRiJGVuc2VtYmxcbilcblxuZ2VuZWJvZHkudGIgPC0gZ2VuZS50YiAlPiUgZHBseXI6Om11dGF0ZShzdGFydCA9IFRTUy0xMCoxMDAwLCBlbmQgPSBUU1MgKyAxMCoxMDAwKSAlPiVcbiAgZHBseXI6OnNlbGVjdChjaHIsIHN0YXJ0LCBlbmQpXG5nZW5lYm9keS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZWJvZHkudGIpXG5cbnBlYWsuSDNLMjdhYyA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXEdTTTI0Mzg0NzZfRUMtREctMzQ1OC1IM0syN0FDX0FTWU5fMS5uYXJyb3dQZWFrLmJlZFxcKSlcblxuXG4jIFN0ZXAgMTogRmluZCBvdmVybGFwcyBiZXR3ZWVuIGdlbmUgYm9kaWVzIGFuZCBwZWFrc1xub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGdlbmVib2R5LmdyLCBwZWFrLkgzSzI3YWMpXG5cbiMgQ3JlYXRlIGEgbGlzdCBtYXBwaW5nIGVhY2ggZ2VuZSB0byB0aGUgaW5kaWNlcyBvZiBwZWFrcyBvdmVybGFwcGluZyB3aXRoIGl0cyBnZW5lIGJvZHlcbm92ZXJsYXBwaW5nX3BlYWtzX3Blcl9nZW5lIDwtIHNwbGl0KHN1YmplY3RIaXRzKG92ZXJsYXBzKSwgcXVlcnlIaXRzKG92ZXJsYXBzKSlcblxuIyBJbml0aWFsaXplIGFuIGVtcHR5IGxpc3QgdG8gc3RvcmUgcmVzdWx0c1xucmVzdWx0c19saXN0IDwtIHZlY3RvcihcXGxpc3RcXCwgbGVuZ3RoKGdlbmVzLmdyKSlcblxuIyBTdGVwIDI6IEZvciBlYWNoIGdlbmUsIGV4Y2x1ZGUgb3ZlcmxhcHBpbmcgcGVha3MgYW5kIGZpbmQgdGhlIG5lYXJlc3QgcGVhayB0byBpdHMgVFNTXG5mb3IgKGkgaW4gc2VxX2Fsb25nKGdlbmVzLmdyKSkge1xuICBnZW5lIDwtIGdlbmVzLmdyW2ldXG4gIFxuICAjIEdldCBpbmRpY2VzIG9mIHBlYWtzIG92ZXJsYXBwaW5nIHdpdGggdGhpcyBnZW5lJ3MgYm9keVxuICBvdmVybGFwcGluZ19wZWFrX2luZGljZXMgPC0gb3ZlcmxhcHBpbmdfcGVha3NfcGVyX2dlbmVbW2FzLmNoYXJhY3RlcihpKV1dXG4gIFxuICAjIEV4Y2x1ZGUgb3ZlcmxhcHBpbmcgcGVha3MgZm9yIHRoaXMgZ2VuZVxuICBpZiAoIWlzLm51bGwob3ZlcmxhcHBpbmdfcGVha19pbmRpY2VzKSkge1xuICAgIHBlYWtzX3RvX2NvbnNpZGVyIDwtIHBlYWsuSDNLMjdhY1stb3ZlcmxhcHBpbmdfcGVha19pbmRpY2VzXVxuICB9IGVsc2Uge1xuICAgIHBlYWtzX3RvX2NvbnNpZGVyIDwtIHBlYWsuSDNLMjdhY1xuICB9XG4gIFxuICAjIEZpbmQgdGhlIG5lYXJlc3QgcGVhayB0byB0aGUgVFNTIG9mIHRoaXMgZ2VuZVxuICBuZWFyZXN0X3BlYWtfaW5kZXggPC0gbmVhcmVzdChnZW5lLCBwZWFrc190b19jb25zaWRlcilcbiAgXG4gIGlmIChpcy5uYShuZWFyZXN0X3BlYWtfaW5kZXgpKSB7XG4gICAgIyBObyBwZWFrcyBmb3VuZDsgc2V0IE5BIHZhbHVlc1xuICAgIHJlc3VsdHNfbGlzdFtbaV1dIDwtIGRhdGEuZnJhbWUoXG4gICAgICBlbnNlbWJsID0gbWNvbHMoZ2VuZSkkZW5zZW1ibCxcbiAgICAgIGdlbmVfY2hyID0gYXMuY2hhcmFjdGVyKHNlcW5hbWVzKGdlbmUpKSxcbiAgICAgIGdlbmVfVFNTID0gc3RhcnQoZ2VuZSksXG4gICAgICBwZWFrX2NociA9IE5BLFxuICAgICAgcGVha19zdGFydCA9IE5BLFxuICAgICAgcGVha19lbmQgPSBOQSxcbiAgICAgIGRpc3RhbmNlID0gTkFcbiAgICApXG4gIH0gZWxzZSB7XG4gICAgbmVhcmVzdF9wZWFrIDwtIHBlYWtzX3RvX2NvbnNpZGVyW25lYXJlc3RfcGVha19pbmRleF1cbiAgICBkaXN0IDwtIGRpc3RhbmNlKGdlbmUsIG5lYXJlc3RfcGVhaylcbiAgICBcbiAgICByZXN1bHRzX2xpc3RbW2ldXSA8LSBkYXRhLmZyYW1lKFxuICAgICAgZW5zZW1ibCA9IG1jb2xzKGdlbmUpJGVuc2VtYmwsXG4gICAgICBnZW5lX2NociA9IGFzLmNoYXJhY3RlcihzZXFuYW1lcyhnZW5lKSksXG4gICAgICBnZW5lX1RTUyA9IHN0YXJ0KGdlbmUpLFxuICAgICAgcGVha19jaHIgPSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMobmVhcmVzdF9wZWFrKSksXG4gICAgICBwZWFrX3N0YXJ0ID0gc3RhcnQobmVhcmVzdF9wZWFrKSxcbiAgICAgIHBlYWtfZW5kID0gZW5kKG5lYXJlc3RfcGVhayksXG4gICAgICBkaXN0YW5jZSA9IGRpc3RcbiAgICApXG4gIH1cbn1cblxuIyBDb21iaW5lIHJlc3VsdHMgaW50byBhIHNpbmdsZSBkYXRhIGZyYW1lXG5yZXN1bHRzIDwtIGRvLmNhbGwocmJpbmQsIHJlc3VsdHNfbGlzdClcblxuIyBBZGQgZ3JvdXAgaW5mb3JtYXRpb25cbnJlc3VsdHMgPC0gcmVzdWx0cyAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihcbiAgZW5zZW1ibCAlaW4lIGdyb3VwMSB+IFxcZ3JvdXAxXFwsXG4gIGVuc2VtYmwgJWluJSBncm91cDIgfiBcXGdyb3VwMlxcLFxuICBUUlVFIH4gTkFfY2hhcmFjdGVyX1xuKSlcblxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZGlzdGFuY2VcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRkaXN0YW5jZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuZ2V0UHZhbFdpbGNveChyZXN1bHRzLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKVxuIyBQbG90dGluZ1xuZ2dwbG90KHJlc3VsdHMsIGFlcyh4ID0gZ3JvdXAsIHkgPSBkaXN0YW5jZSwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX3Zpb2xpbigpICtcbiAgZ2VvbV9ib3hwbG90KG91dGxpZXIuc2hhcGUgPSBOQSwgd2lkdGggPSAwLjEsIGZpbGwgPSBcXHdoaXRlXFwpICtcbiAgdGhlbWVfYncoKSArXG4gIGdndGl0bGUoXFxEaXN0YW5jZSB0byBOZWFyZXN0IEgzSzI3YWMgUGVhayBFeGNsdWRpbmcgR2VuZSBCb2R5IE92ZXJsYXBzXFwpICtcbiAgc2NhbGVfeV9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iKSArXG4gIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygwLCA1MCAqIDEwMDApKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpIFxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3), ensembl = V6, chr = V1) %>%\n  dplyr::select(ensembl, chr, TSS) %>% dplyr::filter(ensembl %in% c(group1, group2))\ngenes.gr <- GRanges(\n  seqnames = gene.tb$chr,\n  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),\n  ensembl = gene.tb$ensembl\n)\n\ngenebody.tb <- gene.tb %>% dplyr::mutate(start = TSS-10*1000, end = TSS + 10*1000) %>%\n  dplyr::select(chr, start, end)\ngenebody.gr <- makeGRangesFromDataFrame(genebody.tb)\n\npeak.H3K27ac <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\n\n\n# Step 1: Find overlaps between gene bodies and peaks\noverlaps <- findOverlaps(genebody.gr, peak.H3K27ac)\n\n# Create a list mapping each gene to the indices of peaks overlapping with its gene body\noverlapping_peaks_per_gene <- split(subjectHits(overlaps), queryHits(overlaps))\n\n# Initialize an empty list to store results\nresults_list <- vector(\\list\\, length(genes.gr))\n\n# Step 2: For each gene, exclude overlapping peaks and find the nearest peak to its TSS\nfor (i in seq_along(genes.gr)) {\n  gene <- genes.gr[i]\n  \n  # Get indices of peaks overlapping with this gene's body\n  overlapping_peak_indices <- overlapping_peaks_per_gene[[as.character(i)]]\n  \n  # Exclude overlapping peaks for this gene\n  if (!is.null(overlapping_peak_indices)) {\n    peaks_to_consider <- peak.H3K27ac[-overlapping_peak_indices]\n  } else {\n    peaks_to_consider <- peak.H3K27ac\n  }\n  \n  # Find the nearest peak to the TSS of this gene\n  nearest_peak_index <- nearest(gene, peaks_to_consider)\n  \n  if (is.na(nearest_peak_index)) {\n    # No peaks found; set NA values\n    results_list[[i]] <- data.frame(\n      ensembl = mcols(gene)$ensembl,\n      gene_chr = as.character(seqnames(gene)),\n      gene_TSS = start(gene),\n      peak_chr = NA,\n      peak_start = NA,\n      peak_end = NA,\n      distance = NA\n    )\n  } else {\n    nearest_peak <- peaks_to_consider[nearest_peak_index]\n    dist <- distance(gene, nearest_peak)\n    \n    results_list[[i]] <- data.frame(\n      ensembl = mcols(gene)$ensembl,\n      gene_chr = as.character(seqnames(gene)),\n      gene_TSS = start(gene),\n      peak_chr = as.character(seqnames(nearest_peak)),\n      peak_start = start(nearest_peak),\n      peak_end = end(nearest_peak),\n      distance = dist\n    )\n  }\n}\n\n# Combine results into a single data frame\nresults <- do.call(rbind, results_list)\n\n# Add group information\nresults <- results %>% dplyr::mutate(group = case_when(\n  ensembl %in% group1 ~ \\group1\\,\n  ensembl %in% group2 ~ \\group2\\,\n  TRUE ~ NA_character_\n))\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group == group1) )$distance\n  distance2 <- (data %>% dplyr::filter(group == group2) )$distance\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ngetPvalWilcox(results, \\group1\\, \\group2\\)\n# Plotting\nggplot(results, aes(x = group, y = distance, fill = group)) +\n  geom_violin() +\n  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \\white\\) +\n  theme_bw() +\n  ggtitle(\\Distance to Nearest H3K27ac Peak Excluding Gene Body Overlaps\\) +\n  scale_y_continuous(labels = label_kb_mb) +\n  coord_cartesian(ylim = c(0, 50 * 1000)) +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) \n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuXG5nZW5lLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpLCBlbnNlbWJsID0gVjYsIGNociA9IFYxKSAlPiVcbiAgZHBseXI6OnNlbGVjdChlbnNlbWJsLCBjaHIsIFRTUykgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGMoZ3JvdXAxLCBncm91cDIpKVxuZ2VuZXMuZ3IgPC0gR1JhbmdlcyhcbiAgc2VxbmFtZXMgPSBnZW5lLnRiJGNocixcbiAgcmFuZ2VzID0gSVJhbmdlcyhzdGFydCA9IGdlbmUudGIkVFNTLCBlbmQgPSBnZW5lLnRiJFRTUyksXG4gIGVuc2VtYmwgPSBnZW5lLnRiJGVuc2VtYmxcbilcblxuZ2VuZWJvZHkudGIgPC0gZ2VuZS50YiAlPiUgZHBseXI6Om11dGF0ZShzdGFydCA9IFRTUy0xMCoxMDAwLCBlbmQgPSBUU1MgKyAxMCoxMDAwKSAlPiVcbiAgZHBseXI6OnNlbGVjdChjaHIsIHN0YXJ0LCBlbmQpXG5nZW5lYm9keS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZWJvZHkudGIpXG5cbnBlYWsuSDNLMjdhYyA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXEdTTTI0Mzg0NzZfRUMtREctMzQ1OC1IM0syN0FDX0FTWU5fMS5uYXJyb3dQZWFrLmJlZFxcKSlcblxuXG4jIFN0ZXAgMTogRmluZCBvdmVybGFwcyBiZXR3ZWVuIGdlbmUgYm9kaWVzIGFuZCBwZWFrc1xub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGdlbmVib2R5LmdyLCBwZWFrLkgzSzI3YWMpXG5cbiMgQ3JlYXRlIGEgbGlzdCBtYXBwaW5nIGVhY2ggZ2VuZSB0byB0aGUgaW5kaWNlcyBvZiBwZWFrcyBvdmVybGFwcGluZyB3aXRoIGl0cyBnZW5lIGJvZHlcbm92ZXJsYXBwaW5nX3BlYWtzX3Blcl9nZW5lIDwtIHNwbGl0KHN1YmplY3RIaXRzKG92ZXJsYXBzKSwgcXVlcnlIaXRzKG92ZXJsYXBzKSlcblxuIyBJbml0aWFsaXplIGFuIGVtcHR5IGxpc3QgdG8gc3RvcmUgcmVzdWx0c1xucmVzdWx0c19saXN0IDwtIHZlY3RvcihcXGxpc3RcXCwgbGVuZ3RoKGdlbmVzLmdyKSlcblxuIyBTdGVwIDI6IEZvciBlYWNoIGdlbmUsIGV4Y2x1ZGUgb3ZlcmxhcHBpbmcgcGVha3MgYW5kIGZpbmQgdGhlIG5lYXJlc3QgcGVhayB0byBpdHMgVFNTXG5mb3IgKGkgaW4gc2VxX2Fsb25nKGdlbmVzLmdyKSkge1xuICBnZW5lIDwtIGdlbmVzLmdyW2ldXG4gIFxuICAjIEdldCBpbmRpY2VzIG9mIHBlYWtzIG92ZXJsYXBwaW5nIHdpdGggdGhpcyBnZW5lJ3MgYm9keVxuICBvdmVybGFwcGluZ19wZWFrX2luZGljZXMgPC0gb3ZlcmxhcHBpbmdfcGVha3NfcGVyX2dlbmVbW2FzLmNoYXJhY3RlcihpKV1dXG4gIFxuICAjIEV4Y2x1ZGUgb3ZlcmxhcHBpbmcgcGVha3MgZm9yIHRoaXMgZ2VuZVxuICBpZiAoIWlzLm51bGwob3ZlcmxhcHBpbmdfcGVha19pbmRpY2VzKSkge1xuICAgIHBlYWtzX3RvX2NvbnNpZGVyIDwtIHBlYWsuSDNLMjdhY1stb3ZlcmxhcHBpbmdfcGVha19pbmRpY2VzXVxuICB9IGVsc2Uge1xuICAgIHBlYWtzX3RvX2NvbnNpZGVyIDwtIHBlYWsuSDNLMjdhY1xuICB9XG4gIFxuICAjIEZpbmQgdGhlIG5lYXJlc3QgcGVhayB0byB0aGUgVFNTIG9mIHRoaXMgZ2VuZVxuICBuZWFyZXN0X3BlYWtfaW5kZXggPC0gbmVhcmVzdChnZW5lLCBwZWFrc190b19jb25zaWRlcilcbiAgXG4gIGlmIChpcy5uYShuZWFyZXN0X3BlYWtfaW5kZXgpKSB7XG4gICAgIyBObyBwZWFrcyBmb3VuZDsgc2V0IE5BIHZhbHVlc1xuICAgIHJlc3VsdHNfbGlzdFtbaV1dIDwtIGRhdGEuZnJhbWUoXG4gICAgICBlbnNlbWJsID0gbWNvbHMoZ2VuZSkkZW5zZW1ibCxcbiAgICAgIGdlbmVfY2hyID0gYXMuY2hhcmFjdGVyKHNlcW5hbWVzKGdlbmUpKSxcbiAgICAgIGdlbmVfVFNTID0gc3RhcnQoZ2VuZSksXG4gICAgICBwZWFrX2NociA9IE5BLFxuICAgICAgcGVha19zdGFydCA9IE5BLFxuICAgICAgcGVha19lbmQgPSBOQSxcbiAgICAgIGRpc3RhbmNlID0gTkFcbiAgICApXG4gIH0gZWxzZSB7XG4gICAgbmVhcmVzdF9wZWFrIDwtIHBlYWtzX3RvX2NvbnNpZGVyW25lYXJlc3RfcGVha19pbmRleF1cbiAgICBkaXN0IDwtIGRpc3RhbmNlKGdlbmUsIG5lYXJlc3RfcGVhaylcbiAgICBcbiAgICByZXN1bHRzX2xpc3RbW2ldXSA8LSBkYXRhLmZyYW1lKFxuICAgICAgZW5zZW1ibCA9IG1jb2xzKGdlbmUpJGVuc2VtYmwsXG4gICAgICBnZW5lX2NociA9IGFzLmNoYXJhY3RlcihzZXFuYW1lcyhnZW5lKSksXG4gICAgICBnZW5lX1RTUyA9IHN0YXJ0KGdlbmUpLFxuICAgICAgcGVha19jaHIgPSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMobmVhcmVzdF9wZWFrKSksXG4gICAgICBwZWFrX3N0YXJ0ID0gc3RhcnQobmVhcmVzdF9wZWFrKSxcbiAgICAgIHBlYWtfZW5kID0gZW5kKG5lYXJlc3RfcGVhayksXG4gICAgICBkaXN0YW5jZSA9IGRpc3RcbiAgICApXG4gIH1cbn1cblxuIyBDb21iaW5lIHJlc3VsdHMgaW50byBhIHNpbmdsZSBkYXRhIGZyYW1lXG5yZXN1bHRzIDwtIGRvLmNhbGwocmJpbmQsIHJlc3VsdHNfbGlzdClcblxuIyBBZGQgZ3JvdXAgaW5mb3JtYXRpb25cbnJlc3VsdHMgPC0gcmVzdWx0cyAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihcbiAgZW5zZW1ibCAlaW4lIGdyb3VwMSB+IFxcZ3JvdXAxXFwsXG4gIGVuc2VtYmwgJWluJSBncm91cDIgfiBcXGdyb3VwMlxcLFxuICBUUlVFIH4gTkFfY2hhcmFjdGVyX1xuKSlcblxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBncm91cDEpICkkZGlzdGFuY2VcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IGdyb3VwMikgKSRkaXN0YW5jZVxuICB3aWwgPC0gd2lsY294LnRlc3QoZGlzdGFuY2UxLCBkaXN0YW5jZTIpXG4gIHJldHVybih3aWwkcC52YWx1ZSlcbn1cblxuZ2V0UHZhbFdpbGNveChyZXN1bHRzLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKVxuIyBQbG90dGluZ1xuZ2dwbG90KHJlc3VsdHMsIGFlcyh4ID0gZ3JvdXAsIHkgPSBkaXN0YW5jZSwgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX3Zpb2xpbigpICtcbiAgZ2VvbV9ib3hwbG90KG91dGxpZXIuc2hhcGUgPSBOQSwgd2lkdGggPSAwLjEsIGZpbGwgPSBcXHdoaXRlXFwpICtcbiAgdGhlbWVfYncoKSArXG4gIGdndGl0bGUoXFxEaXN0YW5jZSB0byBOZWFyZXN0IEgzSzI3YWMgUGVhayBFeGNsdWRpbmcgR2VuZSBCb2R5IE92ZXJsYXBzXFwpICtcbiAgc2NhbGVfeV9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iKSArXG4gIGNvb3JkX2NhcnRlc2lhbih5bGltID0gYygwLCA1MCAqIDEwMDApKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpIFxuYGBgXG5gYGAifQ== -->

```r
```r
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS) %>% dplyr::filter(ensembl %in% c(group1, group2))
genes.gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),
  ensembl = gene.tb$ensembl
)

genebody.tb <- gene.tb %>% dplyr::mutate(start = TSS-10*1000, end = TSS + 10*1000) %>%
  dplyr::select(chr, start, end)
genebody.gr <- makeGRangesFromDataFrame(genebody.tb)

peak.H3K27ac <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))


# Step 1: Find overlaps between gene bodies and peaks
overlaps <- findOverlaps(genebody.gr, peak.H3K27ac)

# Create a list mapping each gene to the indices of peaks overlapping with its gene body
overlapping_peaks_per_gene <- split(subjectHits(overlaps), queryHits(overlaps))

# Initialize an empty list to store results
results_list <- vector(\list\, length(genes.gr))

# Step 2: For each gene, exclude overlapping peaks and find the nearest peak to its TSS
for (i in seq_along(genes.gr)) {
  gene <- genes.gr[i]
  
  # Get indices of peaks overlapping with this gene's body
  overlapping_peak_indices <- overlapping_peaks_per_gene[[as.character(i)]]
  
  # Exclude overlapping peaks for this gene
  if (!is.null(overlapping_peak_indices)) {
    peaks_to_consider <- peak.H3K27ac[-overlapping_peak_indices]
  } else {
    peaks_to_consider <- peak.H3K27ac
  }
  
  # Find the nearest peak to the TSS of this gene
  nearest_peak_index <- nearest(gene, peaks_to_consider)
  
  if (is.na(nearest_peak_index)) {
    # No peaks found; set NA values
    results_list[[i]] <- data.frame(
      ensembl = mcols(gene)$ensembl,
      gene_chr = as.character(seqnames(gene)),
      gene_TSS = start(gene),
      peak_chr = NA,
      peak_start = NA,
      peak_end = NA,
      distance = NA
    )
  } else {
    nearest_peak <- peaks_to_consider[nearest_peak_index]
    dist <- distance(gene, nearest_peak)
    
    results_list[[i]] <- data.frame(
      ensembl = mcols(gene)$ensembl,
      gene_chr = as.character(seqnames(gene)),
      gene_TSS = start(gene),
      peak_chr = as.character(seqnames(nearest_peak)),
      peak_start = start(nearest_peak),
      peak_end = end(nearest_peak),
      distance = dist
    )
  }
}

# Combine results into a single data frame
results <- do.call(rbind, results_list)

# Add group information
results <- results %>% dplyr::mutate(group = case_when(
  ensembl %in% group1 ~ \group1\,
  ensembl %in% group2 ~ \group2\,
  TRUE ~ NA_character_
))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$distance
  distance2 <- (data %>% dplyr::filter(group == group2) )$distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

getPvalWilcox(results, \group1\, \group2\)
# Plotting
ggplot(results, aes(x = group, y = distance, fill = group)) +
  geom_violin() +
  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \white\) +
  theme_bw() +
  ggtitle(\Distance to Nearest H3K27ac Peak Excluding Gene Body Overlaps\) +
  scale_y_continuous(labels = label_kb_mb) +
  coord_cartesian(ylim = c(0, 50 * 1000)) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) 
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### binary group - excluding all TSS +- 10kb

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVYRzVuY205MWNERWdQQzBnWm5KbFlXUW9hR1Z5WlNoeVpXWkVhWElzSUZ3aVoyVnVaVXhwYzNSZlpGUkJSMTkyYzE5RVRWTlBYMUpPUVY5c2IyOXdYMkpwYm1GeWVVZHliM1Z3TVM1MGMzWmNJaWtwSkdkbGJtVmNibWR5YjNWd01pQThMU0JtY21WaFpDaG9aWEpsS0hKbFprUnBjaXdnWENKblpXNWxUR2x6ZEY5a1ZFRkhYM1p6WDBSTlUwOWZVazVCWDJ4dmIzQmZZbWx1WVhKNVIzSnZkWEF5TG5SemRsd2lLU2trWjJWdVpWeHVYRzVjYmx4dWJtRnRaU0E4TFNCY0ltTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsY0lseHVYRzVuWlc1bFFXNXViMFJoZEdFZ1BDMGdiRzloWkV4dmIzQkJibTV2UkdGMFlTaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ3aVgzQXRjR1ZmWlc1elpXMWliRXhwYzNRdWRITjJYQ0lwS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdScFptWkRkWFJ2Wm1ZZ1BTQXdMaklwSUNVK0pWeHVJQ0JrY0d4NWNqbzZabWxzZEdWeUtFRnVibTh5SUQwOUlGd2lVQzFGWENJcFhHNWNiblJsYlhBZ1BDMGdaMlZ1WlVGdWJtOUVZWFJoSUNVK0pTQjFibTVsYzNRb1oyVnVaU2xjYmx4dVoyVnVaUzUwWWlBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYQ0p0YlRFd1gwZFNRMjB6T0M1d05sOW5aVzVsWDNOdmNuUmxaQzVpWldSY0lpa3BJQ1UrSlZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0ZSVFV5QTlJR2xtWld4elpTaFdOQ0E5UFNCY0lpdGNJaXdnVmpJc0lGWXpLU3dnWlc1elpXMWliQ0E5SUZZMkxDQmphSElnUFNCV01Ta2dKVDRsWEc0Z0lHUndiSGx5T2pwelpXeGxZM1FvWlc1elpXMWliQ3dnWTJoeUxDQlVVMU1wWEc1Y2JuUmxiWEFnUEMwZ1pIQnNlWEk2T214bFpuUmZhbTlwYmloMFpXMXdMQ0JuWlc1bExuUmlMQ0JpZVNBOUlHTW9YQ0puWlc1bFhDSWdQU0JjSW1WdWMyVnRZbXhjSWlrcFhHNWNiblJsYlhBZ1BDMGdkR1Z0Y0NBbFBpVWdaSEJzZVhJNk9tMTFkR0YwWlNoalpXNTBaWEl4SUQwZ0tITjBZWEowTVNBcklHVnVaREVwTHpJc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWTJWdWRHVnlNaUE5SUNoemRHRnlkRElnS3lCbGJtUXlLUzh5TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR1JwYzNSaGJtTmxNU0E5SUdGaWN5aFVVMU10WTJWdWRHVnlNU2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdaR2x6ZEdGdVkyVXlJRDBnWVdKektGUlRVeTFqWlc1MFpYSXlLU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHRkWFJoZEdVb1pHbHpkR0Z1WTJVZ1BTQndiV0Y0S0dScGMzUmhibU5sTVN3Z1pHbHpkR0Z1WTJVeUtTbGNibHh1ZEdWdGNDQThMU0IwWlcxd0lDVStKU0JuY205MWNGOWllU2huWlc1bEtTQWxQaVVnYzNWdGJXRnlhWHBsS0cxcGJsOWxibWhmWkdsemRHRnVZMlVnUFNCdGFXNG9aR2x6ZEdGdVkyVXBLU0FsUGlWY2JpQWdaSEJzZVhJNk9tMTFkR0YwWlNobmNtOTFjQ0E5SUdOaGMyVmZkMmhsYmloblpXNWxJQ1ZwYmlVZ1ozSnZkWEF4SUg0Z1hDSm5jbTkxY0RGY0lpeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQm5aVzVsSUNWcGJpVWdaM0p2ZFhBeUlINGdYQ0puY205MWNESmNJaXhjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JVVWxWRklINGdUa0VwS1NBbFBpVmNiaUFnWkhCc2VYSTZPbVpwYkhSbGNpZ2hhWE11Ym1Fb1ozSnZkWEFwS1Z4dVhHNWNibWRuY0d4dmRDaDBaVzF3TENCaFpYTW9lQ0E5SUdkeWIzVndMQ0I1SUQwZ2JXbHVYMlZ1YUY5a2FYTjBZVzVqWlN3Z1ptbHNiQ0E5SUdkeWIzVndLU2tnS3lCY2JpQWdaMlZ2YlY5MmFXOXNhVzRvS1NBclhHNGdJR2RsYjIxZlltOTRjR3h2ZENodmRYUnNhV1Z5TG5Ob1lYQmxJRDBnVGtFc0lIZHBaSFJvSUQwZ01DNHhMQ0JtYVd4c0lEMGdYQ0ozYUdsMFpWd2lLU0FyWEc0Z0lIUm9aVzFsWDJKM0tDa2dLMXh1SUNCblozUnBkR3hsS0Z3aVJHbHpkR0Z1WTJVZ2RHOGdUbVZoY21WemRDQkZibWhoYm1ObGNpQm1jbThnUlMxUVhDSXBJQ3RjYmlBZ2MyTmhiR1ZmZVY5amIyNTBhVzUxYjNWektHeGhZbVZzY3lBOUlHeGhZbVZzWDJ0aVgyMWlLU0FnSzF4dUlDQmpiMjl5WkY5allYSjBaWE5wWVc0b2VXeHBiU0E5SUdNb01Dd2dNVEF3TUNBcUlERXdNREFwS1Z4dVhHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuXG5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG5cblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3AtcGVfZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIpICU+JVxuICBkcGx5cjo6ZmlsdGVyKEFubm8yID09IFxcUC1FXFwpXG5cbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSB1bm5lc3QoZ2VuZSlcblxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSwgZW5zZW1ibCA9IFY2LCBjaHIgPSBWMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibCwgY2hyLCBUU1MpXG5cbnRlbXAgPC0gZHBseXI6OmxlZnRfam9pbih0ZW1wLCBnZW5lLnRiLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxcXCkpXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShjZW50ZXIxID0gKHN0YXJ0MSArIGVuZDEpLzIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyMiA9IChzdGFydDIgKyBlbmQyKS8yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpc3RhbmNlMSA9IGFicyhUU1MtY2VudGVyMSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlzdGFuY2UyID0gYWJzKFRTUy1jZW50ZXIyKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBwbWF4KGRpc3RhbmNlMSwgZGlzdGFuY2UyKSlcblxudGVtcCA8LSB0ZW1wICU+JSBncm91cF9ieShnZW5lKSAlPiUgc3VtbWFyaXplKG1pbl9lbmhfZGlzdGFuY2UgPSBtaW4oZGlzdGFuY2UpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihnZW5lICVpbiUgZ3JvdXAxIH4gXFxncm91cDFcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgZ3JvdXAyIH4gXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbmdncGxvdCh0ZW1wLCBhZXMoeCA9IGdyb3VwLCB5ID0gbWluX2VuaF9kaXN0YW5jZSwgZmlsbCA9IGdyb3VwKSkgKyBcbiAgZ2VvbV92aW9saW4oKSArXG4gIGdlb21fYm94cGxvdChvdXRsaWVyLnNoYXBlID0gTkEsIHdpZHRoID0gMC4xLCBmaWxsID0gXFx3aGl0ZVxcKSArXG4gIHRoZW1lX2J3KCkgK1xuICBnZ3RpdGxlKFxcRGlzdGFuY2UgdG8gTmVhcmVzdCBFbmhhbmNlciBmcm8gRS1QXFwpICtcbiAgc2NhbGVfeV9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iKSAgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgMTAwMCAqIDEwMDApKVxuXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->

group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene



name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-pe_ensemblList.tsv\)),
                                 diffCutoff = 0.2) %>%
  dplyr::filter(Anno2 == \P-E\)

temp <- geneAnnoData %>% unnest(gene)

gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS)

temp <- dplyr::left_join(temp, gene.tb, by = c(\gene\ = \ensembl\))

temp <- temp %>% dplyr::mutate(center1 = (start1 + end1)/2,
                               center2 = (start2 + end2)/2,
                               distance1 = abs(TSS-center1),
                               distance2 = abs(TSS-center2)) %>%
  dplyr::mutate(distance = pmax(distance1, distance2))

temp <- temp %>% group_by(gene) %>% summarize(min_enh_distance = min(distance)) %>%
  dplyr::mutate(group = case_when(gene %in% group1 ~ \group1\,
                                  gene %in% group2 ~ \group2\,
                                  TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(temp, aes(x = group, y = min_enh_distance, fill = group)) + 
  geom_violin() +
  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \white\) +
  theme_bw() +
  ggtitle(\Distance to Nearest Enhancer fro E-P\) +
  scale_y_continuous(labels = label_kb_mb)  +
  coord_cartesian(ylim = c(0, 1000 * 1000))



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVhHNW5jbTkxY0RFZ1BDMGdabkpsWVdRb2FHVnlaU2h5WldaRWFYSXNJRnhjWjJWdVpVeHBjM1JmWkZSQlIxOTJjMTlFVFZOUFgxSk9RVjlzYjI5d1gySnBibUZ5ZVVkeWIzVndNUzUwYzNaY1hDa3BKR2RsYm1WY2JtZHliM1Z3TWlBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYRnhuWlc1bFRHbHpkRjlrVkVGSFgzWnpYMFJOVTA5ZlVrNUJYMnh2YjNCZlltbHVZWEo1UjNKdmRYQXlMblJ6ZGx4Y0tTa2taMlZ1WlZ4dVhHNWNibHh1Ym1GdFpTQThMU0JjWEdOb2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxjWEZ4dVhHNW5aVzVsUVc1dWIwUmhkR0VnUEMwZ2JHOWhaRXh2YjNCQmJtNXZSR0YwWVNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRnhjWDNBdGNHVmZaVzV6WlcxaWJFeHBjM1F1ZEhOMlhGd3BLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR1JwWm1aRGRYUnZabVlnUFNBd0xqSXBJQ1UrSlZ4dUlDQmtjR3g1Y2pvNlptbHNkR1Z5S0VGdWJtOHlJRDA5SUZ4Y1VDMUZYRndwWEc1Y2JuUmxiWEFnUEMwZ1oyVnVaVUZ1Ym05RVlYUmhJQ1UrSlNCMWJtNWxjM1FvWjJWdVpTbGNibHh1WjJWdVpTNTBZaUE4TFNCbWNtVmhaQ2hvWlhKbEtISmxaa1JwY2l3Z1hGeHRiVEV3WDBkU1EyMHpPQzV3Tmw5blpXNWxYM052Y25SbFpDNWlaV1JjWENrcElDVStKVnh1SUNCa2NHeDVjam82YlhWMFlYUmxLRlJUVXlBOUlHbG1aV3h6WlNoV05DQTlQU0JjWEN0Y1hDd2dWaklzSUZZektTd2daVzV6WlcxaWJDQTlJRlkyTENCamFISWdQU0JXTVNrZ0pUNGxYRzRnSUdSd2JIbHlPanB6Wld4bFkzUW9aVzV6WlcxaWJDd2dZMmh5TENCVVUxTXBYRzVjYm5SbGJYQWdQQzBnWkhCc2VYSTZPbXhsWm5SZmFtOXBiaWgwWlcxd0xDQm5aVzVsTG5SaUxDQmllU0E5SUdNb1hGeG5aVzVsWEZ3Z1BTQmNYR1Z1YzJWdFlteGNYQ2twWEc1Y2JuUmxiWEFnUEMwZ2RHVnRjQ0FsUGlVZ1pIQnNlWEk2T20xMWRHRjBaU2hqWlc1MFpYSXhJRDBnS0hOMFlYSjBNU0FySUdWdVpERXBMeklzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdZMlZ1ZEdWeU1pQTlJQ2h6ZEdGeWRESWdLeUJsYm1ReUtTOHlMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHUnBjM1JoYm1ObE1TQTlJR0ZpY3loVVUxTXRZMlZ1ZEdWeU1Ta3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1pHbHpkR0Z1WTJVeUlEMGdZV0p6S0ZSVFV5MWpaVzUwWlhJeUtTa2dKVDRsWEc0Z0lHUndiSGx5T2pwdGRYUmhkR1VvWkdsemRHRnVZMlVnUFNCd2JXRjRLR1JwYzNSaGJtTmxNU3dnWkdsemRHRnVZMlV5S1NsY2JseHVkR1Z0Y0NBOExTQjBaVzF3SUNVK0pTQm5jbTkxY0Y5aWVTaG5aVzVsS1NBbFBpVWdjM1Z0YldGeWFYcGxLRzFwYmw5bGJtaGZaR2x6ZEdGdVkyVWdQU0J0YVc0b1pHbHpkR0Z1WTJVcEtTQWxQaVZjYmlBZ1pIQnNlWEk2T20xMWRHRjBaU2huY205MWNDQTlJR05oYzJWZmQyaGxiaWhuWlc1bElDVnBiaVVnWjNKdmRYQXhJSDRnWEZ4bmNtOTFjREZjWEN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCblpXNWxJQ1ZwYmlVZ1ozSnZkWEF5SUg0Z1hGeG5jbTkxY0RKY1hDeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQlVVbFZGSUg0Z1RrRXBLU0FsUGlWY2JpQWdaSEJzZVhJNk9tWnBiSFJsY2lnaGFYTXVibUVvWjNKdmRYQXBLVnh1WEc1Y2JtZG5jR3h2ZENoMFpXMXdMQ0JoWlhNb2VDQTlJR2R5YjNWd0xDQjVJRDBnYldsdVgyVnVhRjlrYVhOMFlXNWpaU3dnWm1sc2JDQTlJR2R5YjNWd0tTa2dLeUJjYmlBZ1oyVnZiVjkyYVc5c2FXNG9LU0FyWEc0Z0lHZGxiMjFmWW05NGNHeHZkQ2h2ZFhSc2FXVnlMbk5vWVhCbElEMGdUa0VzSUhkcFpIUm9JRDBnTUM0eExDQm1hV3hzSUQwZ1hGeDNhR2wwWlZ4Y0tTQXJYRzRnSUhSb1pXMWxYMkozS0NrZ0sxeHVJQ0JuWjNScGRHeGxLRnhjUkdsemRHRnVZMlVnZEc4Z1RtVmhjbVZ6ZENCRmJtaGhibU5sY2lCbWNtOGdSUzFRWEZ3cElDdGNiaUFnYzJOaGJHVmZlVjlqYjI1MGFXNTFiM1Z6S0d4aFltVnNjeUE5SUd4aFltVnNYMnRpWDIxaUtTQWdLMXh1SUNCamIyOXlaRjlqWVhKMFpYTnBZVzRvZVd4cGJTQTlJR01vTUN3Z01UQXdNQ0FxSURFd01EQXBLVnh1WEc1Z1lHQmNibUJnWUNKOSAtLT5cblxuYGBgclxuYGBgclxuXG5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG5cblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3AtcGVfZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIpICU+JVxuICBkcGx5cjo6ZmlsdGVyKEFubm8yID09IFxcUC1FXFwpXG5cbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSB1bm5lc3QoZ2VuZSlcblxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSwgZW5zZW1ibCA9IFY2LCBjaHIgPSBWMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibCwgY2hyLCBUU1MpXG5cbnRlbXAgPC0gZHBseXI6OmxlZnRfam9pbih0ZW1wLCBnZW5lLnRiLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxcXCkpXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShjZW50ZXIxID0gKHN0YXJ0MSArIGVuZDEpLzIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyMiA9IChzdGFydDIgKyBlbmQyKS8yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpc3RhbmNlMSA9IGFicyhUU1MtY2VudGVyMSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlzdGFuY2UyID0gYWJzKFRTUy1jZW50ZXIyKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBwbWF4KGRpc3RhbmNlMSwgZGlzdGFuY2UyKSlcblxudGVtcCA8LSB0ZW1wICU+JSBncm91cF9ieShnZW5lKSAlPiUgc3VtbWFyaXplKG1pbl9lbmhfZGlzdGFuY2UgPSBtaW4oZGlzdGFuY2UpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihnZW5lICVpbiUgZ3JvdXAxIH4gXFxncm91cDFcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgZ3JvdXAyIH4gXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbmdncGxvdCh0ZW1wLCBhZXMoeCA9IGdyb3VwLCB5ID0gbWluX2VuaF9kaXN0YW5jZSwgZmlsbCA9IGdyb3VwKSkgKyBcbiAgZ2VvbV92aW9saW4oKSArXG4gIGdlb21fYm94cGxvdChvdXRsaWVyLnNoYXBlID0gTkEsIHdpZHRoID0gMC4xLCBmaWxsID0gXFx3aGl0ZVxcKSArXG4gIHRoZW1lX2J3KCkgK1xuICBnZ3RpdGxlKFxcRGlzdGFuY2UgdG8gTmVhcmVzdCBFbmhhbmNlciBmcm8gRS1QXFwpICtcbiAgc2NhbGVfeV9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iKSAgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgMTAwMCAqIDEwMDApKVxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG5cblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG5nZW5lQW5ub0RhdGEgPC0gbG9hZExvb3BBbm5vRGF0YShoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcX3AtcGVfZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIpICU+JVxuICBkcGx5cjo6ZmlsdGVyKEFubm8yID09IFxcUC1FXFwpXG5cbnRlbXAgPC0gZ2VuZUFubm9EYXRhICU+JSB1bm5lc3QoZ2VuZSlcblxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSwgZW5zZW1ibCA9IFY2LCBjaHIgPSBWMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZW5zZW1ibCwgY2hyLCBUU1MpXG5cbnRlbXAgPC0gZHBseXI6OmxlZnRfam9pbih0ZW1wLCBnZW5lLnRiLCBieSA9IGMoXFxnZW5lXFwgPSBcXGVuc2VtYmxcXCkpXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShjZW50ZXIxID0gKHN0YXJ0MSArIGVuZDEpLzIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2VudGVyMiA9IChzdGFydDIgKyBlbmQyKS8yLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpc3RhbmNlMSA9IGFicyhUU1MtY2VudGVyMSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlzdGFuY2UyID0gYWJzKFRTUy1jZW50ZXIyKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBwbWF4KGRpc3RhbmNlMSwgZGlzdGFuY2UyKSlcblxudGVtcCA8LSB0ZW1wICU+JSBncm91cF9ieShnZW5lKSAlPiUgc3VtbWFyaXplKG1pbl9lbmhfZGlzdGFuY2UgPSBtaW4oZGlzdGFuY2UpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihnZW5lICVpbiUgZ3JvdXAxIH4gXFxncm91cDFcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgZ3JvdXAyIH4gXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbmdncGxvdCh0ZW1wLCBhZXMoeCA9IGdyb3VwLCB5ID0gbWluX2VuaF9kaXN0YW5jZSwgZmlsbCA9IGdyb3VwKSkgKyBcbiAgZ2VvbV92aW9saW4oKSArXG4gIGdlb21fYm94cGxvdChvdXRsaWVyLnNoYXBlID0gTkEsIHdpZHRoID0gMC4xLCBmaWxsID0gXFx3aGl0ZVxcKSArXG4gIHRoZW1lX2J3KCkgK1xuICBnZ3RpdGxlKFxcRGlzdGFuY2UgdG8gTmVhcmVzdCBFbmhhbmNlciBmcm8gRS1QXFwpICtcbiAgc2NhbGVfeV9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iKSAgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoMCwgMTAwMCAqIDEwMDApKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r

group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene



name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-pe_ensemblList.tsv\)),
                                 diffCutoff = 0.2) %>%
  dplyr::filter(Anno2 == \P-E\)

temp <- geneAnnoData %>% unnest(gene)

gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS)

temp <- dplyr::left_join(temp, gene.tb, by = c(\gene\ = \ensembl\))

temp <- temp %>% dplyr::mutate(center1 = (start1 + end1)/2,
                               center2 = (start2 + end2)/2,
                               distance1 = abs(TSS-center1),
                               distance2 = abs(TSS-center2)) %>%
  dplyr::mutate(distance = pmax(distance1, distance2))

temp <- temp %>% group_by(gene) %>% summarize(min_enh_distance = min(distance)) %>%
  dplyr::mutate(group = case_when(gene %in% group1 ~ \group1\,
                                  gene %in% group2 ~ \group2\,
                                  TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(temp, aes(x = group, y = min_enh_distance, fill = group)) + 
  geom_violin() +
  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \white\) +
  theme_bw() +
  ggtitle(\Distance to Nearest Enhancer fro E-P\) +
  scale_y_continuous(labels = label_kb_mb)  +
  coord_cartesian(ylim = c(0, 1000 * 1000))

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### binary group - excluding specific TSS +- 10 kb

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcIl9wLW5fZW5zZW1ibExpc3QudHN2XCIpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIpXG5cblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKHNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIHNpemUsIFYyLCBWNSwgc2VwID0gXCJfXCIpKVxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKHNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIHNpemUsIFYyLCBWNSwgc2VwID0gXCJfXCIpKVxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX2RUQUd2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBzaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcblxuZ2VuZUFubm9EYXRhIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGMobG9vcC51cCRpZCwgbG9vcC5ubyRpZCwgbG9vcC5kb3duJGlkKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUobG9vcFR5cGUgPSBjYXNlX3doZW4oaWQgJWluJSBjKGxvb3AudXAkaWQsIGxvb3Aubm8kaWQpIH4gXCJpbnNlbnNpdGl2ZVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlkICVpbiUgYyhsb29wLmRvd24kaWQpIH4gXCJzZW5zaXRpdmVcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKVxuXG5kYXRhIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChnZW5lLCBpZCwgbG9vcFR5cGUpICU+JSB1bm5lc3QoZ2VuZSkgJT4lXG4gIGdyb3VwX2J5KGdlbmUpICU+JSBzdW1tYXJpemUoXG4gICAgaW5zZW5zaXRpdmUgPSBzdW0obG9vcFR5cGUgPT0gXCJpbnNlbnNpdGl2ZVwiLCBuYS5ybSA9IFRSVUUpLFxuICAgIHNlbnNpdGl2ZSA9IHN1bShsb29wVHlwZSA9PSBcInNlbnNpdGl2ZVwiLCBuYS5ybSA9IFRSVUUpKVxuXG5cblxuIyMjXG5cbmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlwiKSkkZ2VuZVxuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XCIpKSRnZW5lXG5cbmdlbmVHcm91cCA8LSB0aWJibGUoZ3JvdXAgPSBjKHJlcChcImdyb3VwMVwiLCBsZW5ndGgoZ3JvdXAxKSksIHJlcChcImdyb3VwMlwiLCBsZW5ndGgoZ3JvdXAyKSkpLFxuICAgICAgICAgICAgICAgICAgICBnZW5lID0gYyhncm91cDEsIGdyb3VwMikpXG5cbmRhdGEgPC0gbGVmdF9qb2luKGdlbmVHcm91cCwgZGF0YSwgYnkgPSBjKFwiZ2VuZVwiKSkgJT4lIGRwbHlyOjptdXRhdGUobXV0YXRlKGFjcm9zcyhldmVyeXRoaW5nKCksIH5yZXBsYWNlX25hKC4sIDApKSkpXG5cblxuIyMjXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUocHJlc2VuY2VPZlJldGFpbmVkID0gaWZfZWxzZShpbnNlbnNpdGl2ZSA+IDAsIFwiWUVTXCIsIFwiTk9cIiksXG4gICAgICAgICAgICAgICAgICAgICAgIHBlcmNPZlJldGFpbmVkID0gaWZfZWxzZShpbnNlbnNpdGl2ZSArIHNlbnNpdGl2ZSA9PSAwLCAwLCAxMDAqaW5zZW5zaXRpdmUvKGluc2Vuc2l0aXZlICsgc2Vuc2l0aXZlKSkpXG5cblxuIyMjXG5nZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IHBlcmNPZlJldGFpbmVkLCBmaWxsID0gZ3JvdXApKSArIGdlb21fdmlvbGluKCkgKyBcbiAgZ2VvbV9ib3hwbG90KG91dGxpZXIuc2hhcGUgPSBOQSwgd2lkdGggPSAwLjEsIGZpbGwgPSBcIndoaXRlXCIpICsgdGhlbWVfYncoKVxuXG5cbiMjIyBTdGFja2VkIGJhcnBsb3Rcbmdyb3VwIDwtIGMoXCJncm91cDFcIiwgXCJncm91cDFcIiwgXCJncm91cDJcIiwgXCJncm91cDJcIilcbnByZXNlbmNlT2ZSZXRhaW5lZCA8LSByZXAoYyhcIllFU1wiLCBcIk5PXCIpLCAyKVxucHJlc2VuY2VPZlJldGFpbmVkIDwtIGZhY3RvciAocHJlc2VuY2VPZlJldGFpbmVkLCBsZXZlbHMgPSBjKFwiWUVTXCIsIFwiTk9cIikpXG52YWx1ZSA8LSBjKG5yb3coZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcImdyb3VwMVwiLCBwcmVzZW5jZU9mUmV0YWluZWQgPT0gXCJZRVNcIikpLFxuICAgICAgICAgICBucm93KGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXCJncm91cDFcIiwgcHJlc2VuY2VPZlJldGFpbmVkID09IFwiTk9cIikpLFxuICAgICAgICAgICBucm93KGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXCJncm91cDJcIiwgcHJlc2VuY2VPZlJldGFpbmVkID09IFwiWUVTXCIpKSxcbiAgICAgICAgICAgbnJvdyhkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IFwiZ3JvdXAyXCIsIHByZXNlbmNlT2ZSZXRhaW5lZCA9PSBcIk5PXCIpKSlcbnBsb3REYXRhIDwtIGRhdGEuZnJhbWUoZ3JvdXAsIHByZXNlbmNlT2ZSZXRhaW5lZCwgdmFsdWUpXG5cbmdncGxvdChwbG90RGF0YSwgYWVzKGZpbGw9cHJlc2VuY2VPZlJldGFpbmVkLCB5PXZhbHVlLCB4PWdyb3VwKSkgKyBcbiAgICBnZW9tX2Jhcihwb3NpdGlvbj1cImZpbGxcIiwgc3RhdD1cImlkZW50aXR5XCIpICsgdGhlbWVfY2xhc3NpYygpXG5cblxuYGBgIn0= -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                 diffCutoff = 0.2)\n\n\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(size = V3 - V2,\n                id = paste(V1, size, V2, V5, sep = \\_\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(size = V3 - V2,\n                id = paste(V1, size, V2, V5, sep = \\_\\))\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(size = V3 - V2,\n                id = paste(V1, size, V2, V5, sep = \\_\\))\n\ngeneAnnoData <- geneAnnoData %>% dplyr::filter(id %in% c(loop.up$id, loop.no$id, loop.down$id)) %>%\n  dplyr::mutate(loopType = case_when(id %in% c(loop.up$id, loop.no$id) ~ \\insensitive\\,\n                                     id %in% c(loop.down$id) ~ \\sensitive\\,\n                                     TRUE ~ NA))\n\ndata <- geneAnnoData %>% dplyr::select(gene, id, loopType) %>% unnest(gene) %>%\n  group_by(gene) %>% summarize(\n    insensitive = sum(loopType == \\insensitive\\, na.rm = TRUE),\n    sensitive = sum(loopType == \\sensitive\\, na.rm = TRUE))\n\n\n\n###\n\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ngeneGroup <- tibble(group = c(rep(\\group1\\, length(group1)), rep(\\group2\\, length(group2))),\n                    gene = c(group1, group2))\n\ndata <- left_join(geneGroup, data, by = c(\\gene\\)) %>% dplyr::mutate(mutate(across(everything(), ~replace_na(., 0))))\n\n\n###\ndata <- data %>% dplyr::mutate(presenceOfRetained = if_else(insensitive > 0, \\YES\\, \\NO\\),\n                       percOfRetained = if_else(insensitive + sensitive == 0, 0, 100*insensitive/(insensitive + sensitive)))\n\n\n###\nggplot(data, aes(x = group, y = percOfRetained, fill = group)) + geom_violin() + \n  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \\white\\) + theme_bw()\n\n\n### Stacked barplot\ngroup <- c(\\group1\\, \\group1\\, \\group2\\, \\group2\\)\npresenceOfRetained <- rep(c(\\YES\\, \\NO\\), 2)\npresenceOfRetained <- factor (presenceOfRetained, levels = c(\\YES\\, \\NO\\))\nvalue <- c(nrow(data %>% dplyr::filter(group == \\group1\\, presenceOfRetained == \\YES\\)),\n           nrow(data %>% dplyr::filter(group == \\group1\\, presenceOfRetained == \\NO\\)),\n           nrow(data %>% dplyr::filter(group == \\group2\\, presenceOfRetained == \\YES\\)),\n           nrow(data %>% dplyr::filter(group == \\group2\\, presenceOfRetained == \\NO\\)))\nplotData <- data.frame(group, presenceOfRetained, value)\n\nggplot(plotData, aes(fill=presenceOfRetained, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                 diffCutoff = 0.2)


loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = \_\))

geneAnnoData <- geneAnnoData %>% dplyr::filter(id %in% c(loop.up$id, loop.no$id, loop.down$id)) %>%
  dplyr::mutate(loopType = case_when(id %in% c(loop.up$id, loop.no$id) ~ \insensitive\,
                                     id %in% c(loop.down$id) ~ \sensitive\,
                                     TRUE ~ NA))

data <- geneAnnoData %>% dplyr::select(gene, id, loopType) %>% unnest(gene) %>%
  group_by(gene) %>% summarize(
    insensitive = sum(loopType == \insensitive\, na.rm = TRUE),
    sensitive = sum(loopType == \sensitive\, na.rm = TRUE))



###

group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

geneGroup <- tibble(group = c(rep(\group1\, length(group1)), rep(\group2\, length(group2))),
                    gene = c(group1, group2))

data <- left_join(geneGroup, data, by = c(\gene\)) %>% dplyr::mutate(mutate(across(everything(), ~replace_na(., 0))))


###
data <- data %>% dplyr::mutate(presenceOfRetained = if_else(insensitive > 0, \YES\, \NO\),
                       percOfRetained = if_else(insensitive + sensitive == 0, 0, 100*insensitive/(insensitive + sensitive)))


###
ggplot(data, aes(x = group, y = percOfRetained, fill = group)) + geom_violin() + 
  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \white\) + theme_bw()


### Stacked barplot
group <- c(\group1\, \group1\, \group2\, \group2\)
presenceOfRetained <- rep(c(\YES\, \NO\), 2)
presenceOfRetained <- factor (presenceOfRetained, levels = c(\YES\, \NO\))
value <- c(nrow(data %>% dplyr::filter(group == \group1\, presenceOfRetained == \YES\)),
           nrow(data %>% dplyr::filter(group == \group1\, presenceOfRetained == \NO\)),
           nrow(data %>% dplyr::filter(group == \group2\, presenceOfRetained == \YES\)),
           nrow(data %>% dplyr::filter(group == \group2\, presenceOfRetained == \NO\)))
plotData <- data.frame(group, presenceOfRetained, value)

ggplot(plotData, aes(fill=presenceOfRetained, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLW5fZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIpXG5cblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIHNpemUsIFYyLCBWNSwgc2VwID0gXFxfXFwpKVxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIHNpemUsIFYyLCBWNSwgc2VwID0gXFxfXFwpKVxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX2RUQUd2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBzaXplLCBWMiwgVjUsIHNlcCA9IFxcX1xcKSlcblxuZ2VuZUFubm9EYXRhIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGMobG9vcC51cCRpZCwgbG9vcC5ubyRpZCwgbG9vcC5kb3duJGlkKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUobG9vcFR5cGUgPSBjYXNlX3doZW4oaWQgJWluJSBjKGxvb3AudXAkaWQsIGxvb3Aubm8kaWQpIH4gXFxpbnNlbnNpdGl2ZVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlkICVpbiUgYyhsb29wLmRvd24kaWQpIH4gXFxzZW5zaXRpdmVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKVxuXG5kYXRhIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChnZW5lLCBpZCwgbG9vcFR5cGUpICU+JSB1bm5lc3QoZ2VuZSkgJT4lXG4gIGdyb3VwX2J5KGdlbmUpICU+JSBzdW1tYXJpemUoXG4gICAgaW5zZW5zaXRpdmUgPSBzdW0obG9vcFR5cGUgPT0gXFxpbnNlbnNpdGl2ZVxcLCBuYS5ybSA9IFRSVUUpLFxuICAgIHNlbnNpdGl2ZSA9IHN1bShsb29wVHlwZSA9PSBcXHNlbnNpdGl2ZVxcLCBuYS5ybSA9IFRSVUUpKVxuXG5cblxuIyMjXG5cbmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlxcKSkkZ2VuZVxuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XFwpKSRnZW5lXG5cbmdlbmVHcm91cCA8LSB0aWJibGUoZ3JvdXAgPSBjKHJlcChcXGdyb3VwMVxcLCBsZW5ndGgoZ3JvdXAxKSksIHJlcChcXGdyb3VwMlxcLCBsZW5ndGgoZ3JvdXAyKSkpLFxuICAgICAgICAgICAgICAgICAgICBnZW5lID0gYyhncm91cDEsIGdyb3VwMikpXG5cbmRhdGEgPC0gbGVmdF9qb2luKGdlbmVHcm91cCwgZGF0YSwgYnkgPSBjKFxcZ2VuZVxcKSkgJT4lIGRwbHlyOjptdXRhdGUobXV0YXRlKGFjcm9zcyhldmVyeXRoaW5nKCksIH5yZXBsYWNlX25hKC4sIDApKSkpXG5cblxuIyMjXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUocHJlc2VuY2VPZlJldGFpbmVkID0gaWZfZWxzZShpbnNlbnNpdGl2ZSA+IDAsIFxcWUVTXFwsIFxcTk9cXCksXG4gICAgICAgICAgICAgICAgICAgICAgIHBlcmNPZlJldGFpbmVkID0gaWZfZWxzZShpbnNlbnNpdGl2ZSArIHNlbnNpdGl2ZSA9PSAwLCAwLCAxMDAqaW5zZW5zaXRpdmUvKGluc2Vuc2l0aXZlICsgc2Vuc2l0aXZlKSkpXG5cblxuIyMjXG5nZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IHBlcmNPZlJldGFpbmVkLCBmaWxsID0gZ3JvdXApKSArIGdlb21fdmlvbGluKCkgKyBcbiAgZ2VvbV9ib3hwbG90KG91dGxpZXIuc2hhcGUgPSBOQSwgd2lkdGggPSAwLjEsIGZpbGwgPSBcXHdoaXRlXFwpICsgdGhlbWVfYncoKVxuXG5cbiMjIyBTdGFja2VkIGJhcnBsb3Rcbmdyb3VwIDwtIGMoXFxncm91cDFcXCwgXFxncm91cDFcXCwgXFxncm91cDJcXCwgXFxncm91cDJcXClcbnByZXNlbmNlT2ZSZXRhaW5lZCA8LSByZXAoYyhcXFlFU1xcLCBcXE5PXFwpLCAyKVxucHJlc2VuY2VPZlJldGFpbmVkIDwtIGZhY3RvciAocHJlc2VuY2VPZlJldGFpbmVkLCBsZXZlbHMgPSBjKFxcWUVTXFwsIFxcTk9cXCkpXG52YWx1ZSA8LSBjKG5yb3coZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwMVxcLCBwcmVzZW5jZU9mUmV0YWluZWQgPT0gXFxZRVNcXCkpLFxuICAgICAgICAgICBucm93KGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDFcXCwgcHJlc2VuY2VPZlJldGFpbmVkID09IFxcTk9cXCkpLFxuICAgICAgICAgICBucm93KGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDJcXCwgcHJlc2VuY2VPZlJldGFpbmVkID09IFxcWUVTXFwpKSxcbiAgICAgICAgICAgbnJvdyhkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IFxcZ3JvdXAyXFwsIHByZXNlbmNlT2ZSZXRhaW5lZCA9PSBcXE5PXFwpKSlcbnBsb3REYXRhIDwtIGRhdGEuZnJhbWUoZ3JvdXAsIHByZXNlbmNlT2ZSZXRhaW5lZCwgdmFsdWUpXG5cbmdncGxvdChwbG90RGF0YSwgYWVzKGZpbGw9cHJlc2VuY2VPZlJldGFpbmVkLCB5PXZhbHVlLCB4PWdyb3VwKSkgKyBcbiAgICBnZW9tX2Jhcihwb3NpdGlvbj1cXGZpbGxcXCwgc3RhdD1cXGlkZW50aXR5XFwpICsgdGhlbWVfY2xhc3NpYygpXG5cblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                 diffCutoff = 0.2)\n\n\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(size = V3 - V2,\n                id = paste(V1, size, V2, V5, sep = \\_\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(size = V3 - V2,\n                id = paste(V1, size, V2, V5, sep = \\_\\))\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(size = V3 - V2,\n                id = paste(V1, size, V2, V5, sep = \\_\\))\n\ngeneAnnoData <- geneAnnoData %>% dplyr::filter(id %in% c(loop.up$id, loop.no$id, loop.down$id)) %>%\n  dplyr::mutate(loopType = case_when(id %in% c(loop.up$id, loop.no$id) ~ \\insensitive\\,\n                                     id %in% c(loop.down$id) ~ \\sensitive\\,\n                                     TRUE ~ NA))\n\ndata <- geneAnnoData %>% dplyr::select(gene, id, loopType) %>% unnest(gene) %>%\n  group_by(gene) %>% summarize(\n    insensitive = sum(loopType == \\insensitive\\, na.rm = TRUE),\n    sensitive = sum(loopType == \\sensitive\\, na.rm = TRUE))\n\n\n\n###\n\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ngeneGroup <- tibble(group = c(rep(\\group1\\, length(group1)), rep(\\group2\\, length(group2))),\n                    gene = c(group1, group2))\n\ndata <- left_join(geneGroup, data, by = c(\\gene\\)) %>% dplyr::mutate(mutate(across(everything(), ~replace_na(., 0))))\n\n\n###\ndata <- data %>% dplyr::mutate(presenceOfRetained = if_else(insensitive > 0, \\YES\\, \\NO\\),\n                       percOfRetained = if_else(insensitive + sensitive == 0, 0, 100*insensitive/(insensitive + sensitive)))\n\n\n###\nggplot(data, aes(x = group, y = percOfRetained, fill = group)) + geom_violin() + \n  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \\white\\) + theme_bw()\n\n\n### Stacked barplot\ngroup <- c(\\group1\\, \\group1\\, \\group2\\, \\group2\\)\npresenceOfRetained <- rep(c(\\YES\\, \\NO\\), 2)\npresenceOfRetained <- factor (presenceOfRetained, levels = c(\\YES\\, \\NO\\))\nvalue <- c(nrow(data %>% dplyr::filter(group == \\group1\\, presenceOfRetained == \\YES\\)),\n           nrow(data %>% dplyr::filter(group == \\group1\\, presenceOfRetained == \\NO\\)),\n           nrow(data %>% dplyr::filter(group == \\group2\\, presenceOfRetained == \\YES\\)),\n           nrow(data %>% dplyr::filter(group == \\group2\\, presenceOfRetained == \\NO\\)))\nplotData <- data.frame(group, presenceOfRetained, value)\n\nggplot(plotData, aes(fill=presenceOfRetained, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLW5fZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIpXG5cblxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIHNpemUsIFYyLCBWNSwgc2VwID0gXFxfXFwpKVxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIHNpemUsIFYyLCBWNSwgc2VwID0gXFxfXFwpKVxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX2RUQUd2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBzaXplLCBWMiwgVjUsIHNlcCA9IFxcX1xcKSlcblxuZ2VuZUFubm9EYXRhIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGMobG9vcC51cCRpZCwgbG9vcC5ubyRpZCwgbG9vcC5kb3duJGlkKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUobG9vcFR5cGUgPSBjYXNlX3doZW4oaWQgJWluJSBjKGxvb3AudXAkaWQsIGxvb3Aubm8kaWQpIH4gXFxpbnNlbnNpdGl2ZVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlkICVpbiUgYyhsb29wLmRvd24kaWQpIH4gXFxzZW5zaXRpdmVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKVxuXG5kYXRhIDwtIGdlbmVBbm5vRGF0YSAlPiUgZHBseXI6OnNlbGVjdChnZW5lLCBpZCwgbG9vcFR5cGUpICU+JSB1bm5lc3QoZ2VuZSkgJT4lXG4gIGdyb3VwX2J5KGdlbmUpICU+JSBzdW1tYXJpemUoXG4gICAgaW5zZW5zaXRpdmUgPSBzdW0obG9vcFR5cGUgPT0gXFxpbnNlbnNpdGl2ZVxcLCBuYS5ybSA9IFRSVUUpLFxuICAgIHNlbnNpdGl2ZSA9IHN1bShsb29wVHlwZSA9PSBcXHNlbnNpdGl2ZVxcLCBuYS5ybSA9IFRSVUUpKVxuXG5cblxuIyMjXG5cbmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlxcKSkkZ2VuZVxuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XFwpKSRnZW5lXG5cbmdlbmVHcm91cCA8LSB0aWJibGUoZ3JvdXAgPSBjKHJlcChcXGdyb3VwMVxcLCBsZW5ndGgoZ3JvdXAxKSksIHJlcChcXGdyb3VwMlxcLCBsZW5ndGgoZ3JvdXAyKSkpLFxuICAgICAgICAgICAgICAgICAgICBnZW5lID0gYyhncm91cDEsIGdyb3VwMikpXG5cbmRhdGEgPC0gbGVmdF9qb2luKGdlbmVHcm91cCwgZGF0YSwgYnkgPSBjKFxcZ2VuZVxcKSkgJT4lIGRwbHlyOjptdXRhdGUobXV0YXRlKGFjcm9zcyhldmVyeXRoaW5nKCksIH5yZXBsYWNlX25hKC4sIDApKSkpXG5cblxuIyMjXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUocHJlc2VuY2VPZlJldGFpbmVkID0gaWZfZWxzZShpbnNlbnNpdGl2ZSA+IDAsIFxcWUVTXFwsIFxcTk9cXCksXG4gICAgICAgICAgICAgICAgICAgICAgIHBlcmNPZlJldGFpbmVkID0gaWZfZWxzZShpbnNlbnNpdGl2ZSArIHNlbnNpdGl2ZSA9PSAwLCAwLCAxMDAqaW5zZW5zaXRpdmUvKGluc2Vuc2l0aXZlICsgc2Vuc2l0aXZlKSkpXG5cblxuIyMjXG5nZ3Bsb3QoZGF0YSwgYWVzKHggPSBncm91cCwgeSA9IHBlcmNPZlJldGFpbmVkLCBmaWxsID0gZ3JvdXApKSArIGdlb21fdmlvbGluKCkgKyBcbiAgZ2VvbV9ib3hwbG90KG91dGxpZXIuc2hhcGUgPSBOQSwgd2lkdGggPSAwLjEsIGZpbGwgPSBcXHdoaXRlXFwpICsgdGhlbWVfYncoKVxuXG5cbiMjIyBTdGFja2VkIGJhcnBsb3Rcbmdyb3VwIDwtIGMoXFxncm91cDFcXCwgXFxncm91cDFcXCwgXFxncm91cDJcXCwgXFxncm91cDJcXClcbnByZXNlbmNlT2ZSZXRhaW5lZCA8LSByZXAoYyhcXFlFU1xcLCBcXE5PXFwpLCAyKVxucHJlc2VuY2VPZlJldGFpbmVkIDwtIGZhY3RvciAocHJlc2VuY2VPZlJldGFpbmVkLCBsZXZlbHMgPSBjKFxcWUVTXFwsIFxcTk9cXCkpXG52YWx1ZSA8LSBjKG5yb3coZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwMVxcLCBwcmVzZW5jZU9mUmV0YWluZWQgPT0gXFxZRVNcXCkpLFxuICAgICAgICAgICBucm93KGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDFcXCwgcHJlc2VuY2VPZlJldGFpbmVkID09IFxcTk9cXCkpLFxuICAgICAgICAgICBucm93KGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDJcXCwgcHJlc2VuY2VPZlJldGFpbmVkID09IFxcWUVTXFwpKSxcbiAgICAgICAgICAgbnJvdyhkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IFxcZ3JvdXAyXFwsIHByZXNlbmNlT2ZSZXRhaW5lZCA9PSBcXE5PXFwpKSlcbnBsb3REYXRhIDwtIGRhdGEuZnJhbWUoZ3JvdXAsIHByZXNlbmNlT2ZSZXRhaW5lZCwgdmFsdWUpXG5cbmdncGxvdChwbG90RGF0YSwgYWVzKGZpbGw9cHJlc2VuY2VPZlJldGFpbmVkLCB5PXZhbHVlLCB4PWdyb3VwKSkgKyBcbiAgICBnZW9tX2Jhcihwb3NpdGlvbj1cXGZpbGxcXCwgc3RhdD1cXGlkZW50aXR5XFwpICsgdGhlbWVfY2xhc3NpYygpXG5cblxuYGBgXG5gYGAifQ== -->

```r
```r
name <- \chromo_cons_annoHierarchy\
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                 diffCutoff = 0.2)


loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = \_\))

geneAnnoData <- geneAnnoData %>% dplyr::filter(id %in% c(loop.up$id, loop.no$id, loop.down$id)) %>%
  dplyr::mutate(loopType = case_when(id %in% c(loop.up$id, loop.no$id) ~ \insensitive\,
                                     id %in% c(loop.down$id) ~ \sensitive\,
                                     TRUE ~ NA))

data <- geneAnnoData %>% dplyr::select(gene, id, loopType) %>% unnest(gene) %>%
  group_by(gene) %>% summarize(
    insensitive = sum(loopType == \insensitive\, na.rm = TRUE),
    sensitive = sum(loopType == \sensitive\, na.rm = TRUE))



###

group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

geneGroup <- tibble(group = c(rep(\group1\, length(group1)), rep(\group2\, length(group2))),
                    gene = c(group1, group2))

data <- left_join(geneGroup, data, by = c(\gene\)) %>% dplyr::mutate(mutate(across(everything(), ~replace_na(., 0))))


###
data <- data %>% dplyr::mutate(presenceOfRetained = if_else(insensitive > 0, \YES\, \NO\),
                       percOfRetained = if_else(insensitive + sensitive == 0, 0, 100*insensitive/(insensitive + sensitive)))


###
ggplot(data, aes(x = group, y = percOfRetained, fill = group)) + geom_violin() + 
  geom_boxplot(outlier.shape = NA, width = 0.1, fill = \white\) + theme_bw()


### Stacked barplot
group <- c(\group1\, \group1\, \group2\, \group2\)
presenceOfRetained <- rep(c(\YES\, \NO\), 2)
presenceOfRetained <- factor (presenceOfRetained, levels = c(\YES\, \NO\))
value <- c(nrow(data %>% dplyr::filter(group == \group1\, presenceOfRetained == \YES\)),
           nrow(data %>% dplyr::filter(group == \group1\, presenceOfRetained == \NO\)),
           nrow(data %>% dplyr::filter(group == \group2\, presenceOfRetained == \YES\)),
           nrow(data %>% dplyr::filter(group == \group2\, presenceOfRetained == \NO\)))
plotData <- data.frame(group, presenceOfRetained, value)

ggplot(plotData, aes(fill=presenceOfRetained, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### Only limiting to E-P loops from Micro-C

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcIl9wLXBlX2Vuc2VtYmxMaXN0LnRzdlwiKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yKVxuXG5cbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBzaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBzaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoc2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgc2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5cbmdlbmVBbm5vRGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBjKGxvb3AudXAkaWQsIGxvb3Aubm8kaWQsIGxvb3AuZG93biRpZCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGxvb3BUeXBlID0gY2FzZV93aGVuKGlkICVpbiUgYyhsb29wLnVwJGlkLCBsb29wLm5vJGlkKSB+IFwiaW5zZW5zaXRpdmVcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZCAlaW4lIGMobG9vcC5kb3duJGlkKSB+IFwic2Vuc2l0aXZlXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BKSlcblxuZGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZ2VuZSwgaWQsIGxvb3BUeXBlKSAlPiUgdW5uZXN0KGdlbmUpICU+JVxuICBncm91cF9ieShnZW5lKSAlPiUgc3VtbWFyaXplKFxuICAgIGluc2Vuc2l0aXZlID0gc3VtKGxvb3BUeXBlID09IFwiaW5zZW5zaXRpdmVcIiwgbmEucm0gPSBUUlVFKSxcbiAgICBzZW5zaXRpdmUgPSBzdW0obG9vcFR5cGUgPT0gXCJzZW5zaXRpdmVcIiwgbmEucm0gPSBUUlVFKSlcblxuXG5cbiMjI1xuXG5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcIikpJGdlbmVcbmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlwiKSkkZ2VuZVxuXG5nZW5lR3JvdXAgPC0gdGliYmxlKGdyb3VwID0gYyhyZXAoXCJncm91cDFcIiwgbGVuZ3RoKGdyb3VwMSkpLCByZXAoXCJncm91cDJcIiwgbGVuZ3RoKGdyb3VwMikpKSxcbiAgICAgICAgICAgICAgICAgICAgZ2VuZSA9IGMoZ3JvdXAxLCBncm91cDIpKVxuXG5kYXRhIDwtIGxlZnRfam9pbihnZW5lR3JvdXAsIGRhdGEsIGJ5ID0gYyhcImdlbmVcIikpICU+JSBkcGx5cjo6bXV0YXRlKG11dGF0ZShhY3Jvc3MoZXZlcnl0aGluZygpLCB+cmVwbGFjZV9uYSguLCAwKSkpKVxuXG5cbiMjI1xuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKHByZXNlbmNlT2ZSZXRhaW5lZCA9IGlmX2Vsc2UoaW5zZW5zaXRpdmUgPiAwLCBcIllFU1wiLCBcIk5PXCIpLFxuICAgICAgICAgICAgICAgICAgICAgICBwZXJjT2ZSZXRhaW5lZCA9IGlmX2Vsc2UoaW5zZW5zaXRpdmUgKyBzZW5zaXRpdmUgPT0gMCwgMCwgMTAwKmluc2Vuc2l0aXZlLyhpbnNlbnNpdGl2ZSArIHNlbnNpdGl2ZSkpKVxuXG5cbiMjI1xuZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBwZXJjT2ZSZXRhaW5lZCwgZmlsbCA9IGdyb3VwKSkgKyBnZW9tX3Zpb2xpbigpICsgXG4gIGdlb21fYm94cGxvdChvdXRsaWVyLnNoYXBlID0gTkEsIHdpZHRoID0gMC4wNSwgZmlsbCA9IFwid2hpdGVcIikgKyB0aGVtZV9idygpXG5cblxuIyMjIFN0YWNrZWQgYmFycGxvdFxuZ3JvdXAgPC0gYyhcImdyb3VwMVwiLCBcImdyb3VwMVwiLCBcImdyb3VwMlwiLCBcImdyb3VwMlwiKVxucHJlc2VuY2VPZlJldGFpbmVkIDwtIHJlcChjKFwiWUVTXCIsIFwiTk9cIiksIDIpXG5wcmVzZW5jZU9mUmV0YWluZWQgPC0gZmFjdG9yIChwcmVzZW5jZU9mUmV0YWluZWQsIGxldmVscyA9IGMoXCJZRVNcIiwgXCJOT1wiKSlcbnZhbHVlIDwtIGMobnJvdyhkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IFwiZ3JvdXAxXCIsIHByZXNlbmNlT2ZSZXRhaW5lZCA9PSBcIllFU1wiKSksXG4gICAgICAgICAgIG5yb3coZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcImdyb3VwMVwiLCBwcmVzZW5jZU9mUmV0YWluZWQgPT0gXCJOT1wiKSksXG4gICAgICAgICAgIG5yb3coZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcImdyb3VwMlwiLCBwcmVzZW5jZU9mUmV0YWluZWQgPT0gXCJZRVNcIikpLFxuICAgICAgICAgICBucm93KGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXCJncm91cDJcIiwgcHJlc2VuY2VPZlJldGFpbmVkID09IFwiTk9cIikpKVxucGxvdERhdGEgPC0gZGF0YS5mcmFtZShncm91cCwgcHJlc2VuY2VPZlJldGFpbmVkLCB2YWx1ZSlcblxuZ2dwbG90KHBsb3REYXRhLCBhZXMoZmlsbD1wcmVzZW5jZU9mUmV0YWluZWQsIHk9dmFsdWUsIHg9Z3JvdXApKSArIFxuICAgIGdlb21fYmFyKHBvc2l0aW9uPVwiZmlsbFwiLCBzdGF0PVwiaWRlbnRpdHlcIikgKyB0aGVtZV9jbGFzc2ljKClcblxuXG5gYGAifQ== -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-pe_ensemblList.tsv\\)),\n                                 diffCutoff = 0.2)\n\n\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(size = V3 - V2,\n                id = paste(V1, size, V2, V5, sep = \\_\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(size = V3 - V2,\n                id = paste(V1, size, V2, V5, sep = \\_\\))\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(size = V3 - V2,\n                id = paste(V1, size, V2, V5, sep = \\_\\))\n\ngeneAnnoData <- geneAnnoData %>% dplyr::filter(id %in% c(loop.up$id, loop.no$id, loop.down$id)) %>%\n  dplyr::mutate(loopType = case_when(id %in% c(loop.up$id, loop.no$id) ~ \\insensitive\\,\n                                     id %in% c(loop.down$id) ~ \\sensitive\\,\n                                     TRUE ~ NA))\n\ndata <- geneAnnoData %>% dplyr::select(gene, id, loopType) %>% unnest(gene) %>%\n  group_by(gene) %>% summarize(\n    insensitive = sum(loopType == \\insensitive\\, na.rm = TRUE),\n    sensitive = sum(loopType == \\sensitive\\, na.rm = TRUE))\n\n\n\n###\n\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ngeneGroup <- tibble(group = c(rep(\\group1\\, length(group1)), rep(\\group2\\, length(group2))),\n                    gene = c(group1, group2))\n\ndata <- left_join(geneGroup, data, by = c(\\gene\\)) %>% dplyr::mutate(mutate(across(everything(), ~replace_na(., 0))))\n\n\n###\ndata <- data %>% dplyr::mutate(presenceOfRetained = if_else(insensitive > 0, \\YES\\, \\NO\\),\n                       percOfRetained = if_else(insensitive + sensitive == 0, 0, 100*insensitive/(insensitive + sensitive)))\n\n\n###\nggplot(data, aes(x = group, y = percOfRetained, fill = group)) + geom_violin() + \n  geom_boxplot(outlier.shape = NA, width = 0.05, fill = \\white\\) + theme_bw()\n\n\n### Stacked barplot\ngroup <- c(\\group1\\, \\group1\\, \\group2\\, \\group2\\)\npresenceOfRetained <- rep(c(\\YES\\, \\NO\\), 2)\npresenceOfRetained <- factor (presenceOfRetained, levels = c(\\YES\\, \\NO\\))\nvalue <- c(nrow(data %>% dplyr::filter(group == \\group1\\, presenceOfRetained == \\YES\\)),\n           nrow(data %>% dplyr::filter(group == \\group1\\, presenceOfRetained == \\NO\\)),\n           nrow(data %>% dplyr::filter(group == \\group2\\, presenceOfRetained == \\YES\\)),\n           nrow(data %>% dplyr::filter(group == \\group2\\, presenceOfRetained == \\NO\\)))\nplotData <- data.frame(group, presenceOfRetained, value)\n\nggplot(plotData, aes(fill=presenceOfRetained, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-pe_ensemblList.tsv\)),
                                 diffCutoff = 0.2)


loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = \_\))

geneAnnoData <- geneAnnoData %>% dplyr::filter(id %in% c(loop.up$id, loop.no$id, loop.down$id)) %>%
  dplyr::mutate(loopType = case_when(id %in% c(loop.up$id, loop.no$id) ~ \insensitive\,
                                     id %in% c(loop.down$id) ~ \sensitive\,
                                     TRUE ~ NA))

data <- geneAnnoData %>% dplyr::select(gene, id, loopType) %>% unnest(gene) %>%
  group_by(gene) %>% summarize(
    insensitive = sum(loopType == \insensitive\, na.rm = TRUE),
    sensitive = sum(loopType == \sensitive\, na.rm = TRUE))



###

group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

geneGroup <- tibble(group = c(rep(\group1\, length(group1)), rep(\group2\, length(group2))),
                    gene = c(group1, group2))

data <- left_join(geneGroup, data, by = c(\gene\)) %>% dplyr::mutate(mutate(across(everything(), ~replace_na(., 0))))


###
data <- data %>% dplyr::mutate(presenceOfRetained = if_else(insensitive > 0, \YES\, \NO\),
                       percOfRetained = if_else(insensitive + sensitive == 0, 0, 100*insensitive/(insensitive + sensitive)))


###
ggplot(data, aes(x = group, y = percOfRetained, fill = group)) + geom_violin() + 
  geom_boxplot(outlier.shape = NA, width = 0.05, fill = \white\) + theme_bw()


### Stacked barplot
group <- c(\group1\, \group1\, \group2\, \group2\)
presenceOfRetained <- rep(c(\YES\, \NO\), 2)
presenceOfRetained <- factor (presenceOfRetained, levels = c(\YES\, \NO\))
value <- c(nrow(data %>% dplyr::filter(group == \group1\, presenceOfRetained == \YES\)),
           nrow(data %>% dplyr::filter(group == \group1\, presenceOfRetained == \NO\)),
           nrow(data %>% dplyr::filter(group == \group2\, presenceOfRetained == \YES\)),
           nrow(data %>% dplyr::filter(group == \group2\, presenceOfRetained == \NO\)))
plotData <- data.frame(group, presenceOfRetained, value)

ggplot(plotData, aes(fill=presenceOfRetained, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLXBlX2Vuc2VtYmxMaXN0LnRzdlxcKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yKVxuXG5cbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBzaXplLCBWMiwgVjUsIHNlcCA9IFxcX1xcKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBzaXplLCBWMiwgVjUsIHNlcCA9IFxcX1xcKSlcbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoc2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgc2l6ZSwgVjIsIFY1LCBzZXAgPSBcXF9cXCkpXG5cbmdlbmVBbm5vRGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBjKGxvb3AudXAkaWQsIGxvb3Aubm8kaWQsIGxvb3AuZG93biRpZCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGxvb3BUeXBlID0gY2FzZV93aGVuKGlkICVpbiUgYyhsb29wLnVwJGlkLCBsb29wLm5vJGlkKSB+IFxcaW5zZW5zaXRpdmVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZCAlaW4lIGMobG9vcC5kb3duJGlkKSB+IFxcc2Vuc2l0aXZlXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BKSlcblxuZGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZ2VuZSwgaWQsIGxvb3BUeXBlKSAlPiUgdW5uZXN0KGdlbmUpICU+JVxuICBncm91cF9ieShnZW5lKSAlPiUgc3VtbWFyaXplKFxuICAgIGluc2Vuc2l0aXZlID0gc3VtKGxvb3BUeXBlID09IFxcaW5zZW5zaXRpdmVcXCwgbmEucm0gPSBUUlVFKSxcbiAgICBzZW5zaXRpdmUgPSBzdW0obG9vcFR5cGUgPT0gXFxzZW5zaXRpdmVcXCwgbmEucm0gPSBUUlVFKSlcblxuXG5cbiMjI1xuXG5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG5nZW5lR3JvdXAgPC0gdGliYmxlKGdyb3VwID0gYyhyZXAoXFxncm91cDFcXCwgbGVuZ3RoKGdyb3VwMSkpLCByZXAoXFxncm91cDJcXCwgbGVuZ3RoKGdyb3VwMikpKSxcbiAgICAgICAgICAgICAgICAgICAgZ2VuZSA9IGMoZ3JvdXAxLCBncm91cDIpKVxuXG5kYXRhIDwtIGxlZnRfam9pbihnZW5lR3JvdXAsIGRhdGEsIGJ5ID0gYyhcXGdlbmVcXCkpICU+JSBkcGx5cjo6bXV0YXRlKG11dGF0ZShhY3Jvc3MoZXZlcnl0aGluZygpLCB+cmVwbGFjZV9uYSguLCAwKSkpKVxuXG5cbiMjI1xuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKHByZXNlbmNlT2ZSZXRhaW5lZCA9IGlmX2Vsc2UoaW5zZW5zaXRpdmUgPiAwLCBcXFlFU1xcLCBcXE5PXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICBwZXJjT2ZSZXRhaW5lZCA9IGlmX2Vsc2UoaW5zZW5zaXRpdmUgKyBzZW5zaXRpdmUgPT0gMCwgMCwgMTAwKmluc2Vuc2l0aXZlLyhpbnNlbnNpdGl2ZSArIHNlbnNpdGl2ZSkpKVxuXG5cbiMjI1xuZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBwZXJjT2ZSZXRhaW5lZCwgZmlsbCA9IGdyb3VwKSkgKyBnZW9tX3Zpb2xpbigpICsgXG4gIGdlb21fYm94cGxvdChvdXRsaWVyLnNoYXBlID0gTkEsIHdpZHRoID0gMC4wNSwgZmlsbCA9IFxcd2hpdGVcXCkgKyB0aGVtZV9idygpXG5cblxuIyMjIFN0YWNrZWQgYmFycGxvdFxuZ3JvdXAgPC0gYyhcXGdyb3VwMVxcLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcLCBcXGdyb3VwMlxcKVxucHJlc2VuY2VPZlJldGFpbmVkIDwtIHJlcChjKFxcWUVTXFwsIFxcTk9cXCksIDIpXG5wcmVzZW5jZU9mUmV0YWluZWQgPC0gZmFjdG9yIChwcmVzZW5jZU9mUmV0YWluZWQsIGxldmVscyA9IGMoXFxZRVNcXCwgXFxOT1xcKSlcbnZhbHVlIDwtIGMobnJvdyhkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IFxcZ3JvdXAxXFwsIHByZXNlbmNlT2ZSZXRhaW5lZCA9PSBcXFlFU1xcKSksXG4gICAgICAgICAgIG5yb3coZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwMVxcLCBwcmVzZW5jZU9mUmV0YWluZWQgPT0gXFxOT1xcKSksXG4gICAgICAgICAgIG5yb3coZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwMlxcLCBwcmVzZW5jZU9mUmV0YWluZWQgPT0gXFxZRVNcXCkpLFxuICAgICAgICAgICBucm93KGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDJcXCwgcHJlc2VuY2VPZlJldGFpbmVkID09IFxcTk9cXCkpKVxucGxvdERhdGEgPC0gZGF0YS5mcmFtZShncm91cCwgcHJlc2VuY2VPZlJldGFpbmVkLCB2YWx1ZSlcblxuZ2dwbG90KHBsb3REYXRhLCBhZXMoZmlsbD1wcmVzZW5jZU9mUmV0YWluZWQsIHk9dmFsdWUsIHg9Z3JvdXApKSArIFxuICAgIGdlb21fYmFyKHBvc2l0aW9uPVxcZmlsbFxcLCBzdGF0PVxcaWRlbnRpdHlcXCkgKyB0aGVtZV9jbGFzc2ljKClcblxuXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-pe_ensemblList.tsv\\)),\n                                 diffCutoff = 0.2)\n\n\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(size = V3 - V2,\n                id = paste(V1, size, V2, V5, sep = \\_\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(size = V3 - V2,\n                id = paste(V1, size, V2, V5, sep = \\_\\))\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(size = V3 - V2,\n                id = paste(V1, size, V2, V5, sep = \\_\\))\n\ngeneAnnoData <- geneAnnoData %>% dplyr::filter(id %in% c(loop.up$id, loop.no$id, loop.down$id)) %>%\n  dplyr::mutate(loopType = case_when(id %in% c(loop.up$id, loop.no$id) ~ \\insensitive\\,\n                                     id %in% c(loop.down$id) ~ \\sensitive\\,\n                                     TRUE ~ NA))\n\ndata <- geneAnnoData %>% dplyr::select(gene, id, loopType) %>% unnest(gene) %>%\n  group_by(gene) %>% summarize(\n    insensitive = sum(loopType == \\insensitive\\, na.rm = TRUE),\n    sensitive = sum(loopType == \\sensitive\\, na.rm = TRUE))\n\n\n\n###\n\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ngeneGroup <- tibble(group = c(rep(\\group1\\, length(group1)), rep(\\group2\\, length(group2))),\n                    gene = c(group1, group2))\n\ndata <- left_join(geneGroup, data, by = c(\\gene\\)) %>% dplyr::mutate(mutate(across(everything(), ~replace_na(., 0))))\n\n\n###\ndata <- data %>% dplyr::mutate(presenceOfRetained = if_else(insensitive > 0, \\YES\\, \\NO\\),\n                       percOfRetained = if_else(insensitive + sensitive == 0, 0, 100*insensitive/(insensitive + sensitive)))\n\n\n###\nggplot(data, aes(x = group, y = percOfRetained, fill = group)) + geom_violin() + \n  geom_boxplot(outlier.shape = NA, width = 0.05, fill = \\white\\) + theme_bw()\n\n\n### Stacked barplot\ngroup <- c(\\group1\\, \\group1\\, \\group2\\, \\group2\\)\npresenceOfRetained <- rep(c(\\YES\\, \\NO\\), 2)\npresenceOfRetained <- factor (presenceOfRetained, levels = c(\\YES\\, \\NO\\))\nvalue <- c(nrow(data %>% dplyr::filter(group == \\group1\\, presenceOfRetained == \\YES\\)),\n           nrow(data %>% dplyr::filter(group == \\group1\\, presenceOfRetained == \\NO\\)),\n           nrow(data %>% dplyr::filter(group == \\group2\\, presenceOfRetained == \\YES\\)),\n           nrow(data %>% dplyr::filter(group == \\group2\\, presenceOfRetained == \\NO\\)))\nplotData <- data.frame(group, presenceOfRetained, value)\n\nggplot(plotData, aes(fill=presenceOfRetained, y=value, x=group)) + \n    geom_bar(position=\\fill\\, stat=\\identity\\) + theme_classic()\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLXBlX2Vuc2VtYmxMaXN0LnRzdlxcKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkaWZmQ3V0b2ZmID0gMC4yKVxuXG5cbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBzaXplLCBWMiwgVjUsIHNlcCA9IFxcX1xcKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShzaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBzaXplLCBWMiwgVjUsIHNlcCA9IFxcX1xcKSlcbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoc2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgc2l6ZSwgVjIsIFY1LCBzZXAgPSBcXF9cXCkpXG5cbmdlbmVBbm5vRGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBjKGxvb3AudXAkaWQsIGxvb3Aubm8kaWQsIGxvb3AuZG93biRpZCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGxvb3BUeXBlID0gY2FzZV93aGVuKGlkICVpbiUgYyhsb29wLnVwJGlkLCBsb29wLm5vJGlkKSB+IFxcaW5zZW5zaXRpdmVcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZCAlaW4lIGMobG9vcC5kb3duJGlkKSB+IFxcc2Vuc2l0aXZlXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BKSlcblxuZGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZ2VuZSwgaWQsIGxvb3BUeXBlKSAlPiUgdW5uZXN0KGdlbmUpICU+JVxuICBncm91cF9ieShnZW5lKSAlPiUgc3VtbWFyaXplKFxuICAgIGluc2Vuc2l0aXZlID0gc3VtKGxvb3BUeXBlID09IFxcaW5zZW5zaXRpdmVcXCwgbmEucm0gPSBUUlVFKSxcbiAgICBzZW5zaXRpdmUgPSBzdW0obG9vcFR5cGUgPT0gXFxzZW5zaXRpdmVcXCwgbmEucm0gPSBUUlVFKSlcblxuXG5cbiMjI1xuXG5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG5nZW5lR3JvdXAgPC0gdGliYmxlKGdyb3VwID0gYyhyZXAoXFxncm91cDFcXCwgbGVuZ3RoKGdyb3VwMSkpLCByZXAoXFxncm91cDJcXCwgbGVuZ3RoKGdyb3VwMikpKSxcbiAgICAgICAgICAgICAgICAgICAgZ2VuZSA9IGMoZ3JvdXAxLCBncm91cDIpKVxuXG5kYXRhIDwtIGxlZnRfam9pbihnZW5lR3JvdXAsIGRhdGEsIGJ5ID0gYyhcXGdlbmVcXCkpICU+JSBkcGx5cjo6bXV0YXRlKG11dGF0ZShhY3Jvc3MoZXZlcnl0aGluZygpLCB+cmVwbGFjZV9uYSguLCAwKSkpKVxuXG5cbiMjI1xuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKHByZXNlbmNlT2ZSZXRhaW5lZCA9IGlmX2Vsc2UoaW5zZW5zaXRpdmUgPiAwLCBcXFlFU1xcLCBcXE5PXFwpLFxuICAgICAgICAgICAgICAgICAgICAgICBwZXJjT2ZSZXRhaW5lZCA9IGlmX2Vsc2UoaW5zZW5zaXRpdmUgKyBzZW5zaXRpdmUgPT0gMCwgMCwgMTAwKmluc2Vuc2l0aXZlLyhpbnNlbnNpdGl2ZSArIHNlbnNpdGl2ZSkpKVxuXG5cbiMjI1xuZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBwZXJjT2ZSZXRhaW5lZCwgZmlsbCA9IGdyb3VwKSkgKyBnZW9tX3Zpb2xpbigpICsgXG4gIGdlb21fYm94cGxvdChvdXRsaWVyLnNoYXBlID0gTkEsIHdpZHRoID0gMC4wNSwgZmlsbCA9IFxcd2hpdGVcXCkgKyB0aGVtZV9idygpXG5cblxuIyMjIFN0YWNrZWQgYmFycGxvdFxuZ3JvdXAgPC0gYyhcXGdyb3VwMVxcLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcLCBcXGdyb3VwMlxcKVxucHJlc2VuY2VPZlJldGFpbmVkIDwtIHJlcChjKFxcWUVTXFwsIFxcTk9cXCksIDIpXG5wcmVzZW5jZU9mUmV0YWluZWQgPC0gZmFjdG9yIChwcmVzZW5jZU9mUmV0YWluZWQsIGxldmVscyA9IGMoXFxZRVNcXCwgXFxOT1xcKSlcbnZhbHVlIDwtIGMobnJvdyhkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09IFxcZ3JvdXAxXFwsIHByZXNlbmNlT2ZSZXRhaW5lZCA9PSBcXFlFU1xcKSksXG4gICAgICAgICAgIG5yb3coZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwMVxcLCBwcmVzZW5jZU9mUmV0YWluZWQgPT0gXFxOT1xcKSksXG4gICAgICAgICAgIG5yb3coZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXGdyb3VwMlxcLCBwcmVzZW5jZU9mUmV0YWluZWQgPT0gXFxZRVNcXCkpLFxuICAgICAgICAgICBucm93KGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoZ3JvdXAgPT0gXFxncm91cDJcXCwgcHJlc2VuY2VPZlJldGFpbmVkID09IFxcTk9cXCkpKVxucGxvdERhdGEgPC0gZGF0YS5mcmFtZShncm91cCwgcHJlc2VuY2VPZlJldGFpbmVkLCB2YWx1ZSlcblxuZ2dwbG90KHBsb3REYXRhLCBhZXMoZmlsbD1wcmVzZW5jZU9mUmV0YWluZWQsIHk9dmFsdWUsIHg9Z3JvdXApKSArIFxuICAgIGdlb21fYmFyKHBvc2l0aW9uPVxcZmlsbFxcLCBzdGF0PVxcaWRlbnRpdHlcXCkgKyB0aGVtZV9jbGFzc2ljKClcblxuXG5gYGBcbmBgYCJ9 -->

```r
```r
name <- \chromo_cons_annoHierarchy\
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-pe_ensemblList.tsv\)),
                                 diffCutoff = 0.2)


loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = \_\))

geneAnnoData <- geneAnnoData %>% dplyr::filter(id %in% c(loop.up$id, loop.no$id, loop.down$id)) %>%
  dplyr::mutate(loopType = case_when(id %in% c(loop.up$id, loop.no$id) ~ \insensitive\,
                                     id %in% c(loop.down$id) ~ \sensitive\,
                                     TRUE ~ NA))

data <- geneAnnoData %>% dplyr::select(gene, id, loopType) %>% unnest(gene) %>%
  group_by(gene) %>% summarize(
    insensitive = sum(loopType == \insensitive\, na.rm = TRUE),
    sensitive = sum(loopType == \sensitive\, na.rm = TRUE))



###

group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

geneGroup <- tibble(group = c(rep(\group1\, length(group1)), rep(\group2\, length(group2))),
                    gene = c(group1, group2))

data <- left_join(geneGroup, data, by = c(\gene\)) %>% dplyr::mutate(mutate(across(everything(), ~replace_na(., 0))))


###
data <- data %>% dplyr::mutate(presenceOfRetained = if_else(insensitive > 0, \YES\, \NO\),
                       percOfRetained = if_else(insensitive + sensitive == 0, 0, 100*insensitive/(insensitive + sensitive)))


###
ggplot(data, aes(x = group, y = percOfRetained, fill = group)) + geom_violin() + 
  geom_boxplot(outlier.shape = NA, width = 0.05, fill = \white\) + theme_bw()


### Stacked barplot
group <- c(\group1\, \group1\, \group2\, \group2\)
presenceOfRetained <- rep(c(\YES\, \NO\), 2)
presenceOfRetained <- factor (presenceOfRetained, levels = c(\YES\, \NO\))
value <- c(nrow(data %>% dplyr::filter(group == \group1\, presenceOfRetained == \YES\)),
           nrow(data %>% dplyr::filter(group == \group1\, presenceOfRetained == \NO\)),
           nrow(data %>% dplyr::filter(group == \group2\, presenceOfRetained == \YES\)),
           nrow(data %>% dplyr::filter(group == \group2\, presenceOfRetained == \NO\)))
plotData <- data.frame(group, presenceOfRetained, value)

ggplot(plotData, aes(fill=presenceOfRetained, y=value, x=group)) + 
    geom_bar(position=\fill\, stat=\identity\) + theme_classic()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




### [2.24] (WORKING ON)Checking the percentage of non-important loops
Idea: having one non-perturbed reg loops could be enough.

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubG9vcHMgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfc2NvcmUudHN2XCIpKVxuXG5zYW1wbGUgPC0gXCJHMS5ETVNPLk1lcmdlZFwiXG5mb3Ioc2FtcGxlIGluIGMoXCJHMS5ETVNPLk1lcmdlZFwiLCBcIkcxLmRUQUcuTWVyZ2VkXCIsIFwiRzEuQTQ4NS5NZXJnZWRcIikpe1xuICB0ZW1wLjI1a2IgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcImxvb3BTY29yZV9cIiwgc2FtcGxlLCBcIl8yNWtiLnRzdlwiKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IGVuZDEgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKGNocm9tMSwgYmluU2l6ZSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFwiX1wiKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3BzJGlkKSAlPiVcbiAgICBkcGx5cjo6c2VsZWN0KGNocm9tMSwgc3RhcnQxLCBlbmQxLCBjaHJvbTIsIHN0YXJ0MiwgZW5kMiwgaWQsIG9ic2VydmVkLCBcIk8vRVwiKVxuICBjb2xuYW1lcyh0ZW1wLjI1a2IpIDwtIGMoXCJjaHJvbTFcIiwgXCJzdGFydDFcIiwgXCJlbmQxXCIsIFwiY2hyb20yXCIsIFwic3RhcnQyXCIsIFwiZW5kMlwiLCBcImlkXCIsIFwib2JzXCIsIFwib2JzZXhwXCIpXG4gIFxuICB0ZW1wLjEwa2IgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcImxvb3BTY29yZV9cIiwgc2FtcGxlLCBcIl8xMGtiLnRzdlwiKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IGVuZDEgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKGNocm9tMSwgYmluU2l6ZSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFwiX1wiKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3BzJGlkKSAlPiVcbiAgICBkcGx5cjo6c2VsZWN0KGNocm9tMSwgc3RhcnQxLCBlbmQxLCBjaHJvbTIsIHN0YXJ0MiwgZW5kMiwgaWQsIG9ic2VydmVkLCBcIk8vRVwiKVxuICBjb2xuYW1lcyh0ZW1wLjEwa2IpIDwtIGMoXCJjaHJvbTFcIiwgXCJzdGFydDFcIiwgXCJlbmQxXCIsIFwiY2hyb20yXCIsIFwic3RhcnQyXCIsIFwiZW5kMlwiLCBcImlkXCIsIFwib2JzXCIsIFwib2JzZXhwXCIpXG4gIFxuICB0ZW1wLjVrYiA8LWZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXCJsb29wU2NvcmVfXCIsIHNhbXBsZSwgXCJfNWtiLnRzdlwiKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IGVuZDEgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKGNocm9tMSwgYmluU2l6ZSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFwiX1wiKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3BzJGlkKSAlPiVcbiAgICBkcGx5cjo6c2VsZWN0KGNocm9tMSwgc3RhcnQxLCBlbmQxLCBjaHJvbTIsIHN0YXJ0MiwgZW5kMiwgaWQsIG9ic2VydmVkLCBcIk8vRVwiKVxuICBjb2xuYW1lcyh0ZW1wLjVrYikgPC0gYyhcImNocm9tMVwiLCBcInN0YXJ0MVwiLCBcImVuZDFcIiwgXCJjaHJvbTJcIiwgXCJzdGFydDJcIiwgXCJlbmQyXCIsIFwiaWRcIiwgXCJvYnNcIiwgXCJvYnNleHBcIilcbiAgXG4gIHRlbXAgPC0gYmluZF9yb3dzKHRlbXAuMjVrYiwgdGVtcC4xMGtiLCB0ZW1wLjVrYilcbiAgZndyaXRlKHRlbXAsIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXCJsb29wU2NvcmVfXCIsIHNhbXBsZSwgXCIudHN2XCIpKSwgc2VwID0gXCJcXHRcIilcbn1cblxuXG50ZW1wLkRNU08gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwibG9vcFNjb3JlX0cxLkRNU08uTWVyZ2VkLnRzdlwiKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5ETVNPKSA8LSBjKFwiaWRcIiwgXCJvYnNfRE1TT1wiLCBcIm9ic2V4cF9ETVNPXCIpXG50ZW1wLmRUQUcgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwibG9vcFNjb3JlX0cxLmRUQUcuTWVyZ2VkLnRzdlwiKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5kVEFHKSA8LSBjKFwiaWRcIiwgXCJvYnNfZFRBR1wiLCBcIm9ic2V4cF9kVEFHXCIpXG50ZW1wLkE0ODUgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwibG9vcFNjb3JlX0cxLkE0ODUuTWVyZ2VkLnRzdlwiKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5BNDg1KSA8LSBjKFwiaWRcIiwgXCJvYnNfQTQ4NVwiLCBcIm9ic2V4cF9BNDg1XCIpXG5cbmxvb3BzX29lIDwtIGZ1bGxfam9pbihmdWxsX2pvaW4odGVtcC5ETVNPLCB0ZW1wLmRUQUcsIGJ5ID0gXCJpZFwiKSxcbiAgICAgICAgICB0ZW1wLkE0ODUsIGJ5ID0gXCJpZFwiKSAlPiVcbiAgZHBseXI6Om11dGF0ZShvZUZDX2RUQUdfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgTkEsIG9ic2V4cF9kVEFHL29ic2V4cF9ETVNPKSxcbiAgICAgICAgICAgICAgICBvZUZDX0E0ODVfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgTkEsIG9ic2V4cF9BNDg1L29ic2V4cF9ETVNPKSlcblxuZndyaXRlKGxvb3BzX29lLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFwibG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlwiKSksIHNlcCA9IFwiXFx0XCIpXG5gYGAifQ== -->\n\n```r\nloops <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\nsample <- \\G1.DMSO.Merged\\\nfor(sample in c(\\G1.DMSO.Merged\\, \\G1.dTAG.Merged\\, \\G1.A485.Merged\\)){\n  temp.25kb <- fread(here(consensusDir, paste0(\\loopScore_\\, sample, \\_25kb.tsv\\))) %>%\n    dplyr::mutate(binSize = end1 - start1,\n                  id = paste(chrom1, binSize, start1, start2, sep = \\_\\)) %>%\n    dplyr::filter(id %in% loops$id) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \\O/E\\)\n  colnames(temp.25kb) <- c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\, \\id\\, \\obs\\, \\obsexp\\)\n  \n  temp.10kb <- fread(here(consensusDir, paste0(\\loopScore_\\, sample, \\_10kb.tsv\\))) %>%\n    dplyr::mutate(binSize = end1 - start1,\n                  id = paste(chrom1, binSize, start1, start2, sep = \\_\\)) %>%\n    dplyr::filter(id %in% loops$id) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \\O/E\\)\n  colnames(temp.10kb) <- c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\, \\id\\, \\obs\\, \\obsexp\\)\n  \n  temp.5kb <-fread(here(consensusDir, paste0(\\loopScore_\\, sample, \\_5kb.tsv\\))) %>%\n    dplyr::mutate(binSize = end1 - start1,\n                  id = paste(chrom1, binSize, start1, start2, sep = \\_\\)) %>%\n    dplyr::filter(id %in% loops$id) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \\O/E\\)\n  colnames(temp.5kb) <- c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\, \\id\\, \\obs\\, \\obsexp\\)\n  \n  temp <- bind_rows(temp.25kb, temp.10kb, temp.5kb)\n  fwrite(temp, here(consensusDir, paste0(\\loopScore_\\, sample, \\.tsv\\)), sep = \\\\t\\)\n}\n\n\ntemp.DMSO <- fread(here(consensusDir, \\loopScore_G1.DMSO.Merged.tsv\\)) %>%\n  dplyr::select(id, obs, obsexp)\ncolnames(temp.DMSO) <- c(\\id\\, \\obs_DMSO\\, \\obsexp_DMSO\\)\ntemp.dTAG <- fread(here(consensusDir, \\loopScore_G1.dTAG.Merged.tsv\\)) %>%\n  dplyr::select(id, obs, obsexp)\ncolnames(temp.dTAG) <- c(\\id\\, \\obs_dTAG\\, \\obsexp_dTAG\\)\ntemp.A485 <- fread(here(consensusDir, \\loopScore_G1.A485.Merged.tsv\\)) %>%\n  dplyr::select(id, obs, obsexp)\ncolnames(temp.A485) <- c(\\id\\, \\obs_A485\\, \\obsexp_A485\\)\n\nloops_oe <- full_join(full_join(temp.DMSO, temp.dTAG, by = \\id\\),\n          temp.A485, by = \\id\\) %>%\n  dplyr::mutate(oeFC_dTAG_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_dTAG/obsexp_DMSO),\n                oeFC_A485_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_A485/obsexp_DMSO))\n\nfwrite(loops_oe, here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\)), sep = \\\\t\\)\n```\n\n<!-- rnb-source-end -->\n"} -->
loops <- fread(here(consensusDir, \chromo_cons_score.tsv\))

sample <- \G1.DMSO.Merged\
for(sample in c(\G1.DMSO.Merged\, \G1.dTAG.Merged\, \G1.A485.Merged\)){
  temp.25kb <- fread(here(consensusDir, paste0(\loopScore_\, sample, \_25kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.25kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp.10kb <- fread(here(consensusDir, paste0(\loopScore_\, sample, \_10kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.10kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp.5kb <-fread(here(consensusDir, paste0(\loopScore_\, sample, \_5kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.5kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp <- bind_rows(temp.25kb, temp.10kb, temp.5kb)
  fwrite(temp, here(consensusDir, paste0(\loopScore_\, sample, \.tsv\)), sep = \\t\)
}


temp.DMSO <- fread(here(consensusDir, \loopScore_G1.DMSO.Merged.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.DMSO) <- c(\id\, \obs_DMSO\, \obsexp_DMSO\)
temp.dTAG <- fread(here(consensusDir, \loopScore_G1.dTAG.Merged.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.dTAG) <- c(\id\, \obs_dTAG\, \obsexp_dTAG\)
temp.A485 <- fread(here(consensusDir, \loopScore_G1.A485.Merged.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.A485) <- c(\id\, \obs_A485\, \obsexp_A485\)

loops_oe <- full_join(full_join(temp.DMSO, temp.dTAG, by = \id\),
          temp.A485, by = \id\) %>%
  dplyr::mutate(oeFC_dTAG_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_dTAG/obsexp_DMSO),
                oeFC_A485_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_A485/obsexp_DMSO))

fwrite(loops_oe, here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\)), sep = \\t\)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubG9vcHMgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfc2NvcmUudHN2XFwpKVxuXG5zYW1wbGUgPC0gXFxHMS5ETVNPLk1lcmdlZFxcXG5mb3Ioc2FtcGxlIGluIGMoXFxHMS5ETVNPLk1lcmdlZFxcLCBcXEcxLmRUQUcuTWVyZ2VkXFwsIFxcRzEuQTQ4NS5NZXJnZWRcXCkpe1xuICB0ZW1wLjI1a2IgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9cXCwgc2FtcGxlLCBcXF8yNWtiLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IGVuZDEgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKGNocm9tMSwgYmluU2l6ZSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3BzJGlkKSAlPiVcbiAgICBkcGx5cjo6c2VsZWN0KGNocm9tMSwgc3RhcnQxLCBlbmQxLCBjaHJvbTIsIHN0YXJ0MiwgZW5kMiwgaWQsIG9ic2VydmVkLCBcXE8vRVxcKVxuICBjb2xuYW1lcyh0ZW1wLjI1a2IpIDwtIGMoXFxjaHJvbTFcXCwgXFxzdGFydDFcXCwgXFxlbmQxXFwsIFxcY2hyb20yXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcLCBcXGlkXFwsIFxcb2JzXFwsIFxcb2JzZXhwXFwpXG4gIFxuICB0ZW1wLjEwa2IgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9cXCwgc2FtcGxlLCBcXF8xMGtiLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IGVuZDEgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKGNocm9tMSwgYmluU2l6ZSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3BzJGlkKSAlPiVcbiAgICBkcGx5cjo6c2VsZWN0KGNocm9tMSwgc3RhcnQxLCBlbmQxLCBjaHJvbTIsIHN0YXJ0MiwgZW5kMiwgaWQsIG9ic2VydmVkLCBcXE8vRVxcKVxuICBjb2xuYW1lcyh0ZW1wLjEwa2IpIDwtIGMoXFxjaHJvbTFcXCwgXFxzdGFydDFcXCwgXFxlbmQxXFwsIFxcY2hyb20yXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcLCBcXGlkXFwsIFxcb2JzXFwsIFxcb2JzZXhwXFwpXG4gIFxuICB0ZW1wLjVrYiA8LWZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIHNhbXBsZSwgXFxfNWtiLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IGVuZDEgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKGNocm9tMSwgYmluU2l6ZSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3BzJGlkKSAlPiVcbiAgICBkcGx5cjo6c2VsZWN0KGNocm9tMSwgc3RhcnQxLCBlbmQxLCBjaHJvbTIsIHN0YXJ0MiwgZW5kMiwgaWQsIG9ic2VydmVkLCBcXE8vRVxcKVxuICBjb2xuYW1lcyh0ZW1wLjVrYikgPC0gYyhcXGNocm9tMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHJvbTJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcaWRcXCwgXFxvYnNcXCwgXFxvYnNleHBcXClcbiAgXG4gIHRlbXAgPC0gYmluZF9yb3dzKHRlbXAuMjVrYiwgdGVtcC4xMGtiLCB0ZW1wLjVrYilcbiAgZndyaXRlKHRlbXAsIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIHNhbXBsZSwgXFwudHN2XFwpKSwgc2VwID0gXFxcXHRcXClcbn1cblxuXG50ZW1wLkRNU08gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcbG9vcFNjb3JlX0cxLkRNU08uTWVyZ2VkLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5ETVNPKSA8LSBjKFxcaWRcXCwgXFxvYnNfRE1TT1xcLCBcXG9ic2V4cF9ETVNPXFwpXG50ZW1wLmRUQUcgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcbG9vcFNjb3JlX0cxLmRUQUcuTWVyZ2VkLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5kVEFHKSA8LSBjKFxcaWRcXCwgXFxvYnNfZFRBR1xcLCBcXG9ic2V4cF9kVEFHXFwpXG50ZW1wLkE0ODUgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcbG9vcFNjb3JlX0cxLkE0ODUuTWVyZ2VkLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5BNDg1KSA8LSBjKFxcaWRcXCwgXFxvYnNfQTQ4NVxcLCBcXG9ic2V4cF9BNDg1XFwpXG5cbmxvb3BzX29lIDwtIGZ1bGxfam9pbihmdWxsX2pvaW4odGVtcC5ETVNPLCB0ZW1wLmRUQUcsIGJ5ID0gXFxpZFxcKSxcbiAgICAgICAgICB0ZW1wLkE0ODUsIGJ5ID0gXFxpZFxcKSAlPiVcbiAgZHBseXI6Om11dGF0ZShvZUZDX2RUQUdfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgTkEsIG9ic2V4cF9kVEFHL29ic2V4cF9ETVNPKSxcbiAgICAgICAgICAgICAgICBvZUZDX0E0ODVfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgTkEsIG9ic2V4cF9BNDg1L29ic2V4cF9ETVNPKSlcblxuZndyaXRlKGxvb3BzX29lLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\nloops <- fread(here(consensusDir, \\chromo_cons_score.tsv\\))\n\nsample <- \\G1.DMSO.Merged\\\nfor(sample in c(\\G1.DMSO.Merged\\, \\G1.dTAG.Merged\\, \\G1.A485.Merged\\)){\n  temp.25kb <- fread(here(consensusDir, paste0(\\loopScore_\\, sample, \\_25kb.tsv\\))) %>%\n    dplyr::mutate(binSize = end1 - start1,\n                  id = paste(chrom1, binSize, start1, start2, sep = \\_\\)) %>%\n    dplyr::filter(id %in% loops$id) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \\O/E\\)\n  colnames(temp.25kb) <- c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\, \\id\\, \\obs\\, \\obsexp\\)\n  \n  temp.10kb <- fread(here(consensusDir, paste0(\\loopScore_\\, sample, \\_10kb.tsv\\))) %>%\n    dplyr::mutate(binSize = end1 - start1,\n                  id = paste(chrom1, binSize, start1, start2, sep = \\_\\)) %>%\n    dplyr::filter(id %in% loops$id) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \\O/E\\)\n  colnames(temp.10kb) <- c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\, \\id\\, \\obs\\, \\obsexp\\)\n  \n  temp.5kb <-fread(here(consensusDir, paste0(\\loopScore_\\, sample, \\_5kb.tsv\\))) %>%\n    dplyr::mutate(binSize = end1 - start1,\n                  id = paste(chrom1, binSize, start1, start2, sep = \\_\\)) %>%\n    dplyr::filter(id %in% loops$id) %>%\n    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \\O/E\\)\n  colnames(temp.5kb) <- c(\\chrom1\\, \\start1\\, \\end1\\, \\chrom2\\, \\start2\\, \\end2\\, \\id\\, \\obs\\, \\obsexp\\)\n  \n  temp <- bind_rows(temp.25kb, temp.10kb, temp.5kb)\n  fwrite(temp, here(consensusDir, paste0(\\loopScore_\\, sample, \\.tsv\\)), sep = \\\\t\\)\n}\n\n\ntemp.DMSO <- fread(here(consensusDir, \\loopScore_G1.DMSO.Merged.tsv\\)) %>%\n  dplyr::select(id, obs, obsexp)\ncolnames(temp.DMSO) <- c(\\id\\, \\obs_DMSO\\, \\obsexp_DMSO\\)\ntemp.dTAG <- fread(here(consensusDir, \\loopScore_G1.dTAG.Merged.tsv\\)) %>%\n  dplyr::select(id, obs, obsexp)\ncolnames(temp.dTAG) <- c(\\id\\, \\obs_dTAG\\, \\obsexp_dTAG\\)\ntemp.A485 <- fread(here(consensusDir, \\loopScore_G1.A485.Merged.tsv\\)) %>%\n  dplyr::select(id, obs, obsexp)\ncolnames(temp.A485) <- c(\\id\\, \\obs_A485\\, \\obsexp_A485\\)\n\nloops_oe <- full_join(full_join(temp.DMSO, temp.dTAG, by = \\id\\),\n          temp.A485, by = \\id\\) %>%\n  dplyr::mutate(oeFC_dTAG_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_dTAG/obsexp_DMSO),\n                oeFC_A485_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_A485/obsexp_DMSO))\n\nfwrite(loops_oe, here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\)), sep = \\\\t\\)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubG9vcHMgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfc2NvcmUudHN2XFwpKVxuXG5zYW1wbGUgPC0gXFxHMS5ETVNPLk1lcmdlZFxcXG5mb3Ioc2FtcGxlIGluIGMoXFxHMS5ETVNPLk1lcmdlZFxcLCBcXEcxLmRUQUcuTWVyZ2VkXFwsIFxcRzEuQTQ4NS5NZXJnZWRcXCkpe1xuICB0ZW1wLjI1a2IgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9cXCwgc2FtcGxlLCBcXF8yNWtiLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IGVuZDEgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKGNocm9tMSwgYmluU2l6ZSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3BzJGlkKSAlPiVcbiAgICBkcGx5cjo6c2VsZWN0KGNocm9tMSwgc3RhcnQxLCBlbmQxLCBjaHJvbTIsIHN0YXJ0MiwgZW5kMiwgaWQsIG9ic2VydmVkLCBcXE8vRVxcKVxuICBjb2xuYW1lcyh0ZW1wLjI1a2IpIDwtIGMoXFxjaHJvbTFcXCwgXFxzdGFydDFcXCwgXFxlbmQxXFwsIFxcY2hyb20yXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcLCBcXGlkXFwsIFxcb2JzXFwsIFxcb2JzZXhwXFwpXG4gIFxuICB0ZW1wLjEwa2IgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9cXCwgc2FtcGxlLCBcXF8xMGtiLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IGVuZDEgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKGNocm9tMSwgYmluU2l6ZSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3BzJGlkKSAlPiVcbiAgICBkcGx5cjo6c2VsZWN0KGNocm9tMSwgc3RhcnQxLCBlbmQxLCBjaHJvbTIsIHN0YXJ0MiwgZW5kMiwgaWQsIG9ic2VydmVkLCBcXE8vRVxcKVxuICBjb2xuYW1lcyh0ZW1wLjEwa2IpIDwtIGMoXFxjaHJvbTFcXCwgXFxzdGFydDFcXCwgXFxlbmQxXFwsIFxcY2hyb20yXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcLCBcXGlkXFwsIFxcb2JzXFwsIFxcb2JzZXhwXFwpXG4gIFxuICB0ZW1wLjVrYiA8LWZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIHNhbXBsZSwgXFxfNWtiLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IGVuZDEgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKGNocm9tMSwgYmluU2l6ZSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3BzJGlkKSAlPiVcbiAgICBkcGx5cjo6c2VsZWN0KGNocm9tMSwgc3RhcnQxLCBlbmQxLCBjaHJvbTIsIHN0YXJ0MiwgZW5kMiwgaWQsIG9ic2VydmVkLCBcXE8vRVxcKVxuICBjb2xuYW1lcyh0ZW1wLjVrYikgPC0gYyhcXGNocm9tMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHJvbTJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcaWRcXCwgXFxvYnNcXCwgXFxvYnNleHBcXClcbiAgXG4gIHRlbXAgPC0gYmluZF9yb3dzKHRlbXAuMjVrYiwgdGVtcC4xMGtiLCB0ZW1wLjVrYilcbiAgZndyaXRlKHRlbXAsIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfXFwsIHNhbXBsZSwgXFwudHN2XFwpKSwgc2VwID0gXFxcXHRcXClcbn1cblxuXG50ZW1wLkRNU08gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcbG9vcFNjb3JlX0cxLkRNU08uTWVyZ2VkLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5ETVNPKSA8LSBjKFxcaWRcXCwgXFxvYnNfRE1TT1xcLCBcXG9ic2V4cF9ETVNPXFwpXG50ZW1wLmRUQUcgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcbG9vcFNjb3JlX0cxLmRUQUcuTWVyZ2VkLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5kVEFHKSA8LSBjKFxcaWRcXCwgXFxvYnNfZFRBR1xcLCBcXG9ic2V4cF9kVEFHXFwpXG50ZW1wLkE0ODUgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcbG9vcFNjb3JlX0cxLkE0ODUuTWVyZ2VkLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5BNDg1KSA8LSBjKFxcaWRcXCwgXFxvYnNfQTQ4NVxcLCBcXG9ic2V4cF9BNDg1XFwpXG5cbmxvb3BzX29lIDwtIGZ1bGxfam9pbihmdWxsX2pvaW4odGVtcC5ETVNPLCB0ZW1wLmRUQUcsIGJ5ID0gXFxpZFxcKSxcbiAgICAgICAgICB0ZW1wLkE0ODUsIGJ5ID0gXFxpZFxcKSAlPiVcbiAgZHBseXI6Om11dGF0ZShvZUZDX2RUQUdfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgTkEsIG9ic2V4cF9kVEFHL29ic2V4cF9ETVNPKSxcbiAgICAgICAgICAgICAgICBvZUZDX0E0ODVfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgTkEsIG9ic2V4cF9BNDg1L29ic2V4cF9ETVNPKSlcblxuZndyaXRlKGxvb3BzX29lLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG5gYGBcbmBgYCJ9 -->

```r
```r
loops <- fread(here(consensusDir, \chromo_cons_score.tsv\))

sample <- \G1.DMSO.Merged\
for(sample in c(\G1.DMSO.Merged\, \G1.dTAG.Merged\, \G1.A485.Merged\)){
  temp.25kb <- fread(here(consensusDir, paste0(\loopScore_\, sample, \_25kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.25kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp.10kb <- fread(here(consensusDir, paste0(\loopScore_\, sample, \_10kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.10kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp.5kb <-fread(here(consensusDir, paste0(\loopScore_\, sample, \_5kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.5kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp <- bind_rows(temp.25kb, temp.10kb, temp.5kb)
  fwrite(temp, here(consensusDir, paste0(\loopScore_\, sample, \.tsv\)), sep = \\t\)
}


temp.DMSO <- fread(here(consensusDir, \loopScore_G1.DMSO.Merged.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.DMSO) <- c(\id\, \obs_DMSO\, \obsexp_DMSO\)
temp.dTAG <- fread(here(consensusDir, \loopScore_G1.dTAG.Merged.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.dTAG) <- c(\id\, \obs_dTAG\, \obsexp_dTAG\)
temp.A485 <- fread(here(consensusDir, \loopScore_G1.A485.Merged.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.A485) <- c(\id\, \obs_A485\, \obsexp_A485\)

loops_oe <- full_join(full_join(temp.DMSO, temp.dTAG, by = \id\),
          temp.A485, by = \id\) %>%
  dplyr::mutate(oeFC_dTAG_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_dTAG/obsexp_DMSO),
                oeFC_A485_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_A485/obsexp_DMSO))

fwrite(loops_oe, here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\)), sep = \\t\)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHViRzl2Y0hNZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGd2lZMmh5YjIxdlgyTnZibk5mYzJOdmNtVXVkSE4yWENJcEtWeHVYRzVtYjNJb2MyRnRjR3hsSUdsdUlHTW9YQ0pCYzNsdVl5NVZWRndpTENCY0lrRnplVzVqTGtGSlJGd2lLU2w3WEc0Z0lIUmxiWEF1TWpWcllpQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tGd2liRzl2Y0ZOamIzSmxYMXdpTENCellXMXdiR1VzSUZ3aVh6STFhMkl1ZEhOMlhDSXBLU2tnSlQ0bFhHNGdJQ0FnWkhCc2VYSTZPbTExZEdGMFpTaGlhVzVUYVhwbElEMGdaVzVrTVNBdElITjBZWEowTVN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbGtJRDBnY0dGemRHVW9ZMmh5YjIweExDQmlhVzVUYVhwbExDQnpkR0Z5ZERFc0lITjBZWEowTWl3Z2MyVndJRDBnWENKZlhDSXBLU0FsUGlWY2JpQWdJQ0JrY0d4NWNqbzZabWxzZEdWeUtHbGtJQ1ZwYmlVZ2JHOXZjSE1rYVdRcElDVStKVnh1SUNBZ0lHUndiSGx5T2pwelpXeGxZM1FvWTJoeWIyMHhMQ0J6ZEdGeWRERXNJR1Z1WkRFc0lHTm9jbTl0TWl3Z2MzUmhjblF5TENCbGJtUXlMQ0JwWkN3Z2IySnpaWEoyWldRc0lGd2lUeTlGWENJcFhHNGdJR052Ykc1aGJXVnpLSFJsYlhBdU1qVnJZaWtnUEMwZ1l5aGNJbU5vY205dE1Wd2lMQ0JjSW5OMFlYSjBNVndpTENCY0ltVnVaREZjSWl3Z1hDSmphSEp2YlRKY0lpd2dYQ0p6ZEdGeWRESmNJaXdnWENKbGJtUXlYQ0lzSUZ3aWFXUmNJaXdnWENKdlluTmNJaXdnWENKdlluTmxlSEJjSWlsY2JpQWdYRzRnSUhSbGJYQXVNVEJyWWlBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0Z3aWJHOXZjRk5qYjNKbFgxd2lMQ0J6WVcxd2JHVXNJRndpWHpFd2EySXVkSE4yWENJcEtTa2dKVDRsWEc0Z0lDQWdaSEJzZVhJNk9tMTFkR0YwWlNoaWFXNVRhWHBsSUQwZ1pXNWtNU0F0SUhOMFlYSjBNU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdsa0lEMGdjR0Z6ZEdVb1kyaHliMjB4TENCaWFXNVRhWHBsTENCemRHRnlkREVzSUhOMFlYSjBNaXdnYzJWd0lEMGdYQ0pmWENJcEtTQWxQaVZjYmlBZ0lDQmtjR3g1Y2pvNlptbHNkR1Z5S0dsa0lDVnBiaVVnYkc5dmNITWthV1FwSUNVK0pWeHVJQ0FnSUdSd2JIbHlPanB6Wld4bFkzUW9ZMmh5YjIweExDQnpkR0Z5ZERFc0lHVnVaREVzSUdOb2NtOXRNaXdnYzNSaGNuUXlMQ0JsYm1ReUxDQnBaQ3dnYjJKelpYSjJaV1FzSUZ3aVR5OUZYQ0lwWEc0Z0lHTnZiRzVoYldWektIUmxiWEF1TVRCcllpa2dQQzBnWXloY0ltTm9jbTl0TVZ3aUxDQmNJbk4wWVhKME1Wd2lMQ0JjSW1WdVpERmNJaXdnWENKamFISnZiVEpjSWl3Z1hDSnpkR0Z5ZERKY0lpd2dYQ0psYm1ReVhDSXNJRndpYVdSY0lpd2dYQ0p2WW5OY0lpd2dYQ0p2WW5ObGVIQmNJaWxjYmlBZ1hHNGdJSFJsYlhBdU5XdGlJRHd0Wm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJSEJoYzNSbE1DaGNJbXh2YjNCVFkyOXlaVjljSWl3Z2MyRnRjR3hsTENCY0lsODFhMkl1ZEhOMlhDSXBLU2tnSlQ0bFhHNGdJQ0FnWkhCc2VYSTZPbTExZEdGMFpTaGlhVzVUYVhwbElEMGdaVzVrTVNBdElITjBZWEowTVN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbGtJRDBnY0dGemRHVW9ZMmh5YjIweExDQmlhVzVUYVhwbExDQnpkR0Z5ZERFc0lITjBZWEowTWl3Z2MyVndJRDBnWENKZlhDSXBLU0FsUGlWY2JpQWdJQ0JrY0d4NWNqbzZabWxzZEdWeUtHbGtJQ1ZwYmlVZ2JHOXZjSE1rYVdRcElDVStKVnh1SUNBZ0lHUndiSGx5T2pwelpXeGxZM1FvWTJoeWIyMHhMQ0J6ZEdGeWRERXNJR1Z1WkRFc0lHTm9jbTl0TWl3Z2MzUmhjblF5TENCbGJtUXlMQ0JwWkN3Z2IySnpaWEoyWldRc0lGd2lUeTlGWENJcFhHNGdJR052Ykc1aGJXVnpLSFJsYlhBdU5XdGlLU0E4TFNCaktGd2lZMmh5YjIweFhDSXNJRndpYzNSaGNuUXhYQ0lzSUZ3aVpXNWtNVndpTENCY0ltTm9jbTl0TWx3aUxDQmNJbk4wWVhKME1sd2lMQ0JjSW1WdVpESmNJaXdnWENKcFpGd2lMQ0JjSW05aWMxd2lMQ0JjSW05aWMyVjRjRndpS1Z4dUlDQmNiaUFnZEdWdGNDQThMU0JpYVc1a1gzSnZkM01vZEdWdGNDNHlOV3RpTENCMFpXMXdMakV3YTJJc0lIUmxiWEF1Tld0aUtWeHVJQ0JtZDNKcGRHVW9kR1Z0Y0N3Z2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lIQmhjM1JsTUNoY0lteHZiM0JUWTI5eVpWOWNJaXdnYzJGdGNHeGxMQ0JjSWk1MGMzWmNJaWtwTENCelpYQWdQU0JjSWx4Y2RGd2lLVnh1ZlZ4dVhHNWNiblJsYlhBdVZWUWdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJRndpYkc5dmNGTmpiM0psWDBGemVXNWpMbFZVTG5SemRsd2lLU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHpaV3hsWTNRb2FXUXNJRzlpY3l3Z2IySnpaWGh3S1Z4dVkyOXNibUZ0WlhNb2RHVnRjQzVWVkNrZ1BDMGdZeWhjSW1sa1hDSXNJRndpYjJKelgxVlVYQ0lzSUZ3aWIySnpaWGh3WDFWVVhDSXBYRzUwWlcxd0xrRkpSQ0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnWENKc2IyOXdVMk52Y21WZlFYTjVibU11UVVsRUxuUnpkbHdpS1NrZ0pUNGxYRzRnSUdSd2JIbHlPanB6Wld4bFkzUW9hV1FzSUc5aWN5d2diMkp6Wlhod0tWeHVZMjlzYm1GdFpYTW9kR1Z0Y0M1QlNVUXBJRHd0SUdNb1hDSnBaRndpTENCY0ltOWljMTlCU1VSY0lpd2dYQ0p2WW5ObGVIQmZRVWxFWENJcFhHNWNibXh2YjNCelgyOWxJRHd0SUdaMWJHeGZhbTlwYmloMFpXMXdMbFZVTENCMFpXMXdMa0ZKUkN3Z1lua2dQU0JjSW1sa1hDSXBJQ1UrSlZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0c5bFJrTmZRVWxFWDFWVUlEMGdhV1pmWld4elpTaHZZbk5sZUhCZlZWUWdQVDBnTUN3Z1RrRXNJRzlpYzJWNGNGOUJTVVF2YjJKelpYaHdYMVZVS1NsY2JseHVabmR5YVhSbEtHeHZiM0J6WDI5bExDQm9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tGd2liRzl2Y0ZOamIzSmxYMk52Ym5OZmIySnpaWGh3WDBGemVXNWpMblJ6ZGx3aUtTa3NJSE5sY0NBOUlGd2lYRngwWENJcFhHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxubG9vcHMgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfc2NvcmUudHN2XFwpKVxuXG5mb3Ioc2FtcGxlIGluIGMoXFxBc3luYy5VVFxcLCBcXEFzeW5jLkFJRFxcKSl7XG4gIHRlbXAuMjVrYiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBzYW1wbGUsIFxcXzI1a2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoY2hyb20xLCBzdGFydDEsIGVuZDEsIGNocm9tMiwgc3RhcnQyLCBlbmQyLCBpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuMjVrYikgPC0gYyhcXGNocm9tMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHJvbTJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcaWRcXCwgXFxvYnNcXCwgXFxvYnNleHBcXClcbiAgXG4gIHRlbXAuMTBrYiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBzYW1wbGUsIFxcXzEwa2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoY2hyb20xLCBzdGFydDEsIGVuZDEsIGNocm9tMiwgc3RhcnQyLCBlbmQyLCBpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuMTBrYikgPC0gYyhcXGNocm9tMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHJvbTJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcaWRcXCwgXFxvYnNcXCwgXFxvYnNleHBcXClcbiAgXG4gIHRlbXAuNWtiIDwtZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9cXCwgc2FtcGxlLCBcXF81a2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoY2hyb20xLCBzdGFydDEsIGVuZDEsIGNocm9tMiwgc3RhcnQyLCBlbmQyLCBpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuNWtiKSA8LSBjKFxcY2hyb20xXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocm9tMlxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXCwgXFxpZFxcLCBcXG9ic1xcLCBcXG9ic2V4cFxcKVxuICBcbiAgdGVtcCA8LSBiaW5kX3Jvd3ModGVtcC4yNWtiLCB0ZW1wLjEwa2IsIHRlbXAuNWtiKVxuICBmd3JpdGUodGVtcCwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9cXCwgc2FtcGxlLCBcXC50c3ZcXCkpLCBzZXAgPSBcXFxcdFxcKVxufVxuXG5cbnRlbXAuVVQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcbG9vcFNjb3JlX0FzeW5jLlVULnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5VVCkgPC0gYyhcXGlkXFwsIFxcb2JzX1VUXFwsIFxcb2JzZXhwX1VUXFwpXG50ZW1wLkFJRCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxsb29wU2NvcmVfQXN5bmMuQUlELnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5BSUQpIDwtIGMoXFxpZFxcLCBcXG9ic19BSURcXCwgXFxvYnNleHBfQUlEXFwpXG5cbmxvb3BzX29lIDwtIGZ1bGxfam9pbih0ZW1wLlVULCB0ZW1wLkFJRCwgYnkgPSBcXGlkXFwpICU+JVxuICBkcGx5cjo6bXV0YXRlKG9lRkNfQUlEX1VUID0gaWZfZWxzZShvYnNleHBfVVQgPT0gMCwgTkEsIG9ic2V4cF9BSUQvb2JzZXhwX1VUKSlcblxuZndyaXRlKGxvb3BzX29lLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwX0FzeW5jLnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
loops <- fread(here(consensusDir, \chromo_cons_score.tsv\))

for(sample in c(\Async.UT\, \Async.AID\)){
  temp.25kb <- fread(here(consensusDir, paste0(\loopScore_\, sample, \_25kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.25kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp.10kb <- fread(here(consensusDir, paste0(\loopScore_\, sample, \_10kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.10kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp.5kb <-fread(here(consensusDir, paste0(\loopScore_\, sample, \_5kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.5kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp <- bind_rows(temp.25kb, temp.10kb, temp.5kb)
  fwrite(temp, here(consensusDir, paste0(\loopScore_\, sample, \.tsv\)), sep = \\t\)
}


temp.UT <- fread(here(consensusDir, \loopScore_Async.UT.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.UT) <- c(\id\, \obs_UT\, \obsexp_UT\)
temp.AID <- fread(here(consensusDir, \loopScore_Async.AID.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.AID) <- c(\id\, \obs_AID\, \obsexp_AID\)

loops_oe <- full_join(temp.UT, temp.AID, by = \id\) %>%
  dplyr::mutate(oeFC_AID_UT = if_else(obsexp_UT == 0, NA, obsexp_AID/obsexp_UT))

fwrite(loops_oe, here(consensusDir, paste0(\loopScore_cons_obsexp_Async.tsv\)), sep = \\t\)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJHOXZjSE1nUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ4Y1kyaHliMjF2WDJOdmJuTmZjMk52Y21VdWRITjJYRndwS1Z4dVhHNW1iM0lvYzJGdGNHeGxJR2x1SUdNb1hGeEJjM2x1WXk1VlZGeGNMQ0JjWEVGemVXNWpMa0ZKUkZ4Y0tTbDdYRzRnSUhSbGJYQXVNalZyWWlBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0Z4Y2JHOXZjRk5qYjNKbFgxeGNMQ0J6WVcxd2JHVXNJRnhjWHpJMWEySXVkSE4yWEZ3cEtTa2dKVDRsWEc0Z0lDQWdaSEJzZVhJNk9tMTFkR0YwWlNoaWFXNVRhWHBsSUQwZ1pXNWtNU0F0SUhOMFlYSjBNU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdsa0lEMGdjR0Z6ZEdVb1kyaHliMjB4TENCaWFXNVRhWHBsTENCemRHRnlkREVzSUhOMFlYSjBNaXdnYzJWd0lEMGdYRnhmWEZ3cEtTQWxQaVZjYmlBZ0lDQmtjR3g1Y2pvNlptbHNkR1Z5S0dsa0lDVnBiaVVnYkc5dmNITWthV1FwSUNVK0pWeHVJQ0FnSUdSd2JIbHlPanB6Wld4bFkzUW9ZMmh5YjIweExDQnpkR0Z5ZERFc0lHVnVaREVzSUdOb2NtOXRNaXdnYzNSaGNuUXlMQ0JsYm1ReUxDQnBaQ3dnYjJKelpYSjJaV1FzSUZ4Y1R5OUZYRndwWEc0Z0lHTnZiRzVoYldWektIUmxiWEF1TWpWcllpa2dQQzBnWXloY1hHTm9jbTl0TVZ4Y0xDQmNYSE4wWVhKME1WeGNMQ0JjWEdWdVpERmNYQ3dnWEZ4amFISnZiVEpjWEN3Z1hGeHpkR0Z5ZERKY1hDd2dYRnhsYm1ReVhGd3NJRnhjYVdSY1hDd2dYRnh2WW5OY1hDd2dYRnh2WW5ObGVIQmNYQ2xjYmlBZ1hHNGdJSFJsYlhBdU1UQnJZaUE4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRnhjYkc5dmNGTmpiM0psWDF4Y0xDQnpZVzF3YkdVc0lGeGNYekV3YTJJdWRITjJYRndwS1NrZ0pUNGxYRzRnSUNBZ1pIQnNlWEk2T20xMWRHRjBaU2hpYVc1VGFYcGxJRDBnWlc1a01TQXRJSE4wWVhKME1TeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xrSUQwZ2NHRnpkR1VvWTJoeWIyMHhMQ0JpYVc1VGFYcGxMQ0J6ZEdGeWRERXNJSE4wWVhKME1pd2djMlZ3SUQwZ1hGeGZYRndwS1NBbFBpVmNiaUFnSUNCa2NHeDVjam82Wm1sc2RHVnlLR2xrSUNWcGJpVWdiRzl2Y0hNa2FXUXBJQ1UrSlZ4dUlDQWdJR1J3YkhseU9qcHpaV3hsWTNRb1kyaHliMjB4TENCemRHRnlkREVzSUdWdVpERXNJR05vY205dE1pd2djM1JoY25ReUxDQmxibVF5TENCcFpDd2diMkp6WlhKMlpXUXNJRnhjVHk5RlhGd3BYRzRnSUdOdmJHNWhiV1Z6S0hSbGJYQXVNVEJyWWlrZ1BDMGdZeWhjWEdOb2NtOXRNVnhjTENCY1hITjBZWEowTVZ4Y0xDQmNYR1Z1WkRGY1hDd2dYRnhqYUhKdmJUSmNYQ3dnWEZ4emRHRnlkREpjWEN3Z1hGeGxibVF5WEZ3c0lGeGNhV1JjWEN3Z1hGeHZZbk5jWEN3Z1hGeHZZbk5sZUhCY1hDbGNiaUFnWEc0Z0lIUmxiWEF1Tld0aUlEd3RabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lIQmhjM1JsTUNoY1hHeHZiM0JUWTI5eVpWOWNYQ3dnYzJGdGNHeGxMQ0JjWEY4MWEySXVkSE4yWEZ3cEtTa2dKVDRsWEc0Z0lDQWdaSEJzZVhJNk9tMTFkR0YwWlNoaWFXNVRhWHBsSUQwZ1pXNWtNU0F0SUhOMFlYSjBNU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdsa0lEMGdjR0Z6ZEdVb1kyaHliMjB4TENCaWFXNVRhWHBsTENCemRHRnlkREVzSUhOMFlYSjBNaXdnYzJWd0lEMGdYRnhmWEZ3cEtTQWxQaVZjYmlBZ0lDQmtjR3g1Y2pvNlptbHNkR1Z5S0dsa0lDVnBiaVVnYkc5dmNITWthV1FwSUNVK0pWeHVJQ0FnSUdSd2JIbHlPanB6Wld4bFkzUW9ZMmh5YjIweExDQnpkR0Z5ZERFc0lHVnVaREVzSUdOb2NtOXRNaXdnYzNSaGNuUXlMQ0JsYm1ReUxDQnBaQ3dnYjJKelpYSjJaV1FzSUZ4Y1R5OUZYRndwWEc0Z0lHTnZiRzVoYldWektIUmxiWEF1Tld0aUtTQThMU0JqS0Z4Y1kyaHliMjB4WEZ3c0lGeGNjM1JoY25ReFhGd3NJRnhjWlc1a01WeGNMQ0JjWEdOb2NtOXRNbHhjTENCY1hITjBZWEowTWx4Y0xDQmNYR1Z1WkRKY1hDd2dYRnhwWkZ4Y0xDQmNYRzlpYzF4Y0xDQmNYRzlpYzJWNGNGeGNLVnh1SUNCY2JpQWdkR1Z0Y0NBOExTQmlhVzVrWDNKdmQzTW9kR1Z0Y0M0eU5XdGlMQ0IwWlcxd0xqRXdhMklzSUhSbGJYQXVOV3RpS1Z4dUlDQm1kM0pwZEdVb2RHVnRjQ3dnYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUhCaGMzUmxNQ2hjWEd4dmIzQlRZMjl5WlY5Y1hDd2djMkZ0Y0d4bExDQmNYQzUwYzNaY1hDa3BMQ0J6WlhBZ1BTQmNYRnhjZEZ4Y0tWeHVmVnh1WEc1Y2JuUmxiWEF1VlZRZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGeGNiRzl2Y0ZOamIzSmxYMEZ6ZVc1akxsVlVMblJ6ZGx4Y0tTa2dKVDRsWEc0Z0lHUndiSGx5T2pwelpXeGxZM1FvYVdRc0lHOWljeXdnYjJKelpYaHdLVnh1WTI5c2JtRnRaWE1vZEdWdGNDNVZWQ2tnUEMwZ1l5aGNYR2xrWEZ3c0lGeGNiMkp6WDFWVVhGd3NJRnhjYjJKelpYaHdYMVZVWEZ3cFhHNTBaVzF3TGtGSlJDQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2dYRnhzYjI5d1UyTnZjbVZmUVhONWJtTXVRVWxFTG5SemRseGNLU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHpaV3hsWTNRb2FXUXNJRzlpY3l3Z2IySnpaWGh3S1Z4dVkyOXNibUZ0WlhNb2RHVnRjQzVCU1VRcElEd3RJR01vWEZ4cFpGeGNMQ0JjWEc5aWMxOUJTVVJjWEN3Z1hGeHZZbk5sZUhCZlFVbEVYRndwWEc1Y2JteHZiM0J6WDI5bElEd3RJR1oxYkd4ZmFtOXBiaWgwWlcxd0xsVlVMQ0IwWlcxd0xrRkpSQ3dnWW5rZ1BTQmNYR2xrWEZ3cElDVStKVnh1SUNCa2NHeDVjam82YlhWMFlYUmxLRzlsUmtOZlFVbEVYMVZVSUQwZ2FXWmZaV3h6WlNodlluTmxlSEJmVlZRZ1BUMGdNQ3dnVGtFc0lHOWljMlY0Y0Y5QlNVUXZiMkp6Wlhod1gxVlVLU2xjYmx4dVpuZHlhWFJsS0d4dmIzQnpYMjlsTENCb1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0Z4Y2JHOXZjRk5qYjNKbFgyTnZibk5mYjJKelpYaHdYMEZ6ZVc1akxuUnpkbHhjS1Nrc0lITmxjQ0E5SUZ4Y1hGeDBYRndwWEc1Z1lHQmNibUJnWUNKOSAtLT5cblxuYGBgclxuYGBgclxubG9vcHMgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfc2NvcmUudHN2XFwpKVxuXG5mb3Ioc2FtcGxlIGluIGMoXFxBc3luYy5VVFxcLCBcXEFzeW5jLkFJRFxcKSl7XG4gIHRlbXAuMjVrYiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBzYW1wbGUsIFxcXzI1a2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoY2hyb20xLCBzdGFydDEsIGVuZDEsIGNocm9tMiwgc3RhcnQyLCBlbmQyLCBpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuMjVrYikgPC0gYyhcXGNocm9tMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHJvbTJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcaWRcXCwgXFxvYnNcXCwgXFxvYnNleHBcXClcbiAgXG4gIHRlbXAuMTBrYiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBzYW1wbGUsIFxcXzEwa2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoY2hyb20xLCBzdGFydDEsIGVuZDEsIGNocm9tMiwgc3RhcnQyLCBlbmQyLCBpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuMTBrYikgPC0gYyhcXGNocm9tMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHJvbTJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcaWRcXCwgXFxvYnNcXCwgXFxvYnNleHBcXClcbiAgXG4gIHRlbXAuNWtiIDwtZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9cXCwgc2FtcGxlLCBcXF81a2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoY2hyb20xLCBzdGFydDEsIGVuZDEsIGNocm9tMiwgc3RhcnQyLCBlbmQyLCBpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuNWtiKSA8LSBjKFxcY2hyb20xXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocm9tMlxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXCwgXFxpZFxcLCBcXG9ic1xcLCBcXG9ic2V4cFxcKVxuICBcbiAgdGVtcCA8LSBiaW5kX3Jvd3ModGVtcC4yNWtiLCB0ZW1wLjEwa2IsIHRlbXAuNWtiKVxuICBmd3JpdGUodGVtcCwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9cXCwgc2FtcGxlLCBcXC50c3ZcXCkpLCBzZXAgPSBcXFxcdFxcKVxufVxuXG5cbnRlbXAuVVQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcbG9vcFNjb3JlX0FzeW5jLlVULnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5VVCkgPC0gYyhcXGlkXFwsIFxcb2JzX1VUXFwsIFxcb2JzZXhwX1VUXFwpXG50ZW1wLkFJRCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxsb29wU2NvcmVfQXN5bmMuQUlELnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5BSUQpIDwtIGMoXFxpZFxcLCBcXG9ic19BSURcXCwgXFxvYnNleHBfQUlEXFwpXG5cbmxvb3BzX29lIDwtIGZ1bGxfam9pbih0ZW1wLlVULCB0ZW1wLkFJRCwgYnkgPSBcXGlkXFwpICU+JVxuICBkcGx5cjo6bXV0YXRlKG9lRkNfQUlEX1VUID0gaWZfZWxzZShvYnNleHBfVVQgPT0gMCwgTkEsIG9ic2V4cF9BSUQvb2JzZXhwX1VUKSlcblxuZndyaXRlKGxvb3BzX29lLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwX0FzeW5jLnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubG9vcHMgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfc2NvcmUudHN2XFwpKVxuXG5mb3Ioc2FtcGxlIGluIGMoXFxBc3luYy5VVFxcLCBcXEFzeW5jLkFJRFxcKSl7XG4gIHRlbXAuMjVrYiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBzYW1wbGUsIFxcXzI1a2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoY2hyb20xLCBzdGFydDEsIGVuZDEsIGNocm9tMiwgc3RhcnQyLCBlbmQyLCBpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuMjVrYikgPC0gYyhcXGNocm9tMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHJvbTJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcaWRcXCwgXFxvYnNcXCwgXFxvYnNleHBcXClcbiAgXG4gIHRlbXAuMTBrYiA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX1xcLCBzYW1wbGUsIFxcXzEwa2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoY2hyb20xLCBzdGFydDEsIGVuZDEsIGNocm9tMiwgc3RhcnQyLCBlbmQyLCBpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuMTBrYikgPC0gYyhcXGNocm9tMVxcLCBcXHN0YXJ0MVxcLCBcXGVuZDFcXCwgXFxjaHJvbTJcXCwgXFxzdGFydDJcXCwgXFxlbmQyXFwsIFxcaWRcXCwgXFxvYnNcXCwgXFxvYnNleHBcXClcbiAgXG4gIHRlbXAuNWtiIDwtZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9cXCwgc2FtcGxlLCBcXF81a2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoY2hyb20xLCBzdGFydDEsIGVuZDEsIGNocm9tMiwgc3RhcnQyLCBlbmQyLCBpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuNWtiKSA8LSBjKFxcY2hyb20xXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXGNocm9tMlxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXCwgXFxpZFxcLCBcXG9ic1xcLCBcXG9ic2V4cFxcKVxuICBcbiAgdGVtcCA8LSBiaW5kX3Jvd3ModGVtcC4yNWtiLCB0ZW1wLjEwa2IsIHRlbXAuNWtiKVxuICBmd3JpdGUodGVtcCwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9cXCwgc2FtcGxlLCBcXC50c3ZcXCkpLCBzZXAgPSBcXFxcdFxcKVxufVxuXG5cbnRlbXAuVVQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcbG9vcFNjb3JlX0FzeW5jLlVULnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5VVCkgPC0gYyhcXGlkXFwsIFxcb2JzX1VUXFwsIFxcb2JzZXhwX1VUXFwpXG50ZW1wLkFJRCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxsb29wU2NvcmVfQXN5bmMuQUlELnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoaWQsIG9icywgb2JzZXhwKVxuY29sbmFtZXModGVtcC5BSUQpIDwtIGMoXFxpZFxcLCBcXG9ic19BSURcXCwgXFxvYnNleHBfQUlEXFwpXG5cbmxvb3BzX29lIDwtIGZ1bGxfam9pbih0ZW1wLlVULCB0ZW1wLkFJRCwgYnkgPSBcXGlkXFwpICU+JVxuICBkcGx5cjo6bXV0YXRlKG9lRkNfQUlEX1VUID0gaWZfZWxzZShvYnNleHBfVVQgPT0gMCwgTkEsIG9ic2V4cF9BSUQvb2JzZXhwX1VUKSlcblxuZndyaXRlKGxvb3BzX29lLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwX0FzeW5jLnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG5gYGBcbmBgYCJ9 -->

```r
```r
loops <- fread(here(consensusDir, \chromo_cons_score.tsv\))

for(sample in c(\Async.UT\, \Async.AID\)){
  temp.25kb <- fread(here(consensusDir, paste0(\loopScore_\, sample, \_25kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.25kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp.10kb <- fread(here(consensusDir, paste0(\loopScore_\, sample, \_10kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.10kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp.5kb <-fread(here(consensusDir, paste0(\loopScore_\, sample, \_5kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, \O/E\)
  colnames(temp.5kb) <- c(\chrom1\, \start1\, \end1\, \chrom2\, \start2\, \end2\, \id\, \obs\, \obsexp\)
  
  temp <- bind_rows(temp.25kb, temp.10kb, temp.5kb)
  fwrite(temp, here(consensusDir, paste0(\loopScore_\, sample, \.tsv\)), sep = \\t\)
}


temp.UT <- fread(here(consensusDir, \loopScore_Async.UT.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.UT) <- c(\id\, \obs_UT\, \obsexp_UT\)
temp.AID <- fread(here(consensusDir, \loopScore_Async.AID.tsv\)) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.AID) <- c(\id\, \obs_AID\, \obsexp_AID\)

loops_oe <- full_join(temp.UT, temp.AID, by = \id\) %>%
  dplyr::mutate(oeFC_AID_UT = if_else(obsexp_UT == 0, NA, obsexp_AID/obsexp_UT))

fwrite(loops_oe, here(consensusDir, paste0(\loopScore_cons_obsexp_Async.tsv\)), sep = \\t\)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [2.25] Obs/Exp loops


#### Merging obs/exp scores from different resolution & samples
##### G1

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHViRzl2Y0hNZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGd2lZMmh5YjIxdlgyTnZibk5mYzJOdmNtVXVkSE4yWENJcEtWeHVYRzV5WlhNZ1BDMGdNalZjYmx4dVptOXlJQ2h5WlhNZ2FXNGdZeWd5TlN3Z01UQXNJRFVwS1h0Y2JpQWdYRzRnSUhSbGJYQXVSRTFUVHlBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0Z3aWJHOXZjRk5qYjNKbFgwY3hMa1JOVTA4dVRXVnlaMlZrWDF3aUxDQnlaWE1zSUZ3aWEySXVkSE4yWENJcEtTa2dKVDRsWEc0Z0lDQWdaSEJzZVhJNk9tMTFkR0YwWlNoaWFXNVRhWHBsSUQwZ1pXNWtNU0F0SUhOMFlYSjBNU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdsa0lEMGdjR0Z6ZEdVb1kyaHliMjB4TENCaWFXNVRhWHBsTENCemRHRnlkREVzSUhOMFlYSjBNaXdnYzJWd0lEMGdYQ0pmWENJcEtTQWxQaVZjYmlBZ0lDQmtjR3g1Y2pvNlptbHNkR1Z5S0dsa0lDVnBiaVVnYkc5dmNITWthV1FwSUNVK0pWeHVJQ0FnSUdSd2JIbHlPanB6Wld4bFkzUW9hV1FzSUc5aWMyVnlkbVZrTENCY0lrOHZSVndpS1Z4dUlDQmpiMnh1WVcxbGN5aDBaVzF3TGtSTlUwOHBJRHd0SUdNb1hDSnBaRndpTENCY0ltOWljMTlFVFZOUFhDSXNJRndpYjJKelpYaHdYMFJOVTA5Y0lpbGNiaUFnWEc0Z0lIUmxiWEF1WkZSQlJ5QThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tGd2liRzl2Y0ZOamIzSmxYMGN4TG1SVVFVY3VUV1Z5WjJWa1gxd2lMQ0J5WlhNc0lGd2lhMkl1ZEhOMlhDSXBLU2tnSlQ0bFhHNGdJQ0FnWkhCc2VYSTZPbTExZEdGMFpTaGlhVzVUYVhwbElEMGdaVzVrTVNBdElITjBZWEowTVN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbGtJRDBnY0dGemRHVW9ZMmh5YjIweExDQmlhVzVUYVhwbExDQnpkR0Z5ZERFc0lITjBZWEowTWl3Z2MyVndJRDBnWENKZlhDSXBLU0FsUGlWY2JpQWdJQ0JrY0d4NWNqbzZabWxzZEdWeUtHbGtJQ1ZwYmlVZ2JHOXZjSE1rYVdRcElDVStKVnh1SUNBZ0lHUndiSGx5T2pwelpXeGxZM1FvYVdRc0lHOWljMlZ5ZG1Wa0xDQmNJazh2UlZ3aUtWeHVJQ0JqYjJ4dVlXMWxjeWgwWlcxd0xtUlVRVWNwSUR3dElHTW9YQ0pwWkZ3aUxDQmNJbTlpYzE5a1ZFRkhYQ0lzSUZ3aWIySnpaWGh3WDJSVVFVZGNJaWxjYmlBZ1hHNGdJSFJsYlhBdVFUUTROU0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRndpYkc5dmNGTmpiM0psWDBjeExrRTBPRFV1VFdWeVoyVmtYMXdpTENCeVpYTXNJRndpYTJJdWRITjJYQ0lwS1NrZ0pUNGxYRzRnSUNBZ1pIQnNlWEk2T20xMWRHRjBaU2hpYVc1VGFYcGxJRDBnWlc1a01TQXRJSE4wWVhKME1TeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xrSUQwZ2NHRnpkR1VvWTJoeWIyMHhMQ0JpYVc1VGFYcGxMQ0J6ZEdGeWRERXNJSE4wWVhKME1pd2djMlZ3SUQwZ1hDSmZYQ0lwS1NBbFBpVmNiaUFnSUNCa2NHeDVjam82Wm1sc2RHVnlLR2xrSUNWcGJpVWdiRzl2Y0hNa2FXUXBJQ1UrSlZ4dUlDQWdJR1J3YkhseU9qcHpaV3hsWTNRb2FXUXNJRzlpYzJWeWRtVmtMQ0JjSWs4dlJWd2lLVnh1SUNCamIyeHVZVzFsY3loMFpXMXdMa0UwT0RVcElEd3RJR01vWENKcFpGd2lMQ0JjSW05aWMxOUJORGcxWENJc0lGd2liMkp6Wlhod1gwRTBPRFZjSWlsY2JpQWdYRzRnSUhSbGJYQWdQQzBnWm5Wc2JGOXFiMmx1S0daMWJHeGZhbTlwYmloMFpXMXdMa1JOVTA4c0lIUmxiWEF1WkZSQlJ5d2dZbmtnUFNCaktGd2lhV1JjSWlrcExDQjBaVzF3TGtFME9EVXNJR0o1SUQwZ1l5aGNJbWxrWENJcEtTQWxQaVVnWEc0Z0lDQWdaSEJzZVhJNk9tMTFkR0YwWlNodlpVWkRYMlJVUVVkZlJFMVRUeUE5SUdsbVgyVnNjMlVvYjJKelpYaHdYMFJOVTA4Z1BUMGdNQ3dnVGtFc0lHOWljMlY0Y0Y5a1ZFRkhMMjlpYzJWNGNGOUVUVk5QS1N4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHOWxSa05mUVRRNE5WOUVUVk5QSUQwZ2FXWmZaV3h6WlNodlluTmxlSEJmUkUxVFR5QTlQU0F3TENCT1FTd2diMkp6Wlhod1gwRTBPRFV2YjJKelpYaHdYMFJOVTA4cEtWeHVJQ0JjYmlBZ1puZHlhWFJsS0hSbGJYQXNJR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0J3WVhOMFpUQW9YQ0pzYjI5d1UyTnZjbVZmWTI5dWMxOXZZbk5sZUhCZlhDSXNJSEpsY3l3Z1hDSnJZaTUwYzNaY0lpa3BMQ0J6WlhBZ1BTQmNJbHhjZEZ3aUtWeHVmVnh1WEc1Y2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5sb29wcyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19zY29yZS50c3ZcXCkpXG5cbnJlcyA8LSAyNVxuXG5mb3IgKHJlcyBpbiBjKDI1LCAxMCwgNSkpe1xuICBcbiAgdGVtcC5ETVNPIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfRzEuRE1TTy5NZXJnZWRfXFwsIHJlcywgXFxrYi50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcXF9cXCkpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuRE1TTykgPC0gYyhcXGlkXFwsIFxcb2JzX0RNU09cXCwgXFxvYnNleHBfRE1TT1xcKVxuICBcbiAgdGVtcC5kVEFHIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfRzEuZFRBRy5NZXJnZWRfXFwsIHJlcywgXFxrYi50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcXF9cXCkpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuZFRBRykgPC0gYyhcXGlkXFwsIFxcb2JzX2RUQUdcXCwgXFxvYnNleHBfZFRBR1xcKVxuICBcbiAgdGVtcC5BNDg1IDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfRzEuQTQ4NS5NZXJnZWRfXFwsIHJlcywgXFxrYi50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcXF9cXCkpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuQTQ4NSkgPC0gYyhcXGlkXFwsIFxcb2JzX0E0ODVcXCwgXFxvYnNleHBfQTQ4NVxcKVxuICBcbiAgdGVtcCA8LSBmdWxsX2pvaW4oZnVsbF9qb2luKHRlbXAuRE1TTywgdGVtcC5kVEFHLCBieSA9IGMoXFxpZFxcKSksIHRlbXAuQTQ4NSwgYnkgPSBjKFxcaWRcXCkpICU+JSBcbiAgICBkcGx5cjo6bXV0YXRlKG9lRkNfZFRBR19ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBOQSwgb2JzZXhwX2RUQUcvb2JzZXhwX0RNU08pLFxuICAgICAgICAgICAgICAgICAgb2VGQ19BNDg1X0RNU08gPSBpZl9lbHNlKG9ic2V4cF9ETVNPID09IDAsIE5BLCBvYnNleHBfQTQ4NS9vYnNleHBfRE1TTykpXG4gIFxuICBmd3JpdGUodGVtcCwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9jb25zX29ic2V4cF9cXCwgcmVzLCBcXGtiLnRzdlxcKSksIHNlcCA9IFxcXFx0XFwpXG59XG5cblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
loops <- fread(here(consensusDir, \chromo_cons_score.tsv\))

res <- 25

for (res in c(25, 10, 5)){
  
  temp.DMSO <- fread(here(consensusDir, paste0(\loopScore_G1.DMSO.Merged_\, res, \kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, \O/E\)
  colnames(temp.DMSO) <- c(\id\, \obs_DMSO\, \obsexp_DMSO\)
  
  temp.dTAG <- fread(here(consensusDir, paste0(\loopScore_G1.dTAG.Merged_\, res, \kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, \O/E\)
  colnames(temp.dTAG) <- c(\id\, \obs_dTAG\, \obsexp_dTAG\)
  
  temp.A485 <- fread(here(consensusDir, paste0(\loopScore_G1.A485.Merged_\, res, \kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, \O/E\)
  colnames(temp.A485) <- c(\id\, \obs_A485\, \obsexp_A485\)
  
  temp <- full_join(full_join(temp.DMSO, temp.dTAG, by = c(\id\)), temp.A485, by = c(\id\)) %>% 
    dplyr::mutate(oeFC_dTAG_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_dTAG/obsexp_DMSO),
                  oeFC_A485_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_A485/obsexp_DMSO))
  
  fwrite(temp, here(consensusDir, paste0(\loopScore_cons_obsexp_\, res, \kb.tsv\)), sep = \\t\)
}



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJHOXZjSE1nUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ4Y1kyaHliMjF2WDJOdmJuTmZjMk52Y21VdWRITjJYRndwS1Z4dVhHNXlaWE1nUEMwZ01qVmNibHh1Wm05eUlDaHlaWE1nYVc0Z1l5Z3lOU3dnTVRBc0lEVXBLWHRjYmlBZ1hHNGdJSFJsYlhBdVJFMVRUeUE4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRnhjYkc5dmNGTmpiM0psWDBjeExrUk5VMDh1VFdWeVoyVmtYMXhjTENCeVpYTXNJRnhjYTJJdWRITjJYRndwS1NrZ0pUNGxYRzRnSUNBZ1pIQnNlWEk2T20xMWRHRjBaU2hpYVc1VGFYcGxJRDBnWlc1a01TQXRJSE4wWVhKME1TeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR2xrSUQwZ2NHRnpkR1VvWTJoeWIyMHhMQ0JpYVc1VGFYcGxMQ0J6ZEdGeWRERXNJSE4wWVhKME1pd2djMlZ3SUQwZ1hGeGZYRndwS1NBbFBpVmNiaUFnSUNCa2NHeDVjam82Wm1sc2RHVnlLR2xrSUNWcGJpVWdiRzl2Y0hNa2FXUXBJQ1UrSlZ4dUlDQWdJR1J3YkhseU9qcHpaV3hsWTNRb2FXUXNJRzlpYzJWeWRtVmtMQ0JjWEU4dlJWeGNLVnh1SUNCamIyeHVZVzFsY3loMFpXMXdMa1JOVTA4cElEd3RJR01vWEZ4cFpGeGNMQ0JjWEc5aWMxOUVUVk5QWEZ3c0lGeGNiMkp6Wlhod1gwUk5VMDljWENsY2JpQWdYRzRnSUhSbGJYQXVaRlJCUnlBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0Z4Y2JHOXZjRk5qYjNKbFgwY3hMbVJVUVVjdVRXVnlaMlZrWDF4Y0xDQnlaWE1zSUZ4Y2EySXVkSE4yWEZ3cEtTa2dKVDRsWEc0Z0lDQWdaSEJzZVhJNk9tMTFkR0YwWlNoaWFXNVRhWHBsSUQwZ1pXNWtNU0F0SUhOMFlYSjBNU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdsa0lEMGdjR0Z6ZEdVb1kyaHliMjB4TENCaWFXNVRhWHBsTENCemRHRnlkREVzSUhOMFlYSjBNaXdnYzJWd0lEMGdYRnhmWEZ3cEtTQWxQaVZjYmlBZ0lDQmtjR3g1Y2pvNlptbHNkR1Z5S0dsa0lDVnBiaVVnYkc5dmNITWthV1FwSUNVK0pWeHVJQ0FnSUdSd2JIbHlPanB6Wld4bFkzUW9hV1FzSUc5aWMyVnlkbVZrTENCY1hFOHZSVnhjS1Z4dUlDQmpiMnh1WVcxbGN5aDBaVzF3TG1SVVFVY3BJRHd0SUdNb1hGeHBaRnhjTENCY1hHOWljMTlrVkVGSFhGd3NJRnhjYjJKelpYaHdYMlJVUVVkY1hDbGNiaUFnWEc0Z0lIUmxiWEF1UVRRNE5TQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tGeGNiRzl2Y0ZOamIzSmxYMGN4TGtFME9EVXVUV1Z5WjJWa1gxeGNMQ0J5WlhNc0lGeGNhMkl1ZEhOMlhGd3BLU2tnSlQ0bFhHNGdJQ0FnWkhCc2VYSTZPbTExZEdGMFpTaGlhVzVUYVhwbElEMGdaVzVrTVNBdElITjBZWEowTVN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHbGtJRDBnY0dGemRHVW9ZMmh5YjIweExDQmlhVzVUYVhwbExDQnpkR0Z5ZERFc0lITjBZWEowTWl3Z2MyVndJRDBnWEZ4ZlhGd3BLU0FsUGlWY2JpQWdJQ0JrY0d4NWNqbzZabWxzZEdWeUtHbGtJQ1ZwYmlVZ2JHOXZjSE1rYVdRcElDVStKVnh1SUNBZ0lHUndiSGx5T2pwelpXeGxZM1FvYVdRc0lHOWljMlZ5ZG1Wa0xDQmNYRTh2UlZ4Y0tWeHVJQ0JqYjJ4dVlXMWxjeWgwWlcxd0xrRTBPRFVwSUR3dElHTW9YRnhwWkZ4Y0xDQmNYRzlpYzE5Qk5EZzFYRndzSUZ4Y2IySnpaWGh3WDBFME9EVmNYQ2xjYmlBZ1hHNGdJSFJsYlhBZ1BDMGdablZzYkY5cWIybHVLR1oxYkd4ZmFtOXBiaWgwWlcxd0xrUk5VMDhzSUhSbGJYQXVaRlJCUnl3Z1lua2dQU0JqS0Z4Y2FXUmNYQ2twTENCMFpXMXdMa0UwT0RVc0lHSjVJRDBnWXloY1hHbGtYRndwS1NBbFBpVWdYRzRnSUNBZ1pIQnNlWEk2T20xMWRHRjBaU2h2WlVaRFgyUlVRVWRmUkUxVFR5QTlJR2xtWDJWc2MyVW9iMkp6Wlhod1gwUk5VMDhnUFQwZ01Dd2dUa0VzSUc5aWMyVjRjRjlrVkVGSEwyOWljMlY0Y0Y5RVRWTlBLU3hjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUc5bFJrTmZRVFE0TlY5RVRWTlBJRDBnYVdaZlpXeHpaU2h2WW5ObGVIQmZSRTFUVHlBOVBTQXdMQ0JPUVN3Z2IySnpaWGh3WDBFME9EVXZiMkp6Wlhod1gwUk5VMDhwS1Z4dUlDQmNiaUFnWm5keWFYUmxLSFJsYlhBc0lHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQndZWE4wWlRBb1hGeHNiMjl3VTJOdmNtVmZZMjl1YzE5dlluTmxlSEJmWEZ3c0lISmxjeXdnWEZ4cllpNTBjM1pjWENrcExDQnpaWEFnUFNCY1hGeGNkRnhjS1Z4dWZWeHVYRzVjYm1CZ1lGeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYGBgclxubG9vcHMgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfc2NvcmUudHN2XFwpKVxuXG5yZXMgPC0gMjVcblxuZm9yIChyZXMgaW4gYygyNSwgMTAsIDUpKXtcbiAgXG4gIHRlbXAuRE1TTyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX0cxLkRNU08uTWVyZ2VkX1xcLCByZXMsIFxca2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoaWQsIG9ic2VydmVkLCBcXE8vRVxcKVxuICBjb2xuYW1lcyh0ZW1wLkRNU08pIDwtIGMoXFxpZFxcLCBcXG9ic19ETVNPXFwsIFxcb2JzZXhwX0RNU09cXClcbiAgXG4gIHRlbXAuZFRBRyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX0cxLmRUQUcuTWVyZ2VkX1xcLCByZXMsIFxca2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoaWQsIG9ic2VydmVkLCBcXE8vRVxcKVxuICBjb2xuYW1lcyh0ZW1wLmRUQUcpIDwtIGMoXFxpZFxcLCBcXG9ic19kVEFHXFwsIFxcb2JzZXhwX2RUQUdcXClcbiAgXG4gIHRlbXAuQTQ4NSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX0cxLkE0ODUuTWVyZ2VkX1xcLCByZXMsIFxca2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoaWQsIG9ic2VydmVkLCBcXE8vRVxcKVxuICBjb2xuYW1lcyh0ZW1wLkE0ODUpIDwtIGMoXFxpZFxcLCBcXG9ic19BNDg1XFwsIFxcb2JzZXhwX0E0ODVcXClcbiAgXG4gIHRlbXAgPC0gZnVsbF9qb2luKGZ1bGxfam9pbih0ZW1wLkRNU08sIHRlbXAuZFRBRywgYnkgPSBjKFxcaWRcXCkpLCB0ZW1wLkE0ODUsIGJ5ID0gYyhcXGlkXFwpKSAlPiUgXG4gICAgZHBseXI6Om11dGF0ZShvZUZDX2RUQUdfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgTkEsIG9ic2V4cF9kVEFHL29ic2V4cF9ETVNPKSxcbiAgICAgICAgICAgICAgICAgIG9lRkNfQTQ4NV9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBOQSwgb2JzZXhwX0E0ODUvb2JzZXhwX0RNU08pKVxuICBcbiAgZndyaXRlKHRlbXAsIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfY29uc19vYnNleHBfXFwsIHJlcywgXFxrYi50c3ZcXCkpLCBzZXAgPSBcXFxcdFxcKVxufVxuXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubG9vcHMgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfc2NvcmUudHN2XFwpKVxuXG5yZXMgPC0gMjVcblxuZm9yIChyZXMgaW4gYygyNSwgMTAsIDUpKXtcbiAgXG4gIHRlbXAuRE1TTyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX0cxLkRNU08uTWVyZ2VkX1xcLCByZXMsIFxca2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoaWQsIG9ic2VydmVkLCBcXE8vRVxcKVxuICBjb2xuYW1lcyh0ZW1wLkRNU08pIDwtIGMoXFxpZFxcLCBcXG9ic19ETVNPXFwsIFxcb2JzZXhwX0RNU09cXClcbiAgXG4gIHRlbXAuZFRBRyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX0cxLmRUQUcuTWVyZ2VkX1xcLCByZXMsIFxca2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoaWQsIG9ic2VydmVkLCBcXE8vRVxcKVxuICBjb2xuYW1lcyh0ZW1wLmRUQUcpIDwtIGMoXFxpZFxcLCBcXG9ic19kVEFHXFwsIFxcb2JzZXhwX2RUQUdcXClcbiAgXG4gIHRlbXAuQTQ4NSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX0cxLkE0ODUuTWVyZ2VkX1xcLCByZXMsIFxca2IudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gZW5kMSAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoY2hyb20xLCBiaW5TaXplLCBzdGFydDEsIHN0YXJ0Miwgc2VwID0gXFxfXFwpKSAlPiVcbiAgICBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcHMkaWQpICU+JVxuICAgIGRwbHlyOjpzZWxlY3QoaWQsIG9ic2VydmVkLCBcXE8vRVxcKVxuICBjb2xuYW1lcyh0ZW1wLkE0ODUpIDwtIGMoXFxpZFxcLCBcXG9ic19BNDg1XFwsIFxcb2JzZXhwX0E0ODVcXClcbiAgXG4gIHRlbXAgPC0gZnVsbF9qb2luKGZ1bGxfam9pbih0ZW1wLkRNU08sIHRlbXAuZFRBRywgYnkgPSBjKFxcaWRcXCkpLCB0ZW1wLkE0ODUsIGJ5ID0gYyhcXGlkXFwpKSAlPiUgXG4gICAgZHBseXI6Om11dGF0ZShvZUZDX2RUQUdfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgTkEsIG9ic2V4cF9kVEFHL29ic2V4cF9ETVNPKSxcbiAgICAgICAgICAgICAgICAgIG9lRkNfQTQ4NV9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBOQSwgb2JzZXhwX0E0ODUvb2JzZXhwX0RNU08pKVxuICBcbiAgZndyaXRlKHRlbXAsIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfY29uc19vYnNleHBfXFwsIHJlcywgXFxrYi50c3ZcXCkpLCBzZXAgPSBcXFxcdFxcKVxufVxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
loops <- fread(here(consensusDir, \chromo_cons_score.tsv\))

res <- 25

for (res in c(25, 10, 5)){
  
  temp.DMSO <- fread(here(consensusDir, paste0(\loopScore_G1.DMSO.Merged_\, res, \kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, \O/E\)
  colnames(temp.DMSO) <- c(\id\, \obs_DMSO\, \obsexp_DMSO\)
  
  temp.dTAG <- fread(here(consensusDir, paste0(\loopScore_G1.dTAG.Merged_\, res, \kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, \O/E\)
  colnames(temp.dTAG) <- c(\id\, \obs_dTAG\, \obsexp_dTAG\)
  
  temp.A485 <- fread(here(consensusDir, paste0(\loopScore_G1.A485.Merged_\, res, \kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, \O/E\)
  colnames(temp.A485) <- c(\id\, \obs_A485\, \obsexp_A485\)
  
  temp <- full_join(full_join(temp.DMSO, temp.dTAG, by = c(\id\)), temp.A485, by = c(\id\)) %>% 
    dplyr::mutate(oeFC_dTAG_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_dTAG/obsexp_DMSO),
                  oeFC_A485_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_A485/obsexp_DMSO))
  
  fwrite(temp, here(consensusDir, paste0(\loopScore_cons_obsexp_\, res, \kb.tsv\)), sep = \\t\)
}

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### Async

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHViRzl2Y0hNZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGd2lZMmh5YjIxdlgyTnZibk5mYzJOdmNtVXVkSE4yWENJcEtWeHVYRzV5WlhNZ1BDMGdNalZjYmx4dVptOXlJQ2h5WlhNZ2FXNGdZeWd5TlN3Z01UQXNJRFVwS1h0Y2JpQWdYRzRnSUhSbGJYQXVWVlFnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUhCaGMzUmxNQ2hjSW14dmIzQlRZMjl5WlY5QmMzbHVZeTVWVkY5Y0lpd2djbVZ6TENCY0ltdGlMblJ6ZGx3aUtTa3BJQ1UrSlZ4dUlDQWdJR1J3YkhseU9qcHRkWFJoZEdVb1ltbHVVMmw2WlNBOUlHVnVaREVnTFNCemRHRnlkREVzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCcFpDQTlJSEJoYzNSbEtHTm9jbTl0TVN3Z1ltbHVVMmw2WlN3Z2MzUmhjblF4TENCemRHRnlkRElzSUhObGNDQTlJRndpWDF3aUtTa2dKVDRsWEc0Z0lDQWdaSEJzZVhJNk9tWnBiSFJsY2locFpDQWxhVzRsSUd4dmIzQnpKR2xrS1NBbFBpVmNiaUFnSUNCa2NHeDVjam82YzJWc1pXTjBLR2xrTENCdlluTmxjblpsWkN3Z1hDSlBMMFZjSWlsY2JpQWdZMjlzYm1GdFpYTW9kR1Z0Y0M1VlZDa2dQQzBnWXloY0ltbGtYQ0lzSUZ3aWIySnpYMVZVWENJc0lGd2liMkp6Wlhod1gxVlVYQ0lwWEc0Z0lGeHVJQ0IwWlcxd0xrRkpSQ0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRndpYkc5dmNGTmpiM0psWDBGemVXNWpMa0ZKUkY5Y0lpd2djbVZ6TENCY0ltdGlMblJ6ZGx3aUtTa3BJQ1UrSlZ4dUlDQWdJR1J3YkhseU9qcHRkWFJoZEdVb1ltbHVVMmw2WlNBOUlHVnVaREVnTFNCemRHRnlkREVzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCcFpDQTlJSEJoYzNSbEtHTm9jbTl0TVN3Z1ltbHVVMmw2WlN3Z2MzUmhjblF4TENCemRHRnlkRElzSUhObGNDQTlJRndpWDF3aUtTa2dKVDRsWEc0Z0lDQWdaSEJzZVhJNk9tWnBiSFJsY2locFpDQWxhVzRsSUd4dmIzQnpKR2xrS1NBbFBpVmNiaUFnSUNCa2NHeDVjam82YzJWc1pXTjBLR2xrTENCdlluTmxjblpsWkN3Z1hDSlBMMFZjSWlsY2JpQWdZMjlzYm1GdFpYTW9kR1Z0Y0M1QlNVUXBJRHd0SUdNb1hDSnBaRndpTENCY0ltOWljMTlCU1VSY0lpd2dYQ0p2WW5ObGVIQmZRVWxFWENJcFhHNWNiaUFnWEc0Z0lIUmxiWEFnUEMwZ1puVnNiRjlxYjJsdUtIUmxiWEF1VlZRc0lIUmxiWEF1UVVsRUxDQmllU0E5SUdNb1hDSnBaRndpS1NrZ0pUNGxJRnh1SUNBZ0lHUndiSGx5T2pwdGRYUmhkR1VvYjJWR1ExOUJTVVJmVlZRZ1BTQnBabDlsYkhObEtHOWljMlY0Y0Y5VlZDQTlQU0F3TENCT1FTd2diMkp6Wlhod1gwRkpSQzl2WW5ObGVIQmZWVlFwS1Z4dUlDQmNiaUFnWm5keWFYUmxLSFJsYlhBc0lHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQndZWE4wWlRBb1hDSnNiMjl3VTJOdmNtVmZZMjl1YzE5dlluTmxlSEJmWENJc0lISmxjeXdnWENKcllsOWhjM2x1WXk1MGMzWmNJaWtwTENCelpYQWdQU0JjSWx4Y2RGd2lLVnh1ZlZ4dVhHNWNibUJnWUNKOSAtLT5cblxuYGBgclxubG9vcHMgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfc2NvcmUudHN2XFwpKVxuXG5yZXMgPC0gMjVcblxuZm9yIChyZXMgaW4gYygyNSwgMTAsIDUpKXtcbiAgXG4gIHRlbXAuVVQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9Bc3luYy5VVF9cXCwgcmVzLCBcXGtiLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IGVuZDEgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKGNocm9tMSwgYmluU2l6ZSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3BzJGlkKSAlPiVcbiAgICBkcGx5cjo6c2VsZWN0KGlkLCBvYnNlcnZlZCwgXFxPL0VcXClcbiAgY29sbmFtZXModGVtcC5VVCkgPC0gYyhcXGlkXFwsIFxcb2JzX1VUXFwsIFxcb2JzZXhwX1VUXFwpXG4gIFxuICB0ZW1wLkFJRCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX0FzeW5jLkFJRF9cXCwgcmVzLCBcXGtiLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IGVuZDEgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKGNocm9tMSwgYmluU2l6ZSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3BzJGlkKSAlPiVcbiAgICBkcGx5cjo6c2VsZWN0KGlkLCBvYnNlcnZlZCwgXFxPL0VcXClcbiAgY29sbmFtZXModGVtcC5BSUQpIDwtIGMoXFxpZFxcLCBcXG9ic19BSURcXCwgXFxvYnNleHBfQUlEXFwpXG5cbiAgXG4gIHRlbXAgPC0gZnVsbF9qb2luKHRlbXAuVVQsIHRlbXAuQUlELCBieSA9IGMoXFxpZFxcKSkgJT4lIFxuICAgIGRwbHlyOjptdXRhdGUob2VGQ19BSURfVVQgPSBpZl9lbHNlKG9ic2V4cF9VVCA9PSAwLCBOQSwgb2JzZXhwX0FJRC9vYnNleHBfVVQpKVxuICBcbiAgZndyaXRlKHRlbXAsIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfY29uc19vYnNleHBfXFwsIHJlcywgXFxrYl9hc3luYy50c3ZcXCkpLCBzZXAgPSBcXFxcdFxcKVxufVxuXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
loops <- fread(here(consensusDir, \chromo_cons_score.tsv\))

res <- 25

for (res in c(25, 10, 5)){
  
  temp.UT <- fread(here(consensusDir, paste0(\loopScore_Async.UT_\, res, \kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, \O/E\)
  colnames(temp.UT) <- c(\id\, \obs_UT\, \obsexp_UT\)
  
  temp.AID <- fread(here(consensusDir, paste0(\loopScore_Async.AID_\, res, \kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, \O/E\)
  colnames(temp.AID) <- c(\id\, \obs_AID\, \obsexp_AID\)

  
  temp <- full_join(temp.UT, temp.AID, by = c(\id\)) %>% 
    dplyr::mutate(oeFC_AID_UT = if_else(obsexp_UT == 0, NA, obsexp_AID/obsexp_UT))
  
  fwrite(temp, here(consensusDir, paste0(\loopScore_cons_obsexp_\, res, \kb_async.tsv\)), sep = \\t\)
}



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJHOXZjSE1nUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ4Y1kyaHliMjF2WDJOdmJuTmZjMk52Y21VdWRITjJYRndwS1Z4dVhHNXlaWE1nUEMwZ01qVmNibHh1Wm05eUlDaHlaWE1nYVc0Z1l5Z3lOU3dnTVRBc0lEVXBLWHRjYmlBZ1hHNGdJSFJsYlhBdVZWUWdQQzBnWm5KbFlXUW9hR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJSEJoYzNSbE1DaGNYR3h2YjNCVFkyOXlaVjlCYzNsdVl5NVZWRjljWEN3Z2NtVnpMQ0JjWEd0aUxuUnpkbHhjS1NrcElDVStKVnh1SUNBZ0lHUndiSGx5T2pwdGRYUmhkR1VvWW1sdVUybDZaU0E5SUdWdVpERWdMU0J6ZEdGeWRERXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JwWkNBOUlIQmhjM1JsS0dOb2NtOXRNU3dnWW1sdVUybDZaU3dnYzNSaGNuUXhMQ0J6ZEdGeWRESXNJSE5sY0NBOUlGeGNYMXhjS1NrZ0pUNGxYRzRnSUNBZ1pIQnNlWEk2T21acGJIUmxjaWhwWkNBbGFXNGxJR3h2YjNCekpHbGtLU0FsUGlWY2JpQWdJQ0JrY0d4NWNqbzZjMlZzWldOMEtHbGtMQ0J2WW5ObGNuWmxaQ3dnWEZ4UEwwVmNYQ2xjYmlBZ1kyOXNibUZ0WlhNb2RHVnRjQzVWVkNrZ1BDMGdZeWhjWEdsa1hGd3NJRnhjYjJKelgxVlVYRndzSUZ4Y2IySnpaWGh3WDFWVVhGd3BYRzRnSUZ4dUlDQjBaVzF3TGtGSlJDQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tGeGNiRzl2Y0ZOamIzSmxYMEZ6ZVc1akxrRkpSRjljWEN3Z2NtVnpMQ0JjWEd0aUxuUnpkbHhjS1NrcElDVStKVnh1SUNBZ0lHUndiSGx5T2pwdGRYUmhkR1VvWW1sdVUybDZaU0E5SUdWdVpERWdMU0J6ZEdGeWRERXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JwWkNBOUlIQmhjM1JsS0dOb2NtOXRNU3dnWW1sdVUybDZaU3dnYzNSaGNuUXhMQ0J6ZEdGeWRESXNJSE5sY0NBOUlGeGNYMXhjS1NrZ0pUNGxYRzRnSUNBZ1pIQnNlWEk2T21acGJIUmxjaWhwWkNBbGFXNGxJR3h2YjNCekpHbGtLU0FsUGlWY2JpQWdJQ0JrY0d4NWNqbzZjMlZzWldOMEtHbGtMQ0J2WW5ObGNuWmxaQ3dnWEZ4UEwwVmNYQ2xjYmlBZ1kyOXNibUZ0WlhNb2RHVnRjQzVCU1VRcElEd3RJR01vWEZ4cFpGeGNMQ0JjWEc5aWMxOUJTVVJjWEN3Z1hGeHZZbk5sZUhCZlFVbEVYRndwWEc1Y2JpQWdYRzRnSUhSbGJYQWdQQzBnWm5Wc2JGOXFiMmx1S0hSbGJYQXVWVlFzSUhSbGJYQXVRVWxFTENCaWVTQTlJR01vWEZ4cFpGeGNLU2tnSlQ0bElGeHVJQ0FnSUdSd2JIbHlPanB0ZFhSaGRHVW9iMlZHUTE5QlNVUmZWVlFnUFNCcFpsOWxiSE5sS0c5aWMyVjRjRjlWVkNBOVBTQXdMQ0JPUVN3Z2IySnpaWGh3WDBGSlJDOXZZbk5sZUhCZlZWUXBLVnh1SUNCY2JpQWdabmR5YVhSbEtIUmxiWEFzSUdobGNtVW9ZMjl1YzJWdWMzVnpSR2x5TENCd1lYTjBaVEFvWEZ4c2IyOXdVMk52Y21WZlkyOXVjMTl2WW5ObGVIQmZYRndzSUhKbGN5d2dYRnhyWWw5aGMzbHVZeTUwYzNaY1hDa3BMQ0J6WlhBZ1BTQmNYRnhjZEZ4Y0tWeHVmVnh1WEc1Y2JtQmdZRnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbmBgYHJcbmxvb3BzIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX3Njb3JlLnRzdlxcKSlcblxucmVzIDwtIDI1XG5cbmZvciAocmVzIGluIGMoMjUsIDEwLCA1KSl7XG4gIFxuICB0ZW1wLlVUIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfQXN5bmMuVVRfXFwsIHJlcywgXFxrYi50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcXF9cXCkpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuVVQpIDwtIGMoXFxpZFxcLCBcXG9ic19VVFxcLCBcXG9ic2V4cF9VVFxcKVxuICBcbiAgdGVtcC5BSUQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9Bc3luYy5BSURfXFwsIHJlcywgXFxrYi50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBlbmQxIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShjaHJvbTEsIGJpblNpemUsIHN0YXJ0MSwgc3RhcnQyLCBzZXAgPSBcXF9cXCkpICU+JVxuICAgIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wcyRpZCkgJT4lXG4gICAgZHBseXI6OnNlbGVjdChpZCwgb2JzZXJ2ZWQsIFxcTy9FXFwpXG4gIGNvbG5hbWVzKHRlbXAuQUlEKSA8LSBjKFxcaWRcXCwgXFxvYnNfQUlEXFwsIFxcb2JzZXhwX0FJRFxcKVxuXG4gIFxuICB0ZW1wIDwtIGZ1bGxfam9pbih0ZW1wLlVULCB0ZW1wLkFJRCwgYnkgPSBjKFxcaWRcXCkpICU+JSBcbiAgICBkcGx5cjo6bXV0YXRlKG9lRkNfQUlEX1VUID0gaWZfZWxzZShvYnNleHBfVVQgPT0gMCwgTkEsIG9ic2V4cF9BSUQvb2JzZXhwX1VUKSlcbiAgXG4gIGZ3cml0ZSh0ZW1wLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwX1xcLCByZXMsIFxca2JfYXN5bmMudHN2XFwpKSwgc2VwID0gXFxcXHRcXClcbn1cblxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubG9vcHMgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfc2NvcmUudHN2XFwpKVxuXG5yZXMgPC0gMjVcblxuZm9yIChyZXMgaW4gYygyNSwgMTAsIDUpKXtcbiAgXG4gIHRlbXAuVVQgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9Bc3luYy5VVF9cXCwgcmVzLCBcXGtiLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IGVuZDEgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKGNocm9tMSwgYmluU2l6ZSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3BzJGlkKSAlPiVcbiAgICBkcGx5cjo6c2VsZWN0KGlkLCBvYnNlcnZlZCwgXFxPL0VcXClcbiAgY29sbmFtZXModGVtcC5VVCkgPC0gYyhcXGlkXFwsIFxcb2JzX1VUXFwsIFxcb2JzZXhwX1VUXFwpXG4gIFxuICB0ZW1wLkFJRCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX0FzeW5jLkFJRF9cXCwgcmVzLCBcXGtiLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IGVuZDEgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKGNocm9tMSwgYmluU2l6ZSwgc3RhcnQxLCBzdGFydDIsIHNlcCA9IFxcX1xcKSkgJT4lXG4gICAgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3BzJGlkKSAlPiVcbiAgICBkcGx5cjo6c2VsZWN0KGlkLCBvYnNlcnZlZCwgXFxPL0VcXClcbiAgY29sbmFtZXModGVtcC5BSUQpIDwtIGMoXFxpZFxcLCBcXG9ic19BSURcXCwgXFxvYnNleHBfQUlEXFwpXG5cbiAgXG4gIHRlbXAgPC0gZnVsbF9qb2luKHRlbXAuVVQsIHRlbXAuQUlELCBieSA9IGMoXFxpZFxcKSkgJT4lIFxuICAgIGRwbHlyOjptdXRhdGUob2VGQ19BSURfVVQgPSBpZl9lbHNlKG9ic2V4cF9VVCA9PSAwLCBOQSwgb2JzZXhwX0FJRC9vYnNleHBfVVQpKVxuICBcbiAgZndyaXRlKHRlbXAsIGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfY29uc19vYnNleHBfXFwsIHJlcywgXFxrYl9hc3luYy50c3ZcXCkpLCBzZXAgPSBcXFxcdFxcKVxufVxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
loops <- fread(here(consensusDir, \chromo_cons_score.tsv\))

res <- 25

for (res in c(25, 10, 5)){
  
  temp.UT <- fread(here(consensusDir, paste0(\loopScore_Async.UT_\, res, \kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, \O/E\)
  colnames(temp.UT) <- c(\id\, \obs_UT\, \obsexp_UT\)
  
  temp.AID <- fread(here(consensusDir, paste0(\loopScore_Async.AID_\, res, \kb.tsv\))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = \_\)) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, \O/E\)
  colnames(temp.AID) <- c(\id\, \obs_AID\, \obsexp_AID\)

  
  temp <- full_join(temp.UT, temp.AID, by = c(\id\)) %>% 
    dplyr::mutate(oeFC_AID_UT = if_else(obsexp_UT == 0, NA, obsexp_AID/obsexp_UT))
  
  fwrite(temp, here(consensusDir, paste0(\loopScore_cons_obsexp_\, res, \kb_async.tsv\)), sep = \\t\)
}

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Merging obs/exp per resolution
Only the loops that made to consensus loops are considered
##### G1

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBJbXBvcnRpbmcgbG9vcHNcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5cbmZvcihyZXMgaW4gYygyNSwgMTAsIDUpKXtcbiAgbWluVmFsdWUgPC0gLTRcbiAgbWF4VmFsdWUgPC0gNVxuICBvYnNleHAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcImxvb3BTY29yZV9jb25zX29ic2V4cF9cIiwgcmVzLCBcImtiLnRzdlwiKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUobG9nX29ic2V4cF9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfRE1TTykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kVEFHID0gaWZfZWxzZShvYnNleHBfZFRBRyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfZFRBRykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9BNDg1ID0gaWZfZWxzZShvYnNleHBfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQTQ4NSkpKVxuICBcbiAgXG4gICMgZFRBR1xuICBvYnNleHAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eShvYnNleHAkbG9nX29ic2V4cF9ETVNPLCBvYnNleHAkbG9nX29ic2V4cF9kVEFHLCBuID0gMTAwKVxuICBvYnNleHAgPC0gb2JzZXhwICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuICBnMSA8LSBnZ3Bsb3Qob2JzZXhwLCBhZXMoeCA9IGxvZ19vYnNleHBfRE1TTywgeSA9IGxvZ19vYnNleHBfZFRBRywgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gICAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gICAgZ2d0aXRsZShwYXN0ZTAocmVzLCBcImtiLCBsb2cyKG9icy9leHApXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG4gIFxuICBcbiAgIyBWaXN1YWxpemUgVVAgRE9XTiBsb29wc1xuICB0ZW1wIDwtIG9ic2V4cCAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3AuZG93biRpZClcbiAgdGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic2V4cF9ETVNPLCB0ZW1wJGxvZ19vYnNleHBfZFRBRywgbiA9IDEwMClcbiAgdGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuICBnMiA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzZXhwX0RNU08sIHkgPSBsb2dfb2JzZXhwX2RUQUcsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gICAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICAgIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICAgIGdndGl0bGUocGFzdGUwKHJlcywgXCJrYiwgbG9nMihvYnMvZXhwKSwgZG93blwiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpXG4gIFxuICBcbiAgdGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLm5vJGlkKVxuICB0ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzZXhwX0RNU08sIHRlbXAkbG9nX29ic2V4cF9kVEFHLCBuID0gMTAwKVxuICB0ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG4gIGczIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNleHBfRE1TTywgeSA9IGxvZ19vYnNleHBfZFRBRywgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gICAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gICAgZ2d0aXRsZShwYXN0ZTAocmVzLCBcImtiLCBsb2cyKG9icy9leHApLCBub1wiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpXG4gIFxuICB0ZW1wIDwtIG9ic2V4cCAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3AudXAkaWQpXG4gIHRlbXAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eSh0ZW1wJGxvZ19vYnNleHBfRE1TTywgdGVtcCRsb2dfb2JzZXhwX2RUQUcsIG4gPSAxMDApXG4gIHRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbiAgZzQgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic2V4cF9ETVNPLCB5ID0gbG9nX29ic2V4cF9kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICAgIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgICBnZ3RpdGxlKHBhc3RlMChyZXMsIFwia2IsIGxvZzIob2JzL2V4cCksIHVwXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSlcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXCJvYnNleHBfZFRBR192c19ETVNPX1wiLCByZXMsIFwia2JcIilcbiAgaGVpZ2h0IDwtIDRcbiAgd2lkdGggPC0gMTJcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwbG90X2dyaWQoZzEsIGc0LCBnMywgZzIsIG5jb2wgPSA0KSlcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocGxvdF9ncmlkKGcxLCBnNCwgZzMsIGcyLCBuY29sID0gNCkpXG4gIGRldi5vZmYoKVxufVxuXG5gYGAifQ== -->\n\n```r\n# Importing loops\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\\)) %>% \n  dplyr::mutate(binSize = V3 - V2,\n                id = paste(V1, binSize, V2, V5, sep = \\_\\))\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\\)) %>% \n  dplyr::mutate(binSize = V3 - V2,\n                id = paste(V1, binSize, V2, V5, sep = \\_\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\\)) %>% \n  dplyr::mutate(binSize = V3 - V2,\n                id = paste(V1, binSize, V2, V5, sep = \\_\\))\n\nfor(res in c(25, 10, 5)){\n  minValue <- -4\n  maxValue <- 5\n  obsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp_\\, res, \\kb.tsv\\))) %>%\n    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))\n  \n  \n  # dTAG\n  obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_dTAG, n = 100)\n  obsexp <- obsexp %>% dplyr::arrange(density)\n  g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + \n    geom_point() + theme_bw() + scale_color_viridis(guide = \\none\\) +\n    geom_abline(slope = 1, intercept = 0) +\n    ggtitle(paste0(res, \\kb\n"} -->
# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

for(res in c(25, 10, 5)){
  minValue <- -4
  maxValue <- 5
  obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp_\, res, \kb.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))
  
  
  # dTAG
  obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_dTAG, n = 100)
  obsexp <- obsexp %>% dplyr::arrange(density)
  g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
    geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
    geom_abline(slope = 1, intercept = 0) +
    ggtitle(paste0(res, \kb
```r
# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

for(res in c(25, 10, 5)){
  minValue <- -4
  maxValue <- 5
  obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp_\, res, \kb.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))
  
  
  # dTAG
  obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_dTAG, n = 100)
  obsexp <- obsexp %>% dplyr::arrange(density)
  g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
    geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
    geom_abline(slope = 1, intercept = 0) +
    ggtitle(paste0(res, \kb
Async

<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBJbXBvcnRpbmcgbG9vcHNcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5cbm1pblZhbHVlIDwtIC00XG5tYXhWYWx1ZSA8LSA1XG5cbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFwibG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlwiKSkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0RNU08pKSxcbiAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX2RUQUcgPSBpZl9lbHNlKG9ic2V4cF9kVEFHID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9kVEFHKSksXG4gICAgICAgICAgICAgICAgbG9nX29ic2V4cF9BNDg1ID0gaWZfZWxzZShvYnNleHBfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQTQ4NSkpKVxuXG5cblxuIyBkVEFHXG5vYnNleHAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eShvYnNleHAkbG9nX29ic2V4cF9ETVNPLCBvYnNleHAkbG9nX29ic2V4cF9kVEFHLCBuID0gMTAwKVxub2JzZXhwIDwtIG9ic2V4cCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmcxIDwtIGdncGxvdChvYnNleHAsIGFlcyh4ID0gbG9nX29ic2V4cF9ETVNPLCB5ID0gbG9nX29ic2V4cF9kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzL2V4cClcIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxuIyBWaXN1YWxpemUgVVAgRE9XTiBsb29wc1xudGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLmRvd24kaWQpXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzZXhwX0RNU08sIHRlbXAkbG9nX29ic2V4cF9kVEFHLCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzIgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic2V4cF9ETVNPLCB5ID0gbG9nX29ic2V4cF9kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzL2V4cCksIGRvd25cIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxuXG50ZW1wIDwtIG9ic2V4cCAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3Aubm8kaWQpXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzZXhwX0RNU08sIHRlbXAkbG9nX29ic2V4cF9kVEFHLCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzMgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic2V4cF9ETVNPLCB5ID0gbG9nX29ic2V4cF9kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzL2V4cCksIG5vXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC51cCRpZClcbnRlbXAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eSh0ZW1wJGxvZ19vYnNleHBfRE1TTywgdGVtcCRsb2dfb2JzZXhwX2RUQUcsIG4gPSAxMDApXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nNCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzZXhwX0RNU08sIHkgPSBsb2dfb2JzZXhwX2RUQUcsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMvZXhwKSwgdXBcIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJvYnNleHBfZFRBR192c19ETVNPXCIpXG5oZWlnaHQgPC0gNFxud2lkdGggPC0gMTJcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHBsb3RfZ3JpZChnMSwgZzQsIGczLCBnMiwgbmNvbCA9IDQpKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwbG90X2dyaWQoZzEsIGc0LCBnMywgZzIsIG5jb2wgPSA0KSlcbmRldi5vZmYoKVxuXG5cbiMgU3RydWN0dXJhbFxubG9vcC5zdHIgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9zdHJ1Y3R1cmUuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5zdHIkaWQpXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzZXhwX0RNU08sIHRlbXAkbG9nX29ic2V4cF9kVEFHLCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzUgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic2V4cF9ETVNPLCB5ID0gbG9nX29ic2V4cF9kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzL2V4cCksIHN0cnVjdHVyYWwgbG9vcHNcIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxuIyBSZWcgKFBFLVBFKVxubG9vcC5yZWcgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZS5iZWRwZVwiKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIGJpblNpemUsIFYyLCBWNSwgc2VwID0gXCJfXCIpKVxudGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLnJlZyRpZClcbnRlbXAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eSh0ZW1wJGxvZ19vYnNleHBfRE1TTywgdGVtcCRsb2dfb2JzZXhwX2RUQUcsIG4gPSAxMDApXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nNiA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzZXhwX0RNU08sIHkgPSBsb2dfb2JzZXhwX2RUQUcsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMvZXhwKSwgcmVndWxhdG9yeSBsb29wc1wiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpIFxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJvYnNleHBfZFRBR192c19ETVNPX3N0cl92c19yZWdcIilcbmhlaWdodCA8LSA0XG53aWR0aCA8LSA2XG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwbG90X2dyaWQoZzUsIGc2LCBuY29sID0gMikpXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHBsb3RfZ3JpZChnNSwgZzYsIG5jb2wgPSAyKSlcbmRldi5vZmYoKVxuYGBgIn0= -->

```r
# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

minValue <- -4
maxValue <- 5

obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))



# dTAG
obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_dTAG, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)
```r
# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

minValue <- -4
maxValue <- 5

obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))



# dTAG
obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_dTAG, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)

Comparing obs/exp from chrommosight loop scores

dTAG per res

<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5zcGVjaWZpY0xvb3AuMjVrYiA8LSBmcmVhZChoZXJlKGxvb3BEaXIsIFwiRzEuRE1TTy5NZXJnZWRfY2hyb21vc2lnaHRfMjVrYi5iZWRwZVwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5zcGVjaWZpY0xvb3AuMTBrYiA8LSBmcmVhZChoZXJlKGxvb3BEaXIsIFwiRzEuRE1TTy5NZXJnZWRfY2hyb21vc2lnaHRfMTBrYi5iZWRwZVwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5zcGVjaWZpY0xvb3AuNWtiIDwtIGZyZWFkKGhlcmUobG9vcERpciwgXCJHMS5ETVNPLk1lcmdlZF9jaHJvbW9zaWdodF81a2IuYmVkcGVcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIGJpblNpemUsIFYyLCBWNSwgc2VwID0gXCJfXCIpKVxuXG5zcGVjaWZpY0xvb3BzLkRNU08gPC0gYyhzcGVjaWZpY0xvb3AuMjVrYiRpZCwgc3BlY2lmaWNMb29wLjEwa2IkaWQsIHNwZWNpZmljTG9vcC41a2IkaWQpXG5cblxubWluVmFsdWUgPC0gLTRcbm1heFZhbHVlIDwtIDVcblxub2JzZXhwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXCJsb29wU2NvcmVfY29uc19vYnNleHAudHN2XCIpKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUobG9nX29ic2V4cF9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfRE1TTykpLFxuICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZFRBRyA9IGlmX2Vsc2Uob2JzZXhwX2RUQUcgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX2RUQUcpKSxcbiAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX0E0ODUgPSBpZl9lbHNlKG9ic2V4cF9BNDg1ID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9BNDg1KSkpXG5cblxuXG5cbiMgU3RydWN0dXJhbFxubG9vcC5zdHIgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9zdHJ1Y3R1cmUuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5zdHIkaWQsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZCAlaW4lIHNwZWNpZmljTG9vcHMuRE1TTylcbnRlbXAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eSh0ZW1wJGxvZ19vYnNleHBfRE1TTywgdGVtcCRsb2dfb2JzZXhwX2RUQUcsIG4gPSAxMDApXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nNSA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzZXhwX0RNU08sIHkgPSBsb2dfb2JzZXhwX2RUQUcsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMvZXhwKSwgc3RydWN0dXJhbCBsb29wc1wiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpIFxuXG4jIFJlZyAoUEUtUEUpXG5sb29wLnJlZyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG50ZW1wIDwtIG9ic2V4cCAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3AucmVnJGlkLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWQgJWluJSBzcGVjaWZpY0xvb3BzLkRNU08pXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzZXhwX0RNU08sIHRlbXAkbG9nX29ic2V4cF9kVEFHLCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzYgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic2V4cF9ETVNPLCB5ID0gbG9nX29ic2V4cF9kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzL2V4cCksIHJlZ3VsYXRvcnkgbG9vcHNcIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwib2JzZXhwX2RUQUdfdnNfRE1TT19zdHJfdnNfcmVnX0RNU09zcGVjaWZpY0xvb3BzXCIpXG5oZWlnaHQgPC0gNFxud2lkdGggPC0gNlxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocGxvdF9ncmlkKGc1LCBnNiwgbmNvbCA9IDIpKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwbG90X2dyaWQoZzUsIGc2LCBuY29sID0gMikpXG5kZXYub2ZmKClcblxuYGBgIn0= -->

```r

specificLoop.25kb <- fread(here(loopDir, \G1.DMSO.Merged_chromosight_25kb.bedpe\)) %>%
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
specificLoop.10kb <- fread(here(loopDir, \G1.DMSO.Merged_chromosight_10kb.bedpe\)) %>%
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
specificLoop.5kb <- fread(here(loopDir, \G1.DMSO.Merged_chromosight_5kb.bedpe\)) %>%
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

specificLoops.DMSO <- c(specificLoop.25kb$id, specificLoop.10kb$id, specificLoop.5kb$id)


minValue <- -4
maxValue <- 5

obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))




# Structural
loop.str <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
temp <- obsexp %>% dplyr::filter(id %in% loop.str$id,
                                 id %in% specificLoops.DMSO)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g5 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)
```r

specificLoop.25kb <- fread(here(loopDir, \G1.DMSO.Merged_chromosight_25kb.bedpe\)) %>%
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
specificLoop.10kb <- fread(here(loopDir, \G1.DMSO.Merged_chromosight_10kb.bedpe\)) %>%
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
specificLoop.5kb <- fread(here(loopDir, \G1.DMSO.Merged_chromosight_5kb.bedpe\)) %>%
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

specificLoops.DMSO <- c(specificLoop.25kb$id, specificLoop.10kb$id, specificLoop.5kb$id)


minValue <- -4
maxValue <- 5

obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))




# Structural
loop.str <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
temp <- obsexp %>% dplyr::filter(id %in% loop.str$id,
                                 id %in% specificLoops.DMSO)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g5 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)
dTAG all res

<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiLnRzdlwiKSkpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbm1heFZhbHVlIDwtIDVcbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFwibG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlwiKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUobG9nX29ic2V4cF9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfRE1TTykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kVEFHID0gaWZfZWxzZShvYnNleHBfZFRBRyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfZFRBRykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9BNDg1ID0gaWZfZWxzZShvYnNleHBfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQTQ4NSkpKVxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcImlkXCIpKSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSlcblxuXG4jIEltcG9ydGluZyBsb29wc1xubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVwiKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIGJpblNpemUsIFYyLCBWNSwgc2VwID0gXCJfXCIpKVxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcblxuIyBkaXN0YW5jZSBmaWx0ZXJcbm9ic2V4cCA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGRpc3RhbmNlID4gMWU2KVxuXG5cbiMgZFRBR1xub2JzZXhwJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkob2JzZXhwJGxvZ19vYnNleHBfRE1TTywgb2JzZXhwJGxvZ19vYnNleHBfZFRBRywgbiA9IDEwMClcbm9ic2V4cCA8LSBvYnNleHAgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nMSA8LSBnZ3Bsb3Qob2JzZXhwLCBhZXMoeCA9IGxvZ19vYnNleHBfRE1TTywgeSA9IGxvZ19vYnNleHBfZFRBRywgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icy9leHApXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cbiMgVmlzdWFsaXplIFVQIERPV04gbG9vcHNcbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5kb3duJGlkKVxudGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic2V4cF9ETVNPLCB0ZW1wJGxvZ19vYnNleHBfZFRBRywgbiA9IDEwMClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmcyIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNleHBfRE1TTywgeSA9IGxvZ19vYnNleHBfZFRBRywgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icy9leHApLCBkb3duXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cblxudGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLm5vJGlkKVxudGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic2V4cF9ETVNPLCB0ZW1wJGxvZ19vYnNleHBfZFRBRywgbiA9IDEwMClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmczIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNleHBfRE1TTywgeSA9IGxvZ19vYnNleHBfZFRBRywgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icy9leHApLCBub1wiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpIFxuXG50ZW1wIDwtIG9ic2V4cCAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3AudXAkaWQpXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzZXhwX0RNU08sIHRlbXAkbG9nX29ic2V4cF9kVEFHLCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzQgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic2V4cF9ETVNPLCB5ID0gbG9nX29ic2V4cF9kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzL2V4cCksIHVwXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwib2JzZXhwX2RUQUdfdnNfRE1TT18xbWJvdmVyXCIpXG5oZWlnaHQgPC0gNFxud2lkdGggPC0gMTJcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHBsb3RfZ3JpZChnMSwgZzQsIGczLCBnMiwgbmNvbCA9IDQpKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwbG90X2dyaWQoZzEsIGc0LCBnMywgZzIsIG5jb2wgPSA0KSlcbmRldi5vZmYoKVxuXG5cbiMgU3RydWN0dXJhbFxubG9vcC5zdHIgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9zdHJ1Y3R1cmUuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5zdHIkaWQpXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzZXhwX0RNU08sIHRlbXAkbG9nX29ic2V4cF9kVEFHLCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzUgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic2V4cF9ETVNPLCB5ID0gbG9nX29ic2V4cF9kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzL2V4cCksIHN0cnVjdHVyYWwgbG9vcHNcIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxuIyBSZWcgKFBFLVBFKVxubG9vcC5yZWcgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZS5iZWRwZVwiKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIGJpblNpemUsIFYyLCBWNSwgc2VwID0gXCJfXCIpKVxudGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLnJlZyRpZClcbnRlbXAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eSh0ZW1wJGxvZ19vYnNleHBfRE1TTywgdGVtcCRsb2dfb2JzZXhwX2RUQUcsIG4gPSAxMDApXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nNiA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzZXhwX0RNU08sIHkgPSBsb2dfb2JzZXhwX2RUQUcsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMvZXhwKSwgcmVndWxhdG9yeSBsb29wc1wiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpIFxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJvYnNleHBfZFRBR192c19ETVNPXzFtYm92ZXJfc3RyX3ZzX3JlZ1wiKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDZcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHBsb3RfZ3JpZChnNSwgZzYsIG5jb2wgPSAyKSlcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocGxvdF9ncmlkKGc1LCBnNiwgbmNvbCA9IDIpKVxuZGV2Lm9mZigpXG5gYGAifQ== -->

```r
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue <- -4
maxValue <- 5
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\)) %>% dplyr::mutate(distance = start2 - start1)


# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

# distance filter
obsexp <- data %>% dplyr::filter(distance > 1e6)


# dTAG
obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_dTAG, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)
```r
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue <- -4
maxValue <- 5
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\)) %>% dplyr::mutate(distance = start2 - start1)


# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

# distance filter
obsexp <- data %>% dplyr::filter(distance > 1e6)


# dTAG
obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_dTAG, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)
Plotting only subset

<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubWluVmFsdWUgPC0gLTRcbm1heFZhbHVlIDwtIDEwXG5vYnNleHAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcImxvb3BTY29yZV9jb25zX29ic2V4cC50c3ZcIikpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0RNU08pKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZFRBRyA9IGlmX2Vsc2Uob2JzZXhwX2RUQUcgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX2RUQUcpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfQTQ4NSA9IGlmX2Vsc2Uob2JzZXhwX0E0ODUgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0E0ODUpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNfRE1TTyA9IGlmX2Vsc2Uob2JzX0RNU08gPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzX0RNU08pKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNfZFRBRyA9IGlmX2Vsc2Uob2JzX2RUQUcgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzX2RUQUcpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNfQTQ4NSA9IGlmX2Vsc2Uob2JzX0E0ODUgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzX0E0ODUpKSlcblxuIyBJbXBvcnRpbmcgbG9vcHNcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5cblxuXG4jIGRUQUdcbm9ic2V4cCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KG9ic2V4cCRsb2dfb2JzX0RNU08sIG9ic2V4cCRsb2dfb2JzX2RUQUcsIG4gPSAxMDApXG5vYnNleHAgPC0gb2JzZXhwICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzEgPC0gZ2dwbG90KG9ic2V4cCwgYWVzKHggPSBsb2dfb2JzX0RNU08sIHkgPSBsb2dfb2JzX2RUQUcsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMpXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cbiMgVmlzdWFsaXplIFVQIERPV04gbG9vcHNcbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5kb3duJGlkKVxudGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic19ETVNPLCB0ZW1wJGxvZ19vYnNfZFRBRywgbiA9IDEwMClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmcyIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNfRE1TTywgeSA9IGxvZ19vYnNfZFRBRywgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icyksIGRvd25cIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxuXG50ZW1wIDwtIG9ic2V4cCAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3Aubm8kaWQpXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzX0RNU08sIHRlbXAkbG9nX29ic19kVEFHLCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzMgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic19ETVNPLCB5ID0gbG9nX29ic19kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzKSwgbm9cIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxudGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLnVwJGlkKVxudGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic19ETVNPLCB0ZW1wJGxvZ19vYnNfZFRBRywgbiA9IDEwMClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmc0IDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNfRE1TTywgeSA9IGxvZ19vYnNfZFRBRywgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icyksIHVwXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwib2JzZXhwX2RUQUdfdnNfRE1TT19vYnNcIilcbmhlaWdodCA8LSA0XG53aWR0aCA8LSAxMlxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocGxvdF9ncmlkKGcxLCBnNCwgZzMsIGcyLCBuY29sID0gNCkpXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHBsb3RfZ3JpZChnMSwgZzQsIGczLCBnMiwgbmNvbCA9IDQpKVxuZGV2Lm9mZigpXG5cblxuIyBTdHJ1Y3R1cmFsXG5sb29wLnN0ciA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3N0cnVjdHVyZS5iZWRwZVwiKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIGJpblNpemUsIFYyLCBWNSwgc2VwID0gXCJfXCIpKVxudGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLnN0ciRpZClcbnRlbXAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eSh0ZW1wJGxvZ19vYnNfRE1TTywgdGVtcCRsb2dfb2JzX2RUQUcsIG4gPSAxMDApXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nNSA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzX0RNU08sIHkgPSBsb2dfb2JzX2RUQUcsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMpLCBzdHJ1Y3R1cmFsIGxvb3BzXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cbiMgUmVnIChQRS1QRSlcbmxvb3AucmVnIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGUuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5yZWckaWQpXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzX0RNU08sIHRlbXAkbG9nX29ic19kVEFHLCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzYgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic19ETVNPLCB5ID0gbG9nX29ic19kVEFHLCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzKSwgcmVndWxhdG9yeSBsb29wc1wiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpIFxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJvYnNleHBfZFRBR192c19ETVNPX29ic19zdHJfdnNfcmVnXCIpXG5oZWlnaHQgPC0gNFxud2lkdGggPC0gNlxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocGxvdF9ncmlkKGc1LCBnNiwgbmNvbCA9IDIpKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwbG90X2dyaWQoZzUsIGc2LCBuY29sID0gMikpXG5kZXYub2ZmKClcbmBgYCJ9 -->

```r
minValue <- -4
maxValue <- 10
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                  log_obs_DMSO = if_else(obs_DMSO == 0, minValue, log2(obs_DMSO)),
                  log_obs_dTAG = if_else(obs_dTAG == 0, minValue, log2(obs_dTAG)),
                  log_obs_A485 = if_else(obs_A485 == 0, minValue, log2(obs_A485)))

# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))



# dTAG
obsexp$density <- get_density(obsexp$log_obs_DMSO, obsexp$log_obs_dTAG, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obs_DMSO, y = log_obs_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs)
```r
minValue <- -4
maxValue <- 10
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                  log_obs_DMSO = if_else(obs_DMSO == 0, minValue, log2(obs_DMSO)),
                  log_obs_dTAG = if_else(obs_dTAG == 0, minValue, log2(obs_dTAG)),
                  log_obs_A485 = if_else(obs_A485 == 0, minValue, log2(obs_A485)))

# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))



# dTAG
obsexp$density <- get_density(obsexp$log_obs_DMSO, obsexp$log_obs_dTAG, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obs_DMSO, y = log_obs_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs)
Plotting 1mb

<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBJbXBvcnRpbmcgbG9vcHNcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5cbm1pblZhbHVlIDwtIC04XG5tYXhWYWx1ZSA8LSA3XG5cbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFwibG9vcFNjb3JlX2NvbnNfb2JzZXhwX0FzeW5jLnRzdlwiKSkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfVVQgPSBpZl9lbHNlKG9ic2V4cF9VVCA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfVVQpKSxcbiAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX0FJRCA9IGlmX2Vsc2Uob2JzZXhwX0FJRCA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQUlEKSkpXG5cblxuXG4jIGRUQUdcbm9ic2V4cCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KG9ic2V4cCRsb2dfb2JzZXhwX1VULCBvYnNleHAkbG9nX29ic2V4cF9BSUQsIG4gPSAxMDApXG5vYnNleHAgPC0gb2JzZXhwICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzEgPC0gZ2dwbG90KG9ic2V4cCwgYWVzKHggPSBsb2dfb2JzZXhwX1VULCB5ID0gbG9nX29ic2V4cF9BSUQsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMvZXhwKVwiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpIFxuXG4jIFZpc3VhbGl6ZSBVUCBET1dOIGxvb3BzXG50ZW1wIDwtIG9ic2V4cCAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3AuZG93biRpZClcbnRlbXAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eSh0ZW1wJGxvZ19vYnNleHBfVVQsIHRlbXAkbG9nX29ic2V4cF9BSUQsIG4gPSAxMDApXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nMiA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzZXhwX1VULCB5ID0gbG9nX29ic2V4cF9BSUQsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMvZXhwKSwgZG93blwiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpIFxuXG5cbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5ubyRpZClcbnRlbXAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eSh0ZW1wJGxvZ19vYnNleHBfVVQsIHRlbXAkbG9nX29ic2V4cF9BSUQsIG4gPSAxMDApXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nMyA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzZXhwX1VULCB5ID0gbG9nX29ic2V4cF9BSUQsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMvZXhwKSwgbm9cIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxudGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLnVwJGlkKVxudGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic2V4cF9VVCwgdGVtcCRsb2dfb2JzZXhwX0FJRCwgbiA9IDEwMClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmc0IDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNleHBfVVQsIHkgPSBsb2dfb2JzZXhwX0FJRCwgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icy9leHApLCB1cFwiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpIFxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcIm9ic2V4cF9BSURfdnNfVVRcIilcbmhlaWdodCA8LSA0XG53aWR0aCA8LSAxMlxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocGxvdF9ncmlkKGcxLCBnNCwgZzMsIGcyLCBuY29sID0gNCkpXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHBsb3RfZ3JpZChnMSwgZzQsIGczLCBnMiwgbmNvbCA9IDQpKVxuZGV2Lm9mZigpXG5cblxuIyBTdHJ1Y3R1cmFsXG5sb29wLnN0ciA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3N0cnVjdHVyZS5iZWRwZVwiKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIGJpblNpemUsIFYyLCBWNSwgc2VwID0gXCJfXCIpKVxudGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLnN0ciRpZClcbnRlbXAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eSh0ZW1wJGxvZ19vYnNleHBfVVQsIHRlbXAkbG9nX29ic2V4cF9BSUQsIG4gPSAxMDApXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nNSA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzZXhwX1VULCB5ID0gbG9nX29ic2V4cF9BSUQsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMvZXhwKSwgc3RydWN0dXJhbCBsb29wc1wiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpIFxuXG4jIFJlZyAoUEUtUEUpXG5sb29wLnJlZyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG50ZW1wIDwtIG9ic2V4cCAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3AucmVnJGlkKVxudGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic2V4cF9VVCwgdGVtcCRsb2dfb2JzZXhwX0FJRCwgbiA9IDEwMClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmc2IDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNleHBfVVQsIHkgPSBsb2dfb2JzZXhwX0FJRCwgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icy9leHApLCByZWd1bGF0b3J5IGxvb3BzXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcIm9ic2V4cF9BSURfdnNfVVRfc3RyX3ZzX3JlZ1wiKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDZcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHBsb3RfZ3JpZChnNSwgZzYsIG5jb2wgPSAyKSlcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocGxvdF9ncmlkKGc1LCBnNiwgbmNvbCA9IDIpKVxuZGV2Lm9mZigpXG5gYGAifQ== -->

```r
# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

minValue <- -8
maxValue <- 7

obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp_Async.tsv\))) %>%
  dplyr::mutate(log_obsexp_UT = if_else(obsexp_UT == 0, minValue, log2(obsexp_UT)),
                log_obsexp_AID = if_else(obsexp_AID == 0, minValue, log2(obsexp_AID)))



# dTAG
obsexp$density <- get_density(obsexp$log_obsexp_UT, obsexp$log_obsexp_AID, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obsexp_UT, y = log_obsexp_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obsexp_UT, temp$log_obsexp_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obsexp_UT, y = log_obsexp_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)
```r
# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

minValue <- -8
maxValue <- 7

obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp_Async.tsv\))) %>%
  dplyr::mutate(log_obsexp_UT = if_else(obsexp_UT == 0, minValue, log2(obsexp_UT)),
                log_obsexp_AID = if_else(obsexp_AID == 0, minValue, log2(obsexp_AID)))



# dTAG
obsexp$density <- get_density(obsexp$log_obsexp_UT, obsexp$log_obsexp_AID, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obsexp_UT, y = log_obsexp_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obsexp_UT, temp$log_obsexp_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obsexp_UT, y = log_obsexp_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)
Plotting Obs

<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5taW5WYWx1ZSA8LSAtMjBcbm1heFZhbHVlIDwtIDEwXG5cbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFwibG9vcFNjb3JlX2NvbnNfb2JzZXhwX0FzeW5jLnRzdlwiKSkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfVVQgPSBpZl9lbHNlKG9ic2V4cF9VVCA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfVVQpKSxcbiAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX0FJRCA9IGlmX2Vsc2Uob2JzZXhwX0FJRCA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQUlEKSksXG4gICAgICAgICAgICAgICAgbG9nX29ic19VVCA9IGlmX2Vsc2Uob2JzX1VUID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic19VVCkpLFxuICAgICAgICAgICAgICAgIGxvZ19vYnNfQUlEID0gaWZfZWxzZShvYnNfQUlEID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic19BSUQpKSlcblxuIyBJbXBvcnRpbmcgbG9vcHNcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5cblxuXG4jIGRUQUdcbm9ic2V4cCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KG9ic2V4cCRsb2dfb2JzX1VULCBvYnNleHAkbG9nX29ic19BSUQsIG4gPSAxMDApXG5vYnNleHAgPC0gb2JzZXhwICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzEgPC0gZ2dwbG90KG9ic2V4cCwgYWVzKHggPSBsb2dfb2JzX1VULCB5ID0gbG9nX29ic19BSUQsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMpXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cbiMgVmlzdWFsaXplIFVQIERPV04gbG9vcHNcbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5kb3duJGlkKVxudGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic19VVCwgdGVtcCRsb2dfb2JzX0FJRCwgbiA9IDEwMClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmcyIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNfVVQsIHkgPSBsb2dfb2JzX0FJRCwgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icyksIGRvd25cIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxuXG50ZW1wIDwtIG9ic2V4cCAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3Aubm8kaWQpXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzX1VULCB0ZW1wJGxvZ19vYnNfQUlELCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzMgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic19VVCwgeSA9IGxvZ19vYnNfQUlELCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzKSwgbm9cIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxudGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLnVwJGlkKVxudGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic19VVCwgdGVtcCRsb2dfb2JzX0FJRCwgbiA9IDEwMClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmc0IDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNfVVQsIHkgPSBsb2dfb2JzX0FJRCwgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icyksIHVwXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwib2JzX0FJRF92c19VVF9vYnNcIilcbmhlaWdodCA8LSA0XG53aWR0aCA8LSAxMlxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocGxvdF9ncmlkKGcxLCBnNCwgZzMsIGcyLCBuY29sID0gNCkpXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHBsb3RfZ3JpZChnMSwgZzQsIGczLCBnMiwgbmNvbCA9IDQpKVxuZGV2Lm9mZigpXG5cblxuIyBTdHJ1Y3R1cmFsXG5sb29wLnN0ciA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3N0cnVjdHVyZS5iZWRwZVwiKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIGJpblNpemUsIFYyLCBWNSwgc2VwID0gXCJfXCIpKVxudGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLnN0ciRpZClcbnRlbXAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eSh0ZW1wJGxvZ19vYnNfVVQsIHRlbXAkbG9nX29ic19BSUQsIG4gPSAxMDApXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nNSA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzX1VULCB5ID0gbG9nX29ic19BSUQsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMpLCBzdHJ1Y3R1cmFsIGxvb3BzXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cbiMgUmVnIChQRS1QRSlcbmxvb3AucmVnIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGUuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5yZWckaWQpXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzX1VULCB0ZW1wJGxvZ19vYnNfQUlELCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzYgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic19VVCwgeSA9IGxvZ19vYnNfQUlELCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzKSwgcmVndWxhdG9yeSBsb29wc1wiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpIFxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJvYnNfQUlEX3ZzX1VUX29ic19zdHJfdnNfcmVnXCIpXG5oZWlnaHQgPC0gNFxud2lkdGggPC0gNlxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocGxvdF9ncmlkKGc1LCBnNiwgbmNvbCA9IDIpKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwbG90X2dyaWQoZzUsIGc2LCBuY29sID0gMikpXG5kZXYub2ZmKClcbmBgYCJ9 -->

```r

minValue <- -20
maxValue <- 10

obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp_Async.tsv\))) %>%
  dplyr::mutate(log_obsexp_UT = if_else(obsexp_UT == 0, minValue, log2(obsexp_UT)),
                log_obsexp_AID = if_else(obsexp_AID == 0, minValue, log2(obsexp_AID)),
                log_obs_UT = if_else(obs_UT == 0, minValue, log2(obs_UT)),
                log_obs_AID = if_else(obs_AID == 0, minValue, log2(obs_AID)))

# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))



# dTAG
obsexp$density <- get_density(obsexp$log_obs_UT, obsexp$log_obs_AID, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obs_UT, y = log_obs_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obs_UT, temp$log_obs_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obs_UT, y = log_obs_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs)
```r

minValue <- -20
maxValue <- 10

obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp_Async.tsv\))) %>%
  dplyr::mutate(log_obsexp_UT = if_else(obsexp_UT == 0, minValue, log2(obsexp_UT)),
                log_obsexp_AID = if_else(obsexp_AID == 0, minValue, log2(obsexp_AID)),
                log_obs_UT = if_else(obs_UT == 0, minValue, log2(obs_UT)),
                log_obs_AID = if_else(obs_AID == 0, minValue, log2(obs_AID)))

# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))



# dTAG
obsexp$density <- get_density(obsexp$log_obs_UT, obsexp$log_obs_AID, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obs_UT, y = log_obs_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obs_UT, temp$log_obs_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obs_UT, y = log_obs_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs)
Async.AID all res

<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBJbXBvcnRpbmcgbG9vcHNcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19OT19kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5cbmZvcihyZXMgaW4gYygyNSwgMTAsIDUpKXtcbiAgbWluVmFsdWUgPC0gLTRcbiAgbWF4VmFsdWUgPC0gNVxuICBvYnNleHAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcImxvb3BTY29yZV9jb25zX29ic2V4cF9cIiwgcmVzLCBcImtiLnRzdlwiKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUobG9nX29ic2V4cF9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfRE1TTykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9BNDg1ID0gaWZfZWxzZShvYnNleHBfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQTQ4NSkpKVxuICBcbiAgXG4gICMgQTQ4NVxuICBvYnNleHAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eShvYnNleHAkbG9nX29ic2V4cF9ETVNPLCBvYnNleHAkbG9nX29ic2V4cF9BNDg1LCBuID0gMTAwKVxuICBvYnNleHAgPC0gb2JzZXhwICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuICBnMSA8LSBnZ3Bsb3Qob2JzZXhwLCBhZXMoeCA9IGxvZ19vYnNleHBfRE1TTywgeSA9IGxvZ19vYnNleHBfQTQ4NSwgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gICAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gICAgZ2d0aXRsZShwYXN0ZTAocmVzLCBcImtiLCBsb2cyKG9icy9leHApXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG4gIFxuICBcbiAgIyBWaXN1YWxpemUgVVAgRE9XTiBsb29wc1xuICB0ZW1wIDwtIG9ic2V4cCAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3AuZG93biRpZClcbiAgdGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic2V4cF9ETVNPLCB0ZW1wJGxvZ19vYnNleHBfQTQ4NSwgbiA9IDEwMClcbiAgdGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuICBnMiA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzZXhwX0RNU08sIHkgPSBsb2dfb2JzZXhwX0E0ODUsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gICAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICAgIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICAgIGdndGl0bGUocGFzdGUwKHJlcywgXCJrYiwgbG9nMihvYnMvZXhwKSwgZG93blwiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpIFxuICBcbiAgXG4gIHRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5ubyRpZClcbiAgdGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic2V4cF9ETVNPLCB0ZW1wJGxvZ19vYnNleHBfQTQ4NSwgbiA9IDEwMClcbiAgdGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuICBnMyA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzZXhwX0RNU08sIHkgPSBsb2dfb2JzZXhwX0E0ODUsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gICAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICAgIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICAgIGdndGl0bGUocGFzdGUwKHJlcywgXCJrYiwgbG9nMihvYnMvZXhwKSwgbm9cIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcbiAgXG4gIHRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC51cCRpZClcbiAgdGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic2V4cF9ETVNPLCB0ZW1wJGxvZ19vYnNleHBfQTQ4NSwgbiA9IDEwMClcbiAgdGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuICBnNCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzZXhwX0RNU08sIHkgPSBsb2dfb2JzZXhwX0E0ODUsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gICAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICAgIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICAgIGdndGl0bGUocGFzdGUwKHJlcywgXCJrYiwgbG9nMihvYnMvZXhwKSwgdXBcIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcbiAgXG4gIFxuICBmaWxlTmFtZSA8LSBwYXN0ZTAoXCJvYnNleHBfQTQ4NV92c19ETVNPX1wiLCByZXMsIFwia2JcIilcbiAgaGVpZ2h0IDwtIDRcbiAgd2lkdGggPC0gMTJcbiAgcG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxuICBwcmludChwbG90X2dyaWQoZzEsIGc0LCBnMywgZzIsIG5jb2wgPSA0KSlcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocGxvdF9ncmlkKGcxLCBnNCwgZzMsIGcyLCBuY29sID0gNCkpXG4gIGRldi5vZmYoKVxufVxuXG5gYGAifQ== -->

```r
# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

for(res in c(25, 10, 5)){
  minValue <- -4
  maxValue <- 5
  obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp_\, res, \kb.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))
  
  
  # A485
  obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_A485, n = 100)
  obsexp <- obsexp %>% dplyr::arrange(density)
  g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
    geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
    geom_abline(slope = 1, intercept = 0) +
    ggtitle(paste0(res, \kb
```r
# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

for(res in c(25, 10, 5)){
  minValue <- -4
  maxValue <- 5
  obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp_\, res, \kb.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))
  
  
  # A485
  obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_A485, n = 100)
  obsexp <- obsexp %>% dplyr::arrange(density)
  g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
    geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
    geom_abline(slope = 1, intercept = 0) +
    ggtitle(paste0(res, \kb
Plotting Obs

<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBJbXBvcnRpbmcgbG9vcHNcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19OT19kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5cbm1pblZhbHVlIDwtIC00XG5tYXhWYWx1ZSA8LSA1XG5cbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFwibG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlwiKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUobG9nX29ic2V4cF9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfRE1TTykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9BNDg1ID0gaWZfZWxzZShvYnNleHBfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQTQ4NSkpKVxuXG5cbiMgQTQ4NVxub2JzZXhwJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkob2JzZXhwJGxvZ19vYnNleHBfRE1TTywgb2JzZXhwJGxvZ19vYnNleHBfQTQ4NSwgbiA9IDEwMClcbm9ic2V4cCA8LSBvYnNleHAgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nMSA8LSBnZ3Bsb3Qob2JzZXhwLCBhZXMoeCA9IGxvZ19vYnNleHBfRE1TTywgeSA9IGxvZ19vYnNleHBfQTQ4NSwgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icy9leHApXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cbiMgVmlzdWFsaXplIFVQIERPV04gbG9vcHNcbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5kb3duJGlkKVxudGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic2V4cF9ETVNPLCB0ZW1wJGxvZ19vYnNleHBfQTQ4NSwgbiA9IDEwMClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmcyIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNleHBfRE1TTywgeSA9IGxvZ19vYnNleHBfQTQ4NSwgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icy9leHApLCBkb3duXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cblxudGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLm5vJGlkKVxudGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic2V4cF9ETVNPLCB0ZW1wJGxvZ19vYnNleHBfQTQ4NSwgbiA9IDEwMClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmczIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNleHBfRE1TTywgeSA9IGxvZ19vYnNleHBfQTQ4NSwgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icy9leHApLCBub1wiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpIFxuXG50ZW1wIDwtIG9ic2V4cCAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3AudXAkaWQpXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzZXhwX0RNU08sIHRlbXAkbG9nX29ic2V4cF9BNDg1LCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzQgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic2V4cF9ETVNPLCB5ID0gbG9nX29ic2V4cF9BNDg1LCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzL2V4cCksIHVwXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwib2JzZXhwX0E0ODVfdnNfRE1TT1wiKVxuaGVpZ2h0IDwtIDRcbndpZHRoIDwtIDEyXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIucG5nXCIpKSwgcmVzID0gNjAwLCB1bml0ID0gXCJpblwiLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwbG90X2dyaWQoZzEsIGc0LCBnMywgZzIsIG5jb2wgPSA0KSlcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocGxvdF9ncmlkKGcxLCBnNCwgZzMsIGcyLCBuY29sID0gNCkpXG5kZXYub2ZmKClcblxuXG4jIFN0cnVjdHVyYWxcbmxvb3Auc3RyIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfc3RydWN0dXJlLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG50ZW1wIDwtIG9ic2V4cCAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3Auc3RyJGlkKVxudGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic2V4cF9ETVNPLCB0ZW1wJGxvZ19vYnNleHBfQTQ4NSwgbiA9IDEwMClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmc1IDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNleHBfRE1TTywgeSA9IGxvZ19vYnNleHBfQTQ4NSwgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icy9leHApLCBzdHJ1Y3R1cmFsIGxvb3BzXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cbiMgUmVnIChQRS1QRSlcbmxvb3AucmVnIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGUuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5yZWckaWQpXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzZXhwX0RNU08sIHRlbXAkbG9nX29ic2V4cF9BNDg1LCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzYgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic2V4cF9ETVNPLCB5ID0gbG9nX29ic2V4cF9BNDg1LCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzL2V4cCksIHJlZ3VsYXRvcnkgbG9vcHNcIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwib2JzZXhwX0E0ODVfdnNfRE1TT19zdHJfdnNfcmVnXCIpXG5oZWlnaHQgPC0gNFxud2lkdGggPC0gNlxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocGxvdF9ncmlkKGc1LCBnNiwgbmNvbCA9IDIpKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwbG90X2dyaWQoZzUsIGc2LCBuY29sID0gMikpXG5kZXYub2ZmKClcbmBgYCJ9 -->

```r
# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

minValue <- -4
maxValue <- 5

obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))


# A485
obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_A485, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)
```r
# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))

minValue <- -4
maxValue <- 5

obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))


# A485
obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_A485, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs/exp)
A485 per res

<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubWluVmFsdWUgPC0gLTRcbm1heFZhbHVlIDwtIDEwXG5vYnNleHAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcImxvb3BTY29yZV9jb25zX29ic2V4cC50c3ZcIikpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0RNU08pKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZFRBRyA9IGlmX2Vsc2Uob2JzZXhwX2RUQUcgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX2RUQUcpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfQTQ4NSA9IGlmX2Vsc2Uob2JzZXhwX0E0ODUgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0E0ODUpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNfRE1TTyA9IGlmX2Vsc2Uob2JzX0RNU08gPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzX0RNU08pKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNfZFRBRyA9IGlmX2Vsc2Uob2JzX2RUQUcgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzX2RUQUcpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNfQTQ4NSA9IGlmX2Vsc2Uob2JzX0E0ODUgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzX0E0ODUpKSlcblxuIyBJbXBvcnRpbmcgbG9vcHNcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfQTQ4NXZzRE1TT19OT19kaWZmMC4yLmJlZHBlXCIpKSAlPiUgXG4gIGRwbHlyOjptdXRhdGUoYmluU2l6ZSA9IFYzIC0gVjIsXG4gICAgICAgICAgICAgICAgaWQgPSBwYXN0ZShWMSwgYmluU2l6ZSwgVjIsIFY1LCBzZXAgPSBcIl9cIikpXG5cblxuXG4jIGRUQUdcbm9ic2V4cCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KG9ic2V4cCRsb2dfb2JzX0RNU08sIG9ic2V4cCRsb2dfb2JzX0E0ODUsIG4gPSAxMDApXG5vYnNleHAgPC0gb2JzZXhwICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzEgPC0gZ2dwbG90KG9ic2V4cCwgYWVzKHggPSBsb2dfb2JzX0RNU08sIHkgPSBsb2dfb2JzX0E0ODUsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMpXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cbiMgVmlzdWFsaXplIFVQIERPV04gbG9vcHNcbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5kb3duJGlkKVxudGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic19ETVNPLCB0ZW1wJGxvZ19vYnNfQTQ4NSwgbiA9IDEwMClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmcyIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNfRE1TTywgeSA9IGxvZ19vYnNfQTQ4NSwgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icyksIGRvd25cIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxuXG50ZW1wIDwtIG9ic2V4cCAlPiUgZHBseXI6OmZpbHRlcihpZCAlaW4lIGxvb3Aubm8kaWQpXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzX0RNU08sIHRlbXAkbG9nX29ic19BNDg1LCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzMgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic19ETVNPLCB5ID0gbG9nX29ic19BNDg1LCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzKSwgbm9cIikpICtcbiAgICBjb29yZF9maXhlZCh4bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpLCB5bGltID0gYyhtaW5WYWx1ZSwgbWF4VmFsdWUpKSBcblxudGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLnVwJGlkKVxudGVtcCRkZW5zaXR5IDwtIGdldF9kZW5zaXR5KHRlbXAkbG9nX29ic19ETVNPLCB0ZW1wJGxvZ19vYnNfQTQ4NSwgbiA9IDEwMClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6OmFycmFuZ2UoZGVuc2l0eSlcbmc0IDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGxvZ19vYnNfRE1TTywgeSA9IGxvZ19vYnNfQTQ4NSwgY29sb3IgPSBkZW5zaXR5KSkgKyBcbiAgZ2VvbV9wb2ludCgpICsgdGhlbWVfYncoKSArIHNjYWxlX2NvbG9yX3ZpcmlkaXMoZ3VpZGUgPSBcIm5vbmVcIikgK1xuICBnZW9tX2FibGluZShzbG9wZSA9IDEsIGludGVyY2VwdCA9IDApICtcbiAgZ2d0aXRsZShwYXN0ZTAoXCJsb2cyKG9icyksIHVwXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cblxuZmlsZU5hbWUgPC0gcGFzdGUwKFwib2JzZXhwX0E0ODVfdnNfRE1TT19vYnNcIilcbmhlaWdodCA8LSA0XG53aWR0aCA8LSAxMlxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocGxvdF9ncmlkKGcxLCBnNCwgZzMsIGcyLCBuY29sID0gNCkpXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHBsb3RfZ3JpZChnMSwgZzQsIGczLCBnMiwgbmNvbCA9IDQpKVxuZGV2Lm9mZigpXG5cblxuIyBTdHJ1Y3R1cmFsXG5sb29wLnN0ciA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXCJjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3N0cnVjdHVyZS5iZWRwZVwiKSkgJT4lIFxuICBkcGx5cjo6bXV0YXRlKGJpblNpemUgPSBWMyAtIFYyLFxuICAgICAgICAgICAgICAgIGlkID0gcGFzdGUoVjEsIGJpblNpemUsIFYyLCBWNSwgc2VwID0gXCJfXCIpKVxudGVtcCA8LSBvYnNleHAgJT4lIGRwbHlyOjpmaWx0ZXIoaWQgJWluJSBsb29wLnN0ciRpZClcbnRlbXAkZGVuc2l0eSA8LSBnZXRfZGVuc2l0eSh0ZW1wJGxvZ19vYnNfRE1TTywgdGVtcCRsb2dfb2JzX0E0ODUsIG4gPSAxMDApXG50ZW1wIDwtIHRlbXAgJT4lIGRwbHlyOjphcnJhbmdlKGRlbnNpdHkpXG5nNSA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBsb2dfb2JzX0RNU08sIHkgPSBsb2dfb2JzX0E0ODUsIGNvbG9yID0gZGVuc2l0eSkpICsgXG4gIGdlb21fcG9pbnQoKSArIHRoZW1lX2J3KCkgKyBzY2FsZV9jb2xvcl92aXJpZGlzKGd1aWRlID0gXCJub25lXCIpICtcbiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAxLCBpbnRlcmNlcHQgPSAwKSArXG4gIGdndGl0bGUocGFzdGUwKFwibG9nMihvYnMpLCBzdHJ1Y3R1cmFsIGxvb3BzXCIpKSArXG4gICAgY29vcmRfZml4ZWQoeGxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSwgeWxpbSA9IGMobWluVmFsdWUsIG1heFZhbHVlKSkgXG5cbiMgUmVnIChQRS1QRSlcbmxvb3AucmVnIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGUuYmVkcGVcIikpICU+JSBcbiAgZHBseXI6Om11dGF0ZShiaW5TaXplID0gVjMgLSBWMixcbiAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBiaW5TaXplLCBWMiwgVjUsIHNlcCA9IFwiX1wiKSlcbnRlbXAgPC0gb2JzZXhwICU+JSBkcGx5cjo6ZmlsdGVyKGlkICVpbiUgbG9vcC5yZWckaWQpXG50ZW1wJGRlbnNpdHkgPC0gZ2V0X2RlbnNpdHkodGVtcCRsb2dfb2JzX0RNU08sIHRlbXAkbG9nX29ic19BNDg1LCBuID0gMTAwKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6YXJyYW5nZShkZW5zaXR5KVxuZzYgPC0gZ2dwbG90KHRlbXAsIGFlcyh4ID0gbG9nX29ic19ETVNPLCB5ID0gbG9nX29ic19BNDg1LCBjb2xvciA9IGRlbnNpdHkpKSArIFxuICBnZW9tX3BvaW50KCkgKyB0aGVtZV9idygpICsgc2NhbGVfY29sb3JfdmlyaWRpcyhndWlkZSA9IFwibm9uZVwiKSArXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCkgK1xuICBnZ3RpdGxlKHBhc3RlMChcImxvZzIob2JzKSwgcmVndWxhdG9yeSBsb29wc1wiKSkgK1xuICAgIGNvb3JkX2ZpeGVkKHhsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSksIHlsaW0gPSBjKG1pblZhbHVlLCBtYXhWYWx1ZSkpIFxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJvYnNleHBfQTQ4NV92c19ETVNPX29ic19zdHJfdnNfcmVnXCIpXG5oZWlnaHQgPC0gNFxud2lkdGggPC0gNlxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocGxvdF9ncmlkKGc1LCBnNiwgbmNvbCA9IDIpKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwbG90X2dyaWQoZzUsIGc2LCBuY29sID0gMikpXG5kZXYub2ZmKClcbmBgYCJ9 -->

```r
minValue <- -4
maxValue <- 10
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                  log_obs_DMSO = if_else(obs_DMSO == 0, minValue, log2(obs_DMSO)),
                  log_obs_dTAG = if_else(obs_dTAG == 0, minValue, log2(obs_dTAG)),
                  log_obs_A485 = if_else(obs_A485 == 0, minValue, log2(obs_A485)))

# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))



# dTAG
obsexp$density <- get_density(obsexp$log_obs_DMSO, obsexp$log_obs_A485, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obs_DMSO, y = log_obs_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs)
```r
minValue <- -4
maxValue <- 10
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                  log_obs_DMSO = if_else(obs_DMSO == 0, minValue, log2(obs_DMSO)),
                  log_obs_dTAG = if_else(obs_dTAG == 0, minValue, log2(obs_dTAG)),
                  log_obs_A485 = if_else(obs_A485 == 0, minValue, log2(obs_A485)))

# Importing loops
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_A485vsDMSO_NO_diff0.2.bedpe\)) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = \_\))



# dTAG
obsexp$density <- get_density(obsexp$log_obs_DMSO, obsexp$log_obs_A485, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obs_DMSO, y = log_obs_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs)\)) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = \none\) +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0(\log2(obs)
A485 all res

<!-- rnb-source-begin {"data":"```r\ncreate_dist_vs_avgScore_perTreatment_oe <- function(data, figDir, name, loopList, colorList, se = FALSE){\n  avg_scores_long <- data %>%\n    group_by(distance, Anno2) %>%\n    summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n    ungroup() \n  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + \n    geom_smooth(show.legend = TRUE, se = se)  +\n    #ylim(0, 0.5) +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = colorList) +\n    scale_fill_manual(values = colorList) +\n    labs(title = paste0(name),\n         x = \"Distance\",\n         y = \"Average Score\") +\n    theme(plot.title = element_text(size = 8))\n  \n  fileName <- paste0(\"dist_vs_score_linePlot_\", name)\n  png(here(figDir, paste0(fileName, \".png\")), \n      res = 600, units = \"in\", width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")), \n          width = 4, height = 3)\n  print(p4)\n  dev.off()\n} \n\ncreate_dist_vs_avgDiffScore_perTreatment_oe <- function(data, figDir, name, loopList, colorList, se = FALSE){\n  avg_scores_long <- data %>%\n    group_by(distance, Anno2) %>%\n    summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n    ungroup() \n  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)\n  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + \n    geom_hline(yintercept = 0) +\n    geom_smooth(show.legend = TRUE, se = se)  +\n    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +\n    scale_color_manual(values = colorList) +\n    scale_fill_manual(values = colorList) +\n    labs(title = paste0(name),\n         x = \"Distance\",\n         y = \"Average Diff Score\") +\n    theme(plot.title = element_text(size = 8)) \n  \n  fileName <- paste0(\"dist_vs_score_difflinePlot_\", name)\n  png(here(figDir, paste0(fileName, \".png\")), \n      res = 600, units = \"in\", width = 4, height = 3)\n  print(p4)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")), \n          width = 4, height = 3)\n  print(p4)\n  dev.off()\n} \n\ncreate_dist_barplot_oe <- function(data, figDir, name, note, loopList, diffCutoff, distanceFilter = 2*e6){\n    data <- data %>% \n    dplyr::mutate(distance = start2 - start1,\n                  updown_dTAG_DMSO = ifelse(log_obsexp_diff_dTAG_DMSO > diffCutoff, \"UP\", \n                                            ifelse(log_obsexp_diff_dTAG_DMSO > -diffCutoff, \"NO\", \"DOWN\")),\n                  updown_A485_DMSO = ifelse(log_obsexp_diff_A485_DMSO > diffCutoff, \"UP\", \n                                            ifelse(log_obsexp_diff_A485_DMSO > -diffCutoff, \"NO\", \"DOWN\"))) %>%\n    dplyr::filter(Anno2 %in% loopList,\n                  distance < distanceFilter)\n  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\"UP\", \"NO\", \"DOWN\"))\n  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\"UP\", \"NO\", \"DOWN\"))\n  \n  \n  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%\n    dplyr::filter(Anno2 %in% loopList,\n                  updown_dTAG_DMSO %in% c(\"UP\", \"NO\", \"DOWN\"))\n  p <- ggplot(temp, aes(x = updown_dTAG_DMSO, y = distance)) +\n    geom_violin(aes(fill = updown_dTAG_DMSO)) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = updown_dTAG_DMSO), fun = mean, geom = \"point\", shape = 21, size = 2, fill = \"red\", color = \"black\") +\n    theme_classic() + ggtitle(note) +\n    scale_y_continuous(labels = label_kb_mb)\n  fileName <- paste0(\"size_barplot_\", name, \"_dTAG_vs_DMSO_\", note, \"_\", diffCutoff)\n  height <- 3\n  width <- 4\n  png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\n  print(p)\n  dev.off()\n  \n  \n  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%\n    dplyr::filter(Anno2 %in% loopList,\n                  updown_A485_DMSO %in% c(\"UP\", \"NO\",  \"DOWN\"))\n  p <- ggplot(temp, aes(x = updown_A485_DMSO, y = distance)) +\n    geom_violin(aes(fill = updown_A485_DMSO)) + \n    geom_boxplot(width = 0.1, outlier.shape = NA) +\n    stat_summary(aes(group = updown_A485_DMSO), fun = mean, geom = \"point\", shape = 21, size = 2, fill = \"red\", color = \"black\") +\n    theme_classic() + ggtitle(note) +\n    scale_y_continuous(labels = label_kb_mb)\n  fileName <- paste0(\"size_barplot_\", name, \"_A485_vs_DMSO_\", note, \"_\", diffCutoff)\n  height <- 3\n  width <- 4\n  png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\ncreate_loop_scatterplot_oe <- function(data, figDir, name, Anno2List, diffCutoff){\n  data <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(log_obsexp_diff_dTAG_DMSO > diffCutoff, \"UP\", \n                                            ifelse(log_obsexp_diff_dTAG_DMSO > -diffCutoff, \"NO\", \"DOWN\")),\n                  updown_A485_DMSO = ifelse(log_obsexp_diff_A485_DMSO > diffCutoff, \"UP\", \n                                            ifelse(log_obsexp_diff_A485_DMSO > -diffCutoff, \"NO\", \"DOWN\"))) %>%\n    dplyr::filter(Anno2 %in% Anno2List)\n  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\"UP\", \"NO\", \"DOWN\"))\n  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\"UP\", \"NO\", \"DOWN\"))\n  \n  num.up <- (summary(data$updown_dTAG_DMSO))[\"UP\"]\n  num.no <- (summary(data$updown_dTAG_DMSO))[\"NO\"]\n  num.down <- (summary(data$updown_dTAG_DMSO))[\"DOWN\"]\n  num.all <- num.up + num.no + num.down\n  perc.up <- round(num.up / num.all * 100, 2)\n  perc.no <- round(num.no / num.all * 100, 2)\n  perc.down <- round(num.down / num.all * 100, 2)\n  \n  ### Scatterplot\n    minValue <- -4\n  maxValue <- 5\n  data$density <- get_density(data$log_obsexp_DMSO, data$log_obsexp_dTAG, n = 100)\n  data <- data %>% dplyr::arrange(density)\n  correlation <- cor(data$log_obsexp_DMSO, data$log_obsexp_dTAG)\n  p1 <- ggplot(data, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) +\n    geom_point(show.legend = FALSE) + \n    scale_color_viridis() +\n    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) +\n    geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n    annotate(\"text\", x = minValue, y = maxValue, label = paste0(\"UP: \", num.up, \" (\", perc.up, \"%)\"), \n             color = \"black\", hjust = 0, size = 3) +\n    annotate(\"text\", x = minValue, y = maxValue-1, label = paste0(\"NO: \", num.no, \" (\", perc.no, \"%)\"), \n             color = \"black\", hjust = 0, size = 3) +\n    annotate(\"text\", x = minValue, y = maxValue-2, label = paste0(\"DOWN: \", num.down, \" (\", perc.down, \"%)\"), \n             color = \"black\", hjust = 0, size = 3) +\n    theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5)) +\n    annotate(\"text\", x = minValue, y = maxValue, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n  \n  \n  num.up <- (summary(data$updown_A485_DMSO))[\"UP\"]\n  num.no <- (summary(data$updown_A485_DMSO))[\"NO\"]\n  num.down <- (summary(data$updown_A485_DMSO))[\"DOWN\"]\n  num.all <- num.up + num.no + num.down\n  perc.up <- round(num.up / num.all * 100, 2)\n  perc.no <- round(num.no / num.all * 100, 2)\n  perc.down <- round(num.down / num.all * 100, 2)\n  \n  data$density <- get_density(data$log_obsexp_DMSO, data$log_obsexp_A485, n = 100)\n  data <- data %>% dplyr::arrange(density)\n  correlation <- cor(data$log_obsexp_DMSO, data$log_obsexp_A485)\n  p2 <- ggplot(data, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) +\n    geom_point(show.legend = FALSE) + \n    scale_color_viridis() +\n    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) +\n    geom_abline(slope = 1, intercept = 0, col = \"grey50\", linetype = \"dashed\") +\n    geom_abline(slope = 1, intercept = -diffCutoff, col = \"grey\", linetype = \"dotted\") +\n    geom_abline(slope = 1, intercept = diffCutoff, col = \"grey\", linetype = \"dotted\") +\n    geom_hline(yintercept = 0, alpha = 0.5, color = \"grey\") +\n    geom_vline(xintercept = 0, alpha = 0.5, color = \"grey\") +\n    annotate(\"text\", x = minValue, y = maxValue, label = paste0(\"UP: \", num.up, \" (\", perc.up, \"%)\"), \n             color = \"black\", hjust = 0, size = 3) +\n    annotate(\"text\", x = minValue, y = maxValue-1, label = paste0(\"NO: \", num.no, \" (\", perc.no, \"%)\"), \n             color = \"black\", hjust = 0, size = 3) +\n    annotate(\"text\", x = minValue, y = maxValue-2, label = paste0(\"DOWN: \", num.down, \" (\", perc.down, \"%)\"), \n             color = \"black\", hjust = 0, size = 3) +\n    theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5)) +\n    annotate(\"text\", x = minValue, y = maxValue, label = paste(\"r =\", round(correlation, 2)), size = 5, color = \"black\")\n\n  \n  \n  fileName <- paste0(\"scatterplot_\", name, \"_\", diffCutoff)\n  png(here(figDir, paste0(fileName, \".png\")), res = 600, units = \"in\", width = 5*1.5, height = 2.5*1.5)\n  print(cowplot::plot_grid(p1, p2, align = \"h\"))\n  dev.off()\n  \n  svglite(here(figDir, paste0(fileName, \".svg\")), \n          width = 5*1.5, height = 2.5*1.5)\n  print(cowplot::plot_grid(p1, p2, align = \"h\"))\n  dev.off()\n}\n\nmake_diff_bedpe_oe <- function(data, name, Anno2List, outDir, diffCutoff){\n  data <- data %>%\n    dplyr::mutate(updown_dTAG_DMSO = ifelse(log_obsexp_diff_dTAG_DMSO > diffCutoff, \"UP\", \n                                            ifelse(log_obsexp_diff_dTAG_DMSO > -diffCutoff, \"NO\", \"DOWN\")),\n                  updown_A485_DMSO = ifelse(log_obsexp_diff_A485_DMSO > diffCutoff, \"UP\", \n                                            ifelse(log_obsexp_diff_A485_DMSO > -diffCutoff, \"NO\", \"DOWN\"))) %>%\n    dplyr::filter(Anno2 %in% Anno2List)\n  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\"UP\", \"NO\", \"DOWN\"))\n  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\"UP\", \"NO\", \"DOWN\"))\n  \n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \"UP\") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \"_dTAGvsDMSO_UP_diff\", diffCutoff, \".bedpe\")), \n         sep = \"\\t\", col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \"NO\") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \"_dTAGvsDMSO_NO_diff\", diffCutoff, \".bedpe\")), \n         sep = \"\\t\", col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \"DOWN\") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \"_dTAGvsDMSO_DOWN_diff\", diffCutoff, \".bedpe\")), \n         sep = \"\\t\", col.names = FALSE)\n  \n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \"UP\") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \"_A485vsDMSO_UP_diff\", diffCutoff, \".bedpe\")), \n         sep = \"\\t\", col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \"NO\") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \"_A485vsDMSO_NO_diff\", diffCutoff, \".bedpe\")), \n         sep = \"\\t\", col.names = FALSE)\n  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \"DOWN\") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))\n  fwrite(out.temp, here(outDir, paste0(name, \"_A485vsDMSO_DOWN_diff\", diffCutoff, \".bedpe\")), \n         sep = \"\\t\", col.names = FALSE)\n}\n```"} -->

```r
create_dist_vs_avgScore_perTreatment_oe <- function(data, figDir, name, loopList, colorList, se = FALSE){
  avg_scores_long <- data %>%
    group_by(distance, Anno2) %>%
    summarise(avg_score = mean(score, na.rm = TRUE)) %>%
    ungroup() 
  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + 
    geom_smooth(show.legend = TRUE, se = se)  +
    #ylim(0, 0.5) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = colorList) +
    scale_fill_manual(values = colorList) +
    labs(title = paste0(name),
         x = \Distance\,
         y = \Average Score\) +
    theme(plot.title = element_text(size = 8))
  
  fileName <- paste0(\dist_vs_score_linePlot_\, name)
  png(here(figDir, paste0(fileName, \.png\)), 
      res = 600, units = \in\, width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 4, height = 3)
  print(p4)
  dev.off()
} 

create_dist_vs_avgDiffScore_perTreatment_oe <- function(data, figDir, name, loopList, colorList, se = FALSE){
  avg_scores_long <- data %>%
    group_by(distance, Anno2) %>%
    summarise(avg_score = mean(score, na.rm = TRUE)) %>%
    ungroup() 
  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + 
    geom_hline(yintercept = 0) +
    geom_smooth(show.legend = TRUE, se = se)  +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = colorList) +
    scale_fill_manual(values = colorList) +
    labs(title = paste0(name),
         x = \Distance\,
         y = \Average Diff Score\) +
    theme(plot.title = element_text(size = 8)) 
  
  fileName <- paste0(\dist_vs_score_difflinePlot_\, name)
  png(here(figDir, paste0(fileName, \.png\)), 
      res = 600, units = \in\, width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 4, height = 3)
  print(p4)
  dev.off()
} 

create_dist_barplot_oe <- function(data, figDir, name, note, loopList, diffCutoff, distanceFilter = 2*e6){
    data <- data %>% 
    dplyr::mutate(distance = start2 - start1,
                  updown_dTAG_DMSO = ifelse(log_obsexp_diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(log_obsexp_diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(log_obsexp_diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(log_obsexp_diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\))) %>%
    dplyr::filter(Anno2 %in% loopList,
                  distance < distanceFilter)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  
  
  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%
    dplyr::filter(Anno2 %in% loopList,
                  updown_dTAG_DMSO %in% c(\UP\, \NO\, \DOWN\))
  p <- ggplot(temp, aes(x = updown_dTAG_DMSO, y = distance)) +
    geom_violin(aes(fill = updown_dTAG_DMSO)) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = updown_dTAG_DMSO), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + ggtitle(note) +
    scale_y_continuous(labels = label_kb_mb)
  fileName <- paste0(\size_barplot_\, name, \_dTAG_vs_DMSO_\, note, \_\, diffCutoff)
  height <- 3
  width <- 4
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
  
  
  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%
    dplyr::filter(Anno2 %in% loopList,
                  updown_A485_DMSO %in% c(\UP\, \NO\,  \DOWN\))
  p <- ggplot(temp, aes(x = updown_A485_DMSO, y = distance)) +
    geom_violin(aes(fill = updown_A485_DMSO)) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = updown_A485_DMSO), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + ggtitle(note) +
    scale_y_continuous(labels = label_kb_mb)
  fileName <- paste0(\size_barplot_\, name, \_A485_vs_DMSO_\, note, \_\, diffCutoff)
  height <- 3
  width <- 4
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

create_loop_scatterplot_oe <- function(data, figDir, name, Anno2List, diffCutoff){
  data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(log_obsexp_diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(log_obsexp_diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(log_obsexp_diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(log_obsexp_diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\))) %>%
    dplyr::filter(Anno2 %in% Anno2List)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  
  num.up <- (summary(data$updown_dTAG_DMSO))[\UP\]
  num.no <- (summary(data$updown_dTAG_DMSO))[\NO\]
  num.down <- (summary(data$updown_dTAG_DMSO))[\DOWN\]
  num.all <- num.up + num.no + num.down
  perc.up <- round(num.up / num.all * 100, 2)
  perc.no <- round(num.no / num.all * 100, 2)
  perc.down <- round(num.down / num.all * 100, 2)
  
  ### Scatterplot
    minValue <- -4
  maxValue <- 5
  data$density <- get_density(data$log_obsexp_DMSO, data$log_obsexp_dTAG, n = 100)
  data <- data %>% dplyr::arrange(density)
  correlation <- cor(data$log_obsexp_DMSO, data$log_obsexp_dTAG)
  p1 <- ggplot(data, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) +
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
    annotate(\text\, x = minValue, y = maxValue, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
             color = \black\, hjust = 0, size = 3) +
    annotate(\text\, x = minValue, y = maxValue-1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
             color = \black\, hjust = 0, size = 3) +
    annotate(\text\, x = minValue, y = maxValue-2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
             color = \black\, hjust = 0, size = 3) +
    theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5)) +
    annotate(\text\, x = minValue, y = maxValue, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

  
  
  num.up <- (summary(data$updown_A485_DMSO))[\UP\]
  num.no <- (summary(data$updown_A485_DMSO))[\NO\]
  num.down <- (summary(data$updown_A485_DMSO))[\DOWN\]
  num.all <- num.up + num.no + num.down
  perc.up <- round(num.up / num.all * 100, 2)
  perc.no <- round(num.no / num.all * 100, 2)
  perc.down <- round(num.down / num.all * 100, 2)
  
  data$density <- get_density(data$log_obsexp_DMSO, data$log_obsexp_A485, n = 100)
  data <- data %>% dplyr::arrange(density)
  correlation <- cor(data$log_obsexp_DMSO, data$log_obsexp_A485)
  p2 <- ggplot(data, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) +
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
    annotate(\text\, x = minValue, y = maxValue, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
             color = \black\, hjust = 0, size = 3) +
    annotate(\text\, x = minValue, y = maxValue-1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
             color = \black\, hjust = 0, size = 3) +
    annotate(\text\, x = minValue, y = maxValue-2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
             color = \black\, hjust = 0, size = 3) +
    theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5)) +
    annotate(\text\, x = minValue, y = maxValue, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

  
  
  fileName <- paste0(\scatterplot_\, name, \_\, diffCutoff)
  png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 5*1.5, height = 2.5*1.5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
  
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 5*1.5, height = 2.5*1.5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
}

make_diff_bedpe_oe <- function(data, name, Anno2List, outDir, diffCutoff){
  data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(log_obsexp_diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(log_obsexp_diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(log_obsexp_diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(log_obsexp_diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\))) %>%
    dplyr::filter(Anno2 %in% Anno2List)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \UP\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_dTAGvsDMSO_UP_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \NO\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_dTAGvsDMSO_NO_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \DOWN\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_dTAGvsDMSO_DOWN_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \UP\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_A485vsDMSO_UP_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \NO\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_A485vsDMSO_NO_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \DOWN\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_A485vsDMSO_DOWN_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
}
```

<!-- rnb-source-end -->
```r
create_dist_vs_avgScore_perTreatment_oe <- function(data, figDir, name, loopList, colorList, se = FALSE){
  avg_scores_long <- data %>%
    group_by(distance, Anno2) %>%
    summarise(avg_score = mean(score, na.rm = TRUE)) %>%
    ungroup() 
  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + 
    geom_smooth(show.legend = TRUE, se = se)  +
    #ylim(0, 0.5) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = colorList) +
    scale_fill_manual(values = colorList) +
    labs(title = paste0(name),
         x = \Distance\,
         y = \Average Score\) +
    theme(plot.title = element_text(size = 8))
  
  fileName <- paste0(\dist_vs_score_linePlot_\, name)
  png(here(figDir, paste0(fileName, \.png\)), 
      res = 600, units = \in\, width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 4, height = 3)
  print(p4)
  dev.off()
} 

create_dist_vs_avgDiffScore_perTreatment_oe <- function(data, figDir, name, loopList, colorList, se = FALSE){
  avg_scores_long <- data %>%
    group_by(distance, Anno2) %>%
    summarise(avg_score = mean(score, na.rm = TRUE)) %>%
    ungroup() 
  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + 
    geom_hline(yintercept = 0) +
    geom_smooth(show.legend = TRUE, se = se)  +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = colorList) +
    scale_fill_manual(values = colorList) +
    labs(title = paste0(name),
         x = \Distance\,
         y = \Average Diff Score\) +
    theme(plot.title = element_text(size = 8)) 
  
  fileName <- paste0(\dist_vs_score_difflinePlot_\, name)
  png(here(figDir, paste0(fileName, \.png\)), 
      res = 600, units = \in\, width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 4, height = 3)
  print(p4)
  dev.off()
} 

create_dist_barplot_oe <- function(data, figDir, name, note, loopList, diffCutoff, distanceFilter = 2*e6){
    data <- data %>% 
    dplyr::mutate(distance = start2 - start1,
                  updown_dTAG_DMSO = ifelse(log_obsexp_diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(log_obsexp_diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(log_obsexp_diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(log_obsexp_diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\))) %>%
    dplyr::filter(Anno2 %in% loopList,
                  distance < distanceFilter)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  
  
  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%
    dplyr::filter(Anno2 %in% loopList,
                  updown_dTAG_DMSO %in% c(\UP\, \NO\, \DOWN\))
  p <- ggplot(temp, aes(x = updown_dTAG_DMSO, y = distance)) +
    geom_violin(aes(fill = updown_dTAG_DMSO)) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = updown_dTAG_DMSO), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + ggtitle(note) +
    scale_y_continuous(labels = label_kb_mb)
  fileName <- paste0(\size_barplot_\, name, \_dTAG_vs_DMSO_\, note, \_\, diffCutoff)
  height <- 3
  width <- 4
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
  
  
  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%
    dplyr::filter(Anno2 %in% loopList,
                  updown_A485_DMSO %in% c(\UP\, \NO\,  \DOWN\))
  p <- ggplot(temp, aes(x = updown_A485_DMSO, y = distance)) +
    geom_violin(aes(fill = updown_A485_DMSO)) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = updown_A485_DMSO), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
    theme_classic() + ggtitle(note) +
    scale_y_continuous(labels = label_kb_mb)
  fileName <- paste0(\size_barplot_\, name, \_A485_vs_DMSO_\, note, \_\, diffCutoff)
  height <- 3
  width <- 4
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

create_loop_scatterplot_oe <- function(data, figDir, name, Anno2List, diffCutoff){
  data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(log_obsexp_diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(log_obsexp_diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(log_obsexp_diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(log_obsexp_diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\))) %>%
    dplyr::filter(Anno2 %in% Anno2List)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  
  num.up <- (summary(data$updown_dTAG_DMSO))[\UP\]
  num.no <- (summary(data$updown_dTAG_DMSO))[\NO\]
  num.down <- (summary(data$updown_dTAG_DMSO))[\DOWN\]
  num.all <- num.up + num.no + num.down
  perc.up <- round(num.up / num.all * 100, 2)
  perc.no <- round(num.no / num.all * 100, 2)
  perc.down <- round(num.down / num.all * 100, 2)
  
  ### Scatterplot
    minValue <- -4
  maxValue <- 5
  data$density <- get_density(data$log_obsexp_DMSO, data$log_obsexp_dTAG, n = 100)
  data <- data %>% dplyr::arrange(density)
  correlation <- cor(data$log_obsexp_DMSO, data$log_obsexp_dTAG)
  p1 <- ggplot(data, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) +
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
    annotate(\text\, x = minValue, y = maxValue, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
             color = \black\, hjust = 0, size = 3) +
    annotate(\text\, x = minValue, y = maxValue-1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
             color = \black\, hjust = 0, size = 3) +
    annotate(\text\, x = minValue, y = maxValue-2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
             color = \black\, hjust = 0, size = 3) +
    theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5)) +
    annotate(\text\, x = minValue, y = maxValue, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

  
  
  num.up <- (summary(data$updown_A485_DMSO))[\UP\]
  num.no <- (summary(data$updown_A485_DMSO))[\NO\]
  num.down <- (summary(data$updown_A485_DMSO))[\DOWN\]
  num.all <- num.up + num.no + num.down
  perc.up <- round(num.up / num.all * 100, 2)
  perc.no <- round(num.no / num.all * 100, 2)
  perc.down <- round(num.down / num.all * 100, 2)
  
  data$density <- get_density(data$log_obsexp_DMSO, data$log_obsexp_A485, n = 100)
  data <- data %>% dplyr::arrange(density)
  correlation <- cor(data$log_obsexp_DMSO, data$log_obsexp_A485)
  p2 <- ggplot(data, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) +
    geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
    geom_abline(slope = 1, intercept = -diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_abline(slope = 1, intercept = diffCutoff, col = \grey\, linetype = \dotted\) +
    geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
    geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
    annotate(\text\, x = minValue, y = maxValue, label = paste0(\UP: \, num.up, \ (\, perc.up, \%)\), 
             color = \black\, hjust = 0, size = 3) +
    annotate(\text\, x = minValue, y = maxValue-1, label = paste0(\NO: \, num.no, \ (\, perc.no, \%)\), 
             color = \black\, hjust = 0, size = 3) +
    annotate(\text\, x = minValue, y = maxValue-2, label = paste0(\DOWN: \, num.down, \ (\, perc.down, \%)\), 
             color = \black\, hjust = 0, size = 3) +
    theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5)) +
    annotate(\text\, x = minValue, y = maxValue, label = paste(\r =\, round(correlation, 2)), size = 5, color = \black\)

  
  
  fileName <- paste0(\scatterplot_\, name, \_\, diffCutoff)
  png(here(figDir, paste0(fileName, \.png\)), res = 600, units = \in\, width = 5*1.5, height = 2.5*1.5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
  
  svglite(here(figDir, paste0(fileName, \.svg\)), 
          width = 5*1.5, height = 2.5*1.5)
  print(cowplot::plot_grid(p1, p2, align = \h\))
  dev.off()
}

make_diff_bedpe_oe <- function(data, name, Anno2List, outDir, diffCutoff){
  data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(log_obsexp_diff_dTAG_DMSO > diffCutoff, \UP\, 
                                            ifelse(log_obsexp_diff_dTAG_DMSO > -diffCutoff, \NO\, \DOWN\)),
                  updown_A485_DMSO = ifelse(log_obsexp_diff_A485_DMSO > diffCutoff, \UP\, 
                                            ifelse(log_obsexp_diff_A485_DMSO > -diffCutoff, \NO\, \DOWN\))) %>%
    dplyr::filter(Anno2 %in% Anno2List)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c(\UP\, \NO\, \DOWN\))
  
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \UP\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_dTAGvsDMSO_UP_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \NO\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_dTAGvsDMSO_NO_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == \DOWN\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_dTAGvsDMSO_DOWN_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \UP\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_A485vsDMSO_UP_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \NO\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_A485vsDMSO_NO_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == \DOWN\) %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, \_A485vsDMSO_DOWN_diff\, diffCutoff, \.bedpe\)), 
         sep = \\t\, col.names = FALSE)
}

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

###### Plotting Obs

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJKYlhCdmNuUWdZVzV1YjNSaGRHbHZibHh1Ym1GdFpTQThMU0JjSW1Ob2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxjSWx4dVpHRjBZU0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lMblJ6ZGx3aUtTa3BYRzVjYmlNZ1NXMXdiM0owSUc5aWN5OWxlSEFnYzJOdmNtVnpJR0Z1WkNCdFpYSm5aU0IwYnlCMGFHVWdaR0YwWVhObGRGeHViV2x1Vm1Gc2RXVWdQQzBnTFRSY2JtOWljMlY0Y0NBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0Z3aWJHOXZjRk5qYjNKbFgyTnZibk5mYjJKelpYaHdMblJ6ZGx3aUtTa3BJQ1UrSlZ4dUlDQWdJR1J3YkhseU9qcHRkWFJoZEdVb2JHOW5YMjlpYzJWNGNGOUVUVk5QSUQwZ2FXWmZaV3h6WlNodlluTmxlSEJmUkUxVFR5QTlQU0F3TENCdGFXNVdZV3gxWlN3Z2JHOW5NaWh2WW5ObGVIQmZSRTFUVHlrcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiRzluWDI5aWMyVjRjRjlrVkVGSElEMGdhV1pmWld4elpTaHZZbk5sZUhCZlpGUkJSeUE5UFNBd0xDQnRhVzVXWVd4MVpTd2diRzluTWlodlluTmxlSEJmWkZSQlJ5a3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYkc5blgyOWljMlY0Y0Y5Qk5EZzFJRDBnYVdaZlpXeHpaU2h2WW5ObGVIQmZRVFE0TlNBOVBTQXdMQ0J0YVc1V1lXeDFaU3dnYkc5bk1paHZZbk5sZUhCZlFUUTROU2twS1Z4dVhHNGpJRTFsY21kbElHUmhkR0Z6WlhSY2JtUmhkR0VnUEMwZ1pHRjBZU0FsUGlVZ1pIQnNlWEk2T214bFpuUmZhbTlwYmlodlluTmxlSEFzSUdKNUlEMGdZeWhjSW1sa1hDSXBLVnh1WEc0aklGQnNiM1JjYm5SbGJYQWdQQzBnWkdGMFlTQWxQaVVnWkhCc2VYSTZPbTExZEdGMFpTaGthWE4wWVc1alpTQTlJSE4wWVhKME1pQXRJSE4wWVhKME1Ta2dKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aR2x6ZEdGdVkyVXNJR3h2WjE5dlluTmxlSEJmUkUxVFR5d2dRVzV1YnpJcFhHNWpiMnh1WVcxbGN5aDBaVzF3S1NBOExTQmpLRndpWkdsemRHRnVZMlZjSWl3Z1hDSnpZMjl5WlZ3aUxDQmNJa0Z1Ym04eVhDSXBYRzVqY21WaGRHVmZaR2x6ZEY5MmMxOWhkbWRUWTI5eVpWOXdaWEpVY21WaGRHMWxiblJmYjJVb2RHVnRjQ3dnWm1sblJHbHlMQ0J3WVhOMFpUQW9ibUZ0WlN3Z1hDSmZSRTFUVDE5c2IyZFBSVndpS1N3Z2RXNXBjWFZsS0dSaGRHRWtRVzV1YnpJcExDQmpiMnh2Y2t4cGMzUk1iMjl3S1Z4dVhHNTBaVzF3SUR3dElHUmhkR0VnSlQ0bElHUndiSGx5T2pwdGRYUmhkR1VvWkdsemRHRnVZMlVnUFNCemRHRnlkRElnTFNCemRHRnlkREVwSUNVK0pTQmtjR3g1Y2pvNmMyVnNaV04wS0dScGMzUmhibU5sTENCc2IyZGZiMkp6Wlhod1gyUlVRVWNzSUVGdWJtOHlLVnh1WTI5c2JtRnRaWE1vZEdWdGNDa2dQQzBnWXloY0ltUnBjM1JoYm1ObFhDSXNJRndpYzJOdmNtVmNJaXdnWENKQmJtNXZNbHdpS1Z4dVkzSmxZWFJsWDJScGMzUmZkbk5mWVhablUyTnZjbVZmY0dWeVZISmxZWFJ0Wlc1MFgyOWxLSFJsYlhBc0lHWnBaMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRndpWDJSVVFVZGZiRzluVDBWY0lpa3NJSFZ1YVhGMVpTaGtZWFJoSkVGdWJtOHlLU3dnWTI5c2IzSk1hWE4wVEc5dmNDbGNibHh1WEc0aklFTnlaV0YwYVc1bklHWnBaM1Z5WlhNZ2NHVnlJR1ZoWTJnZ1kyOXVaR2wwYVc5dUxDQmthV1ptWlhKbGJuUnBZV3hjYm5SbGJYQWdQQzBnWkdGMFlTQWxQaVVnWkhCc2VYSTZPbTExZEdGMFpTaGthWE4wWVc1alpTQTlJSE4wWVhKME1pQXRJSE4wWVhKME1TeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCc2IyZGZiMkp6Wlhod1gyUnBabVpmWkZSQlIxOUVUVk5QSUQwZ2JHOW5YMjlpYzJWNGNGOWtWRUZISUMwZ2JHOW5YMjlpYzJWNGNGOUVUVk5QS1NBbFBpVWdYRzRnSUdSd2JIbHlPanB6Wld4bFkzUW9aR2x6ZEdGdVkyVXNJR3h2WjE5dlluTmxlSEJmWkdsbVpsOWtWRUZIWDBSTlUwOHNJRUZ1Ym04eUtWeHVZMjlzYm1GdFpYTW9kR1Z0Y0NrZ1BDMGdZeWhjSW1ScGMzUmhibU5sWENJc0lGd2ljMk52Y21WY0lpd2dYQ0pCYm01dk1sd2lLVnh1WTNKbFlYUmxYMlJwYzNSZmRuTmZZWFpuUkdsbVpsTmpiM0psWDNCbGNsUnlaV0YwYldWdWRGOXZaU2gwWlcxd0xDQm1hV2RFYVhJc0lIQmhjM1JsTUNodVlXMWxMQ0JjSWw5a1ZFRkhYMnh2WjA5RlhDSXBMQ0IxYm1seGRXVW9aR0YwWVNSQmJtNXZNaWtzSUdOdmJHOXlUR2x6ZEV4dmIzQXBYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbiMgSW1wb3J0IGFubm90YXRpb25cbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5XFxcbmRhdGEgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpKVxuXG4jIEltcG9ydCBvYnMvZXhwIHNjb3JlcyBhbmQgbWVyZ2UgdG8gdGhlIGRhdGFzZXRcbm1pblZhbHVlIDwtIC00XG5vYnNleHAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9jb25zX29ic2V4cC50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0RNU08pKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZFRBRyA9IGlmX2Vsc2Uob2JzZXhwX2RUQUcgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX2RUQUcpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfQTQ4NSA9IGlmX2Vsc2Uob2JzZXhwX0E0ODUgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0E0ODUpKSlcblxuIyBNZXJnZSBkYXRhc2V0XG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4ob2JzZXhwLCBieSA9IGMoXFxpZFxcKSlcblxuIyBQbG90XG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBsb2dfb2JzZXhwX0RNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50X29lKHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0RNU09fbG9nT0VcXCksIHVuaXF1ZShkYXRhJEFubm8yKSwgY29sb3JMaXN0TG9vcClcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgbG9nX29ic2V4cF9kVEFHLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudF9vZSh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHX2xvZ09FXFwpLCB1bmlxdWUoZGF0YSRBbm5vMiksIGNvbG9yTGlzdExvb3ApXG5cblxuIyBDcmVhdGluZyBmaWd1cmVzIHBlciBlYWNoIGNvbmRpdGlvbiwgZGlmZmVyZW50aWFsXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX2RUQUdfRE1TTyA9IGxvZ19vYnNleHBfZFRBRyAtIGxvZ19vYnNleHBfRE1TTykgJT4lIFxuICBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnRfb2UodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfZFRBR19sb2dPRVxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpLCBjb2xvckxpc3RMb29wKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
# Import annotation
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\))

# Plot
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obsexp_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, \_DMSO_logOE\), unique(data$Anno2), colorListLoop)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obsexp_dTAG, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, \_dTAG_logOE\), unique(data$Anno2), colorListLoop)


# Creating figures per each condition, differential
temp <- data %>% dplyr::mutate(distance = start2 - start1,
                               log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO) %>% 
  dplyr::select(distance, log_obsexp_diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment_oe(temp, figDir, paste0(name, \_dTAG_logOE\), unique(data$Anno2), colorListLoop)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QkpiWEJ2Y25RZ1lXNXViM1JoZEdsdmJseHVibUZ0WlNBOExTQmNYR05vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGNYRnh1WkdGMFlTQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y0xuUnpkbHhjS1NrcFhHNWNiaU1nU1cxd2IzSjBJRzlpY3k5bGVIQWdjMk52Y21WeklHRnVaQ0J0WlhKblpTQjBieUIwYUdVZ1pHRjBZWE5sZEZ4dWJXbHVWbUZzZFdVZ1BDMGdMVFJjYm05aWMyVjRjQ0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRnhjYkc5dmNGTmpiM0psWDJOdmJuTmZiMkp6Wlhod0xuUnpkbHhjS1NrcElDVStKVnh1SUNBZ0lHUndiSGx5T2pwdGRYUmhkR1VvYkc5blgyOWljMlY0Y0Y5RVRWTlBJRDBnYVdaZlpXeHpaU2h2WW5ObGVIQmZSRTFUVHlBOVBTQXdMQ0J0YVc1V1lXeDFaU3dnYkc5bk1paHZZbk5sZUhCZlJFMVRUeWtwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JHOW5YMjlpYzJWNGNGOWtWRUZISUQwZ2FXWmZaV3h6WlNodlluTmxlSEJmWkZSQlJ5QTlQU0F3TENCdGFXNVdZV3gxWlN3Z2JHOW5NaWh2WW5ObGVIQmZaRlJCUnlrcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiRzluWDI5aWMyVjRjRjlCTkRnMUlEMGdhV1pmWld4elpTaHZZbk5sZUhCZlFUUTROU0E5UFNBd0xDQnRhVzVXWVd4MVpTd2diRzluTWlodlluTmxlSEJmUVRRNE5Ta3BLVnh1WEc0aklFMWxjbWRsSUdSaGRHRnpaWFJjYm1SaGRHRWdQQzBnWkdGMFlTQWxQaVVnWkhCc2VYSTZPbXhsWm5SZmFtOXBiaWh2WW5ObGVIQXNJR0o1SUQwZ1l5aGNYR2xrWEZ3cEtWeHVYRzRqSUZCc2IzUmNiblJsYlhBZ1BDMGdaR0YwWVNBbFBpVWdaSEJzZVhJNk9tMTFkR0YwWlNoa2FYTjBZVzVqWlNBOUlITjBZWEowTWlBdElITjBZWEowTVNrZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1pHbHpkR0Z1WTJVc0lHeHZaMTl2WW5ObGVIQmZSRTFUVHl3Z1FXNXVieklwWEc1amIyeHVZVzFsY3loMFpXMXdLU0E4TFNCaktGeGNaR2x6ZEdGdVkyVmNYQ3dnWEZ4elkyOXlaVnhjTENCY1hFRnVibTh5WEZ3cFhHNWpjbVZoZEdWZlpHbHpkRjkyYzE5aGRtZFRZMjl5WlY5d1pYSlVjbVZoZEcxbGJuUmZiMlVvZEdWdGNDd2dabWxuUkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWEZ4ZlJFMVRUMTlzYjJkUFJWeGNLU3dnZFc1cGNYVmxLR1JoZEdFa1FXNXVieklwTENCamIyeHZja3hwYzNSTWIyOXdLVnh1WEc1MFpXMXdJRHd0SUdSaGRHRWdKVDRsSUdSd2JIbHlPanB0ZFhSaGRHVW9aR2x6ZEdGdVkyVWdQU0J6ZEdGeWRESWdMU0J6ZEdGeWRERXBJQ1UrSlNCa2NHeDVjam82YzJWc1pXTjBLR1JwYzNSaGJtTmxMQ0JzYjJkZmIySnpaWGh3WDJSVVFVY3NJRUZ1Ym04eUtWeHVZMjlzYm1GdFpYTW9kR1Z0Y0NrZ1BDMGdZeWhjWEdScGMzUmhibU5sWEZ3c0lGeGNjMk52Y21WY1hDd2dYRnhCYm01dk1seGNLVnh1WTNKbFlYUmxYMlJwYzNSZmRuTmZZWFpuVTJOdmNtVmZjR1Z5VkhKbFlYUnRaVzUwWDI5bEtIUmxiWEFzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGeGNYMlJVUVVkZmJHOW5UMFZjWENrc0lIVnVhWEYxWlNoa1lYUmhKRUZ1Ym04eUtTd2dZMjlzYjNKTWFYTjBURzl2Y0NsY2JseHVYRzRqSUVOeVpXRjBhVzVuSUdacFozVnlaWE1nY0dWeUlHVmhZMmdnWTI5dVpHbDBhVzl1TENCa2FXWm1aWEpsYm5ScFlXeGNiblJsYlhBZ1BDMGdaR0YwWVNBbFBpVWdaSEJzZVhJNk9tMTFkR0YwWlNoa2FYTjBZVzVqWlNBOUlITjBZWEowTWlBdElITjBZWEowTVN4Y2JpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JzYjJkZmIySnpaWGh3WDJScFptWmZaRlJCUjE5RVRWTlBJRDBnYkc5blgyOWljMlY0Y0Y5a1ZFRkhJQzBnYkc5blgyOWljMlY0Y0Y5RVRWTlBLU0FsUGlVZ1hHNGdJR1J3YkhseU9qcHpaV3hsWTNRb1pHbHpkR0Z1WTJVc0lHeHZaMTl2WW5ObGVIQmZaR2xtWmw5a1ZFRkhYMFJOVTA4c0lFRnVibTh5S1Z4dVkyOXNibUZ0WlhNb2RHVnRjQ2tnUEMwZ1l5aGNYR1JwYzNSaGJtTmxYRndzSUZ4Y2MyTnZjbVZjWEN3Z1hGeEJibTV2TWx4Y0tWeHVZM0psWVhSbFgyUnBjM1JmZG5OZllYWm5SR2xtWmxOamIzSmxYM0JsY2xSeVpXRjBiV1Z1ZEY5dlpTaDBaVzF3TENCbWFXZEVhWElzSUhCaGMzUmxNQ2h1WVcxbExDQmNYRjlrVkVGSFgyeHZaMDlGWEZ3cExDQjFibWx4ZFdVb1pHRjBZU1JCYm01dk1pa3NJR052Ykc5eVRHbHpkRXh2YjNBcFhHNWdZR0JjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbmBgYHJcbiMgSW1wb3J0IGFubm90YXRpb25cbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5XFxcbmRhdGEgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpKVxuXG4jIEltcG9ydCBvYnMvZXhwIHNjb3JlcyBhbmQgbWVyZ2UgdG8gdGhlIGRhdGFzZXRcbm1pblZhbHVlIDwtIC00XG5vYnNleHAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXGxvb3BTY29yZV9jb25zX29ic2V4cC50c3ZcXCkpKSAlPiVcbiAgICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfRE1TTyA9IGlmX2Vsc2Uob2JzZXhwX0RNU08gPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0RNU08pKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZFRBRyA9IGlmX2Vsc2Uob2JzZXhwX2RUQUcgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX2RUQUcpKSxcbiAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfQTQ4NSA9IGlmX2Vsc2Uob2JzZXhwX0E0ODUgPT0gMCwgbWluVmFsdWUsIGxvZzIob2JzZXhwX0E0ODUpKSlcblxuIyBNZXJnZSBkYXRhc2V0XG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4ob2JzZXhwLCBieSA9IGMoXFxpZFxcKSlcblxuIyBQbG90XG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBsb2dfb2JzZXhwX0RNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50X29lKHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0RNU09fbG9nT0VcXCksIHVuaXF1ZShkYXRhJEFubm8yKSwgY29sb3JMaXN0TG9vcClcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgbG9nX29ic2V4cF9kVEFHLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudF9vZSh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHX2xvZ09FXFwpLCB1bmlxdWUoZGF0YSRBbm5vMiksIGNvbG9yTGlzdExvb3ApXG5cblxuIyBDcmVhdGluZyBmaWd1cmVzIHBlciBlYWNoIGNvbmRpdGlvbiwgZGlmZmVyZW50aWFsXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX2RUQUdfRE1TTyA9IGxvZ19vYnNleHBfZFRBRyAtIGxvZ19vYnNleHBfRE1TTykgJT4lIFxuICBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnRfb2UodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfZFRBR19sb2dPRVxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpLCBjb2xvckxpc3RMb29wKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBJbXBvcnQgYW5ub3RhdGlvblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUobG9nX29ic2V4cF9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfRE1TTykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kVEFHID0gaWZfZWxzZShvYnNleHBfZFRBRyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfZFRBRykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9BNDg1ID0gaWZfZWxzZShvYnNleHBfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQTQ4NSkpKVxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcXGlkXFwpKVxuXG4jIFBsb3RcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGxvZ19vYnNleHBfRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdTY29yZV9wZXJUcmVhdG1lbnRfb2UodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfRE1TT19sb2dPRVxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpLCBjb2xvckxpc3RMb29wKVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBsb2dfb2JzZXhwX2RUQUcsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50X29lKHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdfbG9nT0VcXCksIHVuaXF1ZShkYXRhJEFubm8yKSwgY29sb3JMaXN0TG9vcClcblxuXG4jIENyZWF0aW5nIGZpZ3VyZXMgcGVyIGVhY2ggY29uZGl0aW9uLCBkaWZmZXJlbnRpYWxcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPID0gbG9nX29ic2V4cF9kVEFHIC0gbG9nX29ic2V4cF9ETVNPKSAlPiUgXG4gIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08sIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnRGlmZlNjb3JlX3BlclRyZWF0bWVudF9vZSh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHX2xvZ09FXFwpLCB1bmlxdWUoZGF0YSRBbm5vMiksIGNvbG9yTGlzdExvb3ApXG5gYGBcbmBgYCJ9 -->

```r
```r
# Import annotation
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\))

# Plot
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obsexp_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, \_DMSO_logOE\), unique(data$Anno2), colorListLoop)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obsexp_dTAG, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, \_dTAG_logOE\), unique(data$Anno2), colorListLoop)


# Creating figures per each condition, differential
temp <- data %>% dplyr::mutate(distance = start2 - start1,
                               log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO) %>% 
  dplyr::select(distance, log_obsexp_diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment_oe(temp, figDir, paste0(name, \_dTAG_logOE\), unique(data$Anno2), colorListLoop)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [2.26] Repeating few analysis with obs/exp
#### Function

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBJbXBvcnQgYW5ub3RhdGlvblxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFwiLnRzdlwiKSkpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFwibG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlwiKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUobG9nX29ic2V4cF9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfRE1TTykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kVEFHID0gaWZfZWxzZShvYnNleHBfZFRBRyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfZFRBRykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9BNDg1ID0gaWZfZWxzZShvYnNleHBfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQTQ4NSkpKVxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcImlkXCIpKVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX2RUQUdfRE1TTyA9IGxvZ19vYnNleHBfZFRBRyAtIGxvZ19vYnNleHBfRE1TTykgJT4lIFxuICBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXCJkaXN0YW5jZVwiLCBcInNjb3JlXCIsIFwiQW5ubzJcIilcblxuXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShBbm5vMyA9IGNhc2Vfd2hlbihBbm5vMiAlaW4lIGMoXCJTLVhcIiwgXCJTLVNcIikgfiBcIlN0cnVjdHVyYWxcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBBbm5vMiAlaW4lIGMoXCJQLVBcIiwgXCJQLUVcIiwgXCJFLUVcIikgfiBcIlB1cmVfUmVndWxhdG9yeVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEFubm8yICVpbiUgYyhcIlAtU1wiLCBcIlAtWFwiLCBcIkUtU1wiLCBcIkUtWFwiKSB+IFwiUmVsYXhlZF9SZWd1bGF0b3J5XCIpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoQW5ubzMpKVxuXG5sb29wTGlzdCA8LSByZXYoYyhcIlN0cnVjdHVyYWxcIiwgXCJSZWxheGVkX1JlZ3VsYXRvcnlcIiwgXCJQdXJlX1JlZ3VsYXRvcnlcIikpXG5jb2xvckxpc3QgPC0gcmV2KGMocGFsZXR0ZV8zW1tcImdyZXkyXCJdXSwgc3Ryb25nX2dyZWVuLCBkYXJrZW4oc3Ryb25nX2dyZWVuLCBhbW91bnQgPSAwLjUpKSlcbmF2Z19zY29yZXNfbG9uZyA8LSB0ZW1wICU+JVxuICBncm91cF9ieShkaXN0YW5jZSwgQW5ubzMpICU+JVxuICBzdW1tYXJpc2UoYXZnX3Njb3JlID0gbWVhbihzY29yZSwgbmEucm0gPSBUUlVFKSkgJT4lXG4gIHVuZ3JvdXAoKSBcbmF2Z19zY29yZXNfbG9uZyRBbm5vMyA8LSBmYWN0b3IoYXZnX3Njb3Jlc19sb25nJEFubm8zLCBsZXZlbCA9IGxvb3BMaXN0KVxuXG5wNCA8LSBnZ3Bsb3QoYXZnX3Njb3Jlc19sb25nLCBhZXMoeCA9IGRpc3RhbmNlLCB5ID0gYXZnX3Njb3JlLCBjb2xvciA9IEFubm8zKSkgKyBcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCxcbiAgICAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIixcbiAgICAgICAgICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgICAgICAgICBsaW5lZW5kID0gXCJzcXVhcmVcIikgK1xuICBnZW9tX3Ntb290aChzaG93LmxlZ2VuZCA9IFRSVUUsIHNlID0gVFJVRSxcbiAgICAgICAgICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICAgICAgICAgIGxpbmVlbmQgPSBcInNxdWFyZVwiLFxuICAgICAgICAgICAgICBhZXMoZmlsbCA9IEFubm8zKSkgICtcbiAgdGhlbWVfY2xhc3NpYygpICsgXG4gIHNjYWxlX3hfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgK1xuICBzY2FsZV9jb2xvcl9tYW51YWwodmFsdWVzID0gY29sb3JMaXN0KSArXG4gIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGNvbG9yTGlzdCkgK1xuICBsYWJzKHggPSBcIkxvb3Agc2l6ZVwiLFxuICAgICAgIHkgPSBcIs6UIGxvZzIob2JzL2V4cClcIixcbiAgICAgICBjb2xvciA9IFwiTG9vcCB0eXBlc1wiLCBmaWxsID0gXCJMb29wIHR5cGVzXCIpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCIsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcInNxdWFyZVwiXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFwidHJhbnNwYXJlbnRcIiksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKSArXG4gIGd1aWRlcyhcbiAgICBjb2xvciA9IGd1aWRlX2xlZ2VuZChcbiAgICAgIGtleXdpZHRoID0gMC41LCAgIyBBZGp1c3QgdGhlIHdpZHRoIG9mIHRoZSBsZWdlbmQgY29sb3Igc3F1YXJlc1xuICAgICAga2V5aGVpZ2h0ID0gMC41ICAjIEFkanVzdCB0aGUgaGVpZ2h0IG9mIHRoZSBsZWdlbmQgY29sb3Igc3F1YXJlc1xuICAgIClcbiAgKVxuXG5cblxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcImRpc3RfdnNfc2NvcmVfZGlmZmxpbmVQbG90X2dyb3VwZWRcIiwgbmFtZSlcblxud2lkdGggPC0gcGFuZWxTaXplKDIuNSkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS4yNSkqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCBcbiAgICByZXMgPSA2MDAsIHVuaXRzID0gXCJpblwiLCB3aWR0aCA9IHdpZHRoLCBoZWlnaHQgPSBoZWlnaHQpXG5wcmludChwNClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCBcbiAgICAgICAgd2lkdGggPSB3aWR0aCwgaGVpZ2h0ID0gaGVpZ2h0KVxucHJpbnQocDQpXG5kZXYub2ZmKClcblxuXG5cbmBgYCJ9 -->\n\n```r\n# Import annotation\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\n\n# Import obs/exp scores and merge to the dataset\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))\n\n# Merge dataset\ndata <- data %>% dplyr::left_join(obsexp, by = c(\\id\\))\n\ntemp <- data %>% dplyr::mutate(distance = start2 - start1,\n                               log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO) %>% \n  dplyr::select(distance, log_obsexp_diff_dTAG_DMSO, Anno2)\ncolnames(temp) <- c(\\distance\\, \\score\\, \\Anno2\\)\n\n\n\ntemp <- temp %>% dplyr::mutate(Anno3 = case_when(Anno2 %in% c(\\S-X\\, \\S-S\\) ~ \\Structural\\,\n                                                 Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\) ~ \\Pure_Regulatory\\,\n                                                 Anno2 %in% c(\\P-S\\, \\P-X\\, \\E-S\\, \\E-X\\) ~ \\Relaxed_Regulatory\\)) %>%\n  dplyr::filter(!is.na(Anno3))\n\nloopList <- rev(c(\\Structural\\, \\Relaxed_Regulatory\\, \\Pure_Regulatory\\))\ncolorList <- rev(c(palette_3[[\\grey2\\]], strong_green, darken(strong_green, amount = 0.5)))\navg_scores_long <- temp %>%\n  group_by(distance, Anno3) %>%\n  summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n  ungroup() \navg_scores_long$Anno3 <- factor(avg_scores_long$Anno3, level = loopList)\n\np4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno3)) + \n  geom_hline(yintercept = 0,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_smooth(show.legend = TRUE, se = TRUE,\n              size = lineThick*mmToLineUnit,\n              lineend = \\square\\,\n              aes(fill = Anno3))  +\n  theme_classic() + \n  scale_x_continuous(labels = label_kb_mb) +\n  scale_color_manual(values = colorList) +\n  scale_fill_manual(values = colorList) +\n  labs(x = \\Loop size\\,\n       y = \\Δ log2(obs/exp)\\,\n       color = \\Loop types\\, fill = \\Loop types\\) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +\n  guides(\n    color = guide_legend(\n      keywidth = 0.5,  # Adjust the width of the legend color squares\n      keyheight = 0.5  # Adjust the height of the legend color squares\n    )\n  )\n\n\n\n\n\nfileName <- paste0(\\dist_vs_score_difflinePlot_grouped\\, name)\n\nwidth <- panelSize(2.5)*mmToInch\nheight <- panelSize(1.25)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), \n    res = 600, units = \\in\\, width = width, height = height)\nprint(p4)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)), \n        width = width, height = height)\nprint(p4)\ndev.off()\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
# Import annotation
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\))

temp <- data %>% dplyr::mutate(distance = start2 - start1,
                               log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO) %>% 
  dplyr::select(distance, log_obsexp_diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)



temp <- temp %>% dplyr::mutate(Anno3 = case_when(Anno2 %in% c(\S-X\, \S-S\) ~ \Structural\,
                                                 Anno2 %in% c(\P-P\, \P-E\, \E-E\) ~ \Pure_Regulatory\,
                                                 Anno2 %in% c(\P-S\, \P-X\, \E-S\, \E-X\) ~ \Relaxed_Regulatory\)) %>%
  dplyr::filter(!is.na(Anno3))

loopList <- rev(c(\Structural\, \Relaxed_Regulatory\, \Pure_Regulatory\))
colorList <- rev(c(palette_3[[\grey2\]], strong_green, darken(strong_green, amount = 0.5)))
avg_scores_long <- temp %>%
  group_by(distance, Anno3) %>%
  summarise(avg_score = mean(score, na.rm = TRUE)) %>%
  ungroup() 
avg_scores_long$Anno3 <- factor(avg_scores_long$Anno3, level = loopList)

p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno3)) + 
  geom_hline(yintercept = 0,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) +
  geom_smooth(show.legend = TRUE, se = TRUE,
              size = lineThick*mmToLineUnit,
              lineend = \square\,
              aes(fill = Anno3))  +
  theme_classic() + 
  scale_x_continuous(labels = label_kb_mb) +
  scale_color_manual(values = colorList) +
  scale_fill_manual(values = colorList) +
  labs(x = \Loop size\,
       y = \Δ log2(obs/exp)\,
       color = \Loop types\, fill = \Loop types\) +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +
  guides(
    color = guide_legend(
      keywidth = 0.5,  # Adjust the width of the legend color squares
      keyheight = 0.5  # Adjust the height of the legend color squares
    )
  )





fileName <- paste0(\dist_vs_score_difflinePlot_grouped\, name)

width <- panelSize(2.5)*mmToInch
height <- panelSize(1.25)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), 
    res = 600, units = \in\, width = width, height = height)
print(p4)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)), 
        width = width, height = height)
print(p4)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBJbXBvcnQgYW5ub3RhdGlvblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUobG9nX29ic2V4cF9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfRE1TTykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kVEFHID0gaWZfZWxzZShvYnNleHBfZFRBRyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfZFRBRykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9BNDg1ID0gaWZfZWxzZShvYnNleHBfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQTQ4NSkpKVxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcXGlkXFwpKVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX2RUQUdfRE1TTyA9IGxvZ19vYnNleHBfZFRBRyAtIGxvZ19vYnNleHBfRE1TTykgJT4lIFxuICBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcblxuXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShBbm5vMyA9IGNhc2Vfd2hlbihBbm5vMiAlaW4lIGMoXFxTLVhcXCwgXFxTLVNcXCkgfiBcXFN0cnVjdHVyYWxcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBBbm5vMiAlaW4lIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCkgfiBcXFB1cmVfUmVndWxhdG9yeVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEFubm8yICVpbiUgYyhcXFAtU1xcLCBcXFAtWFxcLCBcXEUtU1xcLCBcXEUtWFxcKSB+IFxcUmVsYXhlZF9SZWd1bGF0b3J5XFwpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoQW5ubzMpKVxuXG5sb29wTGlzdCA8LSByZXYoYyhcXFN0cnVjdHVyYWxcXCwgXFxSZWxheGVkX1JlZ3VsYXRvcnlcXCwgXFxQdXJlX1JlZ3VsYXRvcnlcXCkpXG5jb2xvckxpc3QgPC0gcmV2KGMocGFsZXR0ZV8zW1tcXGdyZXkyXFxdXSwgc3Ryb25nX2dyZWVuLCBkYXJrZW4oc3Ryb25nX2dyZWVuLCBhbW91bnQgPSAwLjUpKSlcbmF2Z19zY29yZXNfbG9uZyA8LSB0ZW1wICU+JVxuICBncm91cF9ieShkaXN0YW5jZSwgQW5ubzMpICU+JVxuICBzdW1tYXJpc2UoYXZnX3Njb3JlID0gbWVhbihzY29yZSwgbmEucm0gPSBUUlVFKSkgJT4lXG4gIHVuZ3JvdXAoKSBcbmF2Z19zY29yZXNfbG9uZyRBbm5vMyA8LSBmYWN0b3IoYXZnX3Njb3Jlc19sb25nJEFubm8zLCBsZXZlbCA9IGxvb3BMaXN0KVxuXG5wNCA8LSBnZ3Bsb3QoYXZnX3Njb3Jlc19sb25nLCBhZXMoeCA9IGRpc3RhbmNlLCB5ID0gYXZnX3Njb3JlLCBjb2xvciA9IEFubm8zKSkgKyBcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCxcbiAgICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCxcbiAgICAgICAgICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgICAgICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXCkgK1xuICBnZW9tX3Ntb290aChzaG93LmxlZ2VuZCA9IFRSVUUsIHNlID0gVFJVRSxcbiAgICAgICAgICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICAgICAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcLFxuICAgICAgICAgICAgICBhZXMoZmlsbCA9IEFubm8zKSkgICtcbiAgdGhlbWVfY2xhc3NpYygpICsgXG4gIHNjYWxlX3hfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgK1xuICBzY2FsZV9jb2xvcl9tYW51YWwodmFsdWVzID0gY29sb3JMaXN0KSArXG4gIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGNvbG9yTGlzdCkgK1xuICBsYWJzKHggPSBcXExvb3Agc2l6ZVxcLFxuICAgICAgIHkgPSBcXM6UIGxvZzIob2JzL2V4cClcXCxcbiAgICAgICBjb2xvciA9IFxcTG9vcCB0eXBlc1xcLCBmaWxsID0gXFxMb29wIHR5cGVzXFwpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKSArXG4gIGd1aWRlcyhcbiAgICBjb2xvciA9IGd1aWRlX2xlZ2VuZChcbiAgICAgIGtleXdpZHRoID0gMC41LCAgIyBBZGp1c3QgdGhlIHdpZHRoIG9mIHRoZSBsZWdlbmQgY29sb3Igc3F1YXJlc1xuICAgICAga2V5aGVpZ2h0ID0gMC41ICAjIEFkanVzdCB0aGUgaGVpZ2h0IG9mIHRoZSBsZWdlbmQgY29sb3Igc3F1YXJlc1xuICAgIClcbiAgKVxuXG5cblxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGRpc3RfdnNfc2NvcmVfZGlmZmxpbmVQbG90X2dyb3VwZWRcXCwgbmFtZSlcblxud2lkdGggPC0gcGFuZWxTaXplKDIuNSkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS4yNSkqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCBcbiAgICByZXMgPSA2MDAsIHVuaXRzID0gXFxpblxcLCB3aWR0aCA9IHdpZHRoLCBoZWlnaHQgPSBoZWlnaHQpXG5wcmludChwNClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCBcbiAgICAgICAgd2lkdGggPSB3aWR0aCwgaGVpZ2h0ID0gaGVpZ2h0KVxucHJpbnQocDQpXG5kZXYub2ZmKClcblxuXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\n# Import annotation\nname <- \\chromo_cons_annoHierarchy\\\ndata <- fread(here(consensusDir, paste0(name, \\.tsv\\)))\n\n# Import obs/exp scores and merge to the dataset\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))\n\n# Merge dataset\ndata <- data %>% dplyr::left_join(obsexp, by = c(\\id\\))\n\ntemp <- data %>% dplyr::mutate(distance = start2 - start1,\n                               log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO) %>% \n  dplyr::select(distance, log_obsexp_diff_dTAG_DMSO, Anno2)\ncolnames(temp) <- c(\\distance\\, \\score\\, \\Anno2\\)\n\n\n\ntemp <- temp %>% dplyr::mutate(Anno3 = case_when(Anno2 %in% c(\\S-X\\, \\S-S\\) ~ \\Structural\\,\n                                                 Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\) ~ \\Pure_Regulatory\\,\n                                                 Anno2 %in% c(\\P-S\\, \\P-X\\, \\E-S\\, \\E-X\\) ~ \\Relaxed_Regulatory\\)) %>%\n  dplyr::filter(!is.na(Anno3))\n\nloopList <- rev(c(\\Structural\\, \\Relaxed_Regulatory\\, \\Pure_Regulatory\\))\ncolorList <- rev(c(palette_3[[\\grey2\\]], strong_green, darken(strong_green, amount = 0.5)))\navg_scores_long <- temp %>%\n  group_by(distance, Anno3) %>%\n  summarise(avg_score = mean(score, na.rm = TRUE)) %>%\n  ungroup() \navg_scores_long$Anno3 <- factor(avg_scores_long$Anno3, level = loopList)\n\np4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno3)) + \n  geom_hline(yintercept = 0,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) +\n  geom_smooth(show.legend = TRUE, se = TRUE,\n              size = lineThick*mmToLineUnit,\n              lineend = \\square\\,\n              aes(fill = Anno3))  +\n  theme_classic() + \n  scale_x_continuous(labels = label_kb_mb) +\n  scale_color_manual(values = colorList) +\n  scale_fill_manual(values = colorList) +\n  labs(x = \\Loop size\\,\n       y = \\Δ log2(obs/exp)\\,\n       color = \\Loop types\\, fill = \\Loop types\\) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +\n  guides(\n    color = guide_legend(\n      keywidth = 0.5,  # Adjust the width of the legend color squares\n      keyheight = 0.5  # Adjust the height of the legend color squares\n    )\n  )\n\n\n\n\n\nfileName <- paste0(\\dist_vs_score_difflinePlot_grouped\\, name)\n\nwidth <- panelSize(2.5)*mmToInch\nheight <- panelSize(1.25)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), \n    res = 600, units = \\in\\, width = width, height = height)\nprint(p4)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)), \n        width = width, height = height)\nprint(p4)\ndev.off()\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBJbXBvcnQgYW5ub3RhdGlvblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUobG9nX29ic2V4cF9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfRE1TTykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kVEFHID0gaWZfZWxzZShvYnNleHBfZFRBRyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfZFRBRykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9BNDg1ID0gaWZfZWxzZShvYnNleHBfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQTQ4NSkpKVxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcXGlkXFwpKVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX2RUQUdfRE1TTyA9IGxvZ19vYnNleHBfZFRBRyAtIGxvZ19vYnNleHBfRE1TTykgJT4lIFxuICBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcblxuXG5cbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShBbm5vMyA9IGNhc2Vfd2hlbihBbm5vMiAlaW4lIGMoXFxTLVhcXCwgXFxTLVNcXCkgfiBcXFN0cnVjdHVyYWxcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBBbm5vMiAlaW4lIGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxFLUVcXCkgfiBcXFB1cmVfUmVndWxhdG9yeVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEFubm8yICVpbiUgYyhcXFAtU1xcLCBcXFAtWFxcLCBcXEUtU1xcLCBcXEUtWFxcKSB+IFxcUmVsYXhlZF9SZWd1bGF0b3J5XFwpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoQW5ubzMpKVxuXG5sb29wTGlzdCA8LSByZXYoYyhcXFN0cnVjdHVyYWxcXCwgXFxSZWxheGVkX1JlZ3VsYXRvcnlcXCwgXFxQdXJlX1JlZ3VsYXRvcnlcXCkpXG5jb2xvckxpc3QgPC0gcmV2KGMocGFsZXR0ZV8zW1tcXGdyZXkyXFxdXSwgc3Ryb25nX2dyZWVuLCBkYXJrZW4oc3Ryb25nX2dyZWVuLCBhbW91bnQgPSAwLjUpKSlcbmF2Z19zY29yZXNfbG9uZyA8LSB0ZW1wICU+JVxuICBncm91cF9ieShkaXN0YW5jZSwgQW5ubzMpICU+JVxuICBzdW1tYXJpc2UoYXZnX3Njb3JlID0gbWVhbihzY29yZSwgbmEucm0gPSBUUlVFKSkgJT4lXG4gIHVuZ3JvdXAoKSBcbmF2Z19zY29yZXNfbG9uZyRBbm5vMyA8LSBmYWN0b3IoYXZnX3Njb3Jlc19sb25nJEFubm8zLCBsZXZlbCA9IGxvb3BMaXN0KVxuXG5wNCA8LSBnZ3Bsb3QoYXZnX3Njb3Jlc19sb25nLCBhZXMoeCA9IGRpc3RhbmNlLCB5ID0gYXZnX3Njb3JlLCBjb2xvciA9IEFubm8zKSkgKyBcbiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMCxcbiAgICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCxcbiAgICAgICAgICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgICAgICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXCkgK1xuICBnZW9tX3Ntb290aChzaG93LmxlZ2VuZCA9IFRSVUUsIHNlID0gVFJVRSxcbiAgICAgICAgICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICAgICAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcLFxuICAgICAgICAgICAgICBhZXMoZmlsbCA9IEFubm8zKSkgICtcbiAgdGhlbWVfY2xhc3NpYygpICsgXG4gIHNjYWxlX3hfY29udGludW91cyhsYWJlbHMgPSBsYWJlbF9rYl9tYikgK1xuICBzY2FsZV9jb2xvcl9tYW51YWwodmFsdWVzID0gY29sb3JMaXN0KSArXG4gIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGNvbG9yTGlzdCkgK1xuICBsYWJzKHggPSBcXExvb3Agc2l6ZVxcLFxuICAgICAgIHkgPSBcXM6UIGxvZzIob2JzL2V4cClcXCxcbiAgICAgICBjb2xvciA9IFxcTG9vcCB0eXBlc1xcLCBmaWxsID0gXFxMb29wIHR5cGVzXFwpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKSArXG4gIGd1aWRlcyhcbiAgICBjb2xvciA9IGd1aWRlX2xlZ2VuZChcbiAgICAgIGtleXdpZHRoID0gMC41LCAgIyBBZGp1c3QgdGhlIHdpZHRoIG9mIHRoZSBsZWdlbmQgY29sb3Igc3F1YXJlc1xuICAgICAga2V5aGVpZ2h0ID0gMC41ICAjIEFkanVzdCB0aGUgaGVpZ2h0IG9mIHRoZSBsZWdlbmQgY29sb3Igc3F1YXJlc1xuICAgIClcbiAgKVxuXG5cblxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGRpc3RfdnNfc2NvcmVfZGlmZmxpbmVQbG90X2dyb3VwZWRcXCwgbmFtZSlcblxud2lkdGggPC0gcGFuZWxTaXplKDIuNSkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS4yNSkqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCBcbiAgICByZXMgPSA2MDAsIHVuaXRzID0gXFxpblxcLCB3aWR0aCA9IHdpZHRoLCBoZWlnaHQgPSBoZWlnaHQpXG5wcmludChwNClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCBcbiAgICAgICAgd2lkdGggPSB3aWR0aCwgaGVpZ2h0ID0gaGVpZ2h0KVxucHJpbnQocDQpXG5kZXYub2ZmKClcblxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
# Import annotation
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\))

temp <- data %>% dplyr::mutate(distance = start2 - start1,
                               log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO) %>% 
  dplyr::select(distance, log_obsexp_diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)



temp <- temp %>% dplyr::mutate(Anno3 = case_when(Anno2 %in% c(\S-X\, \S-S\) ~ \Structural\,
                                                 Anno2 %in% c(\P-P\, \P-E\, \E-E\) ~ \Pure_Regulatory\,
                                                 Anno2 %in% c(\P-S\, \P-X\, \E-S\, \E-X\) ~ \Relaxed_Regulatory\)) %>%
  dplyr::filter(!is.na(Anno3))

loopList <- rev(c(\Structural\, \Relaxed_Regulatory\, \Pure_Regulatory\))
colorList <- rev(c(palette_3[[\grey2\]], strong_green, darken(strong_green, amount = 0.5)))
avg_scores_long <- temp %>%
  group_by(distance, Anno3) %>%
  summarise(avg_score = mean(score, na.rm = TRUE)) %>%
  ungroup() 
avg_scores_long$Anno3 <- factor(avg_scores_long$Anno3, level = loopList)

p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno3)) + 
  geom_hline(yintercept = 0,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) +
  geom_smooth(show.legend = TRUE, se = TRUE,
              size = lineThick*mmToLineUnit,
              lineend = \square\,
              aes(fill = Anno3))  +
  theme_classic() + 
  scale_x_continuous(labels = label_kb_mb) +
  scale_color_manual(values = colorList) +
  scale_fill_manual(values = colorList) +
  labs(x = \Loop size\,
       y = \Δ log2(obs/exp)\,
       color = \Loop types\, fill = \Loop types\) +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +
  guides(
    color = guide_legend(
      keywidth = 0.5,  # Adjust the width of the legend color squares
      keyheight = 0.5  # Adjust the height of the legend color squares
    )
  )





fileName <- paste0(\dist_vs_score_difflinePlot_grouped\, name)

width <- panelSize(2.5)*mmToInch
height <- panelSize(1.25)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), 
    res = 600, units = \in\, width = width, height = height)
print(p4)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)), 
        width = width, height = height)
print(p4)
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Distance vs score plot
##### dTAG
###### OE

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJKYlhCdmNuUWdZVzV1YjNSaGRHbHZibHh1Ym1GdFpTQThMU0JjSW1Ob2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxjSWx4dVpHRjBZU0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lMblJ6ZGx3aUtTa3BYRzVjYmlNZ1NXMXdiM0owSUc5aWN5OWxlSEFnYzJOdmNtVnpJR0Z1WkNCdFpYSm5aU0IwYnlCMGFHVWdaR0YwWVhObGRGeHViV2x1Vm1Gc2RXVWdQQzBnTFRSY2JtOWljMlY0Y0NBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0Z3aWJHOXZjRk5qYjNKbFgyTnZibk5mYjJKelpYaHdMblJ6ZGx3aUtTa3BJQ1UrSlZ4dUlDQWdJR1J3YkhseU9qcHRkWFJoZEdVb2JHOW5YMjlpYzE5RVRWTlBJRDBnYVdaZlpXeHpaU2h2WW5OZlJFMVRUeUE5UFNBd0xDQnRhVzVXWVd4MVpTd2diRzluTWlodlluTmZSRTFUVHlrcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiRzluWDI5aWMxOWtWRUZISUQwZ2FXWmZaV3h6WlNodlluTmZaRlJCUnlBOVBTQXdMQ0J0YVc1V1lXeDFaU3dnYkc5bk1paHZZbk5mWkZSQlJ5a3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYkc5blgyOWljMTlCTkRnMUlEMGdhV1pmWld4elpTaHZZbk5mUVRRNE5TQTlQU0F3TENCdGFXNVdZV3gxWlN3Z2JHOW5NaWh2WW5OZlFUUTROU2twS1Z4dVhHNGpJRTFsY21kbElHUmhkR0Z6WlhSY2JtUmhkR0VnUEMwZ1pHRjBZU0FsUGlVZ1pIQnNlWEk2T214bFpuUmZhbTlwYmlodlluTmxlSEFzSUdKNUlEMGdZeWhjSW1sa1hDSXBLVnh1WEc0aklGQnNiM1JjYm5SbGJYQWdQQzBnWkdGMFlTQWxQaVVnWkhCc2VYSTZPbTExZEdGMFpTaGthWE4wWVc1alpTQTlJSE4wWVhKME1pQXRJSE4wWVhKME1Ta2dKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aR2x6ZEdGdVkyVXNJR3h2WjE5dlluTmZSRTFUVHl3Z1FXNXVieklwWEc1amIyeHVZVzFsY3loMFpXMXdLU0E4TFNCaktGd2laR2x6ZEdGdVkyVmNJaXdnWENKelkyOXlaVndpTENCY0lrRnVibTh5WENJcFhHNWpjbVZoZEdWZlpHbHpkRjkyYzE5aGRtZFRZMjl5WlY5d1pYSlVjbVZoZEcxbGJuUmZiMlVvZEdWdGNDd2dabWxuUkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWENKZlJFMVRUMTlzYjJkUFluTmNJaWtzSUhWdWFYRjFaU2hrWVhSaEpFRnVibTh5S1N3Z1kyOXNiM0pNYVhOMFRHOXZjQ2xjYmx4dWRHVnRjQ0E4TFNCa1lYUmhJQ1UrSlNCa2NHeDVjam82YlhWMFlYUmxLR1JwYzNSaGJtTmxJRDBnYzNSaGNuUXlJQzBnYzNSaGNuUXhLU0FsUGlVZ1pIQnNlWEk2T25ObGJHVmpkQ2hrYVhOMFlXNWpaU3dnYkc5blgyOWljMTlrVkVGSExDQkJibTV2TWlsY2JtTnZiRzVoYldWektIUmxiWEFwSUR3dElHTW9YQ0prYVhOMFlXNWpaVndpTENCY0luTmpiM0psWENJc0lGd2lRVzV1YnpKY0lpbGNibU55WldGMFpWOWthWE4wWDNaelgyRjJaMU5qYjNKbFgzQmxjbFJ5WldGMGJXVnVkRjl2WlNoMFpXMXdMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY0lsOWtWRUZIWDJ4dlowOWljMXdpS1N3Z2RXNXBjWFZsS0dSaGRHRWtRVzV1YnpJcExDQmpiMnh2Y2t4cGMzUk1iMjl3S1Z4dVhHNWNiaU1nUTNKbFlYUnBibWNnWm1sbmRYSmxjeUJ3WlhJZ1pXRmphQ0JqYjI1a2FYUnBiMjRzSUdScFptWmxjbVZ1ZEdsaGJGeHVkR1Z0Y0NBOExTQmtZWFJoSUNVK0pTQmtjR3g1Y2pvNmJYVjBZWFJsS0dScGMzUmhibU5sSUQwZ2MzUmhjblF5SUMwZ2MzUmhjblF4TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3h2WjE5dlluTmZaR2xtWmw5a1ZFRkhYMFJOVTA4Z1BTQnNiMmRmYjJKelgyUlVRVWNnTFNCc2IyZGZiMkp6WDBSTlUwOHBJQ1UrSlNCY2JpQWdaSEJzZVhJNk9uTmxiR1ZqZENoa2FYTjBZVzVqWlN3Z2JHOW5YMjlpYzE5a2FXWm1YMlJVUVVkZlJFMVRUeXdnUVc1dWJ6SXBYRzVqYjJ4dVlXMWxjeWgwWlcxd0tTQThMU0JqS0Z3aVpHbHpkR0Z1WTJWY0lpd2dYQ0p6WTI5eVpWd2lMQ0JjSWtGdWJtOHlYQ0lwWEc1amNtVmhkR1ZmWkdsemRGOTJjMTloZG1kRWFXWm1VMk52Y21WZmNHVnlWSEpsWVhSdFpXNTBYMjlsS0hSbGJYQXNJR1pwWjBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ3aVgyUlVRVWRmYkc5blQySnpYQ0lwTENCMWJtbHhkV1VvWkdGMFlTUkJibTV2TWlrc0lHTnZiRzl5VEdsemRFeHZiM0FwWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG4jIEltcG9ydCBhbm5vdGF0aW9uXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcblxuIyBJbXBvcnQgb2JzL2V4cCBzY29yZXMgYW5kIG1lcmdlIHRvIHRoZSBkYXRhc2V0XG5taW5WYWx1ZSA8LSAtNFxub2JzZXhwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfY29uc19vYnNleHAudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShsb2dfb2JzX0RNU08gPSBpZl9lbHNlKG9ic19ETVNPID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic19ETVNPKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzX2RUQUcgPSBpZl9lbHNlKG9ic19kVEFHID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic19kVEFHKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzX0E0ODUgPSBpZl9lbHNlKG9ic19BNDg1ID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic19BNDg1KSkpXG5cbiMgTWVyZ2UgZGF0YXNldFxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bGVmdF9qb2luKG9ic2V4cCwgYnkgPSBjKFxcaWRcXCkpXG5cbiMgUGxvdFxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgbG9nX29ic19ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudF9vZSh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9ETVNPX2xvZ09ic1xcKSwgdW5pcXVlKGRhdGEkQW5ubzIpLCBjb2xvckxpc3RMb29wKVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBsb2dfb2JzX2RUQUcsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50X29lKHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdfbG9nT2JzXFwpLCB1bmlxdWUoZGF0YSRBbm5vMiksIGNvbG9yTGlzdExvb3ApXG5cblxuIyBDcmVhdGluZyBmaWd1cmVzIHBlciBlYWNoIGNvbmRpdGlvbiwgZGlmZmVyZW50aWFsXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9nX29ic19kaWZmX2RUQUdfRE1TTyA9IGxvZ19vYnNfZFRBRyAtIGxvZ19vYnNfRE1TTykgJT4lIFxuICBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBsb2dfb2JzX2RpZmZfZFRBR19ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnRfb2UodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfZFRBR19sb2dPYnNcXCksIHVuaXF1ZShkYXRhJEFubm8yKSwgY29sb3JMaXN0TG9vcClcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
# Import annotation
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obs_DMSO = if_else(obs_DMSO == 0, minValue, log2(obs_DMSO)),
                  log_obs_dTAG = if_else(obs_dTAG == 0, minValue, log2(obs_dTAG)),
                  log_obs_A485 = if_else(obs_A485 == 0, minValue, log2(obs_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\))

# Plot
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obs_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, \_DMSO_logObs\), unique(data$Anno2), colorListLoop)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obs_dTAG, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, \_dTAG_logObs\), unique(data$Anno2), colorListLoop)


# Creating figures per each condition, differential
temp <- data %>% dplyr::mutate(distance = start2 - start1,
                               log_obs_diff_dTAG_DMSO = log_obs_dTAG - log_obs_DMSO) %>% 
  dplyr::select(distance, log_obs_diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment_oe(temp, figDir, paste0(name, \_dTAG_logObs\), unique(data$Anno2), colorListLoop)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QkpiWEJ2Y25RZ1lXNXViM1JoZEdsdmJseHVibUZ0WlNBOExTQmNYR05vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGNYRnh1WkdGMFlTQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y0xuUnpkbHhjS1NrcFhHNWNiaU1nU1cxd2IzSjBJRzlpY3k5bGVIQWdjMk52Y21WeklHRnVaQ0J0WlhKblpTQjBieUIwYUdVZ1pHRjBZWE5sZEZ4dWJXbHVWbUZzZFdVZ1BDMGdMVFJjYm05aWMyVjRjQ0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRnhjYkc5dmNGTmpiM0psWDJOdmJuTmZiMkp6Wlhod0xuUnpkbHhjS1NrcElDVStKVnh1SUNBZ0lHUndiSGx5T2pwdGRYUmhkR1VvYkc5blgyOWljMTlFVFZOUElEMGdhV1pmWld4elpTaHZZbk5mUkUxVFR5QTlQU0F3TENCdGFXNVdZV3gxWlN3Z2JHOW5NaWh2WW5OZlJFMVRUeWtwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JHOW5YMjlpYzE5a1ZFRkhJRDBnYVdaZlpXeHpaU2h2WW5OZlpGUkJSeUE5UFNBd0xDQnRhVzVXWVd4MVpTd2diRzluTWlodlluTmZaRlJCUnlrcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiRzluWDI5aWMxOUJORGcxSUQwZ2FXWmZaV3h6WlNodlluTmZRVFE0TlNBOVBTQXdMQ0J0YVc1V1lXeDFaU3dnYkc5bk1paHZZbk5mUVRRNE5Ta3BLVnh1WEc0aklFMWxjbWRsSUdSaGRHRnpaWFJjYm1SaGRHRWdQQzBnWkdGMFlTQWxQaVVnWkhCc2VYSTZPbXhsWm5SZmFtOXBiaWh2WW5ObGVIQXNJR0o1SUQwZ1l5aGNYR2xrWEZ3cEtWeHVYRzRqSUZCc2IzUmNiblJsYlhBZ1BDMGdaR0YwWVNBbFBpVWdaSEJzZVhJNk9tMTFkR0YwWlNoa2FYTjBZVzVqWlNBOUlITjBZWEowTWlBdElITjBZWEowTVNrZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1pHbHpkR0Z1WTJVc0lHeHZaMTl2WW5OZlJFMVRUeXdnUVc1dWJ6SXBYRzVqYjJ4dVlXMWxjeWgwWlcxd0tTQThMU0JqS0Z4Y1pHbHpkR0Z1WTJWY1hDd2dYRnh6WTI5eVpWeGNMQ0JjWEVGdWJtOHlYRndwWEc1amNtVmhkR1ZmWkdsemRGOTJjMTloZG1kVFkyOXlaVjl3WlhKVWNtVmhkRzFsYm5SZmIyVW9kR1Z0Y0N3Z1ptbG5SR2x5TENCd1lYTjBaVEFvYm1GdFpTd2dYRnhmUkUxVFQxOXNiMmRQWW5OY1hDa3NJSFZ1YVhGMVpTaGtZWFJoSkVGdWJtOHlLU3dnWTI5c2IzSk1hWE4wVEc5dmNDbGNibHh1ZEdWdGNDQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZiWFYwWVhSbEtHUnBjM1JoYm1ObElEMGdjM1JoY25ReUlDMGdjM1JoY25ReEtTQWxQaVVnWkhCc2VYSTZPbk5sYkdWamRDaGthWE4wWVc1alpTd2diRzluWDI5aWMxOWtWRUZITENCQmJtNXZNaWxjYm1OdmJHNWhiV1Z6S0hSbGJYQXBJRHd0SUdNb1hGeGthWE4wWVc1alpWeGNMQ0JjWEhOamIzSmxYRndzSUZ4Y1FXNXViekpjWENsY2JtTnlaV0YwWlY5a2FYTjBYM1p6WDJGMloxTmpiM0psWDNCbGNsUnlaV0YwYldWdWRGOXZaU2gwWlcxd0xDQm1hV2RFYVhJc0lIQmhjM1JsTUNodVlXMWxMQ0JjWEY5a1ZFRkhYMnh2WjA5aWMxeGNLU3dnZFc1cGNYVmxLR1JoZEdFa1FXNXVieklwTENCamIyeHZja3hwYzNSTWIyOXdLVnh1WEc1Y2JpTWdRM0psWVhScGJtY2dabWxuZFhKbGN5QndaWElnWldGamFDQmpiMjVrYVhScGIyNHNJR1JwWm1abGNtVnVkR2xoYkZ4dWRHVnRjQ0E4TFNCa1lYUmhJQ1UrSlNCa2NHeDVjam82YlhWMFlYUmxLR1JwYzNSaGJtTmxJRDBnYzNSaGNuUXlJQzBnYzNSaGNuUXhMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHeHZaMTl2WW5OZlpHbG1abDlrVkVGSFgwUk5VMDhnUFNCc2IyZGZiMkp6WDJSVVFVY2dMU0JzYjJkZmIySnpYMFJOVTA4cElDVStKU0JjYmlBZ1pIQnNlWEk2T25ObGJHVmpkQ2hrYVhOMFlXNWpaU3dnYkc5blgyOWljMTlrYVdabVgyUlVRVWRmUkUxVFR5d2dRVzV1YnpJcFhHNWpiMnh1WVcxbGN5aDBaVzF3S1NBOExTQmpLRnhjWkdsemRHRnVZMlZjWEN3Z1hGeHpZMjl5WlZ4Y0xDQmNYRUZ1Ym04eVhGd3BYRzVqY21WaGRHVmZaR2x6ZEY5MmMxOWhkbWRFYVdabVUyTnZjbVZmY0dWeVZISmxZWFJ0Wlc1MFgyOWxLSFJsYlhBc0lHWnBaMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRnhjWDJSVVFVZGZiRzluVDJKelhGd3BMQ0IxYm1seGRXVW9aR0YwWVNSQmJtNXZNaWtzSUdOdmJHOXlUR2x6ZEV4dmIzQXBYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG4jIEltcG9ydCBhbm5vdGF0aW9uXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcblxuIyBJbXBvcnQgb2JzL2V4cCBzY29yZXMgYW5kIG1lcmdlIHRvIHRoZSBkYXRhc2V0XG5taW5WYWx1ZSA8LSAtNFxub2JzZXhwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfY29uc19vYnNleHAudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShsb2dfb2JzX0RNU08gPSBpZl9lbHNlKG9ic19ETVNPID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic19ETVNPKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzX2RUQUcgPSBpZl9lbHNlKG9ic19kVEFHID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic19kVEFHKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzX0E0ODUgPSBpZl9lbHNlKG9ic19BNDg1ID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic19BNDg1KSkpXG5cbiMgTWVyZ2UgZGF0YXNldFxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bGVmdF9qb2luKG9ic2V4cCwgYnkgPSBjKFxcaWRcXCkpXG5cbiMgUGxvdFxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgbG9nX29ic19ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudF9vZSh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9ETVNPX2xvZ09ic1xcKSwgdW5pcXVlKGRhdGEkQW5ubzIpLCBjb2xvckxpc3RMb29wKVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpICU+JSBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBsb2dfb2JzX2RUQUcsIEFubm8yKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGRpc3RhbmNlXFwsIFxcc2NvcmVcXCwgXFxBbm5vMlxcKVxuY3JlYXRlX2Rpc3RfdnNfYXZnU2NvcmVfcGVyVHJlYXRtZW50X29lKHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdfbG9nT2JzXFwpLCB1bmlxdWUoZGF0YSRBbm5vMiksIGNvbG9yTGlzdExvb3ApXG5cblxuIyBDcmVhdGluZyBmaWd1cmVzIHBlciBlYWNoIGNvbmRpdGlvbiwgZGlmZmVyZW50aWFsXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9nX29ic19kaWZmX2RUQUdfRE1TTyA9IGxvZ19vYnNfZFRBRyAtIGxvZ19vYnNfRE1TTykgJT4lIFxuICBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBsb2dfb2JzX2RpZmZfZFRBR19ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnRfb2UodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfZFRBR19sb2dPYnNcXCksIHVuaXF1ZShkYXRhJEFubm8yKSwgY29sb3JMaXN0TG9vcClcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBJbXBvcnQgYW5ub3RhdGlvblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUobG9nX29ic19ETVNPID0gaWZfZWxzZShvYnNfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNfRE1TTykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic19kVEFHID0gaWZfZWxzZShvYnNfZFRBRyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNfZFRBRykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic19BNDg1ID0gaWZfZWxzZShvYnNfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNfQTQ4NSkpKVxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcXGlkXFwpKVxuXG4jIFBsb3RcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGxvZ19vYnNfRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdTY29yZV9wZXJUcmVhdG1lbnRfb2UodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfRE1TT19sb2dPYnNcXCksIHVuaXF1ZShkYXRhJEFubm8yKSwgY29sb3JMaXN0TG9vcClcblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgbG9nX29ic19kVEFHLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudF9vZSh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9kVEFHX2xvZ09ic1xcKSwgdW5pcXVlKGRhdGEkQW5ubzIpLCBjb2xvckxpc3RMb29wKVxuXG5cbiMgQ3JlYXRpbmcgZmlndXJlcyBwZXIgZWFjaCBjb25kaXRpb24sIGRpZmZlcmVudGlhbFxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvZ19vYnNfZGlmZl9kVEFHX0RNU08gPSBsb2dfb2JzX2RUQUcgLSBsb2dfb2JzX0RNU08pICU+JSBcbiAgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgbG9nX29ic19kaWZmX2RUQUdfRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdEaWZmU2NvcmVfcGVyVHJlYXRtZW50X29lKHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2RUQUdfbG9nT2JzXFwpLCB1bmlxdWUoZGF0YSRBbm5vMiksIGNvbG9yTGlzdExvb3ApXG5gYGBcbmBgYCJ9 -->

```r
```r
# Import annotation
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obs_DMSO = if_else(obs_DMSO == 0, minValue, log2(obs_DMSO)),
                  log_obs_dTAG = if_else(obs_dTAG == 0, minValue, log2(obs_dTAG)),
                  log_obs_A485 = if_else(obs_A485 == 0, minValue, log2(obs_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\))

# Plot
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obs_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, \_DMSO_logObs\), unique(data$Anno2), colorListLoop)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obs_dTAG, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, \_dTAG_logObs\), unique(data$Anno2), colorListLoop)


# Creating figures per each condition, differential
temp <- data %>% dplyr::mutate(distance = start2 - start1,
                               log_obs_diff_dTAG_DMSO = log_obs_dTAG - log_obs_DMSO) %>% 
  dplyr::select(distance, log_obs_diff_dTAG_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment_oe(temp, figDir, paste0(name, \_dTAG_logObs\), unique(data$Anno2), colorListLoop)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


###### OE, grouped

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJKYlhCdmNuUWdZVzV1YjNSaGRHbHZibHh1Ym1GdFpTQThMU0JjSW1Ob2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxjSWx4dVpHRjBZU0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lMblJ6ZGx3aUtTa3BYRzVjYmlNZ1NXMXdiM0owSUc5aWN5OWxlSEFnYzJOdmNtVnpJR0Z1WkNCdFpYSm5aU0IwYnlCMGFHVWdaR0YwWVhObGRGeHViV2x1Vm1Gc2RXVWdQQzBnTFRSY2JtOWljMlY0Y0NBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0Z3aWJHOXZjRk5qYjNKbFgyTnZibk5mYjJKelpYaHdMblJ6ZGx3aUtTa3BJQ1UrSlZ4dUlDQWdJR1J3YkhseU9qcHRkWFJoZEdVb2JHOW5YMjlpYzJWNGNGOUVUVk5QSUQwZ2FXWmZaV3h6WlNodlluTmxlSEJmUkUxVFR5QTlQU0F3TENCdGFXNVdZV3gxWlN3Z2JHOW5NaWh2WW5ObGVIQmZSRTFUVHlrcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiRzluWDI5aWMyVjRjRjlrVkVGSElEMGdhV1pmWld4elpTaHZZbk5sZUhCZlpGUkJSeUE5UFNBd0xDQnRhVzVXWVd4MVpTd2diRzluTWlodlluTmxlSEJmWkZSQlJ5a3BMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYkc5blgyOWljMlY0Y0Y5Qk5EZzFJRDBnYVdaZlpXeHpaU2h2WW5ObGVIQmZRVFE0TlNBOVBTQXdMQ0J0YVc1V1lXeDFaU3dnYkc5bk1paHZZbk5sZUhCZlFUUTROU2twS1Z4dVhHNGpJRTFsY21kbElHUmhkR0Z6WlhSY2JtUmhkR0VnUEMwZ1pHRjBZU0FsUGlVZ1pIQnNlWEk2T214bFpuUmZhbTlwYmlodlluTmxlSEFzSUdKNUlEMGdZeWhjSW1sa1hDSXBLVnh1WEc0aklGQnNiM1JjYm5SbGJYQWdQQzBnWkdGMFlTQWxQaVVnWkhCc2VYSTZPbTExZEdGMFpTaGthWE4wWVc1alpTQTlJSE4wWVhKME1pQXRJSE4wWVhKME1Ta2dKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aR2x6ZEdGdVkyVXNJR3h2WjE5dlluTmxlSEJmUVRRNE5Td2dRVzV1YnpJcFhHNWpiMnh1WVcxbGN5aDBaVzF3S1NBOExTQmpLRndpWkdsemRHRnVZMlZjSWl3Z1hDSnpZMjl5WlZ3aUxDQmNJa0Z1Ym04eVhDSXBYRzVqY21WaGRHVmZaR2x6ZEY5MmMxOWhkbWRUWTI5eVpWOXdaWEpVY21WaGRHMWxiblJmYjJVb2RHVnRjQ3dnWm1sblJHbHlMQ0J3WVhOMFpUQW9ibUZ0WlN3Z1hDSmZRVFE0TlY5c2IyZFBSVndpS1N3Z2RXNXBjWFZsS0dSaGRHRWtRVzV1YnpJcExDQmpiMnh2Y2t4cGMzUk1iMjl3S1Z4dVhHNWNiaU1nUTNKbFlYUnBibWNnWm1sbmRYSmxjeUJ3WlhJZ1pXRmphQ0JqYjI1a2FYUnBiMjRzSUdScFptWmxjbVZ1ZEdsaGJGeHVkR1Z0Y0NBOExTQmtZWFJoSUNVK0pTQmtjR3g1Y2pvNmJYVjBZWFJsS0dScGMzUmhibU5sSUQwZ2MzUmhjblF5SUMwZ2MzUmhjblF4TEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR3h2WjE5dlluTmxlSEJmWkdsbVpsOUJORGcxWDBSTlUwOGdQU0JzYjJkZmIySnpaWGh3WDBFME9EVWdMU0JzYjJkZmIySnpaWGh3WDBSTlUwOHBJQ1UrSlNCY2JpQWdaSEJzZVhJNk9uTmxiR1ZqZENoa2FYTjBZVzVqWlN3Z2JHOW5YMjlpYzJWNGNGOWthV1ptWDBFME9EVmZSRTFUVHl3Z1FXNXVieklwWEc1amIyeHVZVzFsY3loMFpXMXdLU0E4TFNCaktGd2laR2x6ZEdGdVkyVmNJaXdnWENKelkyOXlaVndpTENCY0lrRnVibTh5WENJcFhHNWpjbVZoZEdWZlpHbHpkRjkyYzE5aGRtZEVhV1ptVTJOdmNtVmZjR1Z5VkhKbFlYUnRaVzUwWDI5bEtIUmxiWEFzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lYMEUwT0RWZmJHOW5UMFZjSWlrc0lIVnVhWEYxWlNoa1lYUmhKRUZ1Ym04eUtTd2dZMjlzYjNKTWFYTjBURzl2Y0NsY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG4jIEltcG9ydCBhbm5vdGF0aW9uXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kYXRhIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFwudHN2XFwpKSlcblxuIyBJbXBvcnQgb2JzL2V4cCBzY29yZXMgYW5kIG1lcmdlIHRvIHRoZSBkYXRhc2V0XG5taW5WYWx1ZSA8LSAtNFxub2JzZXhwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfY29uc19vYnNleHAudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShsb2dfb2JzZXhwX0RNU08gPSBpZl9lbHNlKG9ic2V4cF9ETVNPID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9ETVNPKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX2RUQUcgPSBpZl9lbHNlKG9ic2V4cF9kVEFHID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9kVEFHKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX0E0ODUgPSBpZl9lbHNlKG9ic2V4cF9BNDg1ID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9BNDg1KSkpXG5cbiMgTWVyZ2UgZGF0YXNldFxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bGVmdF9qb2luKG9ic2V4cCwgYnkgPSBjKFxcaWRcXCkpXG5cbiMgUGxvdFxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKSAlPiUgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgbG9nX29ic2V4cF9BNDg1LCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z1Njb3JlX3BlclRyZWF0bWVudF9vZSh0ZW1wLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9BNDg1X2xvZ09FXFwpLCB1bmlxdWUoZGF0YSRBbm5vMiksIGNvbG9yTGlzdExvb3ApXG5cblxuIyBDcmVhdGluZyBmaWd1cmVzIHBlciBlYWNoIGNvbmRpdGlvbiwgZGlmZmVyZW50aWFsXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA9IGxvZ19vYnNleHBfQTQ4NSAtIGxvZ19vYnNleHBfRE1TTykgJT4lIFxuICBkcGx5cjo6c2VsZWN0KGRpc3RhbmNlLCBsb2dfb2JzZXhwX2RpZmZfQTQ4NV9ETVNPLCBBbm5vMilcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxkaXN0YW5jZVxcLCBcXHNjb3JlXFwsIFxcQW5ubzJcXClcbmNyZWF0ZV9kaXN0X3ZzX2F2Z0RpZmZTY29yZV9wZXJUcmVhdG1lbnRfb2UodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NV9sb2dPRVxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpLCBjb2xvckxpc3RMb29wKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
# Import annotation
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\))

# Plot
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obsexp_A485, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, \_A485_logOE\), unique(data$Anno2), colorListLoop)


# Creating figures per each condition, differential
temp <- data %>% dplyr::mutate(distance = start2 - start1,
                               log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO) %>% 
  dplyr::select(distance, log_obsexp_diff_A485_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment_oe(temp, figDir, paste0(name, \_A485_logOE\), unique(data$Anno2), colorListLoop)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QkpiWEJ2Y25RZ1lXNXViM1JoZEdsdmJseHVibUZ0WlNBOExTQmNYR05vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGNYRnh1WkdGMFlTQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y0xuUnpkbHhjS1NrcFhHNWNiaU1nU1cxd2IzSjBJRzlpY3k5bGVIQWdjMk52Y21WeklHRnVaQ0J0WlhKblpTQjBieUIwYUdVZ1pHRjBZWE5sZEZ4dWJXbHVWbUZzZFdVZ1BDMGdMVFJjYm05aWMyVjRjQ0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRnhjYkc5dmNGTmpiM0psWDJOdmJuTmZiMkp6Wlhod0xuUnpkbHhjS1NrcElDVStKVnh1SUNBZ0lHUndiSGx5T2pwdGRYUmhkR1VvYkc5blgyOWljMlY0Y0Y5RVRWTlBJRDBnYVdaZlpXeHpaU2h2WW5ObGVIQmZSRTFUVHlBOVBTQXdMQ0J0YVc1V1lXeDFaU3dnYkc5bk1paHZZbk5sZUhCZlJFMVRUeWtwTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ2JHOW5YMjlpYzJWNGNGOWtWRUZISUQwZ2FXWmZaV3h6WlNodlluTmxlSEJmWkZSQlJ5QTlQU0F3TENCdGFXNVdZV3gxWlN3Z2JHOW5NaWh2WW5ObGVIQmZaRlJCUnlrcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiRzluWDI5aWMyVjRjRjlCTkRnMUlEMGdhV1pmWld4elpTaHZZbk5sZUhCZlFUUTROU0E5UFNBd0xDQnRhVzVXWVd4MVpTd2diRzluTWlodlluTmxlSEJmUVRRNE5Ta3BLVnh1WEc0aklFMWxjbWRsSUdSaGRHRnpaWFJjYm1SaGRHRWdQQzBnWkdGMFlTQWxQaVVnWkhCc2VYSTZPbXhsWm5SZmFtOXBiaWh2WW5ObGVIQXNJR0o1SUQwZ1l5aGNYR2xrWEZ3cEtWeHVYRzRqSUZCc2IzUmNiblJsYlhBZ1BDMGdaR0YwWVNBbFBpVWdaSEJzZVhJNk9tMTFkR0YwWlNoa2FYTjBZVzVqWlNBOUlITjBZWEowTWlBdElITjBZWEowTVNrZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1pHbHpkR0Z1WTJVc0lHeHZaMTl2WW5ObGVIQmZRVFE0TlN3Z1FXNXVieklwWEc1amIyeHVZVzFsY3loMFpXMXdLU0E4TFNCaktGeGNaR2x6ZEdGdVkyVmNYQ3dnWEZ4elkyOXlaVnhjTENCY1hFRnVibTh5WEZ3cFhHNWpjbVZoZEdWZlpHbHpkRjkyYzE5aGRtZFRZMjl5WlY5d1pYSlVjbVZoZEcxbGJuUmZiMlVvZEdWdGNDd2dabWxuUkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWEZ4ZlFUUTROVjlzYjJkUFJWeGNLU3dnZFc1cGNYVmxLR1JoZEdFa1FXNXVieklwTENCamIyeHZja3hwYzNSTWIyOXdLVnh1WEc1Y2JpTWdRM0psWVhScGJtY2dabWxuZFhKbGN5QndaWElnWldGamFDQmpiMjVrYVhScGIyNHNJR1JwWm1abGNtVnVkR2xoYkZ4dWRHVnRjQ0E4TFNCa1lYUmhJQ1UrSlNCa2NHeDVjam82YlhWMFlYUmxLR1JwYzNSaGJtTmxJRDBnYzNSaGNuUXlJQzBnYzNSaGNuUXhMRnh1SUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHeHZaMTl2WW5ObGVIQmZaR2xtWmw5Qk5EZzFYMFJOVTA4Z1BTQnNiMmRmYjJKelpYaHdYMEUwT0RVZ0xTQnNiMmRmYjJKelpYaHdYMFJOVTA4cElDVStKU0JjYmlBZ1pIQnNlWEk2T25ObGJHVmpkQ2hrYVhOMFlXNWpaU3dnYkc5blgyOWljMlY0Y0Y5a2FXWm1YMEUwT0RWZlJFMVRUeXdnUVc1dWJ6SXBYRzVqYjJ4dVlXMWxjeWgwWlcxd0tTQThMU0JqS0Z4Y1pHbHpkR0Z1WTJWY1hDd2dYRnh6WTI5eVpWeGNMQ0JjWEVGdWJtOHlYRndwWEc1amNtVmhkR1ZmWkdsemRGOTJjMTloZG1kRWFXWm1VMk52Y21WZmNHVnlWSEpsWVhSdFpXNTBYMjlsS0hSbGJYQXNJR1pwWjBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gwRTBPRFZmYkc5blQwVmNYQ2tzSUhWdWFYRjFaU2hrWVhSaEpFRnVibTh5S1N3Z1kyOXNiM0pNYVhOMFRHOXZjQ2xjYm1CZ1lGeHVZR0JnSW4wPSAtLT5cblxuYGBgclxuYGBgclxuIyBJbXBvcnQgYW5ub3RhdGlvblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUobG9nX29ic2V4cF9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfRE1TTykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kVEFHID0gaWZfZWxzZShvYnNleHBfZFRBRyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfZFRBRykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9BNDg1ID0gaWZfZWxzZShvYnNleHBfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQTQ4NSkpKVxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcXGlkXFwpKVxuXG4jIFBsb3RcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGxvZ19vYnNleHBfQTQ4NSwgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdTY29yZV9wZXJUcmVhdG1lbnRfb2UodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NV9sb2dPRVxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpLCBjb2xvckxpc3RMb29wKVxuXG5cbiMgQ3JlYXRpbmcgZmlndXJlcyBwZXIgZWFjaCBjb25kaXRpb24sIGRpZmZlcmVudGlhbFxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZGlmZl9BNDg1X0RNU08gPSBsb2dfb2JzZXhwX0E0ODUgLSBsb2dfb2JzZXhwX0RNU08pICU+JSBcbiAgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgbG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdEaWZmU2NvcmVfcGVyVHJlYXRtZW50X29lKHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0E0ODVfbG9nT0VcXCksIHVuaXF1ZShkYXRhJEFubm8yKSwgY29sb3JMaXN0TG9vcClcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBJbXBvcnQgYW5ub3RhdGlvblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPC0gLTRcbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUobG9nX29ic2V4cF9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfRE1TTykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kVEFHID0gaWZfZWxzZShvYnNleHBfZFRBRyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfZFRBRykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9BNDg1ID0gaWZfZWxzZShvYnNleHBfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQTQ4NSkpKVxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcXGlkXFwpKVxuXG4jIFBsb3RcbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSkgJT4lIGRwbHlyOjpzZWxlY3QoZGlzdGFuY2UsIGxvZ19vYnNleHBfQTQ4NSwgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdTY29yZV9wZXJUcmVhdG1lbnRfb2UodGVtcCwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfQTQ4NV9sb2dPRVxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpLCBjb2xvckxpc3RMb29wKVxuXG5cbiMgQ3JlYXRpbmcgZmlndXJlcyBwZXIgZWFjaCBjb25kaXRpb24sIGRpZmZlcmVudGlhbFxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZGlmZl9BNDg1X0RNU08gPSBsb2dfb2JzZXhwX0E0ODUgLSBsb2dfb2JzZXhwX0RNU08pICU+JSBcbiAgZHBseXI6OnNlbGVjdChkaXN0YW5jZSwgbG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTywgQW5ubzIpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcZGlzdGFuY2VcXCwgXFxzY29yZVxcLCBcXEFubm8yXFwpXG5jcmVhdGVfZGlzdF92c19hdmdEaWZmU2NvcmVfcGVyVHJlYXRtZW50X29lKHRlbXAsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX0E0ODVfbG9nT0VcXCksIHVuaXF1ZShkYXRhJEFubm8yKSwgY29sb3JMaXN0TG9vcClcbmBgYFxuYGBgIn0= -->

```r
```r
# Import annotation
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\))

# Plot
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obsexp_A485, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, \_A485_logOE\), unique(data$Anno2), colorListLoop)


# Creating figures per each condition, differential
temp <- data %>% dplyr::mutate(distance = start2 - start1,
                               log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO) %>% 
  dplyr::select(distance, log_obsexp_diff_A485_DMSO, Anno2)
colnames(temp) <- c(\distance\, \score\, \Anno2\)
create_dist_vs_avgDiffScore_perTreatment_oe(temp, figDir, paste0(name, \_A485_logOE\), unique(data$Anno2), colorListLoop)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


###### Observed

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJKYlhCdmNuUWdZVzV1YjNSaGRHbHZibHh1Ym1GdFpTQThMU0JjSW1Ob2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxjSWx4dVpHRjBZU0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lMblJ6ZGx3aUtTa3BYRzVjYmlNZ1NXMXdiM0owSUc5aWN5OWxlSEFnYzJOdmNtVnpJR0Z1WkNCdFpYSm5aU0IwYnlCMGFHVWdaR0YwWVhObGRGeHViV2x1Vm1Gc2RXVWdQU0F0TkZ4dWIySnpaWGh3SUR3dElHWnlaV0ZrS0dobGNtVW9ZMjl1YzJWdWMzVnpSR2x5TENCd1lYTjBaVEFvWENKc2IyOXdVMk52Y21WZlkyOXVjMTl2WW5ObGVIQXVkSE4yWENJcEtTa2dKVDRsWEc0Z0lDQWdaSEJzZVhJNk9tMTFkR0YwWlNoc2IyZGZiMkp6Wlhod1gwUk5VMDhnUFNCcFpsOWxiSE5sS0c5aWMyVjRjRjlFVFZOUElEMDlJREFzSUcxcGJsWmhiSFZsTENCc2IyY3lLRzlpYzJWNGNGOUVUVk5QS1Nrc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnNiMmRmYjJKelpYaHdYMlJVUVVjZ1BTQnBabDlsYkhObEtHOWljMlY0Y0Y5a1ZFRkhJRDA5SURBc0lHMXBibFpoYkhWbExDQnNiMmN5S0c5aWMyVjRjRjlrVkVGSEtTa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JzYjJkZmIySnpaWGh3WDBFME9EVWdQU0JwWmw5bGJITmxLRzlpYzJWNGNGOUJORGcxSUQwOUlEQXNJRzFwYmxaaGJIVmxMQ0JzYjJjeUtHOWljMlY0Y0Y5Qk5EZzFLU2twWEc1Y2JpTWdUV1Z5WjJVZ1pHRjBZWE5sZEZ4dVpHRjBZU0E4TFNCa1lYUmhJQ1UrSlNCa2NHeDVjam82YkdWbWRGOXFiMmx1S0c5aWMyVjRjQ3dnWW5rZ1BTQmpLRndpYVdSY0lpa3BJQ1UrSlZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0d4dloxOXZZbk5sZUhCZlpHbG1abDlrVkVGSFgwUk5VMDhnUFNCc2IyZGZiMkp6Wlhod1gyUlVRVWNnTFNCc2IyZGZiMkp6Wlhod1gwUk5VMDhzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYkc5blgyOWljMlY0Y0Y5a2FXWm1YMEUwT0RWZlJFMVRUeUE5SUd4dloxOXZZbk5sZUhCZlFUUTROU0F0SUd4dloxOXZZbk5sZUhCZlJFMVRUeWxjYmx4dVpHbG1aa04xZEc5bVppQThMU0F3TGpWY2JtTnlaV0YwWlY5c2IyOXdYM05qWVhSMFpYSndiRzkwWDI5bEtHUmhkR0VzSUdacFowUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lYMnh2WjA5Rlgxd2lMQ0JjSW1Gc2JGd2lLU3dnZFc1cGNYVmxLR1JoZEdFa1FXNXVieklwTENCa2FXWm1RM1YwYjJabUtWeHVZM0psWVhSbFgyeHZiM0JmYzJOaGRIUmxjbkJzYjNSZmIyVW9aR0YwWVN3Z1ptbG5SR2x5TENCd1lYTjBaVEFvYm1GdFpTd2dYQ0pmYkc5blQwVmZYQ0lzSUZ3aWNtVm5YQ0lwTENCaktGd2lVQzFRWENJc0lGd2lVQzFGWENJc0lGd2lSUzFGWENJcExDQmthV1ptUTNWMGIyWm1LVnh1WTNKbFlYUmxYMnh2YjNCZmMyTmhkSFJsY25Cc2IzUmZiMlVvWkdGMFlTd2dabWxuUkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWENKZmJHOW5UMFZmWENJc0lGd2ljM1J5WENJcExDQmpLRndpVXkxVFhDSXNJRndpVXkxWVhDSXBMQ0JrYVdabVEzVjBiMlptS1Z4dVhHNWNibHh1WTNKbFlYUmxYMlJwYzNSZlltRnljR3h2ZEY5dlpTaGtZWFJoTENCbWFXZEVhWElzSUhCaGMzUmxNQ2h1WVcxbExDQmNJbDlzYjJkUFJWd2lLU3dnWENKaGJHeGNJaXdnSUhWdWFYRjFaU2hrWVhSaEpFRnVibTh5S1N3Z1pHbG1aa04xZEc5bVppbGNibU55WldGMFpWOWthWE4wWDJKaGNuQnNiM1JmYjJVb1pHRjBZU3dnWm1sblJHbHlMQ0J3WVhOMFpUQW9ibUZ0WlN3Z1hDSmZiRzluVDBWY0lpa3NJRndpY21WblhDSXNJQ0JqS0Z3aVVDMVFYQ0lzSUZ3aVVDMUZYQ0lzSUZ3aVJTMUZYQ0lwTENCa2FXWm1RM1YwYjJabUtWeHVZM0psWVhSbFgyUnBjM1JmWW1GeWNHeHZkRjl2WlNoa1lYUmhMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY0lsOXNiMmRQUlZ3aUtTd2dYQ0p5WldkZk1XMWlYQ0lzSUNCaktGd2lVQzFRWENJc0lGd2lVQzFGWENJc0lGd2lSUzFGWENJcExDQmthV1ptUTNWMGIyWm1MQ0F4WlRZcFhHNWpjbVZoZEdWZlpHbHpkRjlpWVhKd2JHOTBYMjlsS0dSaGRHRXNJR1pwWjBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ3aVgyeHZaMDlGWENJcExDQmNJbk4wY2x3aUxDQWdZeWhjSWxNdFUxd2lMQ0JjSWxNdFdGd2lLU3dnWkdsbVprTjFkRzltWmlsY2JtTnlaV0YwWlY5a2FYTjBYMkpoY25Cc2IzUmZiMlVvWkdGMFlTd2dabWxuUkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWENKZmJHOW5UMFZjSWlrc0lGd2ljM1J5WHpGdFlsd2lMQ0FnWXloY0lsTXRVMXdpTENCY0lsTXRXRndpS1N3Z1pHbG1aa04xZEc5bVppd2dNV1UyS1Z4dVhHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuIyBJbXBvcnQgYW5ub3RhdGlvblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPSAtNFxub2JzZXhwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfY29uc19vYnNleHAudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShsb2dfb2JzZXhwX0RNU08gPSBpZl9lbHNlKG9ic2V4cF9ETVNPID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9ETVNPKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX2RUQUcgPSBpZl9lbHNlKG9ic2V4cF9kVEFHID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9kVEFHKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX0E0ODUgPSBpZl9lbHNlKG9ic2V4cF9BNDg1ID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9BNDg1KSkpXG5cbiMgTWVyZ2UgZGF0YXNldFxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bGVmdF9qb2luKG9ic2V4cCwgYnkgPSBjKFxcaWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08gPSBsb2dfb2JzZXhwX2RUQUcgLSBsb2dfb2JzZXhwX0RNU08sXG4gICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA9IGxvZ19vYnNleHBfQTQ4NSAtIGxvZ19vYnNleHBfRE1TTylcblxuZGlmZkN1dG9mZiA8LSAwLjVcbmNyZWF0ZV9sb29wX3NjYXR0ZXJwbG90X29lKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2xvZ09FX1xcLCBcXGFsbFxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpLCBkaWZmQ3V0b2ZmKVxuY3JlYXRlX2xvb3Bfc2NhdHRlcnBsb3Rfb2UoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfbG9nT0VfXFwsIFxccmVnXFwpLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCBkaWZmQ3V0b2ZmKVxuY3JlYXRlX2xvb3Bfc2NhdHRlcnBsb3Rfb2UoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfbG9nT0VfXFwsIFxcc3RyXFwpLCBjKFxcUy1TXFwsIFxcUy1YXFwpLCBkaWZmQ3V0b2ZmKVxuXG5cblxuY3JlYXRlX2Rpc3RfYmFycGxvdF9vZShkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9sb2dPRVxcKSwgXFxhbGxcXCwgIHVuaXF1ZShkYXRhJEFubm8yKSwgZGlmZkN1dG9mZilcbmNyZWF0ZV9kaXN0X2JhcnBsb3Rfb2UoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfbG9nT0VcXCksIFxccmVnXFwsICBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCBkaWZmQ3V0b2ZmKVxuY3JlYXRlX2Rpc3RfYmFycGxvdF9vZShkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9sb2dPRVxcKSwgXFxyZWdfMW1iXFwsICBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCBkaWZmQ3V0b2ZmLCAxZTYpXG5jcmVhdGVfZGlzdF9iYXJwbG90X29lKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2xvZ09FXFwpLCBcXHN0clxcLCAgYyhcXFMtU1xcLCBcXFMtWFxcKSwgZGlmZkN1dG9mZilcbmNyZWF0ZV9kaXN0X2JhcnBsb3Rfb2UoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfbG9nT0VcXCksIFxcc3RyXzFtYlxcLCAgYyhcXFMtU1xcLCBcXFMtWFxcKSwgZGlmZkN1dG9mZiwgMWU2KVxuXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
# Import annotation
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue = -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\)) %>%
  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

diffCutoff <- 0.5
create_loop_scatterplot_oe(data, figDir, paste0(name, \_logOE_\, \all\), unique(data$Anno2), diffCutoff)
create_loop_scatterplot_oe(data, figDir, paste0(name, \_logOE_\, \reg\), c(\P-P\, \P-E\, \E-E\), diffCutoff)
create_loop_scatterplot_oe(data, figDir, paste0(name, \_logOE_\, \str\), c(\S-S\, \S-X\), diffCutoff)



create_dist_barplot_oe(data, figDir, paste0(name, \_logOE\), \all\,  unique(data$Anno2), diffCutoff)
create_dist_barplot_oe(data, figDir, paste0(name, \_logOE\), \reg\,  c(\P-P\, \P-E\, \E-E\), diffCutoff)
create_dist_barplot_oe(data, figDir, paste0(name, \_logOE\), \reg_1mb\,  c(\P-P\, \P-E\, \E-E\), diffCutoff, 1e6)
create_dist_barplot_oe(data, figDir, paste0(name, \_logOE\), \str\,  c(\S-S\, \S-X\), diffCutoff)
create_dist_barplot_oe(data, figDir, paste0(name, \_logOE\), \str_1mb\,  c(\S-S\, \S-X\), diffCutoff, 1e6)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QkpiWEJ2Y25RZ1lXNXViM1JoZEdsdmJseHVibUZ0WlNBOExTQmNYR05vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGNYRnh1WkdGMFlTQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y0xuUnpkbHhjS1NrcFhHNWNiaU1nU1cxd2IzSjBJRzlpY3k5bGVIQWdjMk52Y21WeklHRnVaQ0J0WlhKblpTQjBieUIwYUdVZ1pHRjBZWE5sZEZ4dWJXbHVWbUZzZFdVZ1BTQXRORnh1YjJKelpYaHdJRHd0SUdaeVpXRmtLR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0J3WVhOMFpUQW9YRnhzYjI5d1UyTnZjbVZmWTI5dWMxOXZZbk5sZUhBdWRITjJYRndwS1NrZ0pUNGxYRzRnSUNBZ1pIQnNlWEk2T20xMWRHRjBaU2hzYjJkZmIySnpaWGh3WDBSTlUwOGdQU0JwWmw5bGJITmxLRzlpYzJWNGNGOUVUVk5QSUQwOUlEQXNJRzFwYmxaaGJIVmxMQ0JzYjJjeUtHOWljMlY0Y0Y5RVRWTlBLU2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCc2IyZGZiMkp6Wlhod1gyUlVRVWNnUFNCcFpsOWxiSE5sS0c5aWMyVjRjRjlrVkVGSElEMDlJREFzSUcxcGJsWmhiSFZsTENCc2IyY3lLRzlpYzJWNGNGOWtWRUZIS1Nrc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnNiMmRmYjJKelpYaHdYMEUwT0RVZ1BTQnBabDlsYkhObEtHOWljMlY0Y0Y5Qk5EZzFJRDA5SURBc0lHMXBibFpoYkhWbExDQnNiMmN5S0c5aWMyVjRjRjlCTkRnMUtTa3BYRzVjYmlNZ1RXVnlaMlVnWkdGMFlYTmxkRnh1WkdGMFlTQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZiR1ZtZEY5cWIybHVLRzlpYzJWNGNDd2dZbmtnUFNCaktGeGNhV1JjWENrcElDVStKVnh1SUNCa2NHeDVjam82YlhWMFlYUmxLR3h2WjE5dlluTmxlSEJmWkdsbVpsOWtWRUZIWDBSTlUwOGdQU0JzYjJkZmIySnpaWGh3WDJSVVFVY2dMU0JzYjJkZmIySnpaWGh3WDBSTlUwOHNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiRzluWDI5aWMyVjRjRjlrYVdabVgwRTBPRFZmUkUxVFR5QTlJR3h2WjE5dlluTmxlSEJmUVRRNE5TQXRJR3h2WjE5dlluTmxlSEJmUkUxVFR5bGNibHh1WkdsbVprTjFkRzltWmlBOExTQXdMalZjYm1OeVpXRjBaVjlzYjI5d1gzTmpZWFIwWlhKd2JHOTBYMjlsS0dSaGRHRXNJR1pwWjBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gyeHZaMDlGWDF4Y0xDQmNYR0ZzYkZ4Y0tTd2dkVzVwY1hWbEtHUmhkR0VrUVc1dWJ6SXBMQ0JrYVdabVEzVjBiMlptS1Z4dVkzSmxZWFJsWDJ4dmIzQmZjMk5oZEhSbGNuQnNiM1JmYjJVb1pHRjBZU3dnWm1sblJHbHlMQ0J3WVhOMFpUQW9ibUZ0WlN3Z1hGeGZiRzluVDBWZlhGd3NJRnhjY21WblhGd3BMQ0JqS0Z4Y1VDMVFYRndzSUZ4Y1VDMUZYRndzSUZ4Y1JTMUZYRndwTENCa2FXWm1RM1YwYjJabUtWeHVZM0psWVhSbFgyeHZiM0JmYzJOaGRIUmxjbkJzYjNSZmIyVW9aR0YwWVN3Z1ptbG5SR2x5TENCd1lYTjBaVEFvYm1GdFpTd2dYRnhmYkc5blQwVmZYRndzSUZ4Y2MzUnlYRndwTENCaktGeGNVeTFUWEZ3c0lGeGNVeTFZWEZ3cExDQmthV1ptUTNWMGIyWm1LVnh1WEc1Y2JseHVZM0psWVhSbFgyUnBjM1JmWW1GeWNHeHZkRjl2WlNoa1lYUmhMQ0JtYVdkRWFYSXNJSEJoYzNSbE1DaHVZVzFsTENCY1hGOXNiMmRQUlZ4Y0tTd2dYRnhoYkd4Y1hDd2dJSFZ1YVhGMVpTaGtZWFJoSkVGdWJtOHlLU3dnWkdsbVprTjFkRzltWmlsY2JtTnlaV0YwWlY5a2FYTjBYMkpoY25Cc2IzUmZiMlVvWkdGMFlTd2dabWxuUkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWEZ4ZmJHOW5UMFZjWENrc0lGeGNjbVZuWEZ3c0lDQmpLRnhjVUMxUVhGd3NJRnhjVUMxRlhGd3NJRnhjUlMxRlhGd3BMQ0JrYVdabVEzVjBiMlptS1Z4dVkzSmxZWFJsWDJScGMzUmZZbUZ5Y0d4dmRGOXZaU2hrWVhSaExDQm1hV2RFYVhJc0lIQmhjM1JsTUNodVlXMWxMQ0JjWEY5c2IyZFBSVnhjS1N3Z1hGeHlaV2RmTVcxaVhGd3NJQ0JqS0Z4Y1VDMVFYRndzSUZ4Y1VDMUZYRndzSUZ4Y1JTMUZYRndwTENCa2FXWm1RM1YwYjJabUxDQXhaVFlwWEc1amNtVmhkR1ZmWkdsemRGOWlZWEp3Ykc5MFgyOWxLR1JoZEdFc0lHWnBaMFJwY2l3Z2NHRnpkR1V3S0c1aGJXVXNJRnhjWDJ4dlowOUZYRndwTENCY1hITjBjbHhjTENBZ1l5aGNYRk10VTF4Y0xDQmNYRk10V0Z4Y0tTd2daR2xtWmtOMWRHOW1aaWxjYm1OeVpXRjBaVjlrYVhOMFgySmhjbkJzYjNSZmIyVW9aR0YwWVN3Z1ptbG5SR2x5TENCd1lYTjBaVEFvYm1GdFpTd2dYRnhmYkc5blQwVmNYQ2tzSUZ4Y2MzUnlYekZ0WWx4Y0xDQWdZeWhjWEZNdFUxeGNMQ0JjWEZNdFdGeGNLU3dnWkdsbVprTjFkRzltWml3Z01XVTJLVnh1WEc1Z1lHQmNibUJnWUNKOSAtLT5cblxuYGBgclxuYGBgclxuIyBJbXBvcnQgYW5ub3RhdGlvblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPSAtNFxub2JzZXhwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfY29uc19vYnNleHAudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShsb2dfb2JzZXhwX0RNU08gPSBpZl9lbHNlKG9ic2V4cF9ETVNPID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9ETVNPKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX2RUQUcgPSBpZl9lbHNlKG9ic2V4cF9kVEFHID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9kVEFHKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX0E0ODUgPSBpZl9lbHNlKG9ic2V4cF9BNDg1ID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9BNDg1KSkpXG5cbiMgTWVyZ2UgZGF0YXNldFxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bGVmdF9qb2luKG9ic2V4cCwgYnkgPSBjKFxcaWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08gPSBsb2dfb2JzZXhwX2RUQUcgLSBsb2dfb2JzZXhwX0RNU08sXG4gICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA9IGxvZ19vYnNleHBfQTQ4NSAtIGxvZ19vYnNleHBfRE1TTylcblxuZGlmZkN1dG9mZiA8LSAwLjVcbmNyZWF0ZV9sb29wX3NjYXR0ZXJwbG90X29lKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2xvZ09FX1xcLCBcXGFsbFxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpLCBkaWZmQ3V0b2ZmKVxuY3JlYXRlX2xvb3Bfc2NhdHRlcnBsb3Rfb2UoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfbG9nT0VfXFwsIFxccmVnXFwpLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCBkaWZmQ3V0b2ZmKVxuY3JlYXRlX2xvb3Bfc2NhdHRlcnBsb3Rfb2UoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfbG9nT0VfXFwsIFxcc3RyXFwpLCBjKFxcUy1TXFwsIFxcUy1YXFwpLCBkaWZmQ3V0b2ZmKVxuXG5cblxuY3JlYXRlX2Rpc3RfYmFycGxvdF9vZShkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9sb2dPRVxcKSwgXFxhbGxcXCwgIHVuaXF1ZShkYXRhJEFubm8yKSwgZGlmZkN1dG9mZilcbmNyZWF0ZV9kaXN0X2JhcnBsb3Rfb2UoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfbG9nT0VcXCksIFxccmVnXFwsICBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCBkaWZmQ3V0b2ZmKVxuY3JlYXRlX2Rpc3RfYmFycGxvdF9vZShkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9sb2dPRVxcKSwgXFxyZWdfMW1iXFwsICBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCBkaWZmQ3V0b2ZmLCAxZTYpXG5jcmVhdGVfZGlzdF9iYXJwbG90X29lKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2xvZ09FXFwpLCBcXHN0clxcLCAgYyhcXFMtU1xcLCBcXFMtWFxcKSwgZGlmZkN1dG9mZilcbmNyZWF0ZV9kaXN0X2JhcnBsb3Rfb2UoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfbG9nT0VcXCksIFxcc3RyXzFtYlxcLCAgYyhcXFMtU1xcLCBcXFMtWFxcKSwgZGlmZkN1dG9mZiwgMWU2KVxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBJbXBvcnQgYW5ub3RhdGlvblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPSAtNFxub2JzZXhwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfY29uc19vYnNleHAudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShsb2dfb2JzZXhwX0RNU08gPSBpZl9lbHNlKG9ic2V4cF9ETVNPID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9ETVNPKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX2RUQUcgPSBpZl9lbHNlKG9ic2V4cF9kVEFHID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9kVEFHKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX0E0ODUgPSBpZl9lbHNlKG9ic2V4cF9BNDg1ID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9BNDg1KSkpXG5cbiMgTWVyZ2UgZGF0YXNldFxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bGVmdF9qb2luKG9ic2V4cCwgYnkgPSBjKFxcaWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08gPSBsb2dfb2JzZXhwX2RUQUcgLSBsb2dfb2JzZXhwX0RNU08sXG4gICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA9IGxvZ19vYnNleHBfQTQ4NSAtIGxvZ19vYnNleHBfRE1TTylcblxuZGlmZkN1dG9mZiA8LSAwLjVcbmNyZWF0ZV9sb29wX3NjYXR0ZXJwbG90X29lKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2xvZ09FX1xcLCBcXGFsbFxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpLCBkaWZmQ3V0b2ZmKVxuY3JlYXRlX2xvb3Bfc2NhdHRlcnBsb3Rfb2UoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfbG9nT0VfXFwsIFxccmVnXFwpLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCBkaWZmQ3V0b2ZmKVxuY3JlYXRlX2xvb3Bfc2NhdHRlcnBsb3Rfb2UoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfbG9nT0VfXFwsIFxcc3RyXFwpLCBjKFxcUy1TXFwsIFxcUy1YXFwpLCBkaWZmQ3V0b2ZmKVxuXG5cblxuY3JlYXRlX2Rpc3RfYmFycGxvdF9vZShkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9sb2dPRVxcKSwgXFxhbGxcXCwgIHVuaXF1ZShkYXRhJEFubm8yKSwgZGlmZkN1dG9mZilcbmNyZWF0ZV9kaXN0X2JhcnBsb3Rfb2UoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfbG9nT0VcXCksIFxccmVnXFwsICBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCBkaWZmQ3V0b2ZmKVxuY3JlYXRlX2Rpc3RfYmFycGxvdF9vZShkYXRhLCBmaWdEaXIsIHBhc3RlMChuYW1lLCBcXF9sb2dPRVxcKSwgXFxyZWdfMW1iXFwsICBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCBkaWZmQ3V0b2ZmLCAxZTYpXG5jcmVhdGVfZGlzdF9iYXJwbG90X29lKGRhdGEsIGZpZ0RpciwgcGFzdGUwKG5hbWUsIFxcX2xvZ09FXFwpLCBcXHN0clxcLCAgYyhcXFMtU1xcLCBcXFMtWFxcKSwgZGlmZkN1dG9mZilcbmNyZWF0ZV9kaXN0X2JhcnBsb3Rfb2UoZGF0YSwgZmlnRGlyLCBwYXN0ZTAobmFtZSwgXFxfbG9nT0VcXCksIFxcc3RyXzFtYlxcLCAgYyhcXFMtU1xcLCBcXFMtWFxcKSwgZGlmZkN1dG9mZiwgMWU2KVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
# Import annotation
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue = -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\)) %>%
  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

diffCutoff <- 0.5
create_loop_scatterplot_oe(data, figDir, paste0(name, \_logOE_\, \all\), unique(data$Anno2), diffCutoff)
create_loop_scatterplot_oe(data, figDir, paste0(name, \_logOE_\, \reg\), c(\P-P\, \P-E\, \E-E\), diffCutoff)
create_loop_scatterplot_oe(data, figDir, paste0(name, \_logOE_\, \str\), c(\S-S\, \S-X\), diffCutoff)



create_dist_barplot_oe(data, figDir, paste0(name, \_logOE\), \all\,  unique(data$Anno2), diffCutoff)
create_dist_barplot_oe(data, figDir, paste0(name, \_logOE\), \reg\,  c(\P-P\, \P-E\, \E-E\), diffCutoff)
create_dist_barplot_oe(data, figDir, paste0(name, \_logOE\), \reg_1mb\,  c(\P-P\, \P-E\, \E-E\), diffCutoff, 1e6)
create_dist_barplot_oe(data, figDir, paste0(name, \_logOE\), \str\,  c(\S-S\, \S-X\), diffCutoff)
create_dist_barplot_oe(data, figDir, paste0(name, \_logOE\), \str_1mb\,  c(\S-S\, \S-X\), diffCutoff, 1e6)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### A485

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJKYlhCdmNuUWdZVzV1YjNSaGRHbHZibHh1Ym1GdFpTQThMU0JjSW1Ob2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxjSWx4dVpHRjBZU0E4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRzVoYldVc0lGd2lMblJ6ZGx3aUtTa3BYRzVjYmlNZ1NXMXdiM0owSUc5aWN5OWxlSEFnYzJOdmNtVnpJR0Z1WkNCdFpYSm5aU0IwYnlCMGFHVWdaR0YwWVhObGRGeHViV2x1Vm1Gc2RXVWdQU0F0TkZ4dWIySnpaWGh3SUR3dElHWnlaV0ZrS0dobGNtVW9ZMjl1YzJWdWMzVnpSR2x5TENCd1lYTjBaVEFvWENKc2IyOXdVMk52Y21WZlkyOXVjMTl2WW5ObGVIQXVkSE4yWENJcEtTa2dKVDRsWEc0Z0lDQWdaSEJzZVhJNk9tMTFkR0YwWlNoc2IyZGZiMkp6Wlhod1gwUk5VMDhnUFNCcFpsOWxiSE5sS0c5aWMyVjRjRjlFVFZOUElEMDlJREFzSUcxcGJsWmhiSFZsTENCc2IyY3lLRzlpYzJWNGNGOUVUVk5QS1Nrc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnNiMmRmYjJKelpYaHdYMlJVUVVjZ1BTQnBabDlsYkhObEtHOWljMlY0Y0Y5a1ZFRkhJRDA5SURBc0lHMXBibFpoYkhWbExDQnNiMmN5S0c5aWMyVjRjRjlrVkVGSEtTa3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JzYjJkZmIySnpaWGh3WDBFME9EVWdQU0JwWmw5bGJITmxLRzlpYzJWNGNGOUJORGcxSUQwOUlEQXNJRzFwYmxaaGJIVmxMQ0JzYjJjeUtHOWljMlY0Y0Y5Qk5EZzFLU2twWEc1Y2JpTWdUV1Z5WjJVZ1pHRjBZWE5sZEZ4dVpHRjBZU0E4TFNCa1lYUmhJQ1UrSlNCa2NHeDVjam82YkdWbWRGOXFiMmx1S0c5aWMyVjRjQ3dnWW5rZ1BTQmpLRndpYVdSY0lpa3BJQ1UrSlZ4dUlDQmtjR3g1Y2pvNmJYVjBZWFJsS0d4dloxOXZZbk5sZUhCZlpHbG1abDlrVkVGSFgwUk5VMDhnUFNCc2IyZGZiMkp6Wlhod1gyUlVRVWNnTFNCc2IyZGZiMkp6Wlhod1gwUk5VMDhzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnYkc5blgyOWljMlY0Y0Y5a2FXWm1YMEUwT0RWZlJFMVRUeUE5SUd4dloxOXZZbk5sZUhCZlFUUTROU0F0SUd4dloxOXZZbk5sZUhCZlJFMVRUeWxjYm1ScFptWkRkWFJ2Wm1ZZ1BDMGdNQzQxWEc1dFlXdGxYMlJwWm1aZlltVmtjR1ZmYjJVb1pHRjBZU3dnY0dGemRHVXdLRzVoYldVc0lGd2lYMnh2WjA5Rlgxd2lMQ0JjSW1Gc2JGd2lLU3dnZFc1cGNYVmxLR1JoZEdFa1FXNXVieklwTENCamIyNXpaVzV6ZFhORWFYSXNJR1JwWm1aRGRYUnZabVlwWEc1dFlXdGxYMlJwWm1aZlltVmtjR1ZmYjJVb1pHRjBZU3dnY0dGemRHVXdLRzVoYldVc0lGd2lYMnh2WjA5Rlgxd2lMQ0JjSW5CbExYQmxYQ0lwTENCaktGd2lVQzFRWENJc0lGd2lVQzFGWENJc0lGd2lSUzFGWENJcExDQmpiMjV6Wlc1emRYTkVhWElzSUdScFptWkRkWFJ2Wm1ZcFhHNXRZV3RsWDJScFptWmZZbVZrY0dWZmIyVW9aR0YwWVN3Z2NHRnpkR1V3S0c1aGJXVXNJRndpWDJ4dlowOUZYMXdpTENCY0luTjBjbHdpS1N3Z1l5aGNJbE10VTF3aUxDQmNJbE10V0Z3aUtTd2dZMjl1YzJWdWMzVnpSR2x5TENCa2FXWm1RM1YwYjJabUtWeHVYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbiMgSW1wb3J0IGFubm90YXRpb25cbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5XFxcbmRhdGEgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpKVxuXG4jIEltcG9ydCBvYnMvZXhwIHNjb3JlcyBhbmQgbWVyZ2UgdG8gdGhlIGRhdGFzZXRcbm1pblZhbHVlID0gLTRcbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUobG9nX29ic2V4cF9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfRE1TTykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kVEFHID0gaWZfZWxzZShvYnNleHBfZFRBRyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfZFRBRykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9BNDg1ID0gaWZfZWxzZShvYnNleHBfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQTQ4NSkpKVxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcXGlkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPID0gbG9nX29ic2V4cF9kVEFHIC0gbG9nX29ic2V4cF9ETVNPLFxuICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZGlmZl9BNDg1X0RNU08gPSBsb2dfb2JzZXhwX0E0ODUgLSBsb2dfb2JzZXhwX0RNU08pXG5kaWZmQ3V0b2ZmIDwtIDAuNVxubWFrZV9kaWZmX2JlZHBlX29lKGRhdGEsIHBhc3RlMChuYW1lLCBcXF9sb2dPRV9cXCwgXFxhbGxcXCksIHVuaXF1ZShkYXRhJEFubm8yKSwgY29uc2Vuc3VzRGlyLCBkaWZmQ3V0b2ZmKVxubWFrZV9kaWZmX2JlZHBlX29lKGRhdGEsIHBhc3RlMChuYW1lLCBcXF9sb2dPRV9cXCwgXFxwZS1wZVxcKSwgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSwgY29uc2Vuc3VzRGlyLCBkaWZmQ3V0b2ZmKVxubWFrZV9kaWZmX2JlZHBlX29lKGRhdGEsIHBhc3RlMChuYW1lLCBcXF9sb2dPRV9cXCwgXFxzdHJcXCksIGMoXFxTLVNcXCwgXFxTLVhcXCksIGNvbnNlbnN1c0RpciwgZGlmZkN1dG9mZilcblxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
# Import annotation
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue = -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\)) %>%
  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)
diffCutoff <- 0.5
make_diff_bedpe_oe(data, paste0(name, \_logOE_\, \all\), unique(data$Anno2), consensusDir, diffCutoff)
make_diff_bedpe_oe(data, paste0(name, \_logOE_\, \pe-pe\), c(\P-P\, \P-E\, \E-E\), consensusDir, diffCutoff)
make_diff_bedpe_oe(data, paste0(name, \_logOE_\, \str\), c(\S-S\, \S-X\), consensusDir, diffCutoff)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QkpiWEJ2Y25RZ1lXNXViM1JoZEdsdmJseHVibUZ0WlNBOExTQmNYR05vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGNYRnh1WkdGMFlTQThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y0xuUnpkbHhjS1NrcFhHNWNiaU1nU1cxd2IzSjBJRzlpY3k5bGVIQWdjMk52Y21WeklHRnVaQ0J0WlhKblpTQjBieUIwYUdVZ1pHRjBZWE5sZEZ4dWJXbHVWbUZzZFdVZ1BTQXRORnh1YjJKelpYaHdJRHd0SUdaeVpXRmtLR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0J3WVhOMFpUQW9YRnhzYjI5d1UyTnZjbVZmWTI5dWMxOXZZbk5sZUhBdWRITjJYRndwS1NrZ0pUNGxYRzRnSUNBZ1pIQnNlWEk2T20xMWRHRjBaU2hzYjJkZmIySnpaWGh3WDBSTlUwOGdQU0JwWmw5bGJITmxLRzlpYzJWNGNGOUVUVk5QSUQwOUlEQXNJRzFwYmxaaGJIVmxMQ0JzYjJjeUtHOWljMlY0Y0Y5RVRWTlBLU2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNCc2IyZGZiMkp6Wlhod1gyUlVRVWNnUFNCcFpsOWxiSE5sS0c5aWMyVjRjRjlrVkVGSElEMDlJREFzSUcxcGJsWmhiSFZsTENCc2IyY3lLRzlpYzJWNGNGOWtWRUZIS1Nrc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQnNiMmRmYjJKelpYaHdYMEUwT0RVZ1BTQnBabDlsYkhObEtHOWljMlY0Y0Y5Qk5EZzFJRDA5SURBc0lHMXBibFpoYkhWbExDQnNiMmN5S0c5aWMyVjRjRjlCTkRnMUtTa3BYRzVjYmlNZ1RXVnlaMlVnWkdGMFlYTmxkRnh1WkdGMFlTQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZiR1ZtZEY5cWIybHVLRzlpYzJWNGNDd2dZbmtnUFNCaktGeGNhV1JjWENrcElDVStKVnh1SUNCa2NHeDVjam82YlhWMFlYUmxLR3h2WjE5dlluTmxlSEJmWkdsbVpsOWtWRUZIWDBSTlUwOGdQU0JzYjJkZmIySnpaWGh3WDJSVVFVY2dMU0JzYjJkZmIySnpaWGh3WDBSTlUwOHNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdiRzluWDI5aWMyVjRjRjlrYVdabVgwRTBPRFZmUkUxVFR5QTlJR3h2WjE5dlluTmxlSEJmUVRRNE5TQXRJR3h2WjE5dlluTmxlSEJmUkUxVFR5bGNibVJwWm1aRGRYUnZabVlnUEMwZ01DNDFYRzV0WVd0bFgyUnBabVpmWW1Wa2NHVmZiMlVvWkdGMFlTd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gyeHZaMDlGWDF4Y0xDQmNYR0ZzYkZ4Y0tTd2dkVzVwY1hWbEtHUmhkR0VrUVc1dWJ6SXBMQ0JqYjI1elpXNXpkWE5FYVhJc0lHUnBabVpEZFhSdlptWXBYRzV0WVd0bFgyUnBabVpmWW1Wa2NHVmZiMlVvWkdGMFlTd2djR0Z6ZEdVd0tHNWhiV1VzSUZ4Y1gyeHZaMDlGWDF4Y0xDQmNYSEJsTFhCbFhGd3BMQ0JqS0Z4Y1VDMVFYRndzSUZ4Y1VDMUZYRndzSUZ4Y1JTMUZYRndwTENCamIyNXpaVzV6ZFhORWFYSXNJR1JwWm1aRGRYUnZabVlwWEc1dFlXdGxYMlJwWm1aZlltVmtjR1ZmYjJVb1pHRjBZU3dnY0dGemRHVXdLRzVoYldVc0lGeGNYMnh2WjA5RlgxeGNMQ0JjWEhOMGNseGNLU3dnWXloY1hGTXRVMXhjTENCY1hGTXRXRnhjS1N3Z1kyOXVjMlZ1YzNWelJHbHlMQ0JrYVdabVEzVjBiMlptS1Z4dVhHNWdZR0JjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbmBgYHJcbiMgSW1wb3J0IGFubm90YXRpb25cbm5hbWUgPC0gXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5XFxcbmRhdGEgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXC50c3ZcXCkpKVxuXG4jIEltcG9ydCBvYnMvZXhwIHNjb3JlcyBhbmQgbWVyZ2UgdG8gdGhlIGRhdGFzZXRcbm1pblZhbHVlID0gLTRcbm9ic2V4cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcbG9vcFNjb3JlX2NvbnNfb2JzZXhwLnRzdlxcKSkpICU+JVxuICAgIGRwbHlyOjptdXRhdGUobG9nX29ic2V4cF9ETVNPID0gaWZfZWxzZShvYnNleHBfRE1TTyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfRE1TTykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kVEFHID0gaWZfZWxzZShvYnNleHBfZFRBRyA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfZFRBRykpLFxuICAgICAgICAgICAgICAgICAgbG9nX29ic2V4cF9BNDg1ID0gaWZfZWxzZShvYnNleHBfQTQ4NSA9PSAwLCBtaW5WYWx1ZSwgbG9nMihvYnNleHBfQTQ4NSkpKVxuXG4jIE1lcmdlIGRhdGFzZXRcbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihvYnNleHAsIGJ5ID0gYyhcXGlkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShsb2dfb2JzZXhwX2RpZmZfZFRBR19ETVNPID0gbG9nX29ic2V4cF9kVEFHIC0gbG9nX29ic2V4cF9ETVNPLFxuICAgICAgICAgICAgICAgIGxvZ19vYnNleHBfZGlmZl9BNDg1X0RNU08gPSBsb2dfb2JzZXhwX0E0ODUgLSBsb2dfb2JzZXhwX0RNU08pXG5kaWZmQ3V0b2ZmIDwtIDAuNVxubWFrZV9kaWZmX2JlZHBlX29lKGRhdGEsIHBhc3RlMChuYW1lLCBcXF9sb2dPRV9cXCwgXFxhbGxcXCksIHVuaXF1ZShkYXRhJEFubm8yKSwgY29uc2Vuc3VzRGlyLCBkaWZmQ3V0b2ZmKVxubWFrZV9kaWZmX2JlZHBlX29lKGRhdGEsIHBhc3RlMChuYW1lLCBcXF9sb2dPRV9cXCwgXFxwZS1wZVxcKSwgYyhcXFAtUFxcLCBcXFAtRVxcLCBcXEUtRVxcKSwgY29uc2Vuc3VzRGlyLCBkaWZmQ3V0b2ZmKVxubWFrZV9kaWZmX2JlZHBlX29lKGRhdGEsIHBhc3RlMChuYW1lLCBcXF9sb2dPRV9cXCwgXFxzdHJcXCksIGMoXFxTLVNcXCwgXFxTLVhcXCksIGNvbnNlbnN1c0RpciwgZGlmZkN1dG9mZilcblxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBJbXBvcnQgYW5ub3RhdGlvblxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGF0YSA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKG5hbWUsIFxcLnRzdlxcKSkpXG5cbiMgSW1wb3J0IG9icy9leHAgc2NvcmVzIGFuZCBtZXJnZSB0byB0aGUgZGF0YXNldFxubWluVmFsdWUgPSAtNFxub2JzZXhwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAoXFxsb29wU2NvcmVfY29uc19vYnNleHAudHN2XFwpKSkgJT4lXG4gICAgZHBseXI6Om11dGF0ZShsb2dfb2JzZXhwX0RNU08gPSBpZl9lbHNlKG9ic2V4cF9ETVNPID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9ETVNPKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX2RUQUcgPSBpZl9lbHNlKG9ic2V4cF9kVEFHID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9kVEFHKSksXG4gICAgICAgICAgICAgICAgICBsb2dfb2JzZXhwX0E0ODUgPSBpZl9lbHNlKG9ic2V4cF9BNDg1ID09IDAsIG1pblZhbHVlLCBsb2cyKG9ic2V4cF9BNDg1KSkpXG5cbiMgTWVyZ2UgZGF0YXNldFxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bGVmdF9qb2luKG9ic2V4cCwgYnkgPSBjKFxcaWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGxvZ19vYnNleHBfZGlmZl9kVEFHX0RNU08gPSBsb2dfb2JzZXhwX2RUQUcgLSBsb2dfb2JzZXhwX0RNU08sXG4gICAgICAgICAgICAgICAgbG9nX29ic2V4cF9kaWZmX0E0ODVfRE1TTyA9IGxvZ19vYnNleHBfQTQ4NSAtIGxvZ19vYnNleHBfRE1TTylcbmRpZmZDdXRvZmYgPC0gMC41XG5tYWtlX2RpZmZfYmVkcGVfb2UoZGF0YSwgcGFzdGUwKG5hbWUsIFxcX2xvZ09FX1xcLCBcXGFsbFxcKSwgdW5pcXVlKGRhdGEkQW5ubzIpLCBjb25zZW5zdXNEaXIsIGRpZmZDdXRvZmYpXG5tYWtlX2RpZmZfYmVkcGVfb2UoZGF0YSwgcGFzdGUwKG5hbWUsIFxcX2xvZ09FX1xcLCBcXHBlLXBlXFwpLCBjKFxcUC1QXFwsIFxcUC1FXFwsIFxcRS1FXFwpLCBjb25zZW5zdXNEaXIsIGRpZmZDdXRvZmYpXG5tYWtlX2RpZmZfYmVkcGVfb2UoZGF0YSwgcGFzdGUwKG5hbWUsIFxcX2xvZ09FX1xcLCBcXHN0clxcKSwgYyhcXFMtU1xcLCBcXFMtWFxcKSwgY29uc2Vuc3VzRGlyLCBkaWZmQ3V0b2ZmKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
# Import annotation
name <- \chromo_cons_annoHierarchy\
data <- fread(here(consensusDir, paste0(name, \.tsv\)))

# Import obs/exp scores and merge to the dataset
minValue = -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c(\id\)) %>%
  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)
diffCutoff <- 0.5
make_diff_bedpe_oe(data, paste0(name, \_logOE_\, \all\), unique(data$Anno2), consensusDir, diffCutoff)
make_diff_bedpe_oe(data, paste0(name, \_logOE_\, \pe-pe\), c(\P-P\, \P-E\, \E-E\), consensusDir, diffCutoff)
make_diff_bedpe_oe(data, paste0(name, \_logOE_\, \str\), c(\S-S\, \S-X\), consensusDir, diffCutoff)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Get size distribution of differential loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVaM0p2ZFhBeElEd3RJR1p5WldGa0tHaGxjbVVvY21WbVJHbHlMQ0JjSW1kbGJtVk1hWE4wWDJSVVFVZGZkbk5mUkUxVFQxOVNUa0ZmYkc5dmNGOWlhVzVoY25sSGNtOTFjREV1ZEhOMlhDSXBLU1JuWlc1bFhHNW5jbTkxY0RJZ1BDMGdabkpsWVdRb2FHVnlaU2h5WldaRWFYSXNJRndpWjJWdVpVeHBjM1JmWkZSQlIxOTJjMTlFVFZOUFgxSk9RVjlzYjI5d1gySnBibUZ5ZVVkeWIzVndNaTUwYzNaY0lpa3BKR2RsYm1WY2JseHVabXhoYm10VGFYcGxJRHd0SURGY2JtZGxibVV1ZEdJZ1BDMGdabkpsWVdRb2FHVnlaU2h5WldaRWFYSXNJRndpYlcweE1GOUhVa050TXpndWNEWmZaMlZ1WlY5emIzSjBaV1F1WW1Wa1hDSXBLU0FsUGlWY2JpQWdaSEJzZVhJNk9tMTFkR0YwWlNoVVUxTWdQU0JwWm1Wc2MyVW9WalFnUFQwZ1hDSXJYQ0lzSUZZeUxDQldNeWtzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnVkZOVGMzUmhjblFnUFNCVVUxTWdMU0JtYkdGdWExTnBlbVVzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnVkZOVFpXNWtJRDBnVkZOVElDc2dabXhoYm10VGFYcGxLU0FsUGlWY2JpQWdaSEJzZVhJNk9uTmxiR1ZqZENoV01Td2dWRk5UYzNSaGNuUXNJRlJUVTJWdVpDd2dWallwWEc1amIyeHVZVzFsY3loblpXNWxMblJpS1NBOExTQmpLRndpWTJoeVhDSXNJRndpYzNSaGNuUmNJaXdnWENKbGJtUmNJaXdnWENKbGJuTmxiV0pzWENJcFhHNWNibUpsWkM0eElEd3RJR2RsYm1VdWRHSWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9aVzV6WlcxaWJDQWxhVzRsSUdkeWIzVndNU2tnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWXlneExDQXlMQ0F6S1NsY2JtSmxaQzR5SUR3dElHZGxibVV1ZEdJZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1pXNXpaVzFpYkNBbGFXNGxJR2R5YjNWd01pa2dKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9ZeWd4TENBeUxDQXpLU2xjYmx4dVpuZHlhWFJsS0dKbFpDNHhMQ0JvWlhKbEtISmxaa1JwY2l3Z1hDSlVVMU5mWW1sdVlYSjVSM0p2ZFhBeExtSmxaRndpS1N3Z2MyVndJRDBnWENKY1hIUmNJaXdnWTI5c0xtNWhiV1Z6SUQwZ1JrRk1VMFVwWEc1bWQzSnBkR1VvWW1Wa0xqSXNJR2hsY21Vb2NtVm1SR2x5TENCY0lsUlRVMTlpYVc1aGNubEhjbTkxY0RJdVltVmtYQ0lwTENCelpYQWdQU0JjSWx4Y2RGd2lMQ0JqYjJ3dWJtRnRaWE1nUFNCR1FVeFRSU2xjYmx4dVhHNWNibWRsYm1VdWRHSWdQQzBnWm5KbFlXUW9hR1Z5WlNoeVpXWkVhWElzSUZ3aWJXMHhNRjlIVWtOdE16Z3VjRFpmWjJWdVpWOXpiM0owWldRdVltVmtYQ0lwS1Z4dVhHNWlaV1F1TVNBOExTQm5aVzVsTG5SaUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtGWTJJQ1ZwYmlVZ1ozSnZkWEF4S1Z4dVltVmtMaklnUEMwZ1oyVnVaUzUwWWlBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2loV05pQWxhVzRsSUdkeWIzVndNaWxjYmx4dVpuZHlhWFJsS0dKbFpDNHhMQ0JvWlhKbEtISmxaa1JwY2l3Z1hDSlVVMU5mWW1sdVlYSjVSM0p2ZFhBeFgyZDBaaTVpWldSY0lpa3NJSE5sY0NBOUlGd2lYRngwWENJc0lHTnZiQzV1WVcxbGN5QTlJRVpCVEZORktWeHVabmR5YVhSbEtHSmxaQzR5TENCb1pYSmxLSEpsWmtScGNpd2dYQ0pVVTFOZlltbHVZWEo1UjNKdmRYQXlYMmQwWmk1aVpXUmNJaWtzSUhObGNDQTlJRndpWEZ4MFhDSXNJR052YkM1dVlXMWxjeUE5SUVaQlRGTkZLVnh1WEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG5mbGFua1NpemUgPC0gMVxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSxcbiAgICAgICAgICAgICAgICBUU1NzdGFydCA9IFRTUyAtIGZsYW5rU2l6ZSxcbiAgICAgICAgICAgICAgICBUU1NlbmQgPSBUU1MgKyBmbGFua1NpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBUU1NzdGFydCwgVFNTZW5kLCBWNilcbmNvbG5hbWVzKGdlbmUudGIpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGVuc2VtYmxcXClcblxuYmVkLjEgPC0gZ2VuZS50YiAlPiUgZHBseXI6OmZpbHRlcihlbnNlbWJsICVpbiUgZ3JvdXAxKSAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuYmVkLjIgPC0gZ2VuZS50YiAlPiUgZHBseXI6OmZpbHRlcihlbnNlbWJsICVpbiUgZ3JvdXAyKSAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuXG5md3JpdGUoYmVkLjEsIGhlcmUocmVmRGlyLCBcXFRTU19iaW5hcnlHcm91cDEuYmVkXFwpLCBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBGQUxTRSlcbmZ3cml0ZShiZWQuMiwgaGVyZShyZWZEaXIsIFxcVFNTX2JpbmFyeUdyb3VwMi5iZWRcXCksIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IEZBTFNFKVxuXG5cblxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpXG5cbmJlZC4xIDwtIGdlbmUudGIgJT4lIGRwbHlyOjpmaWx0ZXIoVjYgJWluJSBncm91cDEpXG5iZWQuMiA8LSBnZW5lLnRiICU+JSBkcGx5cjo6ZmlsdGVyKFY2ICVpbiUgZ3JvdXAyKVxuXG5md3JpdGUoYmVkLjEsIGhlcmUocmVmRGlyLCBcXFRTU19iaW5hcnlHcm91cDFfZ3RmLmJlZFxcKSwgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gRkFMU0UpXG5md3JpdGUoYmVkLjIsIGhlcmUocmVmRGlyLCBcXFRTU19iaW5hcnlHcm91cDJfZ3RmLmJlZFxcKSwgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gRkFMU0UpXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

flankSize <- 1
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6)
colnames(gene.tb) <- c(\chr\, \start\, \end\, \ensembl\)

bed.1 <- gene.tb %>% dplyr::filter(ensembl %in% group1) %>% dplyr::select(c(1, 2, 3))
bed.2 <- gene.tb %>% dplyr::filter(ensembl %in% group2) %>% dplyr::select(c(1, 2, 3))

fwrite(bed.1, here(refDir, \TSS_binaryGroup1.bed\), sep = \\t\, col.names = FALSE)
fwrite(bed.2, here(refDir, \TSS_binaryGroup2.bed\), sep = \\t\, col.names = FALSE)



gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\))

bed.1 <- gene.tb %>% dplyr::filter(V6 %in% group1)
bed.2 <- gene.tb %>% dplyr::filter(V6 %in% group2)

fwrite(bed.1, here(refDir, \TSS_binaryGroup1_gtf.bed\), sep = \\t\, col.names = FALSE)
fwrite(bed.2, here(refDir, \TSS_binaryGroup2_gtf.bed\), sep = \\t\, col.names = FALSE)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVozSnZkWEF4SUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNYR2RsYm1WTWFYTjBYMlJVUVVkZmRuTmZSRTFUVDE5U1RrRmZiRzl2Y0Y5aWFXNWhjbmxIY205MWNERXVkSE4yWEZ3cEtTUm5aVzVsWEc1bmNtOTFjRElnUEMwZ1puSmxZV1FvYUdWeVpTaHlaV1pFYVhJc0lGeGNaMlZ1WlV4cGMzUmZaRlJCUjE5MmMxOUVUVk5QWDFKT1FWOXNiMjl3WDJKcGJtRnllVWR5YjNWd01pNTBjM1pjWENrcEpHZGxibVZjYmx4dVpteGhibXRUYVhwbElEd3RJREZjYm1kbGJtVXVkR0lnUEMwZ1puSmxZV1FvYUdWeVpTaHlaV1pFYVhJc0lGeGNiVzB4TUY5SFVrTnRNemd1Y0RaZloyVnVaVjl6YjNKMFpXUXVZbVZrWEZ3cEtTQWxQaVZjYmlBZ1pIQnNlWEk2T20xMWRHRjBaU2hVVTFNZ1BTQnBabVZzYzJVb1ZqUWdQVDBnWEZ3clhGd3NJRll5TENCV015a3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdWRk5UYzNSaGNuUWdQU0JVVTFNZ0xTQm1iR0Z1YTFOcGVtVXNYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdWRk5UWlc1a0lEMGdWRk5USUNzZ1pteGhibXRUYVhwbEtTQWxQaVZjYmlBZ1pIQnNlWEk2T25ObGJHVmpkQ2hXTVN3Z1ZGTlRjM1JoY25Rc0lGUlRVMlZ1WkN3Z1ZqWXBYRzVqYjJ4dVlXMWxjeWhuWlc1bExuUmlLU0E4TFNCaktGeGNZMmh5WEZ3c0lGeGNjM1JoY25SY1hDd2dYRnhsYm1SY1hDd2dYRnhsYm5ObGJXSnNYRndwWEc1Y2JtSmxaQzR4SUR3dElHZGxibVV1ZEdJZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1pXNXpaVzFpYkNBbGFXNGxJR2R5YjNWd01Ta2dKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9ZeWd4TENBeUxDQXpLU2xjYm1KbFpDNHlJRHd0SUdkbGJtVXVkR0lnSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvWlc1elpXMWliQ0FsYVc0bElHZHliM1Z3TWlrZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1l5Z3hMQ0F5TENBektTbGNibHh1Wm5keWFYUmxLR0psWkM0eExDQm9aWEpsS0hKbFprUnBjaXdnWEZ4VVUxTmZZbWx1WVhKNVIzSnZkWEF4TG1KbFpGeGNLU3dnYzJWd0lEMGdYRnhjWEhSY1hDd2dZMjlzTG01aGJXVnpJRDBnUmtGTVUwVXBYRzVtZDNKcGRHVW9ZbVZrTGpJc0lHaGxjbVVvY21WbVJHbHlMQ0JjWEZSVFUxOWlhVzVoY25sSGNtOTFjREl1WW1Wa1hGd3BMQ0J6WlhBZ1BTQmNYRnhjZEZ4Y0xDQmpiMnd1Ym1GdFpYTWdQU0JHUVV4VFJTbGNibHh1WEc1Y2JtZGxibVV1ZEdJZ1BDMGdabkpsWVdRb2FHVnlaU2h5WldaRWFYSXNJRnhjYlcweE1GOUhVa050TXpndWNEWmZaMlZ1WlY5emIzSjBaV1F1WW1Wa1hGd3BLVnh1WEc1aVpXUXVNU0E4TFNCblpXNWxMblJpSUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0ZZMklDVnBiaVVnWjNKdmRYQXhLVnh1WW1Wa0xqSWdQQzBnWjJWdVpTNTBZaUFsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhXTmlBbGFXNGxJR2R5YjNWd01pbGNibHh1Wm5keWFYUmxLR0psWkM0eExDQm9aWEpsS0hKbFprUnBjaXdnWEZ4VVUxTmZZbWx1WVhKNVIzSnZkWEF4WDJkMFppNWlaV1JjWENrc0lITmxjQ0E5SUZ4Y1hGeDBYRndzSUdOdmJDNXVZVzFsY3lBOUlFWkJURk5GS1Z4dVpuZHlhWFJsS0dKbFpDNHlMQ0JvWlhKbEtISmxaa1JwY2l3Z1hGeFVVMU5mWW1sdVlYSjVSM0p2ZFhBeVgyZDBaaTVpWldSY1hDa3NJSE5sY0NBOUlGeGNYRngwWEZ3c0lHTnZiQzV1WVcxbGN5QTlJRVpCVEZORktWeHVYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG5mbGFua1NpemUgPC0gMVxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSxcbiAgICAgICAgICAgICAgICBUU1NzdGFydCA9IFRTUyAtIGZsYW5rU2l6ZSxcbiAgICAgICAgICAgICAgICBUU1NlbmQgPSBUU1MgKyBmbGFua1NpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBUU1NzdGFydCwgVFNTZW5kLCBWNilcbmNvbG5hbWVzKGdlbmUudGIpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGVuc2VtYmxcXClcblxuYmVkLjEgPC0gZ2VuZS50YiAlPiUgZHBseXI6OmZpbHRlcihlbnNlbWJsICVpbiUgZ3JvdXAxKSAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuYmVkLjIgPC0gZ2VuZS50YiAlPiUgZHBseXI6OmZpbHRlcihlbnNlbWJsICVpbiUgZ3JvdXAyKSAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuXG5md3JpdGUoYmVkLjEsIGhlcmUocmVmRGlyLCBcXFRTU19iaW5hcnlHcm91cDEuYmVkXFwpLCBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBGQUxTRSlcbmZ3cml0ZShiZWQuMiwgaGVyZShyZWZEaXIsIFxcVFNTX2JpbmFyeUdyb3VwMi5iZWRcXCksIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IEZBTFNFKVxuXG5cblxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpXG5cbmJlZC4xIDwtIGdlbmUudGIgJT4lIGRwbHlyOjpmaWx0ZXIoVjYgJWluJSBncm91cDEpXG5iZWQuMiA8LSBnZW5lLnRiICU+JSBkcGx5cjo6ZmlsdGVyKFY2ICVpbiUgZ3JvdXAyKVxuXG5md3JpdGUoYmVkLjEsIGhlcmUocmVmRGlyLCBcXFRTU19iaW5hcnlHcm91cDFfZ3RmLmJlZFxcKSwgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gRkFMU0UpXG5md3JpdGUoYmVkLjIsIGhlcmUocmVmRGlyLCBcXFRTU19iaW5hcnlHcm91cDJfZ3RmLmJlZFxcKSwgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gRkFMU0UpXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuZmxhbmtTaXplIDwtIDFcbmdlbmUudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXFwrXFwsIFYyLCBWMyksXG4gICAgICAgICAgICAgICAgVFNTc3RhcnQgPSBUU1MgLSBmbGFua1NpemUsXG4gICAgICAgICAgICAgICAgVFNTZW5kID0gVFNTICsgZmxhbmtTaXplKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWMSwgVFNTc3RhcnQsIFRTU2VuZCwgVjYpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxlbnNlbWJsXFwpXG5cbmJlZC4xIDwtIGdlbmUudGIgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGdyb3VwMSkgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzKSlcbmJlZC4yIDwtIGdlbmUudGIgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGdyb3VwMikgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzKSlcblxuZndyaXRlKGJlZC4xLCBoZXJlKHJlZkRpciwgXFxUU1NfYmluYXJ5R3JvdXAxLmJlZFxcKSwgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gRkFMU0UpXG5md3JpdGUoYmVkLjIsIGhlcmUocmVmRGlyLCBcXFRTU19iaW5hcnlHcm91cDIuYmVkXFwpLCBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBGQUxTRSlcblxuXG5cbmdlbmUudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKVxuXG5iZWQuMSA8LSBnZW5lLnRiICU+JSBkcGx5cjo6ZmlsdGVyKFY2ICVpbiUgZ3JvdXAxKVxuYmVkLjIgPC0gZ2VuZS50YiAlPiUgZHBseXI6OmZpbHRlcihWNiAlaW4lIGdyb3VwMilcblxuZndyaXRlKGJlZC4xLCBoZXJlKHJlZkRpciwgXFxUU1NfYmluYXJ5R3JvdXAxX2d0Zi5iZWRcXCksIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IEZBTFNFKVxuZndyaXRlKGJlZC4yLCBoZXJlKHJlZkRpciwgXFxUU1NfYmluYXJ5R3JvdXAyX2d0Zi5iZWRcXCksIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IEZBTFNFKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

flankSize <- 1
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6)
colnames(gene.tb) <- c(\chr\, \start\, \end\, \ensembl\)

bed.1 <- gene.tb %>% dplyr::filter(ensembl %in% group1) %>% dplyr::select(c(1, 2, 3))
bed.2 <- gene.tb %>% dplyr::filter(ensembl %in% group2) %>% dplyr::select(c(1, 2, 3))

fwrite(bed.1, here(refDir, \TSS_binaryGroup1.bed\), sep = \\t\, col.names = FALSE)
fwrite(bed.2, here(refDir, \TSS_binaryGroup2.bed\), sep = \\t\, col.names = FALSE)



gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\))

bed.1 <- gene.tb %>% dplyr::filter(V6 %in% group1)
bed.2 <- gene.tb %>% dplyr::filter(V6 %in% group2)

fwrite(bed.1, here(refDir, \TSS_binaryGroup1_gtf.bed\), sep = \\t\, col.names = FALSE)
fwrite(bed.2, here(refDir, \TSS_binaryGroup2_gtf.bed\), sep = \\t\, col.names = FALSE)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Splitting loops into diff bedpe

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVaM0p2ZFhBeElEd3RJR1p5WldGa0tHaGxjbVVvY21WbVJHbHlMQ0JjSW1kbGJtVk1hWE4wWDJSVVFVZGZkbk5mUkUxVFQxOVNUa0ZmYkc5dmNGOWlhVzVoY25sSGNtOTFjREV1ZEhOMlhDSXBLU1JuWlc1bFhHNW5jbTkxY0RJZ1BDMGdabkpsWVdRb2FHVnlaU2h5WldaRWFYSXNJRndpWjJWdVpVeHBjM1JmWkZSQlIxOTJjMTlFVFZOUFgxSk9RVjlzYjI5d1gySnBibUZ5ZVVkeWIzVndNaTUwYzNaY0lpa3BKR2RsYm1WY2JseHVaR0YwWVNBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYQ0p5WldGa1EyOTFiblF1Wm1sc2RHVnlaV1F1VkZCTkxtRnNiQzUwYzNaY0lpa3BJQ1UrSlNCa2NHeDVjam82YlhWMFlYUmxLRnh1SUNCbmNtOTFjQ0E5SUdOaGMyVmZkMmhsYmlobGJuTmxiV0pzSUNWcGJpVWdaM0p2ZFhBeElINGdYQ0puY205MWNERmNJaXhjYmlBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ1pXNXpaVzFpYkNBbGFXNGxJR2R5YjNWd01pQitJRndpWjNKdmRYQXlYQ0lzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGUlNWVVVnZmlCT1FTbGNiaWtnSlQ0bFhHNGdJR1J3YkhseU9qcG1hV3gwWlhJb0lXbHpMbTVoS0dkeWIzVndLU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHpaV3hsWTNRb1l5Z3pOQ3dnTVN3Z015d2dOQ3dnTlN3Z01UUXNJREUxTENBek5Da3BYRzVjYm1SaGRHRWdQQzBnWkdGMFlTQWxQaVVnYlhWMFlYUmxLR0YyWlhKaFoyVWdQU0J5YjNkTlpXRnVjeWhoWTNKdmMzTW9ZMjlzYm1GdFpYTW9aR0YwWVNsYk16bzNYU2twS1Z4dVhHNTBaVzF3SUR3dElHUmhkR0VnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWjNKdmRYQXNJR0YyWlhKaFoyVXBYRzVjYmx4dVoyVjBVSFpoYkZkcGJHTnZlQ0E4TFNCbWRXNWpkR2x2Ymloa1lYUmhMQ0JuY205MWNERXNJR2R5YjNWd01pbDdYRzRnSUdScGMzUmhibU5sTVNBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFdkeWIzVndNU2tnS1NSaGRtVnlZV2RsWEc0Z0lHUnBjM1JoYm1ObE1pQThMU0FvWkdGMFlTQWxQaVVnWkhCc2VYSTZPbVpwYkhSbGNpaG5jbTkxY0NBOVBXZHliM1Z3TWlrZ0tTUmhkbVZ5WVdkbFhHNGdJSGRwYkNBOExTQjNhV3hqYjNndWRHVnpkQ2hrYVhOMFlXNWpaVEVzSUdScGMzUmhibU5sTWlsY2JpQWdjbVYwZFhKdUtIZHBiQ1J3TG5aaGJIVmxLVnh1ZlZ4dVhHNXdkbUZzSUR3dElHTnZiblpRZG1Gc2RXVW9aMlYwVUhaaGJGZHBiR052ZUNoMFpXMXdMQ0JjSW1keWIzVndNVndpTENCY0ltZHliM1Z3TWx3aUtTbGNibHh1WjJkd2JHOTBLSFJsYlhBc0lHRmxjeWg0SUQwZ1ozSnZkWEFzSUhrZ1BTQmhkbVZ5WVdkbEtTa2dLeUJuWlc5dFgySnZlSEJzYjNRb0tTQXJJSE5qWVd4bFgzbGZiRzluTVRBb0tTQXJYRzRnSUhsc1lXSW9YQ0poZG1kVVVFMWNJaWtnS3lCMGFHVnRaVjlqYkdGemMybGpLQ2tnSzF4dUlDQmhibTV2ZEdGMFpTaGNJblJsZUhSY0lpd2dlQ0E5SURFc0lIa2dQU0F4TURBd01Dd2diR0ZpWld3Z1BTQndkbUZzS1Z4dVhHNWNibHh1WEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG5kYXRhIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXHJlYWRDb3VudC5maWx0ZXJlZC5UUE0uYWxsLnRzdlxcKSkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gY2FzZV93aGVuKGVuc2VtYmwgJWluJSBncm91cDEgfiBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICAgICBlbnNlbWJsICVpbiUgZ3JvdXAyIH4gXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BKVxuKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKSAlPiVcbiAgZHBseXI6OnNlbGVjdChjKDM0LCAxLCAzLCA0LCA1LCAxNCwgMTUsIDM0KSlcblxuZGF0YSA8LSBkYXRhICU+JSBtdXRhdGUoYXZlcmFnZSA9IHJvd01lYW5zKGFjcm9zcyhjb2xuYW1lcyhkYXRhKVszOjddKSkpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYXZlcmFnZSlcblxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJGF2ZXJhZ2VcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJGF2ZXJhZ2VcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnB2YWwgPC0gY29udlB2YWx1ZShnZXRQdmFsV2lsY294KHRlbXAsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpKVxuXG5nZ3Bsb3QodGVtcCwgYWVzKHggPSBncm91cCwgeSA9IGF2ZXJhZ2UpKSArIGdlb21fYm94cGxvdCgpICsgc2NhbGVfeV9sb2cxMCgpICtcbiAgeWxhYihcXGF2Z1RQTVxcKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDEwMDAwLCBsYWJlbCA9IHB2YWwpXG5cblxuXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

data <- fread(here(refDir, \readCount.filtered.TPM.all.tsv\)) %>% dplyr::mutate(
  group = case_when(ensembl %in% group1 ~ \group1\,
                    ensembl %in% group2 ~ \group2\,
                    TRUE ~ NA)
) %>%
  dplyr::filter(!is.na(group)) %>%
  dplyr::select(c(34, 1, 3, 4, 5, 14, 15, 34))

data <- data %>% mutate(average = rowMeans(across(colnames(data)[3:7])))

temp <- data %>% dplyr::select(group, average)


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$average
  distance2 <- (data %>% dplyr::filter(group ==group2) )$average
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pval <- convPvalue(getPvalWilcox(temp, \group1\, \group2\))

ggplot(temp, aes(x = group, y = average)) + geom_boxplot() + scale_y_log10() +
  ylab(\avgTPM\) + theme_classic() +
  annotate(\text\, x = 1, y = 10000, label = pval)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVozSnZkWEF4SUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNYR2RsYm1WTWFYTjBYMlJVUVVkZmRuTmZSRTFUVDE5U1RrRmZiRzl2Y0Y5aWFXNWhjbmxIY205MWNERXVkSE4yWEZ3cEtTUm5aVzVsWEc1bmNtOTFjRElnUEMwZ1puSmxZV1FvYUdWeVpTaHlaV1pFYVhJc0lGeGNaMlZ1WlV4cGMzUmZaRlJCUjE5MmMxOUVUVk5QWDFKT1FWOXNiMjl3WDJKcGJtRnllVWR5YjNWd01pNTBjM1pjWENrcEpHZGxibVZjYmx4dVpHRjBZU0E4TFNCbWNtVmhaQ2hvWlhKbEtISmxaa1JwY2l3Z1hGeHlaV0ZrUTI5MWJuUXVabWxzZEdWeVpXUXVWRkJOTG1Gc2JDNTBjM1pjWENrcElDVStKU0JrY0d4NWNqbzZiWFYwWVhSbEtGeHVJQ0JuY205MWNDQTlJR05oYzJWZmQyaGxiaWhsYm5ObGJXSnNJQ1ZwYmlVZ1ozSnZkWEF4SUg0Z1hGeG5jbTkxY0RGY1hDeGNiaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWlc1elpXMWliQ0FsYVc0bElHZHliM1Z3TWlCK0lGeGNaM0p2ZFhBeVhGd3NYRzRnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZSU1ZVVWdmaUJPUVNsY2Jpa2dKVDRsWEc0Z0lHUndiSGx5T2pwbWFXeDBaWElvSVdsekxtNWhLR2R5YjNWd0tTa2dKVDRsWEc0Z0lHUndiSGx5T2pwelpXeGxZM1FvWXlnek5Dd2dNU3dnTXl3Z05Dd2dOU3dnTVRRc0lERTFMQ0F6TkNrcFhHNWNibVJoZEdFZ1BDMGdaR0YwWVNBbFBpVWdiWFYwWVhSbEtHRjJaWEpoWjJVZ1BTQnliM2ROWldGdWN5aGhZM0p2YzNNb1kyOXNibUZ0WlhNb1pHRjBZU2xiTXpvM1hTa3BLVnh1WEc1MFpXMXdJRHd0SUdSaGRHRWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9aM0p2ZFhBc0lHRjJaWEpoWjJVcFhHNWNibHh1WjJWMFVIWmhiRmRwYkdOdmVDQThMU0JtZFc1amRHbHZiaWhrWVhSaExDQm5jbTkxY0RFc0lHZHliM1Z3TWlsN1hHNGdJR1JwYzNSaGJtTmxNU0E4TFNBb1pHRjBZU0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhuY205MWNDQTlQV2R5YjNWd01Ta2dLU1JoZG1WeVlXZGxYRzRnSUdScGMzUmhibU5sTWlBOExTQW9aR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2lobmNtOTFjQ0E5UFdkeWIzVndNaWtnS1NSaGRtVnlZV2RsWEc0Z0lIZHBiQ0E4TFNCM2FXeGpiM2d1ZEdWemRDaGthWE4wWVc1alpURXNJR1JwYzNSaGJtTmxNaWxjYmlBZ2NtVjBkWEp1S0hkcGJDUndMblpoYkhWbEtWeHVmVnh1WEc1d2RtRnNJRHd0SUdOdmJuWlFkbUZzZFdVb1oyVjBVSFpoYkZkcGJHTnZlQ2gwWlcxd0xDQmNYR2R5YjNWd01WeGNMQ0JjWEdkeWIzVndNbHhjS1NsY2JseHVaMmR3Ykc5MEtIUmxiWEFzSUdGbGN5aDRJRDBnWjNKdmRYQXNJSGtnUFNCaGRtVnlZV2RsS1NrZ0t5Qm5aVzl0WDJKdmVIQnNiM1FvS1NBcklITmpZV3hsWDNsZmJHOW5NVEFvS1NBclhHNGdJSGxzWVdJb1hGeGhkbWRVVUUxY1hDa2dLeUIwYUdWdFpWOWpiR0Z6YzJsaktDa2dLMXh1SUNCaGJtNXZkR0YwWlNoY1hIUmxlSFJjWEN3Z2VDQTlJREVzSUhrZ1BTQXhNREF3TUN3Z2JHRmlaV3dnUFNCd2RtRnNLVnh1WEc1Y2JseHVYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG5kYXRhIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXHJlYWRDb3VudC5maWx0ZXJlZC5UUE0uYWxsLnRzdlxcKSkgJT4lIGRwbHlyOjptdXRhdGUoXG4gIGdyb3VwID0gY2FzZV93aGVuKGVuc2VtYmwgJWluJSBncm91cDEgfiBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICAgICBlbnNlbWJsICVpbiUgZ3JvdXAyIH4gXFxncm91cDJcXCxcbiAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BKVxuKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKSAlPiVcbiAgZHBseXI6OnNlbGVjdChjKDM0LCAxLCAzLCA0LCA1LCAxNCwgMTUsIDM0KSlcblxuZGF0YSA8LSBkYXRhICU+JSBtdXRhdGUoYXZlcmFnZSA9IHJvd01lYW5zKGFjcm9zcyhjb2xuYW1lcyhkYXRhKVszOjddKSkpXG5cbnRlbXAgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdChncm91cCwgYXZlcmFnZSlcblxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJGF2ZXJhZ2VcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJGF2ZXJhZ2VcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnB2YWwgPC0gY29udlB2YWx1ZShnZXRQdmFsV2lsY294KHRlbXAsIFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpKVxuXG5nZ3Bsb3QodGVtcCwgYWVzKHggPSBncm91cCwgeSA9IGF2ZXJhZ2UpKSArIGdlb21fYm94cGxvdCgpICsgc2NhbGVfeV9sb2cxMCgpICtcbiAgeWxhYihcXGF2Z1RQTVxcKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDEwMDAwLCBsYWJlbCA9IHB2YWwpXG5cblxuXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuZGF0YSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxyZWFkQ291bnQuZmlsdGVyZWQuVFBNLmFsbC50c3ZcXCkpICU+JSBkcGx5cjo6bXV0YXRlKFxuICBncm91cCA9IGNhc2Vfd2hlbihlbnNlbWJsICVpbiUgZ3JvdXAxIH4gXFxncm91cDFcXCxcbiAgICAgICAgICAgICAgICAgICAgZW5zZW1ibCAlaW4lIGdyb3VwMiB+IFxcZ3JvdXAyXFwsXG4gICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSlcbikgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoYygzNCwgMSwgMywgNCwgNSwgMTQsIDE1LCAzNCkpXG5cbmRhdGEgPC0gZGF0YSAlPiUgbXV0YXRlKGF2ZXJhZ2UgPSByb3dNZWFucyhhY3Jvc3MoY29sbmFtZXMoZGF0YSlbMzo3XSkpKVxuXG50ZW1wIDwtIGRhdGEgJT4lIGRwbHlyOjpzZWxlY3QoZ3JvdXAsIGF2ZXJhZ2UpXG5cblxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMSkgKSRhdmVyYWdlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PWdyb3VwMikgKSRhdmVyYWdlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wdmFsIDwtIGNvbnZQdmFsdWUoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSlcblxuZ2dwbG90KHRlbXAsIGFlcyh4ID0gZ3JvdXAsIHkgPSBhdmVyYWdlKSkgKyBnZW9tX2JveHBsb3QoKSArIHNjYWxlX3lfbG9nMTAoKSArXG4gIHlsYWIoXFxhdmdUUE1cXCkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAxMDAwMCwgbGFiZWwgPSBwdmFsKVxuXG5cblxuXG5gYGBcbmBgYCJ9 -->

```r
```r
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

data <- fread(here(refDir, \readCount.filtered.TPM.all.tsv\)) %>% dplyr::mutate(
  group = case_when(ensembl %in% group1 ~ \group1\,
                    ensembl %in% group2 ~ \group2\,
                    TRUE ~ NA)
) %>%
  dplyr::filter(!is.na(group)) %>%
  dplyr::select(c(34, 1, 3, 4, 5, 14, 15, 34))

data <- data %>% mutate(average = rowMeans(across(colnames(data)[3:7])))

temp <- data %>% dplyr::select(group, average)


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$average
  distance2 <- (data %>% dplyr::filter(group ==group2) )$average
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pval <- convPvalue(getPvalWilcox(temp, \group1\, \group2\))

ggplot(temp, aes(x = group, y = average)) + geom_boxplot() + scale_y_log10() +
  ylab(\avgTPM\) + theme_classic() +
  annotate(\text\, x = 1, y = 10000, label = pval)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [2.27] Extracting TSS for deeptools

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ngroup1 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\"))$gene\ngroup2 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\"))$gene\n\nflankSize <- 1\ngene.tb <- fread(here(refDir, \"mm10_GRCm38.p6_gene_sorted.bed\")) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \"+\", V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6)\ncolnames(gene.tb) <- c(\"chr\", \"start\", \"end\", \"ensembl\")\n\nbed.1 <- gene.tb %>% dplyr::filter(ensembl %in% group1) %>% dplyr::select(c(1, 2, 3))\nbed.2 <- gene.tb %>% dplyr::filter(ensembl %in% group2) %>% dplyr::select(c(1, 2, 3))\n\n\ndata <- fread(here(\"../..\", \"result\", \"stripenn\", \"result_filtered.tsv\"))\n\nggplot(data, aes(x = width)) + geom_histogram() + theme_classic() +\n scale_x_continuous(labels = label_kb_mb)\n\n\n## Checking overlap with gene TSS\n\ntss <- fread(here(refDir, \"mm10_GRCm38.p6_TSS2.5kb.bed\"))\n\ntss.group1 <- tss %>% dplyr::filter(V6 %in% group1) %>% dplyr::select(V1, V2, V3)\ncolnames(tss.group1) <- c(\"chr\", \"start\", \"end\")\ntss.group1.gr <- makeGRangesFromDataFrame(tss.group1)\n\ntss.group2 <- tss %>% dplyr::filter(V6 %in% group2) %>% dplyr::select(V1, V2, V3)\ncolnames(tss.group2) <- c(\"chr\", \"start\", \"end\")\ntss.group2.gr <- makeGRangesFromDataFrame(tss.group2)\n\n## Anchor of stripes\ntemp <- data %>% dplyr::select(chr, pos1, pos2)\ncolnames(temp) <- c(\"chr\", \"start\", \"end\")\n\nstripeAnchor.gr <- makeGRangesFromDataFrame(temp)\n\noverlap.group1 <- findOverlaps(tss.group1.gr, stripeAnchor.gr)\noverlap.group2 <- findOverlaps(tss.group2.gr, stripeAnchor.gr)\n\nlength(unique(queryHits(overlap.group1)))\nlength(unique(queryHits(overlap.group2)))\n\n\n## body of stripes\ntemp <- data %>% dplyr::select(chr, pos3, pos4)\ncolnames(temp) <- c(\"chr\", \"start\", \"end\")\n\nstripeBody.gr <- makeGRangesFromDataFrame(temp)\n\noverlap.group1 <- findOverlaps(tss.group1.gr, stripeBody.gr)\noverlap.group2 <- findOverlaps(tss.group2.gr, stripeBody.gr)\n\nlength(unique(queryHits(overlap.group1)))\nlength(unique(queryHits(overlap.group2)))\n\n## Checking RAD21/CTCF presence at anchor\noverlap.body.ctcf <- findOverlaps(stripeBody.gr, peak.CTCF)\noverlap.body.rad21 <- findOverlaps(stripeBody.gr, peak.RAD21)\noverlap.anchor.ctcf <- findOverlaps(stripeAnchor.gr, peak.CTCF)\noverlap.anchor.rad21 <- findOverlaps(stripeAnchor.gr, peak.RAD21)\n\nlength(unique(queryHits(overlap.body.ctcf)))\nlength(unique(queryHits(overlap.body.rad21)))\n\nlength(unique(queryHits(overlap.anchor.ctcf)))\nlength(unique(queryHits(overlap.anchor.rad21)))\n  \n## Checking overlap with loop anchor (PE-PE)\nloop.up <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\"))\nloop.no <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\"))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\"))\nanchor.down <- extractAnchor(loop.down)\n\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\n## Checking overlap with loop anchor (ALL)\nloop.up <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\"))\nloop.no <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\"))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\"))\nanchor.down <- extractAnchor(loop.down)\n\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\n## Checking overlap with loop anchor (Structure)\nloop.up <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_structure_dTAGvsDMSO_UP_diff0.2.bedpe\"))\nloop.no <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_structure_dTAGvsDMSO_NO_diff0.2.bedpe\"))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_structure_dTAGvsDMSO_DOWN_diff0.2.bedpe\"))\nanchor.down <- extractAnchor(loop.down)\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\nlength(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100\nlength(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100\n\n\n## Checking overlap with loop anchor (RelaxedReg)\nloop.up <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_UP_diff0.2.bedpe\"))\nloop.no <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_NO_diff0.2.bedpe\"))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_DOWN_diff0.2.bedpe\"))\nanchor.down <- extractAnchor(loop.down)\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\nlength(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100\nlength(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100\n\n\n\n\n```"} -->\n\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nflankSize <- 1\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\start\\, \\end\\, \\ensembl\\)\n\nbed.1 <- gene.tb %>% dplyr::filter(ensembl %in% group1) %>% dplyr::select(c(1, 2, 3))\nbed.2 <- gene.tb %>% dplyr::filter(ensembl %in% group2) %>% dplyr::select(c(1, 2, 3))\n\n\ndata <- fread(here(\\../..\\, \\result\\, \\stripenn\\, \\result_filtered.tsv\\))\n\nggplot(data, aes(x = width)) + geom_histogram() + theme_classic() +\n scale_x_continuous(labels = label_kb_mb)\n\n\n## Checking overlap with gene TSS\n\ntss <- fread(here(refDir, \\mm10_GRCm38.p6_TSS2.5kb.bed\\))\n\ntss.group1 <- tss %>% dplyr::filter(V6 %in% group1) %>% dplyr::select(V1, V2, V3)\ncolnames(tss.group1) <- c(\\chr\\, \\start\\, \\end\\)\ntss.group1.gr <- makeGRangesFromDataFrame(tss.group1)\n\ntss.group2 <- tss %>% dplyr::filter(V6 %in% group2) %>% dplyr::select(V1, V2, V3)\ncolnames(tss.group2) <- c(\\chr\\, \\start\\, \\end\\)\ntss.group2.gr <- makeGRangesFromDataFrame(tss.group2)\n\n## Anchor of stripes\ntemp <- data %>% dplyr::select(chr, pos1, pos2)\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\n\nstripeAnchor.gr <- makeGRangesFromDataFrame(temp)\n\noverlap.group1 <- findOverlaps(tss.group1.gr, stripeAnchor.gr)\noverlap.group2 <- findOverlaps(tss.group2.gr, stripeAnchor.gr)\n\nlength(unique(queryHits(overlap.group1)))\nlength(unique(queryHits(overlap.group2)))\n\n\n## body of stripes\ntemp <- data %>% dplyr::select(chr, pos3, pos4)\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\n\nstripeBody.gr <- makeGRangesFromDataFrame(temp)\n\noverlap.group1 <- findOverlaps(tss.group1.gr, stripeBody.gr)\noverlap.group2 <- findOverlaps(tss.group2.gr, stripeBody.gr)\n\nlength(unique(queryHits(overlap.group1)))\nlength(unique(queryHits(overlap.group2)))\n\n## Checking RAD21/CTCF presence at anchor\noverlap.body.ctcf <- findOverlaps(stripeBody.gr, peak.CTCF)\noverlap.body.rad21 <- findOverlaps(stripeBody.gr, peak.RAD21)\noverlap.anchor.ctcf <- findOverlaps(stripeAnchor.gr, peak.CTCF)\noverlap.anchor.rad21 <- findOverlaps(stripeAnchor.gr, peak.RAD21)\n\nlength(unique(queryHits(overlap.body.ctcf)))\nlength(unique(queryHits(overlap.body.rad21)))\n\nlength(unique(queryHits(overlap.anchor.ctcf)))\nlength(unique(queryHits(overlap.anchor.rad21)))\n  \n## Checking overlap with loop anchor (PE-PE)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\n## Checking overlap with loop anchor (ALL)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\n## Checking overlap with loop anchor (Structure)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\nlength(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100\nlength(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100\n\n\n## Checking overlap with loop anchor (RelaxedReg)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\nlength(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100\nlength(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100\n\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

flankSize <- 1
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6)
colnames(gene.tb) <- c(\chr\, \start\, \end\, \ensembl\)

bed.1 <- gene.tb %>% dplyr::filter(ensembl %in% group1) %>% dplyr::select(c(1, 2, 3))
bed.2 <- gene.tb %>% dplyr::filter(ensembl %in% group2) %>% dplyr::select(c(1, 2, 3))


data <- fread(here(\../..\, \result\, \stripenn\, \result_filtered.tsv\))

ggplot(data, aes(x = width)) + geom_histogram() + theme_classic() +
 scale_x_continuous(labels = label_kb_mb)


## Checking overlap with gene TSS

tss <- fread(here(refDir, \mm10_GRCm38.p6_TSS2.5kb.bed\))

tss.group1 <- tss %>% dplyr::filter(V6 %in% group1) %>% dplyr::select(V1, V2, V3)
colnames(tss.group1) <- c(\chr\, \start\, \end\)
tss.group1.gr <- makeGRangesFromDataFrame(tss.group1)

tss.group2 <- tss %>% dplyr::filter(V6 %in% group2) %>% dplyr::select(V1, V2, V3)
colnames(tss.group2) <- c(\chr\, \start\, \end\)
tss.group2.gr <- makeGRangesFromDataFrame(tss.group2)

## Anchor of stripes
temp <- data %>% dplyr::select(chr, pos1, pos2)
colnames(temp) <- c(\chr\, \start\, \end\)

stripeAnchor.gr <- makeGRangesFromDataFrame(temp)

overlap.group1 <- findOverlaps(tss.group1.gr, stripeAnchor.gr)
overlap.group2 <- findOverlaps(tss.group2.gr, stripeAnchor.gr)

length(unique(queryHits(overlap.group1)))
length(unique(queryHits(overlap.group2)))


## body of stripes
temp <- data %>% dplyr::select(chr, pos3, pos4)
colnames(temp) <- c(\chr\, \start\, \end\)

stripeBody.gr <- makeGRangesFromDataFrame(temp)

overlap.group1 <- findOverlaps(tss.group1.gr, stripeBody.gr)
overlap.group2 <- findOverlaps(tss.group2.gr, stripeBody.gr)

length(unique(queryHits(overlap.group1)))
length(unique(queryHits(overlap.group2)))

## Checking RAD21/CTCF presence at anchor
overlap.body.ctcf <- findOverlaps(stripeBody.gr, peak.CTCF)
overlap.body.rad21 <- findOverlaps(stripeBody.gr, peak.RAD21)
overlap.anchor.ctcf <- findOverlaps(stripeAnchor.gr, peak.CTCF)
overlap.anchor.rad21 <- findOverlaps(stripeAnchor.gr, peak.RAD21)

length(unique(queryHits(overlap.body.ctcf)))
length(unique(queryHits(overlap.body.rad21)))

length(unique(queryHits(overlap.anchor.ctcf)))
length(unique(queryHits(overlap.anchor.rad21)))
  
## Checking overlap with loop anchor (PE-PE)
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)


overlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)
overlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)
overlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)
overlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)

length(unique(subjectHits(overlap.body.upno)))
length(unique(subjectHits(overlap.body.down)))
length(unique(subjectHits(overlap.anchor.upno)))
length(unique(subjectHits(overlap.anchor.down)))


## Checking overlap with loop anchor (ALL)
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)


overlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)
overlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)
overlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)
overlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)

length(unique(subjectHits(overlap.body.upno)))
length(unique(subjectHits(overlap.body.down)))
length(unique(subjectHits(overlap.anchor.upno)))
length(unique(subjectHits(overlap.anchor.down)))


## Checking overlap with loop anchor (Structure)
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)

overlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)
overlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)
overlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)
overlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)

length(unique(subjectHits(overlap.body.upno)))
length(unique(subjectHits(overlap.body.down)))
length(unique(subjectHits(overlap.anchor.upno)))
length(unique(subjectHits(overlap.anchor.down)))


length(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100
length(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100
length(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100
length(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100


## Checking overlap with loop anchor (RelaxedReg)
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)

overlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)
overlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)
overlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)
overlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)

length(unique(subjectHits(overlap.body.upno)))
length(unique(subjectHits(overlap.body.down)))
length(unique(subjectHits(overlap.anchor.upno)))
length(unique(subjectHits(overlap.anchor.down)))


length(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100
length(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100
length(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100
length(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nflankSize <- 1\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\start\\, \\end\\, \\ensembl\\)\n\nbed.1 <- gene.tb %>% dplyr::filter(ensembl %in% group1) %>% dplyr::select(c(1, 2, 3))\nbed.2 <- gene.tb %>% dplyr::filter(ensembl %in% group2) %>% dplyr::select(c(1, 2, 3))\n\n\ndata <- fread(here(\\../..\\, \\result\\, \\stripenn\\, \\result_filtered.tsv\\))\n\nggplot(data, aes(x = width)) + geom_histogram() + theme_classic() +\n scale_x_continuous(labels = label_kb_mb)\n\n\n## Checking overlap with gene TSS\n\ntss <- fread(here(refDir, \\mm10_GRCm38.p6_TSS2.5kb.bed\\))\n\ntss.group1 <- tss %>% dplyr::filter(V6 %in% group1) %>% dplyr::select(V1, V2, V3)\ncolnames(tss.group1) <- c(\\chr\\, \\start\\, \\end\\)\ntss.group1.gr <- makeGRangesFromDataFrame(tss.group1)\n\ntss.group2 <- tss %>% dplyr::filter(V6 %in% group2) %>% dplyr::select(V1, V2, V3)\ncolnames(tss.group2) <- c(\\chr\\, \\start\\, \\end\\)\ntss.group2.gr <- makeGRangesFromDataFrame(tss.group2)\n\n## Anchor of stripes\ntemp <- data %>% dplyr::select(chr, pos1, pos2)\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\n\nstripeAnchor.gr <- makeGRangesFromDataFrame(temp)\n\noverlap.group1 <- findOverlaps(tss.group1.gr, stripeAnchor.gr)\noverlap.group2 <- findOverlaps(tss.group2.gr, stripeAnchor.gr)\n\nlength(unique(queryHits(overlap.group1)))\nlength(unique(queryHits(overlap.group2)))\n\n\n## body of stripes\ntemp <- data %>% dplyr::select(chr, pos3, pos4)\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\n\nstripeBody.gr <- makeGRangesFromDataFrame(temp)\n\noverlap.group1 <- findOverlaps(tss.group1.gr, stripeBody.gr)\noverlap.group2 <- findOverlaps(tss.group2.gr, stripeBody.gr)\n\nlength(unique(queryHits(overlap.group1)))\nlength(unique(queryHits(overlap.group2)))\n\n## Checking RAD21/CTCF presence at anchor\noverlap.body.ctcf <- findOverlaps(stripeBody.gr, peak.CTCF)\noverlap.body.rad21 <- findOverlaps(stripeBody.gr, peak.RAD21)\noverlap.anchor.ctcf <- findOverlaps(stripeAnchor.gr, peak.CTCF)\noverlap.anchor.rad21 <- findOverlaps(stripeAnchor.gr, peak.RAD21)\n\nlength(unique(queryHits(overlap.body.ctcf)))\nlength(unique(queryHits(overlap.body.rad21)))\n\nlength(unique(queryHits(overlap.anchor.ctcf)))\nlength(unique(queryHits(overlap.anchor.rad21)))\n  \n## Checking overlap with loop anchor (PE-PE)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\n## Checking overlap with loop anchor (ALL)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\n## Checking overlap with loop anchor (Structure)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\nlength(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100\nlength(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100\n\n\n## Checking overlap with loop anchor (RelaxedReg)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\nlength(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100\nlength(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100\n\n\n\n\n```\n```"} -->\n\n```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nflankSize <- 1\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\start\\, \\end\\, \\ensembl\\)\n\nbed.1 <- gene.tb %>% dplyr::filter(ensembl %in% group1) %>% dplyr::select(c(1, 2, 3))\nbed.2 <- gene.tb %>% dplyr::filter(ensembl %in% group2) %>% dplyr::select(c(1, 2, 3))\n\n\ndata <- fread(here(\\../..\\, \\result\\, \\stripenn\\, \\result_filtered.tsv\\))\n\nggplot(data, aes(x = width)) + geom_histogram() + theme_classic() +\n scale_x_continuous(labels = label_kb_mb)\n\n\n## Checking overlap with gene TSS\n\ntss <- fread(here(refDir, \\mm10_GRCm38.p6_TSS2.5kb.bed\\))\n\ntss.group1 <- tss %>% dplyr::filter(V6 %in% group1) %>% dplyr::select(V1, V2, V3)\ncolnames(tss.group1) <- c(\\chr\\, \\start\\, \\end\\)\ntss.group1.gr <- makeGRangesFromDataFrame(tss.group1)\n\ntss.group2 <- tss %>% dplyr::filter(V6 %in% group2) %>% dplyr::select(V1, V2, V3)\ncolnames(tss.group2) <- c(\\chr\\, \\start\\, \\end\\)\ntss.group2.gr <- makeGRangesFromDataFrame(tss.group2)\n\n## Anchor of stripes\ntemp <- data %>% dplyr::select(chr, pos1, pos2)\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\n\nstripeAnchor.gr <- makeGRangesFromDataFrame(temp)\n\noverlap.group1 <- findOverlaps(tss.group1.gr, stripeAnchor.gr)\noverlap.group2 <- findOverlaps(tss.group2.gr, stripeAnchor.gr)\n\nlength(unique(queryHits(overlap.group1)))\nlength(unique(queryHits(overlap.group2)))\n\n\n## body of stripes\ntemp <- data %>% dplyr::select(chr, pos3, pos4)\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\n\nstripeBody.gr <- makeGRangesFromDataFrame(temp)\n\noverlap.group1 <- findOverlaps(tss.group1.gr, stripeBody.gr)\noverlap.group2 <- findOverlaps(tss.group2.gr, stripeBody.gr)\n\nlength(unique(queryHits(overlap.group1)))\nlength(unique(queryHits(overlap.group2)))\n\n## Checking RAD21/CTCF presence at anchor\noverlap.body.ctcf <- findOverlaps(stripeBody.gr, peak.CTCF)\noverlap.body.rad21 <- findOverlaps(stripeBody.gr, peak.RAD21)\noverlap.anchor.ctcf <- findOverlaps(stripeAnchor.gr, peak.CTCF)\noverlap.anchor.rad21 <- findOverlaps(stripeAnchor.gr, peak.RAD21)\n\nlength(unique(queryHits(overlap.body.ctcf)))\nlength(unique(queryHits(overlap.body.rad21)))\n\nlength(unique(queryHits(overlap.anchor.ctcf)))\nlength(unique(queryHits(overlap.anchor.rad21)))\n  \n## Checking overlap with loop anchor (PE-PE)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\n## Checking overlap with loop anchor (ALL)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\n## Checking overlap with loop anchor (Structure)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\nlength(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100\nlength(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100\n\n\n## Checking overlap with loop anchor (RelaxedReg)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\nlength(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100\nlength(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100\n\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nflankSize <- 1\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\start\\, \\end\\, \\ensembl\\)\n\nbed.1 <- gene.tb %>% dplyr::filter(ensembl %in% group1) %>% dplyr::select(c(1, 2, 3))\nbed.2 <- gene.tb %>% dplyr::filter(ensembl %in% group2) %>% dplyr::select(c(1, 2, 3))\n\n\ndata <- fread(here(\\../..\\, \\result\\, \\stripenn\\, \\result_filtered.tsv\\))\n\nggplot(data, aes(x = width)) + geom_histogram() + theme_classic() +\n scale_x_continuous(labels = label_kb_mb)\n\n\n## Checking overlap with gene TSS\n\ntss <- fread(here(refDir, \\mm10_GRCm38.p6_TSS2.5kb.bed\\))\n\ntss.group1 <- tss %>% dplyr::filter(V6 %in% group1) %>% dplyr::select(V1, V2, V3)\ncolnames(tss.group1) <- c(\\chr\\, \\start\\, \\end\\)\ntss.group1.gr <- makeGRangesFromDataFrame(tss.group1)\n\ntss.group2 <- tss %>% dplyr::filter(V6 %in% group2) %>% dplyr::select(V1, V2, V3)\ncolnames(tss.group2) <- c(\\chr\\, \\start\\, \\end\\)\ntss.group2.gr <- makeGRangesFromDataFrame(tss.group2)\n\n## Anchor of stripes\ntemp <- data %>% dplyr::select(chr, pos1, pos2)\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\n\nstripeAnchor.gr <- makeGRangesFromDataFrame(temp)\n\noverlap.group1 <- findOverlaps(tss.group1.gr, stripeAnchor.gr)\noverlap.group2 <- findOverlaps(tss.group2.gr, stripeAnchor.gr)\n\nlength(unique(queryHits(overlap.group1)))\nlength(unique(queryHits(overlap.group2)))\n\n\n## body of stripes\ntemp <- data %>% dplyr::select(chr, pos3, pos4)\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\n\nstripeBody.gr <- makeGRangesFromDataFrame(temp)\n\noverlap.group1 <- findOverlaps(tss.group1.gr, stripeBody.gr)\noverlap.group2 <- findOverlaps(tss.group2.gr, stripeBody.gr)\n\nlength(unique(queryHits(overlap.group1)))\nlength(unique(queryHits(overlap.group2)))\n\n## Checking RAD21/CTCF presence at anchor\noverlap.body.ctcf <- findOverlaps(stripeBody.gr, peak.CTCF)\noverlap.body.rad21 <- findOverlaps(stripeBody.gr, peak.RAD21)\noverlap.anchor.ctcf <- findOverlaps(stripeAnchor.gr, peak.CTCF)\noverlap.anchor.rad21 <- findOverlaps(stripeAnchor.gr, peak.RAD21)\n\nlength(unique(queryHits(overlap.body.ctcf)))\nlength(unique(queryHits(overlap.body.rad21)))\n\nlength(unique(queryHits(overlap.anchor.ctcf)))\nlength(unique(queryHits(overlap.anchor.rad21)))\n  \n## Checking overlap with loop anchor (PE-PE)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\n## Checking overlap with loop anchor (ALL)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\n## Checking overlap with loop anchor (Structure)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_structure_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\nlength(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100\nlength(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100\n\n\n## Checking overlap with loop anchor (RelaxedReg)\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nanchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\nanchor.down <- extractAnchor(loop.down)\n\noverlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)\noverlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)\noverlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)\noverlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)\n\nlength(unique(subjectHits(overlap.body.upno)))\nlength(unique(subjectHits(overlap.body.down)))\nlength(unique(subjectHits(overlap.anchor.upno)))\nlength(unique(subjectHits(overlap.anchor.down)))\n\n\nlength(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100\nlength(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100\nlength(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100\n\n\n\n\n```\n```"} -->

```r
```r
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

flankSize <- 1
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6)
colnames(gene.tb) <- c(\chr\, \start\, \end\, \ensembl\)

bed.1 <- gene.tb %>% dplyr::filter(ensembl %in% group1) %>% dplyr::select(c(1, 2, 3))
bed.2 <- gene.tb %>% dplyr::filter(ensembl %in% group2) %>% dplyr::select(c(1, 2, 3))


data <- fread(here(\../..\, \result\, \stripenn\, \result_filtered.tsv\))

ggplot(data, aes(x = width)) + geom_histogram() + theme_classic() +
 scale_x_continuous(labels = label_kb_mb)


## Checking overlap with gene TSS

tss <- fread(here(refDir, \mm10_GRCm38.p6_TSS2.5kb.bed\))

tss.group1 <- tss %>% dplyr::filter(V6 %in% group1) %>% dplyr::select(V1, V2, V3)
colnames(tss.group1) <- c(\chr\, \start\, \end\)
tss.group1.gr <- makeGRangesFromDataFrame(tss.group1)

tss.group2 <- tss %>% dplyr::filter(V6 %in% group2) %>% dplyr::select(V1, V2, V3)
colnames(tss.group2) <- c(\chr\, \start\, \end\)
tss.group2.gr <- makeGRangesFromDataFrame(tss.group2)

## Anchor of stripes
temp <- data %>% dplyr::select(chr, pos1, pos2)
colnames(temp) <- c(\chr\, \start\, \end\)

stripeAnchor.gr <- makeGRangesFromDataFrame(temp)

overlap.group1 <- findOverlaps(tss.group1.gr, stripeAnchor.gr)
overlap.group2 <- findOverlaps(tss.group2.gr, stripeAnchor.gr)

length(unique(queryHits(overlap.group1)))
length(unique(queryHits(overlap.group2)))


## body of stripes
temp <- data %>% dplyr::select(chr, pos3, pos4)
colnames(temp) <- c(\chr\, \start\, \end\)

stripeBody.gr <- makeGRangesFromDataFrame(temp)

overlap.group1 <- findOverlaps(tss.group1.gr, stripeBody.gr)
overlap.group2 <- findOverlaps(tss.group2.gr, stripeBody.gr)

length(unique(queryHits(overlap.group1)))
length(unique(queryHits(overlap.group2)))

## Checking RAD21/CTCF presence at anchor
overlap.body.ctcf <- findOverlaps(stripeBody.gr, peak.CTCF)
overlap.body.rad21 <- findOverlaps(stripeBody.gr, peak.RAD21)
overlap.anchor.ctcf <- findOverlaps(stripeAnchor.gr, peak.CTCF)
overlap.anchor.rad21 <- findOverlaps(stripeAnchor.gr, peak.RAD21)

length(unique(queryHits(overlap.body.ctcf)))
length(unique(queryHits(overlap.body.rad21)))

length(unique(queryHits(overlap.anchor.ctcf)))
length(unique(queryHits(overlap.anchor.rad21)))
  
## Checking overlap with loop anchor (PE-PE)
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)


overlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)
overlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)
overlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)
overlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)

length(unique(subjectHits(overlap.body.upno)))
length(unique(subjectHits(overlap.body.down)))
length(unique(subjectHits(overlap.anchor.upno)))
length(unique(subjectHits(overlap.anchor.down)))


## Checking overlap with loop anchor (ALL)
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)


overlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)
overlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)
overlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)
overlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)

length(unique(subjectHits(overlap.body.upno)))
length(unique(subjectHits(overlap.body.down)))
length(unique(subjectHits(overlap.anchor.upno)))
length(unique(subjectHits(overlap.anchor.down)))


## Checking overlap with loop anchor (Structure)
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)

overlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)
overlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)
overlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)
overlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)

length(unique(subjectHits(overlap.body.upno)))
length(unique(subjectHits(overlap.body.down)))
length(unique(subjectHits(overlap.anchor.upno)))
length(unique(subjectHits(overlap.anchor.down)))


length(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100
length(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100
length(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100
length(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100


## Checking overlap with loop anchor (RelaxedReg)
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)

overlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)
overlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)
overlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)
overlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)

length(unique(subjectHits(overlap.body.upno)))
length(unique(subjectHits(overlap.body.down)))
length(unique(subjectHits(overlap.anchor.upno)))
length(unique(subjectHits(overlap.anchor.down)))


length(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100
length(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100
length(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100
length(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [2.28] Checking gene expression levels of binaryGroup

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjbVZ6ZFd4MGN5QThMU0IwYVdKaWJHVW9hU0E5SUc1MWJXVnlhV01vS1N3Z2RYQnVieUE5SUc1MWJXVnlhV01vS1N3Z1pHOTNiaUE5SUc1MWJXVnlhV01vS1NsY2JseHVabTl5S0drZ2FXNGdjMlZ4S0RFc0lERXdLU2w3WEc0Z0lHUmhkR0VnUEMwZ1puSmxZV1FvYUdWeVpTaHlaV1pFYVhJc0lGd2lSSGxzWVc1ZmFIVmlYMlZ6WXk1amMzWmNJaWtwWEc0Z0lGeHVJQ0JrWVhSaExtaDFZaUE4TFNCa1lYUmhJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLR0ZzYkY5c1kyOXVJRDRnYVNsY2JpQWdkR1Z0Y0NBOExTQmtZWFJoTG1oMVlpQWxQaVVnWkhCc2VYSTZPbk5sYkdWamRDaGpLREVzSURJc0lETXBLVnh1SUNCamIyeHVZVzFsY3loMFpXMXdLU0E4TFNCaktGd2lZMmh5WENJc0lGd2ljM1JoY25SY0lpd2dYQ0psYm1SY0lpbGNiaUFnYUhWaUxtRnVZMmh2Y2lBOExTQnRZV3RsUjFKaGJtZGxjMFp5YjIxRVlYUmhSbkpoYldVb2RHVnRjQ2xjYmlBZ1hHNGdJRnh1SUNCY2JteHZiM0F1ZFhBZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGd2lZMmh5YjIxdlgyTnZibk5mWVc1dWIwaHBaWEpoY21Ob2VWOWhiR3hmWkZSQlIzWnpSRTFUVDE5VlVGOWthV1ptTUM0eUxtSmxaSEJsWENJcEtWeHViRzl2Y0M1dWJ5QThMU0JtY21WaFpDaG9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2dYQ0pqYUhKdmJXOWZZMjl1YzE5aGJtNXZTR2xsY21GeVkyaDVYMkZzYkY5a1ZFRkhkbk5FVFZOUFgwNVBYMlJwWm1Zd0xqSXVZbVZrY0dWY0lpa3BYRzVoYm1Ob2IzSXVkWEJ1YnlBOExTQmxlSFJ5WVdOMFFXNWphRzl5S0dKcGJtUmZjbTkzY3loc2IyOXdMblZ3TENCc2IyOXdMbTV2S1NsY2JseHViRzl2Y0M1a2IzZHVJRHd0SUdaeVpXRmtLR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0JjSW1Ob2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxmWVd4c1gyUlVRVWQyYzBSTlUwOWZSRTlYVGw5a2FXWm1NQzR5TG1KbFpIQmxYQ0lwS1Z4dVlXNWphRzl5TG1SdmQyNGdQQzBnWlhoMGNtRmpkRUZ1WTJodmNpaHNiMjl3TG1SdmQyNHBYRzVjYmlBZ1hHNGdJRzkyWlhKc1lYQXVkWEJ1YnlBOExTQm1hVzVrVDNabGNteGhjSE1vWVc1amFHOXlMblZ3Ym04c0lHaDFZaTVoYm1Ob2IzSXBYRzRnSUc5MlpYSnNZWEF1Wkc5M2JpQThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG1SdmQyNHNJR2gxWWk1aGJtTm9iM0lwWEc0Z0lGeHVJQ0J1TVNBOExTQnNaVzVuZEdnb2RXNXBjWFZsS0hGMVpYSjVTR2wwY3lodmRtVnliR0Z3TG5Wd2JtOHBLU2xjYmlBZ2JqSWdQQzBnYkdWdVozUm9LSFZ1YVhGMVpTaHhkV1Z5ZVVocGRITW9iM1psY214aGNDNWtiM2R1S1NrcFhHNGdJRnh1SUNCd1pYSmpNU0E4TFNCeWIzVnVaQ2h1TVM5c1pXNW5kR2dvYjNabGNteGhjQzUxY0c1dktTb3hNREFzSURJcFhHNGdJSEJsY21NeUlEd3RJSEp2ZFc1a0tHNHlMMnhsYm1kMGFDaHZkbVZ5YkdGd0xtUnZkMjRwS2pFd01Dd2dNaWxjYmlBZ1hHNGdJSEpsYzNWc2RITWdQQzBnY21WemRXeDBjeUFsUGlVZ1lXUmtYM0p2ZHlocElEMGdhU3dnZFhCdWJ5QTlJSEJsY21NeExDQmtiM2R1SUQwZ2NHVnlZeklwWEc1OVhHNWNibHh1WEc1eVpYTjFiSFJ6WDJ4dmJtY2dQQzBnY21WemRXeDBjeUFsUGlWY2JpQWdjR2wyYjNSZmJHOXVaMlZ5S0dOdmJITWdQU0JqS0hWd2JtOHNJR1J2ZDI0cExDQnVZVzFsYzE5MGJ5QTlJRndpUjNKdmRYQmNJaXdnZG1Gc2RXVnpYM1J2SUQwZ1hDSlFaWEpqWlc1MFlXZGxYQ0lwWEc1Y2JuSmxjM1ZzZEhOZmJHOXVaeVJIY205MWNDQThMU0JtWVdOMGIzSW9jbVZ6ZFd4MGMxOXNiMjVuSkVkeWIzVndMQ0JzWlhabGJITWdQU0JqS0Z3aWRYQnViMXdpTENCY0ltUnZkMjVjSWlrcFhHNGpJRU55WldGMFpTQjBhR1VnWW1GeUlIQnNiM1JjYm1kbmNHeHZkQ2h5WlhOMWJIUnpYMnh2Ym1jc0lHRmxjeWg0SUQwZ1ptRmpkRzl5S0drcExDQjVJRDBnVUdWeVkyVnVkR0ZuWlN3Z1ptbHNiQ0E5SUVkeWIzVndLU2tnSzF4dUlDQm5aVzl0WDJKaGNpaHpkR0YwSUQwZ1hDSnBaR1Z1ZEdsMGVWd2lMQ0J3YjNOcGRHbHZiaUE5SUZ3aVpHOWtaMlZjSWlrZ0sxeHVJQ0JzWVdKektGeHVJQ0FnSUhScGRHeGxJRDBnWENKQmJHd2diRzl2Y0hOY0lpeGNiaUFnSUNCNElEMGdYQ0pRY21WelpXNWpaU0J2WmlCb2RXSWdZVzVqYUc5eUlIZHBkR2dnUG1rZ1kyOXVibVZqZEdsdmJuTmNJaXhjYmlBZ0lDQjVJRDBnWENKUVpYSmpaVzUwWVdkbFhDSmNiaUFnS1NBclhHNGdJSFJvWlcxbFgyMXBibWx0WVd3b0tTQXJYRzRnSUhOallXeGxYMlpwYkd4ZmJXRnVkV0ZzS0haaGJIVmxjeUE5SUdNb1hDSjFjRzV2WENJZ1BTQmNJbUpzZFdWY0lpd2dYQ0prYjNkdVhDSWdQU0JjSW5KbFpGd2lLU2tnSzF4dUlDQjBhR1Z0WlNoaGVHbHpMblJsZUhRdWVDQTlJR1ZzWlcxbGJuUmZkR1Y0ZENoaGJtZHNaU0E5SURRMUxDQm9hblZ6ZENBOUlERXBLU0FySUhsc2FXMG9NQ3dnTVRBd0tWeHVZR0JnSW4wPSAtLT5cblxuYGBgclxucmVzdWx0cyA8LSB0aWJibGUoaSA9IG51bWVyaWMoKSwgdXBubyA9IG51bWVyaWMoKSwgZG93biA9IG51bWVyaWMoKSlcblxuZm9yKGkgaW4gc2VxKDEsIDEwKSl7XG4gIGRhdGEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcRHlsYW5faHViX2VzYy5jc3ZcXCkpXG4gIFxuICBkYXRhLmh1YiA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGFsbF9sY29uID4gaSlcbiAgdGVtcCA8LSBkYXRhLmh1YiAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuICBjb2xuYW1lcyh0ZW1wKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbiAgaHViLmFuY2hvciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcbiAgXG4gIFxuICBcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXBubyA8LSBleHRyYWN0QW5jaG9yKGJpbmRfcm93cyhsb29wLnVwLCBsb29wLm5vKSlcblxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX2RUQUd2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLmRvd24gPC0gZXh0cmFjdEFuY2hvcihsb29wLmRvd24pXG5cbiAgXG4gIG92ZXJsYXAudXBubyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwbm8sIGh1Yi5hbmNob3IpXG4gIG92ZXJsYXAuZG93biA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmRvd24sIGh1Yi5hbmNob3IpXG4gIFxuICBuMSA8LSBsZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhvdmVybGFwLnVwbm8pKSlcbiAgbjIgPC0gbGVuZ3RoKHVuaXF1ZShxdWVyeUhpdHMob3ZlcmxhcC5kb3duKSkpXG4gIFxuICBwZXJjMSA8LSByb3VuZChuMS9sZW5ndGgob3ZlcmxhcC51cG5vKSoxMDAsIDIpXG4gIHBlcmMyIDwtIHJvdW5kKG4yL2xlbmd0aChvdmVybGFwLmRvd24pKjEwMCwgMilcbiAgXG4gIHJlc3VsdHMgPC0gcmVzdWx0cyAlPiUgYWRkX3JvdyhpID0gaSwgdXBubyA9IHBlcmMxLCBkb3duID0gcGVyYzIpXG59XG5cblxuXG5yZXN1bHRzX2xvbmcgPC0gcmVzdWx0cyAlPiVcbiAgcGl2b3RfbG9uZ2VyKGNvbHMgPSBjKHVwbm8sIGRvd24pLCBuYW1lc190byA9IFxcR3JvdXBcXCwgdmFsdWVzX3RvID0gXFxQZXJjZW50YWdlXFwpXG5cbnJlc3VsdHNfbG9uZyRHcm91cCA8LSBmYWN0b3IocmVzdWx0c19sb25nJEdyb3VwLCBsZXZlbHMgPSBjKFxcdXBub1xcLCBcXGRvd25cXCkpXG4jIENyZWF0ZSB0aGUgYmFyIHBsb3RcbmdncGxvdChyZXN1bHRzX2xvbmcsIGFlcyh4ID0gZmFjdG9yKGkpLCB5ID0gUGVyY2VudGFnZSwgZmlsbCA9IEdyb3VwKSkgK1xuICBnZW9tX2JhcihzdGF0ID0gXFxpZGVudGl0eVxcLCBwb3NpdGlvbiA9IFxcZG9kZ2VcXCkgK1xuICBsYWJzKFxuICAgIHRpdGxlID0gXFxBbGwgbG9vcHNcXCxcbiAgICB4ID0gXFxQcmVzZW5jZSBvZiBodWIgYW5jaG9yIHdpdGggPmkgY29ubmVjdGlvbnNcXCxcbiAgICB5ID0gXFxQZXJjZW50YWdlXFxcbiAgKSArXG4gIHRoZW1lX21pbmltYWwoKSArXG4gIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGMoXFx1cG5vXFwgPSBcXGJsdWVcXCwgXFxkb3duXFwgPSBcXHJlZFxcKSkgK1xuICB0aGVtZShheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChhbmdsZSA9IDQ1LCBoanVzdCA9IDEpKSArIHlsaW0oMCwgMTAwKVxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->
results <- tibble(i = numeric(), upno = numeric(), down = numeric())

for(i in seq(1, 10)){
  data <- fread(here(refDir, \Dylan_hub_esc.csv\))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c(\chr\, \start\, \end\)
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)

  
  overlap.upno <- findOverlaps(anchor.upno, hub.anchor)
  overlap.down <- findOverlaps(anchor.down, hub.anchor)
  
  n1 <- length(unique(queryHits(overlap.upno)))
  n2 <- length(unique(queryHits(overlap.down)))
  
  perc1 <- round(n1/length(overlap.upno)*100, 2)
  perc2 <- round(n2/length(overlap.down)*100, 2)
  
  results <- results %>% add_row(i = i, upno = perc1, down = perc2)
}



results_long <- results %>%
  pivot_longer(cols = c(upno, down), names_to = \Group\, values_to = \Percentage\)

results_long$Group <- factor(results_long$Group, levels = c(\upno\, \down\))
# Create the bar plot
ggplot(results_long, aes(x = factor(i), y = Percentage, fill = Group)) +
  geom_bar(stat = \identity\, position = \dodge\) +
  labs(
    title = \All loops\,
    x = \Presence of hub anchor with >i connections\,
    y = \Percentage\
  ) +
  theme_minimal() +
  scale_fill_manual(values = c(\upno\ = \blue\, \down\ = \red\)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1)) + ylim(0, 100)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWNtVnpkV3gwY3lBOExTQjBhV0ppYkdVb2FTQTlJRzUxYldWeWFXTW9LU3dnZFhCdWJ5QTlJRzUxYldWeWFXTW9LU3dnWkc5M2JpQTlJRzUxYldWeWFXTW9LU2xjYmx4dVptOXlLR2tnYVc0Z2MyVnhLREVzSURFd0tTbDdYRzRnSUdSaGRHRWdQQzBnWm5KbFlXUW9hR1Z5WlNoeVpXWkVhWElzSUZ4Y1JIbHNZVzVmYUhWaVgyVnpZeTVqYzNaY1hDa3BYRzRnSUZ4dUlDQmtZWFJoTG1oMVlpQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHRnNiRjlzWTI5dUlENGdhU2xjYmlBZ2RHVnRjQ0E4TFNCa1lYUmhMbWgxWWlBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoaktERXNJRElzSURNcEtWeHVJQ0JqYjJ4dVlXMWxjeWgwWlcxd0tTQThMU0JqS0Z4Y1kyaHlYRndzSUZ4Y2MzUmhjblJjWEN3Z1hGeGxibVJjWENsY2JpQWdhSFZpTG1GdVkyaHZjaUE4TFNCdFlXdGxSMUpoYm1kbGMwWnliMjFFWVhSaFJuSmhiV1VvZEdWdGNDbGNiaUFnWEc0Z0lGeHVJQ0JjYm14dmIzQXVkWEFnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ4Y1kyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5aGJHeGZaRlJCUjNaelJFMVRUMTlWVUY5a2FXWm1NQzR5TG1KbFpIQmxYRndwS1Z4dWJHOXZjQzV1YnlBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z1hGeGphSEp2Ylc5ZlkyOXVjMTloYm01dlNHbGxjbUZ5WTJoNVgyRnNiRjlrVkVGSGRuTkVUVk5QWDA1UFgyUnBabVl3TGpJdVltVmtjR1ZjWENrcFhHNWhibU5vYjNJdWRYQnVieUE4TFNCbGVIUnlZV04wUVc1amFHOXlLR0pwYm1SZmNtOTNjeWhzYjI5d0xuVndMQ0JzYjI5d0xtNXZLU2xjYmx4dWJHOXZjQzVrYjNkdUlEd3RJR1p5WldGa0tHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQmNYR05vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGZZV3hzWDJSVVFVZDJjMFJOVTA5ZlJFOVhUbDlrYVdabU1DNHlMbUpsWkhCbFhGd3BLVnh1WVc1amFHOXlMbVJ2ZDI0Z1BDMGdaWGgwY21GamRFRnVZMmh2Y2loc2IyOXdMbVJ2ZDI0cFhHNWNiaUFnWEc0Z0lHOTJaWEpzWVhBdWRYQnVieUE4TFNCbWFXNWtUM1psY214aGNITW9ZVzVqYUc5eUxuVndibThzSUdoMVlpNWhibU5vYjNJcFhHNGdJRzkyWlhKc1lYQXVaRzkzYmlBOExTQm1hVzVrVDNabGNteGhjSE1vWVc1amFHOXlMbVJ2ZDI0c0lHaDFZaTVoYm1Ob2IzSXBYRzRnSUZ4dUlDQnVNU0E4TFNCc1pXNW5kR2dvZFc1cGNYVmxLSEYxWlhKNVNHbDBjeWh2ZG1WeWJHRndMblZ3Ym04cEtTbGNiaUFnYmpJZ1BDMGdiR1Z1WjNSb0tIVnVhWEYxWlNoeGRXVnllVWhwZEhNb2IzWmxjbXhoY0M1a2IzZHVLU2twWEc0Z0lGeHVJQ0J3WlhKak1TQThMU0J5YjNWdVpDaHVNUzlzWlc1bmRHZ29iM1psY214aGNDNTFjRzV2S1NveE1EQXNJRElwWEc0Z0lIQmxjbU15SUR3dElISnZkVzVrS0c0eUwyeGxibWQwYUNodmRtVnliR0Z3TG1SdmQyNHBLakV3TUN3Z01pbGNiaUFnWEc0Z0lISmxjM1ZzZEhNZ1BDMGdjbVZ6ZFd4MGN5QWxQaVVnWVdSa1gzSnZkeWhwSUQwZ2FTd2dkWEJ1YnlBOUlIQmxjbU14TENCa2IzZHVJRDBnY0dWeVl6SXBYRzU5WEc1Y2JseHVYRzV5WlhOMWJIUnpYMnh2Ym1jZ1BDMGdjbVZ6ZFd4MGN5QWxQaVZjYmlBZ2NHbDJiM1JmYkc5dVoyVnlLR052YkhNZ1BTQmpLSFZ3Ym04c0lHUnZkMjRwTENCdVlXMWxjMTkwYnlBOUlGeGNSM0p2ZFhCY1hDd2dkbUZzZFdWelgzUnZJRDBnWEZ4UVpYSmpaVzUwWVdkbFhGd3BYRzVjYm5KbGMzVnNkSE5mYkc5dVp5UkhjbTkxY0NBOExTQm1ZV04wYjNJb2NtVnpkV3gwYzE5c2IyNW5KRWR5YjNWd0xDQnNaWFpsYkhNZ1BTQmpLRnhjZFhCdWIxeGNMQ0JjWEdSdmQyNWNYQ2twWEc0aklFTnlaV0YwWlNCMGFHVWdZbUZ5SUhCc2IzUmNibWRuY0d4dmRDaHlaWE4xYkhSelgyeHZibWNzSUdGbGN5aDRJRDBnWm1GamRHOXlLR2twTENCNUlEMGdVR1Z5WTJWdWRHRm5aU3dnWm1sc2JDQTlJRWR5YjNWd0tTa2dLMXh1SUNCblpXOXRYMkpoY2loemRHRjBJRDBnWEZ4cFpHVnVkR2wwZVZ4Y0xDQndiM05wZEdsdmJpQTlJRnhjWkc5a1oyVmNYQ2tnSzF4dUlDQnNZV0p6S0Z4dUlDQWdJSFJwZEd4bElEMGdYRnhCYkd3Z2JHOXZjSE5jWEN4Y2JpQWdJQ0I0SUQwZ1hGeFFjbVZ6Wlc1alpTQnZaaUJvZFdJZ1lXNWphRzl5SUhkcGRHZ2dQbWtnWTI5dWJtVmpkR2x2Ym5OY1hDeGNiaUFnSUNCNUlEMGdYRnhRWlhKalpXNTBZV2RsWEZ4Y2JpQWdLU0FyWEc0Z0lIUm9aVzFsWDIxcGJtbHRZV3dvS1NBclhHNGdJSE5qWVd4bFgyWnBiR3hmYldGdWRXRnNLSFpoYkhWbGN5QTlJR01vWEZ4MWNHNXZYRndnUFNCY1hHSnNkV1ZjWEN3Z1hGeGtiM2R1WEZ3Z1BTQmNYSEpsWkZ4Y0tTa2dLMXh1SUNCMGFHVnRaU2hoZUdsekxuUmxlSFF1ZUNBOUlHVnNaVzFsYm5SZmRHVjRkQ2hoYm1kc1pTQTlJRFExTENCb2FuVnpkQ0E5SURFcEtTQXJJSGxzYVcwb01Dd2dNVEF3S1Z4dVlHQmdYRzVnWUdBaWZRPT0gLS0+XG5cbmBgYHJcbmBgYHJcbnJlc3VsdHMgPC0gdGliYmxlKGkgPSBudW1lcmljKCksIHVwbm8gPSBudW1lcmljKCksIGRvd24gPSBudW1lcmljKCkpXG5cbmZvcihpIGluIHNlcSgxLCAxMCkpe1xuICBkYXRhIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXER5bGFuX2h1Yl9lc2MuY3N2XFwpKVxuICBcbiAgZGF0YS5odWIgPC0gZGF0YSAlPiUgZHBseXI6OmZpbHRlcihhbGxfbGNvbiA+IGkpXG4gIHRlbXAgPC0gZGF0YS5odWIgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzKSlcbiAgY29sbmFtZXModGVtcCkgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG4gIGh1Yi5hbmNob3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRlbXApXG4gIFxuICBcbiAgXG5sb29wLnVwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX2RUQUd2c0RNU09fVVBfZGlmZjAuMi5iZWRwZVxcKSlcbmxvb3Aubm8gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLnVwbm8gPC0gZXh0cmFjdEFuY2hvcihiaW5kX3Jvd3MobG9vcC51cCwgbG9vcC5ubykpXG5cbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci5kb3duIDwtIGV4dHJhY3RBbmNob3IobG9vcC5kb3duKVxuXG4gIFxuICBvdmVybGFwLnVwbm8gPC0gZmluZE92ZXJsYXBzKGFuY2hvci51cG5vLCBodWIuYW5jaG9yKVxuICBvdmVybGFwLmRvd24gPC0gZmluZE92ZXJsYXBzKGFuY2hvci5kb3duLCBodWIuYW5jaG9yKVxuICBcbiAgbjEgPC0gbGVuZ3RoKHVuaXF1ZShxdWVyeUhpdHMob3ZlcmxhcC51cG5vKSkpXG4gIG4yIDwtIGxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKG92ZXJsYXAuZG93bikpKVxuICBcbiAgcGVyYzEgPC0gcm91bmQobjEvbGVuZ3RoKG92ZXJsYXAudXBubykqMTAwLCAyKVxuICBwZXJjMiA8LSByb3VuZChuMi9sZW5ndGgob3ZlcmxhcC5kb3duKSoxMDAsIDIpXG4gIFxuICByZXN1bHRzIDwtIHJlc3VsdHMgJT4lIGFkZF9yb3coaSA9IGksIHVwbm8gPSBwZXJjMSwgZG93biA9IHBlcmMyKVxufVxuXG5cblxucmVzdWx0c19sb25nIDwtIHJlc3VsdHMgJT4lXG4gIHBpdm90X2xvbmdlcihjb2xzID0gYyh1cG5vLCBkb3duKSwgbmFtZXNfdG8gPSBcXEdyb3VwXFwsIHZhbHVlc190byA9IFxcUGVyY2VudGFnZVxcKVxuXG5yZXN1bHRzX2xvbmckR3JvdXAgPC0gZmFjdG9yKHJlc3VsdHNfbG9uZyRHcm91cCwgbGV2ZWxzID0gYyhcXHVwbm9cXCwgXFxkb3duXFwpKVxuIyBDcmVhdGUgdGhlIGJhciBwbG90XG5nZ3Bsb3QocmVzdWx0c19sb25nLCBhZXMoeCA9IGZhY3RvcihpKSwgeSA9IFBlcmNlbnRhZ2UsIGZpbGwgPSBHcm91cCkpICtcbiAgZ2VvbV9iYXIoc3RhdCA9IFxcaWRlbnRpdHlcXCwgcG9zaXRpb24gPSBcXGRvZGdlXFwpICtcbiAgbGFicyhcbiAgICB0aXRsZSA9IFxcQWxsIGxvb3BzXFwsXG4gICAgeCA9IFxcUHJlc2VuY2Ugb2YgaHViIGFuY2hvciB3aXRoID5pIGNvbm5lY3Rpb25zXFwsXG4gICAgeSA9IFxcUGVyY2VudGFnZVxcXG4gICkgK1xuICB0aGVtZV9taW5pbWFsKCkgK1xuICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFxcdXBub1xcID0gXFxibHVlXFwsIFxcZG93blxcID0gXFxyZWRcXCkpICtcbiAgdGhlbWUoYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoYW5nbGUgPSA0NSwgaGp1c3QgPSAxKSkgKyB5bGltKDAsIDEwMClcbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxucmVzdWx0cyA8LSB0aWJibGUoaSA9IG51bWVyaWMoKSwgdXBubyA9IG51bWVyaWMoKSwgZG93biA9IG51bWVyaWMoKSlcblxuZm9yKGkgaW4gc2VxKDEsIDEwKSl7XG4gIGRhdGEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcRHlsYW5faHViX2VzYy5jc3ZcXCkpXG4gIFxuICBkYXRhLmh1YiA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGFsbF9sY29uID4gaSlcbiAgdGVtcCA8LSBkYXRhLmh1YiAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuICBjb2xuYW1lcyh0ZW1wKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbiAgaHViLmFuY2hvciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcbiAgXG4gIFxuICBcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9hbGxfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X2FsbF9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXBubyA8LSBleHRyYWN0QW5jaG9yKGJpbmRfcm93cyhsb29wLnVwLCBsb29wLm5vKSlcblxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfYWxsX2RUQUd2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLmRvd24gPC0gZXh0cmFjdEFuY2hvcihsb29wLmRvd24pXG5cbiAgXG4gIG92ZXJsYXAudXBubyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwbm8sIGh1Yi5hbmNob3IpXG4gIG92ZXJsYXAuZG93biA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmRvd24sIGh1Yi5hbmNob3IpXG4gIFxuICBuMSA8LSBsZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhvdmVybGFwLnVwbm8pKSlcbiAgbjIgPC0gbGVuZ3RoKHVuaXF1ZShxdWVyeUhpdHMob3ZlcmxhcC5kb3duKSkpXG4gIFxuICBwZXJjMSA8LSByb3VuZChuMS9sZW5ndGgob3ZlcmxhcC51cG5vKSoxMDAsIDIpXG4gIHBlcmMyIDwtIHJvdW5kKG4yL2xlbmd0aChvdmVybGFwLmRvd24pKjEwMCwgMilcbiAgXG4gIHJlc3VsdHMgPC0gcmVzdWx0cyAlPiUgYWRkX3JvdyhpID0gaSwgdXBubyA9IHBlcmMxLCBkb3duID0gcGVyYzIpXG59XG5cblxuXG5yZXN1bHRzX2xvbmcgPC0gcmVzdWx0cyAlPiVcbiAgcGl2b3RfbG9uZ2VyKGNvbHMgPSBjKHVwbm8sIGRvd24pLCBuYW1lc190byA9IFxcR3JvdXBcXCwgdmFsdWVzX3RvID0gXFxQZXJjZW50YWdlXFwpXG5cbnJlc3VsdHNfbG9uZyRHcm91cCA8LSBmYWN0b3IocmVzdWx0c19sb25nJEdyb3VwLCBsZXZlbHMgPSBjKFxcdXBub1xcLCBcXGRvd25cXCkpXG4jIENyZWF0ZSB0aGUgYmFyIHBsb3RcbmdncGxvdChyZXN1bHRzX2xvbmcsIGFlcyh4ID0gZmFjdG9yKGkpLCB5ID0gUGVyY2VudGFnZSwgZmlsbCA9IEdyb3VwKSkgK1xuICBnZW9tX2JhcihzdGF0ID0gXFxpZGVudGl0eVxcLCBwb3NpdGlvbiA9IFxcZG9kZ2VcXCkgK1xuICBsYWJzKFxuICAgIHRpdGxlID0gXFxBbGwgbG9vcHNcXCxcbiAgICB4ID0gXFxQcmVzZW5jZSBvZiBodWIgYW5jaG9yIHdpdGggPmkgY29ubmVjdGlvbnNcXCxcbiAgICB5ID0gXFxQZXJjZW50YWdlXFxcbiAgKSArXG4gIHRoZW1lX21pbmltYWwoKSArXG4gIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGMoXFx1cG5vXFwgPSBcXGJsdWVcXCwgXFxkb3duXFwgPSBcXHJlZFxcKSkgK1xuICB0aGVtZShheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChhbmdsZSA9IDQ1LCBoanVzdCA9IDEpKSArIHlsaW0oMCwgMTAwKVxuYGBgXG5gYGAifQ== -->

```r
```r
results <- tibble(i = numeric(), upno = numeric(), down = numeric())

for(i in seq(1, 10)){
  data <- fread(here(refDir, \Dylan_hub_esc.csv\))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c(\chr\, \start\, \end\)
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)

  
  overlap.upno <- findOverlaps(anchor.upno, hub.anchor)
  overlap.down <- findOverlaps(anchor.down, hub.anchor)
  
  n1 <- length(unique(queryHits(overlap.upno)))
  n2 <- length(unique(queryHits(overlap.down)))
  
  perc1 <- round(n1/length(overlap.upno)*100, 2)
  perc2 <- round(n2/length(overlap.down)*100, 2)
  
  results <- results %>% add_row(i = i, upno = perc1, down = perc2)
}



results_long <- results %>%
  pivot_longer(cols = c(upno, down), names_to = \Group\, values_to = \Percentage\)

results_long$Group <- factor(results_long$Group, levels = c(\upno\, \down\))
# Create the bar plot
ggplot(results_long, aes(x = factor(i), y = Percentage, fill = Group)) +
  geom_bar(stat = \identity\, position = \dodge\) +
  labs(
    title = \All loops\,
    x = \Presence of hub anchor with >i connections\,
    y = \Percentage\
  ) +
  theme_minimal() +
  scale_fill_manual(values = c(\upno\ = \blue\, \down\ = \red\)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1)) + ylim(0, 100)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [2.29] Checking overlap with Stripes

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\nloop.up <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\"))\nloop.no <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\"))\nloop.upno <- (bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\"))\n\ngetOverlapLoopNum <- function(loop, peak){\n  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))\n  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))\n  a <- queryHits(findOverlaps(anchor1, peak))\n  b <- queryHits(findOverlaps(anchor2, peak))\n  return(length(unique(c(a, b))))\n}\n\ngetSEOverlapFisher <- function(allLoop, subsetLoop, peak){\n  all.overlap <- getOverlapLoopNum(allLoop, peak)\n  all.notOverlap <- nrow(allLoop) - all.overlap\n  \n  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)\n  subset.notOverlap <- nrow(subsetLoop) - subset.overlap\n  \n  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,\n                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)\n  colnames(contingency_table) <- c(\"Overlapping\", \"Not_Overlapping\")\n  rownames(contingency_table) <- c(\"All loops\", \"Subset loops\")\n  \n  # Perform Fisher's Exact Test\n  fisher_test_result <- fisher.test(contingency_table)\n  return(fisher_test_result)\n}\n\nname <- \"chromo_cons_annoHierarchy\"\nloop <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe.bedpe\"))\n\n\ni <- 2\ndata <- fread(here(refDir, \"Dylan_hub_esc.csv\"))\n\ndata.hub <- data %>% dplyr::filter(all_lcon > i)\ntemp <- data.hub %>% dplyr::select(c(1, 2, 3))\ncolnames(temp) <- c(\"chr\", \"start\", \"end\")\nhub.anchor <- makeGRangesFromDataFrame(temp)\n\n\ntemp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)\nresult.tb <- tibble(loopType = \"UP/NO\",\n                    target = paste0(\"hub_\", i),\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\ntemp <- getSEOverlapFisher(loop, loop.down, hub.anchor)\nresult.tb <- result.tb %>% \n  add_row(loopType = \"DOWN\",\n          target =  paste0(\"hub_\", i),\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\nfor(i in c(5)){\n  data <- fread(here(refDir, \"Dylan_hub_esc.csv\"))\n  \n  data.hub <- data %>% dplyr::filter(all_lcon > i)\n  temp <- data.hub %>% dplyr::select(c(1, 2, 3))\n  colnames(temp) <- c(\"chr\", \"start\", \"end\")\n  hub.anchor <- makeGRangesFromDataFrame(temp)\n  \n  \n  temp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)\n  result.tb <- result.tb %>% add_row(loopType = \"UP/NO\",\n                      target = paste0(\"hub_\", i),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  temp <- getSEOverlapFisher(loop, loop.down, hub.anchor)\n  result.tb <- result.tb %>% \n    add_row(loopType = \"DOWN\",\n            target =  paste0(\"hub_\", i),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  \n}\n\nlibrary(circlize)\ndata <- result.tb\nheatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%\npivot_wider(names_from = loopType, values_from = oddsRatio) %>%\n  column_to_rownames(var = \"target\")\n\npvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%\n  pivot_wider(names_from = loopType, values_from = pvalue) %>%\n  column_to_rownames(var = \"target\")\n\n# col_fun <- colorRamp2(c(0, 1, 2), \n#                       c(\"blue\", \"white\", \"red\"))\n\ndata$target <- factor(data$target, levels = c(\"hub_5\", \"hub_2\"))\ndata$loopType <- factor(data$loopType, levels = c(\"UP/NO\", \"DOWN\"))\np <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\"#4852A0\", \"white\", \"#CB333A\"),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \"white\", high = \"#CB333A\",\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\n\nfileName <- here(figDir, \"heatmap_hub_enrichment_dotplot_all\")\nwidth <- panelSize(1.65)*mmToInch\nheight <- panelSize(1.1)*mmToInch\n# # png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n# # print(p)\n# # dev.off()\nsvglite(paste0(fileName, \".svg\"),  height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nloop.upno <- (bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\n\ngetOverlapLoopNum <- function(loop, peak){\n  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))\n  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))\n  a <- queryHits(findOverlaps(anchor1, peak))\n  b <- queryHits(findOverlaps(anchor2, peak))\n  return(length(unique(c(a, b))))\n}\n\ngetSEOverlapFisher <- function(allLoop, subsetLoop, peak){\n  all.overlap <- getOverlapLoopNum(allLoop, peak)\n  all.notOverlap <- nrow(allLoop) - all.overlap\n  \n  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)\n  subset.notOverlap <- nrow(subsetLoop) - subset.overlap\n  \n  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,\n                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)\n  colnames(contingency_table) <- c(\\Overlapping\\, \\Not_Overlapping\\)\n  rownames(contingency_table) <- c(\\All loops\\, \\Subset loops\\)\n  \n  # Perform Fisher's Exact Test\n  fisher_test_result <- fisher.test(contingency_table)\n  return(fisher_test_result)\n}\n\nname <- \\chromo_cons_annoHierarchy\\\nloop <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\))\n\n\ni <- 2\ndata <- fread(here(refDir, \\Dylan_hub_esc.csv\\))\n\ndata.hub <- data %>% dplyr::filter(all_lcon > i)\ntemp <- data.hub %>% dplyr::select(c(1, 2, 3))\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\nhub.anchor <- makeGRangesFromDataFrame(temp)\n\n\ntemp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)\nresult.tb <- tibble(loopType = \\UP/NO\\,\n                    target = paste0(\\hub_\\, i),\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\ntemp <- getSEOverlapFisher(loop, loop.down, hub.anchor)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target =  paste0(\\hub_\\, i),\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\nfor(i in c(5)){\n  data <- fread(here(refDir, \\Dylan_hub_esc.csv\\))\n  \n  data.hub <- data %>% dplyr::filter(all_lcon > i)\n  temp <- data.hub %>% dplyr::select(c(1, 2, 3))\n  colnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\n  hub.anchor <- makeGRangesFromDataFrame(temp)\n  \n  \n  temp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)\n  result.tb <- result.tb %>% add_row(loopType = \\UP/NO\\,\n                      target = paste0(\\hub_\\, i),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  temp <- getSEOverlapFisher(loop, loop.down, hub.anchor)\n  result.tb <- result.tb %>% \n    add_row(loopType = \\DOWN\\,\n            target =  paste0(\\hub_\\, i),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  \n}\n\nlibrary(circlize)\ndata <- result.tb\nheatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%\npivot_wider(names_from = loopType, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%\n  pivot_wider(names_from = loopType, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\n# col_fun <- colorRamp2(c(0, 1, 2), \n#                       c(\\blue\\, \\white\\, \\red\\))\n\ndata$target <- factor(data$target, levels = c(\\hub_5\\, \\hub_2\\))\ndata$loopType <- factor(data$loopType, levels = c(\\UP/NO\\, \\DOWN\\))\np <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\\#4852A0\\, \\white\\, \\#CB333A\\),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \\white\\, high = \\#CB333A\\,\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\n\nfileName <- here(figDir, \\heatmap_hub_enrichment_dotplot_all\\)\nwidth <- panelSize(1.65)*mmToInch\nheight <- panelSize(1.1)*mmToInch\n# # png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# # print(p)\n# # dev.off()\nsvglite(paste0(fileName, \\.svg\\),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
loop.upno <- (bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))

getOverlapLoopNum <- function(loop, peak){
  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))
  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))
  a <- queryHits(findOverlaps(anchor1, peak))
  b <- queryHits(findOverlaps(anchor2, peak))
  return(length(unique(c(a, b))))
}

getSEOverlapFisher <- function(allLoop, subsetLoop, peak){
  all.overlap <- getOverlapLoopNum(allLoop, peak)
  all.notOverlap <- nrow(allLoop) - all.overlap
  
  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)
  subset.notOverlap <- nrow(subsetLoop) - subset.overlap
  
  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,
                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)
  colnames(contingency_table) <- c(\Overlapping\, \Not_Overlapping\)
  rownames(contingency_table) <- c(\All loops\, \Subset loops\)
  
  # Perform Fisher's Exact Test
  fisher_test_result <- fisher.test(contingency_table)
  return(fisher_test_result)
}

name <- \chromo_cons_annoHierarchy\
loop <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\))


i <- 2
data <- fread(here(refDir, \Dylan_hub_esc.csv\))

data.hub <- data %>% dplyr::filter(all_lcon > i)
temp <- data.hub %>% dplyr::select(c(1, 2, 3))
colnames(temp) <- c(\chr\, \start\, \end\)
hub.anchor <- makeGRangesFromDataFrame(temp)


temp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)
result.tb <- tibble(loopType = \UP/NO\,
                    target = paste0(\hub_\, i),
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)
temp <- getSEOverlapFisher(loop, loop.down, hub.anchor)
result.tb <- result.tb %>% 
  add_row(loopType = \DOWN\,
          target =  paste0(\hub_\, i),
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)


for(i in c(5)){
  data <- fread(here(refDir, \Dylan_hub_esc.csv\))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c(\chr\, \start\, \end\)
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  temp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)
  result.tb <- result.tb %>% add_row(loopType = \UP/NO\,
                      target = paste0(\hub_\, i),
                      pvalue = temp$p.value,
                      oddsRatio = temp$estimate)
  temp <- getSEOverlapFisher(loop, loop.down, hub.anchor)
  result.tb <- result.tb %>% 
    add_row(loopType = \DOWN\,
            target =  paste0(\hub_\, i),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  
}

library(circlize)
data <- result.tb
heatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%
pivot_wider(names_from = loopType, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%
  pivot_wider(names_from = loopType, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

# col_fun <- colorRamp2(c(0, 1, 2), 
#                       c(\blue\, \white\, \red\))

data$target <- factor(data$target, levels = c(\hub_5\, \hub_2\))
data$loopType <- factor(data$loopType, levels = c(\UP/NO\, \DOWN\))
p <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
  scale_fill_gradientn(colors = c(\#4852A0\, \white\, \#CB333A\),  # Define gradient colors
                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), 
                      #low = \white\, high = \#CB333A\,
                      #                  limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )


fileName <- here(figDir, \heatmap_hub_enrichment_dotplot_all\)
width <- panelSize(1.65)*mmToInch
height <- panelSize(1.1)*mmToInch
# # png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# # print(p)
# # dev.off()
svglite(paste0(fileName, \.svg\),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nloop.upno <- (bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\n\ngetOverlapLoopNum <- function(loop, peak){\n  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))\n  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))\n  a <- queryHits(findOverlaps(anchor1, peak))\n  b <- queryHits(findOverlaps(anchor2, peak))\n  return(length(unique(c(a, b))))\n}\n\ngetSEOverlapFisher <- function(allLoop, subsetLoop, peak){\n  all.overlap <- getOverlapLoopNum(allLoop, peak)\n  all.notOverlap <- nrow(allLoop) - all.overlap\n  \n  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)\n  subset.notOverlap <- nrow(subsetLoop) - subset.overlap\n  \n  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,\n                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)\n  colnames(contingency_table) <- c(\\Overlapping\\, \\Not_Overlapping\\)\n  rownames(contingency_table) <- c(\\All loops\\, \\Subset loops\\)\n  \n  # Perform Fisher's Exact Test\n  fisher_test_result <- fisher.test(contingency_table)\n  return(fisher_test_result)\n}\n\nname <- \\chromo_cons_annoHierarchy\\\nloop <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\))\n\n\ni <- 2\ndata <- fread(here(refDir, \\Dylan_hub_esc.csv\\))\n\ndata.hub <- data %>% dplyr::filter(all_lcon > i)\ntemp <- data.hub %>% dplyr::select(c(1, 2, 3))\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\nhub.anchor <- makeGRangesFromDataFrame(temp)\n\n\ntemp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)\nresult.tb <- tibble(loopType = \\UP/NO\\,\n                    target = paste0(\\hub_\\, i),\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\ntemp <- getSEOverlapFisher(loop, loop.down, hub.anchor)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target =  paste0(\\hub_\\, i),\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\nfor(i in c(5)){\n  data <- fread(here(refDir, \\Dylan_hub_esc.csv\\))\n  \n  data.hub <- data %>% dplyr::filter(all_lcon > i)\n  temp <- data.hub %>% dplyr::select(c(1, 2, 3))\n  colnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\n  hub.anchor <- makeGRangesFromDataFrame(temp)\n  \n  \n  temp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)\n  result.tb <- result.tb %>% add_row(loopType = \\UP/NO\\,\n                      target = paste0(\\hub_\\, i),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  temp <- getSEOverlapFisher(loop, loop.down, hub.anchor)\n  result.tb <- result.tb %>% \n    add_row(loopType = \\DOWN\\,\n            target =  paste0(\\hub_\\, i),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  \n}\n\nlibrary(circlize)\ndata <- result.tb\nheatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%\npivot_wider(names_from = loopType, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%\n  pivot_wider(names_from = loopType, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\n# col_fun <- colorRamp2(c(0, 1, 2), \n#                       c(\\blue\\, \\white\\, \\red\\))\n\ndata$target <- factor(data$target, levels = c(\\hub_5\\, \\hub_2\\))\ndata$loopType <- factor(data$loopType, levels = c(\\UP/NO\\, \\DOWN\\))\np <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\\#4852A0\\, \\white\\, \\#CB333A\\),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \\white\\, high = \\#CB333A\\,\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\n\nfileName <- here(figDir, \\heatmap_hub_enrichment_dotplot_all\\)\nwidth <- panelSize(1.65)*mmToInch\nheight <- panelSize(1.1)*mmToInch\n# # png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# # print(p)\n# # dev.off()\nsvglite(paste0(fileName, \\.svg\\),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nloop.upno <- (bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\n\ngetOverlapLoopNum <- function(loop, peak){\n  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))\n  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))\n  a <- queryHits(findOverlaps(anchor1, peak))\n  b <- queryHits(findOverlaps(anchor2, peak))\n  return(length(unique(c(a, b))))\n}\n\ngetSEOverlapFisher <- function(allLoop, subsetLoop, peak){\n  all.overlap <- getOverlapLoopNum(allLoop, peak)\n  all.notOverlap <- nrow(allLoop) - all.overlap\n  \n  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)\n  subset.notOverlap <- nrow(subsetLoop) - subset.overlap\n  \n  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,\n                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)\n  colnames(contingency_table) <- c(\\Overlapping\\, \\Not_Overlapping\\)\n  rownames(contingency_table) <- c(\\All loops\\, \\Subset loops\\)\n  \n  # Perform Fisher's Exact Test\n  fisher_test_result <- fisher.test(contingency_table)\n  return(fisher_test_result)\n}\n\nname <- \\chromo_cons_annoHierarchy\\\nloop <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\))\n\n\ni <- 2\ndata <- fread(here(refDir, \\Dylan_hub_esc.csv\\))\n\ndata.hub <- data %>% dplyr::filter(all_lcon > i)\ntemp <- data.hub %>% dplyr::select(c(1, 2, 3))\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\nhub.anchor <- makeGRangesFromDataFrame(temp)\n\n\ntemp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)\nresult.tb <- tibble(loopType = \\UP/NO\\,\n                    target = paste0(\\hub_\\, i),\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\ntemp <- getSEOverlapFisher(loop, loop.down, hub.anchor)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target =  paste0(\\hub_\\, i),\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\nfor(i in c(5)){\n  data <- fread(here(refDir, \\Dylan_hub_esc.csv\\))\n  \n  data.hub <- data %>% dplyr::filter(all_lcon > i)\n  temp <- data.hub %>% dplyr::select(c(1, 2, 3))\n  colnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\n  hub.anchor <- makeGRangesFromDataFrame(temp)\n  \n  \n  temp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)\n  result.tb <- result.tb %>% add_row(loopType = \\UP/NO\\,\n                      target = paste0(\\hub_\\, i),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  temp <- getSEOverlapFisher(loop, loop.down, hub.anchor)\n  result.tb <- result.tb %>% \n    add_row(loopType = \\DOWN\\,\n            target =  paste0(\\hub_\\, i),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  \n}\n\nlibrary(circlize)\ndata <- result.tb\nheatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%\npivot_wider(names_from = loopType, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%\n  pivot_wider(names_from = loopType, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\n# col_fun <- colorRamp2(c(0, 1, 2), \n#                       c(\\blue\\, \\white\\, \\red\\))\n\ndata$target <- factor(data$target, levels = c(\\hub_5\\, \\hub_2\\))\ndata$loopType <- factor(data$loopType, levels = c(\\UP/NO\\, \\DOWN\\))\np <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\\#4852A0\\, \\white\\, \\#CB333A\\),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \\white\\, high = \\#CB333A\\,\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\n\nfileName <- here(figDir, \\heatmap_hub_enrichment_dotplot_all\\)\nwidth <- panelSize(1.65)*mmToInch\nheight <- panelSize(1.1)*mmToInch\n# # png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# # print(p)\n# # dev.off()\nsvglite(paste0(fileName, \\.svg\\),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\))\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\))\nloop.upno <- (bind_rows(loop.up, loop.no))\n\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\))\n\ngetOverlapLoopNum <- function(loop, peak){\n  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))\n  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))\n  a <- queryHits(findOverlaps(anchor1, peak))\n  b <- queryHits(findOverlaps(anchor2, peak))\n  return(length(unique(c(a, b))))\n}\n\ngetSEOverlapFisher <- function(allLoop, subsetLoop, peak){\n  all.overlap <- getOverlapLoopNum(allLoop, peak)\n  all.notOverlap <- nrow(allLoop) - all.overlap\n  \n  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)\n  subset.notOverlap <- nrow(subsetLoop) - subset.overlap\n  \n  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,\n                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)\n  colnames(contingency_table) <- c(\\Overlapping\\, \\Not_Overlapping\\)\n  rownames(contingency_table) <- c(\\All loops\\, \\Subset loops\\)\n  \n  # Perform Fisher's Exact Test\n  fisher_test_result <- fisher.test(contingency_table)\n  return(fisher_test_result)\n}\n\nname <- \\chromo_cons_annoHierarchy\\\nloop <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe.bedpe\\))\n\n\ni <- 2\ndata <- fread(here(refDir, \\Dylan_hub_esc.csv\\))\n\ndata.hub <- data %>% dplyr::filter(all_lcon > i)\ntemp <- data.hub %>% dplyr::select(c(1, 2, 3))\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\nhub.anchor <- makeGRangesFromDataFrame(temp)\n\n\ntemp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)\nresult.tb <- tibble(loopType = \\UP/NO\\,\n                    target = paste0(\\hub_\\, i),\n                    pvalue = temp$p.value,\n                    oddsRatio = temp$estimate)\ntemp <- getSEOverlapFisher(loop, loop.down, hub.anchor)\nresult.tb <- result.tb %>% \n  add_row(loopType = \\DOWN\\,\n          target =  paste0(\\hub_\\, i),\n          pvalue = temp$p.value,\n          oddsRatio = temp$estimate)\n\n\nfor(i in c(5)){\n  data <- fread(here(refDir, \\Dylan_hub_esc.csv\\))\n  \n  data.hub <- data %>% dplyr::filter(all_lcon > i)\n  temp <- data.hub %>% dplyr::select(c(1, 2, 3))\n  colnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\n  hub.anchor <- makeGRangesFromDataFrame(temp)\n  \n  \n  temp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)\n  result.tb <- result.tb %>% add_row(loopType = \\UP/NO\\,\n                      target = paste0(\\hub_\\, i),\n                      pvalue = temp$p.value,\n                      oddsRatio = temp$estimate)\n  temp <- getSEOverlapFisher(loop, loop.down, hub.anchor)\n  result.tb <- result.tb %>% \n    add_row(loopType = \\DOWN\\,\n            target =  paste0(\\hub_\\, i),\n            pvalue = temp$p.value,\n            oddsRatio = temp$estimate)\n  \n  \n}\n\nlibrary(circlize)\ndata <- result.tb\nheatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%\npivot_wider(names_from = loopType, values_from = oddsRatio) %>%\n  column_to_rownames(var = \\target\\)\n\npvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%\n  pivot_wider(names_from = loopType, values_from = pvalue) %>%\n  column_to_rownames(var = \\target\\)\n\n# col_fun <- colorRamp2(c(0, 1, 2), \n#                       c(\\blue\\, \\white\\, \\red\\))\n\ndata$target <- factor(data$target, levels = c(\\hub_5\\, \\hub_2\\))\ndata$loopType <- factor(data$loopType, levels = c(\\UP/NO\\, \\DOWN\\))\np <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +\n  geom_point(shape = 21,        # Ensures a point with an outline\n             stroke = 1*ptToMM      # Line width for the border\n  ) + theme_bw() + \n  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here\n  scale_fill_gradientn(colors = c(\\#4852A0\\, \\white\\, \\#CB333A\\),  # Define gradient colors\n                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), \n                      #low = \\white\\, high = \\#CB333A\\,\n                      #                  limits = c(1, 3),\n                      oob = scales::squish, # Define gradient colors\n                      guide = guide_colorbar(\n                        barwidth = 1.5/5.08,  # Adjust width of the color bar\n                        barheight = 15/5.08   # Adjust height of the color bar\n                      )\n  ) + labs(x = NULL, y = NULL)  +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )\n\n\nfileName <- here(figDir, \\heatmap_hub_enrichment_dotplot_all\\)\nwidth <- panelSize(1.65)*mmToInch\nheight <- panelSize(1.1)*mmToInch\n# # png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n# # print(p)\n# # dev.off()\nsvglite(paste0(fileName, \\.svg\\),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
loop.upno <- (bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))

getOverlapLoopNum <- function(loop, peak){
  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))
  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))
  a <- queryHits(findOverlaps(anchor1, peak))
  b <- queryHits(findOverlaps(anchor2, peak))
  return(length(unique(c(a, b))))
}

getSEOverlapFisher <- function(allLoop, subsetLoop, peak){
  all.overlap <- getOverlapLoopNum(allLoop, peak)
  all.notOverlap <- nrow(allLoop) - all.overlap
  
  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)
  subset.notOverlap <- nrow(subsetLoop) - subset.overlap
  
  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,
                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)
  colnames(contingency_table) <- c(\Overlapping\, \Not_Overlapping\)
  rownames(contingency_table) <- c(\All loops\, \Subset loops\)
  
  # Perform Fisher's Exact Test
  fisher_test_result <- fisher.test(contingency_table)
  return(fisher_test_result)
}

name <- \chromo_cons_annoHierarchy\
loop <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe.bedpe\))


i <- 2
data <- fread(here(refDir, \Dylan_hub_esc.csv\))

data.hub <- data %>% dplyr::filter(all_lcon > i)
temp <- data.hub %>% dplyr::select(c(1, 2, 3))
colnames(temp) <- c(\chr\, \start\, \end\)
hub.anchor <- makeGRangesFromDataFrame(temp)


temp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)
result.tb <- tibble(loopType = \UP/NO\,
                    target = paste0(\hub_\, i),
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)
temp <- getSEOverlapFisher(loop, loop.down, hub.anchor)
result.tb <- result.tb %>% 
  add_row(loopType = \DOWN\,
          target =  paste0(\hub_\, i),
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)


for(i in c(5)){
  data <- fread(here(refDir, \Dylan_hub_esc.csv\))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c(\chr\, \start\, \end\)
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  temp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)
  result.tb <- result.tb %>% add_row(loopType = \UP/NO\,
                      target = paste0(\hub_\, i),
                      pvalue = temp$p.value,
                      oddsRatio = temp$estimate)
  temp <- getSEOverlapFisher(loop, loop.down, hub.anchor)
  result.tb <- result.tb %>% 
    add_row(loopType = \DOWN\,
            target =  paste0(\hub_\, i),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  
}

library(circlize)
data <- result.tb
heatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%
pivot_wider(names_from = loopType, values_from = oddsRatio) %>%
  column_to_rownames(var = \target\)

pvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%
  pivot_wider(names_from = loopType, values_from = pvalue) %>%
  column_to_rownames(var = \target\)

# col_fun <- colorRamp2(c(0, 1, 2), 
#                       c(\blue\, \white\, \red\))

data$target <- factor(data$target, levels = c(\hub_5\, \hub_2\))
data$loopType <- factor(data$loopType, levels = c(\UP/NO\, \DOWN\))
p <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
  scale_fill_gradientn(colors = c(\#4852A0\, \white\, \#CB333A\),  # Define gradient colors
                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), 
                      #low = \white\, high = \#CB333A\,
                      #                  limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )


fileName <- here(figDir, \heatmap_hub_enrichment_dotplot_all\)
width <- panelSize(1.65)*mmToInch
height <- panelSize(1.1)*mmToInch
# # png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
# # print(p)
# # dev.off()
svglite(paste0(fileName, \.svg\),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [2.30] Hubs from Dylan Paper
#### All loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjbVZ6ZFd4MGN5QThMU0IwYVdKaWJHVW9hU0E5SUc1MWJXVnlhV01vS1N3Z2RYQnVieUE5SUc1MWJXVnlhV01vS1N3Z1pHOTNiaUE5SUc1MWJXVnlhV01vS1NsY2JseHVabTl5S0drZ2FXNGdjMlZ4S0RFc0lERXdLU2w3WEc0Z0lHUmhkR0VnUEMwZ1puSmxZV1FvYUdWeVpTaHlaV1pFYVhJc0lGd2lSSGxzWVc1ZmFIVmlYMlZ6WXk1amMzWmNJaWtwWEc0Z0lGeHVJQ0JrWVhSaExtaDFZaUE4TFNCa1lYUmhJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLR0ZzYkY5c1kyOXVJRDRnYVNsY2JpQWdkR1Z0Y0NBOExTQmtZWFJoTG1oMVlpQWxQaVVnWkhCc2VYSTZPbk5sYkdWamRDaGpLREVzSURJc0lETXBLVnh1SUNCamIyeHVZVzFsY3loMFpXMXdLU0E4TFNCaktGd2lZMmh5WENJc0lGd2ljM1JoY25SY0lpd2dYQ0psYm1SY0lpbGNiaUFnYUhWaUxtRnVZMmh2Y2lBOExTQnRZV3RsUjFKaGJtZGxjMFp5YjIxRVlYUmhSbkpoYldVb2RHVnRjQ2xjYmlBZ1hHNGdJRnh1SUNCY2JteHZiM0F1ZFhBZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGd2lZMmh5YjIxdlgyTnZibk5mWVc1dWIwaHBaWEpoY21Ob2VWOXdaUzF3WlY5a1ZFRkhkbk5FVFZOUFgxVlFYMlJwWm1Zd0xqSXVZbVZrY0dWY0lpa3BYRzVzYjI5d0xtNXZJRHd0SUdaeVpXRmtLR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0JjSW1Ob2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxmY0dVdGNHVmZaRlJCUjNaelJFMVRUMTlPVDE5a2FXWm1NQzR5TG1KbFpIQmxYQ0lwS1Z4dVlXNWphRzl5TG5Wd2JtOGdQQzBnWlhoMGNtRmpkRUZ1WTJodmNpaGlhVzVrWDNKdmQzTW9iRzl2Y0M1MWNDd2diRzl2Y0M1dWJ5a3BYRzVjYm14dmIzQXVaRzkzYmlBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z1hDSmphSEp2Ylc5ZlkyOXVjMTloYm01dlNHbGxjbUZ5WTJoNVgzQmxMWEJsWDJSVVFVZDJjMFJOVTA5ZlJFOVhUbDlrYVdabU1DNHlMbUpsWkhCbFhDSXBLVnh1WVc1amFHOXlMbVJ2ZDI0Z1BDMGdaWGgwY21GamRFRnVZMmh2Y2loc2IyOXdMbVJ2ZDI0cFhHNWNibHh1SUNCY2JpQWdiM1psY214aGNDNTFjRzV2SUR3dElHWnBibVJQZG1WeWJHRndjeWhoYm1Ob2IzSXVkWEJ1Ynl3Z2FIVmlMbUZ1WTJodmNpbGNiaUFnYjNabGNteGhjQzVrYjNkdUlEd3RJR1pwYm1SUGRtVnliR0Z3Y3loaGJtTm9iM0l1Wkc5M2Jpd2dhSFZpTG1GdVkyaHZjaWxjYmlBZ1hHNGdJRzR4SUR3dElHeGxibWQwYUNoMWJtbHhkV1VvY1hWbGNubElhWFJ6S0c5MlpYSnNZWEF1ZFhCdWJ5a3BLVnh1SUNCdU1pQThMU0JzWlc1bmRHZ29kVzVwY1hWbEtIRjFaWEo1U0dsMGN5aHZkbVZ5YkdGd0xtUnZkMjRwS1NsY2JpQWdYRzRnSUhCbGNtTXhJRHd0SUhKdmRXNWtLRzR4TDJ4bGJtZDBhQ2h2ZG1WeWJHRndMblZ3Ym04cEtqRXdNQ3dnTWlsY2JpQWdjR1Z5WXpJZ1BDMGdjbTkxYm1Rb2JqSXZiR1Z1WjNSb0tHOTJaWEpzWVhBdVpHOTNiaWtxTVRBd0xDQXlLVnh1SUNCY2JpQWdjbVZ6ZFd4MGN5QThMU0J5WlhOMWJIUnpJQ1UrSlNCaFpHUmZjbTkzS0drZ1BTQnBMQ0IxY0c1dklEMGdjR1Z5WXpFc0lHUnZkMjRnUFNCd1pYSmpNaWxjYm4xY2JseHVYRzVjYm5KbGMzVnNkSE5mYkc5dVp5QThMU0J5WlhOMWJIUnpJQ1UrSlZ4dUlDQndhWFp2ZEY5c2IyNW5aWElvWTI5c2N5QTlJR01vZFhCdWJ5d2daRzkzYmlrc0lHNWhiV1Z6WDNSdklEMGdYQ0pIY205MWNGd2lMQ0IyWVd4MVpYTmZkRzhnUFNCY0lsQmxjbU5sYm5SaFoyVmNJaWxjYm5KbGMzVnNkSE5mYkc5dVp5UkhjbTkxY0NBOExTQm1ZV04wYjNJb2NtVnpkV3gwYzE5c2IyNW5KRWR5YjNWd0xDQnNaWFpsYkhNZ1BTQmpLRndpZFhCdWIxd2lMQ0JjSW1SdmQyNWNJaWtwWEc1Y2JpTWdRM0psWVhSbElIUm9aU0JpWVhJZ2NHeHZkRnh1WjJkd2JHOTBLSEpsYzNWc2RITmZiRzl1Wnl3Z1lXVnpLSGdnUFNCbVlXTjBiM0lvYVNrc0lIa2dQU0JRWlhKalpXNTBZV2RsTENCbWFXeHNJRDBnUjNKdmRYQXBLU0FyWEc0Z0lHZGxiMjFmWW1GeUtITjBZWFFnUFNCY0ltbGtaVzUwYVhSNVhDSXNJSEJ2YzJsMGFXOXVJRDBnWENKa2IyUm5aVndpS1NBclhHNGdJR3hoWW5Nb1hHNGdJQ0FnZEdsMGJHVWdQU0JjSWxCRkxWQkZJR3h2YjNCelhDSXNYRzRnSUNBZ2VDQTlJRndpVUhKbGMyVnVZMlVnYjJZZ2FIVmlJR0Z1WTJodmNpQjNhWFJvSUQ1cElHTnZibTVsWTNScGIyNXpYQ0lzWEc0Z0lDQWdlU0E5SUZ3aVVHVnlZMlZ1ZEdGblpWd2lYRzRnSUNrZ0sxeHVJQ0IwYUdWdFpWOXRhVzVwYldGc0tDa2dLMXh1SUNCelkyRnNaVjltYVd4c1gyMWhiblZoYkNoMllXeDFaWE1nUFNCaktGd2lkWEJ1YjF3aUlEMGdYQ0ppYkhWbFhDSXNJRndpWkc5M2Jsd2lJRDBnWENKeVpXUmNJaWtwSUN0Y2JpQWdkR2hsYldVb1lYaHBjeTUwWlhoMExuZ2dQU0JsYkdWdFpXNTBYM1JsZUhRb1lXNW5iR1VnUFNBME5Td2dhR3AxYzNRZ1BTQXhLU2tnS3lCNWJHbHRLREFzSURFd01DbGNibUJnWUNKOSAtLT5cblxuYGBgclxucmVzdWx0cyA8LSB0aWJibGUoaSA9IG51bWVyaWMoKSwgdXBubyA9IG51bWVyaWMoKSwgZG93biA9IG51bWVyaWMoKSlcblxuZm9yKGkgaW4gc2VxKDEsIDEwKSl7XG4gIGRhdGEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcRHlsYW5faHViX2VzYy5jc3ZcXCkpXG4gIFxuICBkYXRhLmh1YiA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGFsbF9sY29uID4gaSlcbiAgdGVtcCA8LSBkYXRhLmh1YiAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuICBjb2xuYW1lcyh0ZW1wKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbiAgaHViLmFuY2hvciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcbiAgXG4gIFxuICBcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLnVwbm8gPC0gZXh0cmFjdEFuY2hvcihiaW5kX3Jvd3MobG9vcC51cCwgbG9vcC5ubykpXG5cbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX2RUQUd2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLmRvd24gPC0gZXh0cmFjdEFuY2hvcihsb29wLmRvd24pXG5cblxuICBcbiAgb3ZlcmxhcC51cG5vIDwtIGZpbmRPdmVybGFwcyhhbmNob3IudXBubywgaHViLmFuY2hvcilcbiAgb3ZlcmxhcC5kb3duIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuZG93biwgaHViLmFuY2hvcilcbiAgXG4gIG4xIDwtIGxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKG92ZXJsYXAudXBubykpKVxuICBuMiA8LSBsZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhvdmVybGFwLmRvd24pKSlcbiAgXG4gIHBlcmMxIDwtIHJvdW5kKG4xL2xlbmd0aChvdmVybGFwLnVwbm8pKjEwMCwgMilcbiAgcGVyYzIgPC0gcm91bmQobjIvbGVuZ3RoKG92ZXJsYXAuZG93bikqMTAwLCAyKVxuICBcbiAgcmVzdWx0cyA8LSByZXN1bHRzICU+JSBhZGRfcm93KGkgPSBpLCB1cG5vID0gcGVyYzEsIGRvd24gPSBwZXJjMilcbn1cblxuXG5cbnJlc3VsdHNfbG9uZyA8LSByZXN1bHRzICU+JVxuICBwaXZvdF9sb25nZXIoY29scyA9IGModXBubywgZG93biksIG5hbWVzX3RvID0gXFxHcm91cFxcLCB2YWx1ZXNfdG8gPSBcXFBlcmNlbnRhZ2VcXClcbnJlc3VsdHNfbG9uZyRHcm91cCA8LSBmYWN0b3IocmVzdWx0c19sb25nJEdyb3VwLCBsZXZlbHMgPSBjKFxcdXBub1xcLCBcXGRvd25cXCkpXG5cbiMgQ3JlYXRlIHRoZSBiYXIgcGxvdFxuZ2dwbG90KHJlc3VsdHNfbG9uZywgYWVzKHggPSBmYWN0b3IoaSksIHkgPSBQZXJjZW50YWdlLCBmaWxsID0gR3JvdXApKSArXG4gIGdlb21fYmFyKHN0YXQgPSBcXGlkZW50aXR5XFwsIHBvc2l0aW9uID0gXFxkb2RnZVxcKSArXG4gIGxhYnMoXG4gICAgdGl0bGUgPSBcXFBFLVBFIGxvb3BzXFwsXG4gICAgeCA9IFxcUHJlc2VuY2Ugb2YgaHViIGFuY2hvciB3aXRoID5pIGNvbm5lY3Rpb25zXFwsXG4gICAgeSA9IFxcUGVyY2VudGFnZVxcXG4gICkgK1xuICB0aGVtZV9taW5pbWFsKCkgK1xuICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFxcdXBub1xcID0gXFxibHVlXFwsIFxcZG93blxcID0gXFxyZWRcXCkpICtcbiAgdGhlbWUoYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoYW5nbGUgPSA0NSwgaGp1c3QgPSAxKSkgKyB5bGltKDAsIDEwMClcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
results <- tibble(i = numeric(), upno = numeric(), down = numeric())

for(i in seq(1, 10)){
  data <- fread(here(refDir, \Dylan_hub_esc.csv\))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c(\chr\, \start\, \end\)
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)


  
  overlap.upno <- findOverlaps(anchor.upno, hub.anchor)
  overlap.down <- findOverlaps(anchor.down, hub.anchor)
  
  n1 <- length(unique(queryHits(overlap.upno)))
  n2 <- length(unique(queryHits(overlap.down)))
  
  perc1 <- round(n1/length(overlap.upno)*100, 2)
  perc2 <- round(n2/length(overlap.down)*100, 2)
  
  results <- results %>% add_row(i = i, upno = perc1, down = perc2)
}



results_long <- results %>%
  pivot_longer(cols = c(upno, down), names_to = \Group\, values_to = \Percentage\)
results_long$Group <- factor(results_long$Group, levels = c(\upno\, \down\))

# Create the bar plot
ggplot(results_long, aes(x = factor(i), y = Percentage, fill = Group)) +
  geom_bar(stat = \identity\, position = \dodge\) +
  labs(
    title = \PE-PE loops\,
    x = \Presence of hub anchor with >i connections\,
    y = \Percentage\
  ) +
  theme_minimal() +
  scale_fill_manual(values = c(\upno\ = \blue\, \down\ = \red\)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1)) + ylim(0, 100)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWNtVnpkV3gwY3lBOExTQjBhV0ppYkdVb2FTQTlJRzUxYldWeWFXTW9LU3dnZFhCdWJ5QTlJRzUxYldWeWFXTW9LU3dnWkc5M2JpQTlJRzUxYldWeWFXTW9LU2xjYmx4dVptOXlLR2tnYVc0Z2MyVnhLREVzSURFd0tTbDdYRzRnSUdSaGRHRWdQQzBnWm5KbFlXUW9hR1Z5WlNoeVpXWkVhWElzSUZ4Y1JIbHNZVzVmYUhWaVgyVnpZeTVqYzNaY1hDa3BYRzRnSUZ4dUlDQmtZWFJoTG1oMVlpQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHRnNiRjlzWTI5dUlENGdhU2xjYmlBZ2RHVnRjQ0E4TFNCa1lYUmhMbWgxWWlBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoaktERXNJRElzSURNcEtWeHVJQ0JqYjJ4dVlXMWxjeWgwWlcxd0tTQThMU0JqS0Z4Y1kyaHlYRndzSUZ4Y2MzUmhjblJjWEN3Z1hGeGxibVJjWENsY2JpQWdhSFZpTG1GdVkyaHZjaUE4TFNCdFlXdGxSMUpoYm1kbGMwWnliMjFFWVhSaFJuSmhiV1VvZEdWdGNDbGNiaUFnWEc0Z0lGeHVJQ0JjYm14dmIzQXVkWEFnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ4Y1kyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5d1pTMXdaVjlrVkVGSGRuTkVUVk5QWDFWUVgyUnBabVl3TGpJdVltVmtjR1ZjWENrcFhHNXNiMjl3TG01dklEd3RJR1p5WldGa0tHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQmNYR05vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGZjR1V0Y0dWZlpGUkJSM1p6UkUxVFQxOU9UMTlrYVdabU1DNHlMbUpsWkhCbFhGd3BLVnh1WVc1amFHOXlMblZ3Ym04Z1BDMGdaWGgwY21GamRFRnVZMmh2Y2loaWFXNWtYM0p2ZDNNb2JHOXZjQzUxY0N3Z2JHOXZjQzV1YnlrcFhHNWNibXh2YjNBdVpHOTNiaUE4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnWEZ4amFISnZiVzlmWTI5dWMxOWhibTV2U0dsbGNtRnlZMmg1WDNCbExYQmxYMlJVUVVkMmMwUk5VMDlmUkU5WFRsOWthV1ptTUM0eUxtSmxaSEJsWEZ3cEtWeHVZVzVqYUc5eUxtUnZkMjRnUEMwZ1pYaDBjbUZqZEVGdVkyaHZjaWhzYjI5d0xtUnZkMjRwWEc1Y2JseHVJQ0JjYmlBZ2IzWmxjbXhoY0M1MWNHNXZJRHd0SUdacGJtUlBkbVZ5YkdGd2N5aGhibU5vYjNJdWRYQnVieXdnYUhWaUxtRnVZMmh2Y2lsY2JpQWdiM1psY214aGNDNWtiM2R1SUR3dElHWnBibVJQZG1WeWJHRndjeWhoYm1Ob2IzSXVaRzkzYml3Z2FIVmlMbUZ1WTJodmNpbGNiaUFnWEc0Z0lHNHhJRHd0SUd4bGJtZDBhQ2gxYm1seGRXVW9jWFZsY25sSWFYUnpLRzkyWlhKc1lYQXVkWEJ1YnlrcEtWeHVJQ0J1TWlBOExTQnNaVzVuZEdnb2RXNXBjWFZsS0hGMVpYSjVTR2wwY3lodmRtVnliR0Z3TG1SdmQyNHBLU2xjYmlBZ1hHNGdJSEJsY21NeElEd3RJSEp2ZFc1a0tHNHhMMnhsYm1kMGFDaHZkbVZ5YkdGd0xuVndibThwS2pFd01Dd2dNaWxjYmlBZ2NHVnlZeklnUEMwZ2NtOTFibVFvYmpJdmJHVnVaM1JvS0c5MlpYSnNZWEF1Wkc5M2Jpa3FNVEF3TENBeUtWeHVJQ0JjYmlBZ2NtVnpkV3gwY3lBOExTQnlaWE4xYkhSeklDVStKU0JoWkdSZmNtOTNLR2tnUFNCcExDQjFjRzV2SUQwZ2NHVnlZekVzSUdSdmQyNGdQU0J3WlhKak1pbGNibjFjYmx4dVhHNWNibkpsYzNWc2RITmZiRzl1WnlBOExTQnlaWE4xYkhSeklDVStKVnh1SUNCd2FYWnZkRjlzYjI1blpYSW9ZMjlzY3lBOUlHTW9kWEJ1Ynl3Z1pHOTNiaWtzSUc1aGJXVnpYM1J2SUQwZ1hGeEhjbTkxY0Z4Y0xDQjJZV3gxWlhOZmRHOGdQU0JjWEZCbGNtTmxiblJoWjJWY1hDbGNibkpsYzNWc2RITmZiRzl1WnlSSGNtOTFjQ0E4TFNCbVlXTjBiM0lvY21WemRXeDBjMTlzYjI1bkpFZHliM1Z3TENCc1pYWmxiSE1nUFNCaktGeGNkWEJ1YjF4Y0xDQmNYR1J2ZDI1Y1hDa3BYRzVjYmlNZ1EzSmxZWFJsSUhSb1pTQmlZWElnY0d4dmRGeHVaMmR3Ykc5MEtISmxjM1ZzZEhOZmJHOXVaeXdnWVdWektIZ2dQU0JtWVdOMGIzSW9hU2tzSUhrZ1BTQlFaWEpqWlc1MFlXZGxMQ0JtYVd4c0lEMGdSM0p2ZFhBcEtTQXJYRzRnSUdkbGIyMWZZbUZ5S0hOMFlYUWdQU0JjWEdsa1pXNTBhWFI1WEZ3c0lIQnZjMmwwYVc5dUlEMGdYRnhrYjJSblpWeGNLU0FyWEc0Z0lHeGhZbk1vWEc0Z0lDQWdkR2wwYkdVZ1BTQmNYRkJGTFZCRklHeHZiM0J6WEZ3c1hHNGdJQ0FnZUNBOUlGeGNVSEpsYzJWdVkyVWdiMllnYUhWaUlHRnVZMmh2Y2lCM2FYUm9JRDVwSUdOdmJtNWxZM1JwYjI1elhGd3NYRzRnSUNBZ2VTQTlJRnhjVUdWeVkyVnVkR0ZuWlZ4Y1hHNGdJQ2tnSzF4dUlDQjBhR1Z0WlY5dGFXNXBiV0ZzS0NrZ0sxeHVJQ0J6WTJGc1pWOW1hV3hzWDIxaGJuVmhiQ2gyWVd4MVpYTWdQU0JqS0Z4Y2RYQnViMXhjSUQwZ1hGeGliSFZsWEZ3c0lGeGNaRzkzYmx4Y0lEMGdYRnh5WldSY1hDa3BJQ3RjYmlBZ2RHaGxiV1VvWVhocGN5NTBaWGgwTG5nZ1BTQmxiR1Z0Wlc1MFgzUmxlSFFvWVc1bmJHVWdQU0EwTlN3Z2FHcDFjM1FnUFNBeEtTa2dLeUI1YkdsdEtEQXNJREV3TUNsY2JtQmdZRnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbmBgYHJcbnJlc3VsdHMgPC0gdGliYmxlKGkgPSBudW1lcmljKCksIHVwbm8gPSBudW1lcmljKCksIGRvd24gPSBudW1lcmljKCkpXG5cbmZvcihpIGluIHNlcSgxLCAxMCkpe1xuICBkYXRhIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXER5bGFuX2h1Yl9lc2MuY3N2XFwpKVxuICBcbiAgZGF0YS5odWIgPC0gZGF0YSAlPiUgZHBseXI6OmZpbHRlcihhbGxfbGNvbiA+IGkpXG4gIHRlbXAgPC0gZGF0YS5odWIgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzKSlcbiAgY29sbmFtZXModGVtcCkgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG4gIGh1Yi5hbmNob3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRlbXApXG4gIFxuICBcbiAgXG5sb29wLnVwIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX2RUQUd2c0RNU09fTk9fZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci51cG5vIDwtIGV4dHJhY3RBbmNob3IoYmluZF9yb3dzKGxvb3AudXAsIGxvb3Aubm8pKVxuXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX0RPV05fZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci5kb3duIDwtIGV4dHJhY3RBbmNob3IobG9vcC5kb3duKVxuXG5cbiAgXG4gIG92ZXJsYXAudXBubyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwbm8sIGh1Yi5hbmNob3IpXG4gIG92ZXJsYXAuZG93biA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmRvd24sIGh1Yi5hbmNob3IpXG4gIFxuICBuMSA8LSBsZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhvdmVybGFwLnVwbm8pKSlcbiAgbjIgPC0gbGVuZ3RoKHVuaXF1ZShxdWVyeUhpdHMob3ZlcmxhcC5kb3duKSkpXG4gIFxuICBwZXJjMSA8LSByb3VuZChuMS9sZW5ndGgob3ZlcmxhcC51cG5vKSoxMDAsIDIpXG4gIHBlcmMyIDwtIHJvdW5kKG4yL2xlbmd0aChvdmVybGFwLmRvd24pKjEwMCwgMilcbiAgXG4gIHJlc3VsdHMgPC0gcmVzdWx0cyAlPiUgYWRkX3JvdyhpID0gaSwgdXBubyA9IHBlcmMxLCBkb3duID0gcGVyYzIpXG59XG5cblxuXG5yZXN1bHRzX2xvbmcgPC0gcmVzdWx0cyAlPiVcbiAgcGl2b3RfbG9uZ2VyKGNvbHMgPSBjKHVwbm8sIGRvd24pLCBuYW1lc190byA9IFxcR3JvdXBcXCwgdmFsdWVzX3RvID0gXFxQZXJjZW50YWdlXFwpXG5yZXN1bHRzX2xvbmckR3JvdXAgPC0gZmFjdG9yKHJlc3VsdHNfbG9uZyRHcm91cCwgbGV2ZWxzID0gYyhcXHVwbm9cXCwgXFxkb3duXFwpKVxuXG4jIENyZWF0ZSB0aGUgYmFyIHBsb3RcbmdncGxvdChyZXN1bHRzX2xvbmcsIGFlcyh4ID0gZmFjdG9yKGkpLCB5ID0gUGVyY2VudGFnZSwgZmlsbCA9IEdyb3VwKSkgK1xuICBnZW9tX2JhcihzdGF0ID0gXFxpZGVudGl0eVxcLCBwb3NpdGlvbiA9IFxcZG9kZ2VcXCkgK1xuICBsYWJzKFxuICAgIHRpdGxlID0gXFxQRS1QRSBsb29wc1xcLFxuICAgIHggPSBcXFByZXNlbmNlIG9mIGh1YiBhbmNob3Igd2l0aCA+aSBjb25uZWN0aW9uc1xcLFxuICAgIHkgPSBcXFBlcmNlbnRhZ2VcXFxuICApICtcbiAgdGhlbWVfbWluaW1hbCgpICtcbiAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcXHVwbm9cXCA9IFxcYmx1ZVxcLCBcXGRvd25cXCA9IFxccmVkXFwpKSArXG4gIHRoZW1lKGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KGFuZ2xlID0gNDUsIGhqdXN0ID0gMSkpICsgeWxpbSgwLCAxMDApXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxucmVzdWx0cyA8LSB0aWJibGUoaSA9IG51bWVyaWMoKSwgdXBubyA9IG51bWVyaWMoKSwgZG93biA9IG51bWVyaWMoKSlcblxuZm9yKGkgaW4gc2VxKDEsIDEwKSl7XG4gIGRhdGEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcRHlsYW5faHViX2VzYy5jc3ZcXCkpXG4gIFxuICBkYXRhLmh1YiA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGFsbF9sY29uID4gaSlcbiAgdGVtcCA8LSBkYXRhLmh1YiAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuICBjb2xuYW1lcyh0ZW1wKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbiAgaHViLmFuY2hvciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcbiAgXG4gIFxuICBcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9wZS1wZV9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfcGUtcGVfZFRBR3ZzRE1TT19OT19kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLnVwbm8gPC0gZXh0cmFjdEFuY2hvcihiaW5kX3Jvd3MobG9vcC51cCwgbG9vcC5ubykpXG5cbmxvb3AuZG93biA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3BlLXBlX2RUQUd2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLmRvd24gPC0gZXh0cmFjdEFuY2hvcihsb29wLmRvd24pXG5cblxuICBcbiAgb3ZlcmxhcC51cG5vIDwtIGZpbmRPdmVybGFwcyhhbmNob3IudXBubywgaHViLmFuY2hvcilcbiAgb3ZlcmxhcC5kb3duIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuZG93biwgaHViLmFuY2hvcilcbiAgXG4gIG4xIDwtIGxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKG92ZXJsYXAudXBubykpKVxuICBuMiA8LSBsZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhvdmVybGFwLmRvd24pKSlcbiAgXG4gIHBlcmMxIDwtIHJvdW5kKG4xL2xlbmd0aChvdmVybGFwLnVwbm8pKjEwMCwgMilcbiAgcGVyYzIgPC0gcm91bmQobjIvbGVuZ3RoKG92ZXJsYXAuZG93bikqMTAwLCAyKVxuICBcbiAgcmVzdWx0cyA8LSByZXN1bHRzICU+JSBhZGRfcm93KGkgPSBpLCB1cG5vID0gcGVyYzEsIGRvd24gPSBwZXJjMilcbn1cblxuXG5cbnJlc3VsdHNfbG9uZyA8LSByZXN1bHRzICU+JVxuICBwaXZvdF9sb25nZXIoY29scyA9IGModXBubywgZG93biksIG5hbWVzX3RvID0gXFxHcm91cFxcLCB2YWx1ZXNfdG8gPSBcXFBlcmNlbnRhZ2VcXClcbnJlc3VsdHNfbG9uZyRHcm91cCA8LSBmYWN0b3IocmVzdWx0c19sb25nJEdyb3VwLCBsZXZlbHMgPSBjKFxcdXBub1xcLCBcXGRvd25cXCkpXG5cbiMgQ3JlYXRlIHRoZSBiYXIgcGxvdFxuZ2dwbG90KHJlc3VsdHNfbG9uZywgYWVzKHggPSBmYWN0b3IoaSksIHkgPSBQZXJjZW50YWdlLCBmaWxsID0gR3JvdXApKSArXG4gIGdlb21fYmFyKHN0YXQgPSBcXGlkZW50aXR5XFwsIHBvc2l0aW9uID0gXFxkb2RnZVxcKSArXG4gIGxhYnMoXG4gICAgdGl0bGUgPSBcXFBFLVBFIGxvb3BzXFwsXG4gICAgeCA9IFxcUHJlc2VuY2Ugb2YgaHViIGFuY2hvciB3aXRoID5pIGNvbm5lY3Rpb25zXFwsXG4gICAgeSA9IFxcUGVyY2VudGFnZVxcXG4gICkgK1xuICB0aGVtZV9taW5pbWFsKCkgK1xuICBzY2FsZV9maWxsX21hbnVhbCh2YWx1ZXMgPSBjKFxcdXBub1xcID0gXFxibHVlXFwsIFxcZG93blxcID0gXFxyZWRcXCkpICtcbiAgdGhlbWUoYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoYW5nbGUgPSA0NSwgaGp1c3QgPSAxKSkgKyB5bGltKDAsIDEwMClcbmBgYFxuYGBgIn0= -->

```r
```r
results <- tibble(i = numeric(), upno = numeric(), down = numeric())

for(i in seq(1, 10)){
  data <- fread(here(refDir, \Dylan_hub_esc.csv\))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c(\chr\, \start\, \end\)
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)


  
  overlap.upno <- findOverlaps(anchor.upno, hub.anchor)
  overlap.down <- findOverlaps(anchor.down, hub.anchor)
  
  n1 <- length(unique(queryHits(overlap.upno)))
  n2 <- length(unique(queryHits(overlap.down)))
  
  perc1 <- round(n1/length(overlap.upno)*100, 2)
  perc2 <- round(n2/length(overlap.down)*100, 2)
  
  results <- results %>% add_row(i = i, upno = perc1, down = perc2)
}



results_long <- results %>%
  pivot_longer(cols = c(upno, down), names_to = \Group\, values_to = \Percentage\)
results_long$Group <- factor(results_long$Group, levels = c(\upno\, \down\))

# Create the bar plot
ggplot(results_long, aes(x = factor(i), y = Percentage, fill = Group)) +
  geom_bar(stat = \identity\, position = \dodge\) +
  labs(
    title = \PE-PE loops\,
    x = \Presence of hub anchor with >i connections\,
    y = \Percentage\
  ) +
  theme_minimal() +
  scale_fill_manual(values = c(\upno\ = \blue\, \down\ = \red\)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1)) + ylim(0, 100)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### Fishers

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjbVZ6ZFd4MGN5QThMU0IwYVdKaWJHVW9hU0E5SUc1MWJXVnlhV01vS1N3Z2RYQnVieUE5SUc1MWJXVnlhV01vS1N3Z1pHOTNiaUE5SUc1MWJXVnlhV01vS1NsY2JseHVabTl5S0drZ2FXNGdjMlZ4S0RFc0lERXdLU2w3WEc0Z0lHUmhkR0VnUEMwZ1puSmxZV1FvYUdWeVpTaHlaV1pFYVhJc0lGd2lSSGxzWVc1ZmFIVmlYMlZ6WXk1amMzWmNJaWtwWEc0Z0lGeHVJQ0JrWVhSaExtaDFZaUE4TFNCa1lYUmhJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLR0ZzYkY5c1kyOXVJRDRnYVNsY2JpQWdkR1Z0Y0NBOExTQmtZWFJoTG1oMVlpQWxQaVVnWkhCc2VYSTZPbk5sYkdWamRDaGpLREVzSURJc0lETXBLVnh1SUNCamIyeHVZVzFsY3loMFpXMXdLU0E4TFNCaktGd2lZMmh5WENJc0lGd2ljM1JoY25SY0lpd2dYQ0psYm1SY0lpbGNiaUFnYUhWaUxtRnVZMmh2Y2lBOExTQnRZV3RsUjFKaGJtZGxjMFp5YjIxRVlYUmhSbkpoYldVb2RHVnRjQ2xjYmlBZ1hHNGdJRnh1SUNCY2JteHZiM0F1ZFhBZ1BDMGdabkpsWVdRb2FHVnlaU2hqYjI1elpXNXpkWE5FYVhJc0lGd2lZMmh5YjIxdlgyTnZibk5mWVc1dWIwaHBaWEpoY21Ob2VWOXpkSEoxWTNSMWNtVmZaRlJCUjNaelJFMVRUMTlWVUY5a2FXWm1NQzR5TG1KbFpIQmxYQ0lwS1Z4dWJHOXZjQzV1YnlBOExTQm1jbVZoWkNob1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z1hDSmphSEp2Ylc5ZlkyOXVjMTloYm01dlNHbGxjbUZ5WTJoNVgzTjBjblZqZEhWeVpWOWtWRUZIZG5ORVRWTlBYMDVQWDJScFptWXdMakl1WW1Wa2NHVmNJaWtwWEc1aGJtTm9iM0l1ZFhCdWJ5QThMU0JsZUhSeVlXTjBRVzVqYUc5eUtHSnBibVJmY205M2N5aHNiMjl3TG5Wd0xDQnNiMjl3TG01dktTbGNibHh1Ykc5dmNDNWtiM2R1SUR3dElHWnlaV0ZrS0dobGNtVW9ZMjl1YzJWdWMzVnpSR2x5TENCY0ltTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsZmMzUnlkV04wZFhKbFgyUlVRVWQyYzBSTlUwOWZSRTlYVGw5a2FXWm1NQzR5TG1KbFpIQmxYQ0lwS1Z4dVlXNWphRzl5TG1SdmQyNGdQQzBnWlhoMGNtRmpkRUZ1WTJodmNpaHNiMjl3TG1SdmQyNHBYRzVjYmlBZ1hHNGdJRzkyWlhKc1lYQXVkWEJ1YnlBOExTQm1hVzVrVDNabGNteGhjSE1vWVc1amFHOXlMblZ3Ym04c0lHaDFZaTVoYm1Ob2IzSXBYRzRnSUc5MlpYSnNZWEF1Wkc5M2JpQThMU0JtYVc1a1QzWmxjbXhoY0hNb1lXNWphRzl5TG1SdmQyNHNJR2gxWWk1aGJtTm9iM0lwWEc0Z0lGeHVJQ0J1TVNBOExTQnNaVzVuZEdnb2RXNXBjWFZsS0hGMVpYSjVTR2wwY3lodmRtVnliR0Z3TG5Wd2JtOHBLU2xjYmlBZ2JqSWdQQzBnYkdWdVozUm9LSFZ1YVhGMVpTaHhkV1Z5ZVVocGRITW9iM1psY214aGNDNWtiM2R1S1NrcFhHNGdJRnh1SUNCd1pYSmpNU0E4TFNCeWIzVnVaQ2h1TVM5c1pXNW5kR2dvYjNabGNteGhjQzUxY0c1dktTb3hNREFzSURJcFhHNGdJSEJsY21NeUlEd3RJSEp2ZFc1a0tHNHlMMnhsYm1kMGFDaHZkbVZ5YkdGd0xtUnZkMjRwS2pFd01Dd2dNaWxjYmlBZ1hHNGdJSEpsYzNWc2RITWdQQzBnY21WemRXeDBjeUFsUGlVZ1lXUmtYM0p2ZHlocElEMGdhU3dnZFhCdWJ5QTlJSEJsY21NeExDQmtiM2R1SUQwZ2NHVnlZeklwWEc1OVhHNWNibHh1WEc1eVpYTjFiSFJ6WDJ4dmJtY2dQQzBnY21WemRXeDBjeUFsUGlWY2JpQWdjR2wyYjNSZmJHOXVaMlZ5S0dOdmJITWdQU0JqS0hWd2JtOHNJR1J2ZDI0cExDQnVZVzFsYzE5MGJ5QTlJRndpUjNKdmRYQmNJaXdnZG1Gc2RXVnpYM1J2SUQwZ1hDSlFaWEpqWlc1MFlXZGxYQ0lwWEc1eVpYTjFiSFJ6WDJ4dmJtY2tSM0p2ZFhBZ1BDMGdabUZqZEc5eUtISmxjM1ZzZEhOZmJHOXVaeVJIY205MWNDd2diR1YyWld4eklEMGdZeWhjSW5Wd2JtOWNJaXdnWENKa2IzZHVYQ0lwS1Z4dVhHNGpJRU55WldGMFpTQjBhR1VnWW1GeUlIQnNiM1JjYm1kbmNHeHZkQ2h5WlhOMWJIUnpYMnh2Ym1jc0lHRmxjeWg0SUQwZ1ptRmpkRzl5S0drcExDQjVJRDBnVUdWeVkyVnVkR0ZuWlN3Z1ptbHNiQ0E5SUVkeWIzVndLU2tnSzF4dUlDQm5aVzl0WDJKaGNpaHpkR0YwSUQwZ1hDSnBaR1Z1ZEdsMGVWd2lMQ0J3YjNOcGRHbHZiaUE5SUZ3aVpHOWtaMlZjSWlrZ0sxeHVJQ0JzWVdKektGeHVJQ0FnSUhScGRHeGxJRDBnWENKVGRISjFZM1IxY21VZ2JHOXZjSE5jSWl4Y2JpQWdJQ0I0SUQwZ1hDSlFjbVZ6Wlc1alpTQnZaaUJvZFdJZ1lXNWphRzl5SUhkcGRHZ2dQbWtnWTI5dWJtVmpkR2x2Ym5OY0lpeGNiaUFnSUNCNUlEMGdYQ0pRWlhKalpXNTBZV2RsWENKY2JpQWdLU0FyWEc0Z0lIUm9aVzFsWDIxcGJtbHRZV3dvS1NBclhHNGdJSE5qWVd4bFgyWnBiR3hmYldGdWRXRnNLSFpoYkhWbGN5QTlJR01vWENKMWNHNXZYQ0lnUFNCY0ltSnNkV1ZjSWl3Z1hDSmtiM2R1WENJZ1BTQmNJbkpsWkZ3aUtTa2dLMXh1SUNCMGFHVnRaU2hoZUdsekxuUmxlSFF1ZUNBOUlHVnNaVzFsYm5SZmRHVjRkQ2hoYm1kc1pTQTlJRFExTENCb2FuVnpkQ0E5SURFcEtTQXJJSGxzYVcwb01Dd2dNVEF3S1Z4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG5yZXN1bHRzIDwtIHRpYmJsZShpID0gbnVtZXJpYygpLCB1cG5vID0gbnVtZXJpYygpLCBkb3duID0gbnVtZXJpYygpKVxuXG5mb3IoaSBpbiBzZXEoMSwgMTApKXtcbiAgZGF0YSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxEeWxhbl9odWJfZXNjLmNzdlxcKSlcbiAgXG4gIGRhdGEuaHViIDwtIGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoYWxsX2xjb24gPiBpKVxuICB0ZW1wIDwtIGRhdGEuaHViICU+JSBkcGx5cjo6c2VsZWN0KGMoMSwgMiwgMykpXG4gIGNvbG5hbWVzKHRlbXApIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuICBodWIuYW5jaG9yIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxuICBcbiAgXG4gIFxubG9vcC51cCA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3N0cnVjdHVyZV9kVEFHdnNETVNPX1VQX2RpZmYwLjIuYmVkcGVcXCkpXG5sb29wLm5vIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfc3RydWN0dXJlX2RUQUd2c0RNU09fTk9fZGlmZjAuMi5iZWRwZVxcKSlcbmFuY2hvci51cG5vIDwtIGV4dHJhY3RBbmNob3IoYmluZF9yb3dzKGxvb3AudXAsIGxvb3Aubm8pKVxuXG5sb29wLmRvd24gPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9zdHJ1Y3R1cmVfZFRBR3ZzRE1TT19ET1dOX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IuZG93biA8LSBleHRyYWN0QW5jaG9yKGxvb3AuZG93bilcblxuICBcbiAgb3ZlcmxhcC51cG5vIDwtIGZpbmRPdmVybGFwcyhhbmNob3IudXBubywgaHViLmFuY2hvcilcbiAgb3ZlcmxhcC5kb3duIDwtIGZpbmRPdmVybGFwcyhhbmNob3IuZG93biwgaHViLmFuY2hvcilcbiAgXG4gIG4xIDwtIGxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKG92ZXJsYXAudXBubykpKVxuICBuMiA8LSBsZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhvdmVybGFwLmRvd24pKSlcbiAgXG4gIHBlcmMxIDwtIHJvdW5kKG4xL2xlbmd0aChvdmVybGFwLnVwbm8pKjEwMCwgMilcbiAgcGVyYzIgPC0gcm91bmQobjIvbGVuZ3RoKG92ZXJsYXAuZG93bikqMTAwLCAyKVxuICBcbiAgcmVzdWx0cyA8LSByZXN1bHRzICU+JSBhZGRfcm93KGkgPSBpLCB1cG5vID0gcGVyYzEsIGRvd24gPSBwZXJjMilcbn1cblxuXG5cbnJlc3VsdHNfbG9uZyA8LSByZXN1bHRzICU+JVxuICBwaXZvdF9sb25nZXIoY29scyA9IGModXBubywgZG93biksIG5hbWVzX3RvID0gXFxHcm91cFxcLCB2YWx1ZXNfdG8gPSBcXFBlcmNlbnRhZ2VcXClcbnJlc3VsdHNfbG9uZyRHcm91cCA8LSBmYWN0b3IocmVzdWx0c19sb25nJEdyb3VwLCBsZXZlbHMgPSBjKFxcdXBub1xcLCBcXGRvd25cXCkpXG5cbiMgQ3JlYXRlIHRoZSBiYXIgcGxvdFxuZ2dwbG90KHJlc3VsdHNfbG9uZywgYWVzKHggPSBmYWN0b3IoaSksIHkgPSBQZXJjZW50YWdlLCBmaWxsID0gR3JvdXApKSArXG4gIGdlb21fYmFyKHN0YXQgPSBcXGlkZW50aXR5XFwsIHBvc2l0aW9uID0gXFxkb2RnZVxcKSArXG4gIGxhYnMoXG4gICAgdGl0bGUgPSBcXFN0cnVjdHVyZSBsb29wc1xcLFxuICAgIHggPSBcXFByZXNlbmNlIG9mIGh1YiBhbmNob3Igd2l0aCA+aSBjb25uZWN0aW9uc1xcLFxuICAgIHkgPSBcXFBlcmNlbnRhZ2VcXFxuICApICtcbiAgdGhlbWVfbWluaW1hbCgpICtcbiAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcXHVwbm9cXCA9IFxcYmx1ZVxcLCBcXGRvd25cXCA9IFxccmVkXFwpKSArXG4gIHRoZW1lKGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KGFuZ2xlID0gNDUsIGhqdXN0ID0gMSkpICsgeWxpbSgwLCAxMDApXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
results <- tibble(i = numeric(), upno = numeric(), down = numeric())

for(i in seq(1, 10)){
  data <- fread(here(refDir, \Dylan_hub_esc.csv\))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c(\chr\, \start\, \end\)
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)

  
  overlap.upno <- findOverlaps(anchor.upno, hub.anchor)
  overlap.down <- findOverlaps(anchor.down, hub.anchor)
  
  n1 <- length(unique(queryHits(overlap.upno)))
  n2 <- length(unique(queryHits(overlap.down)))
  
  perc1 <- round(n1/length(overlap.upno)*100, 2)
  perc2 <- round(n2/length(overlap.down)*100, 2)
  
  results <- results %>% add_row(i = i, upno = perc1, down = perc2)
}



results_long <- results %>%
  pivot_longer(cols = c(upno, down), names_to = \Group\, values_to = \Percentage\)
results_long$Group <- factor(results_long$Group, levels = c(\upno\, \down\))

# Create the bar plot
ggplot(results_long, aes(x = factor(i), y = Percentage, fill = Group)) +
  geom_bar(stat = \identity\, position = \dodge\) +
  labs(
    title = \Structure loops\,
    x = \Presence of hub anchor with >i connections\,
    y = \Percentage\
  ) +
  theme_minimal() +
  scale_fill_manual(values = c(\upno\ = \blue\, \down\ = \red\)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1)) + ylim(0, 100)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWNtVnpkV3gwY3lBOExTQjBhV0ppYkdVb2FTQTlJRzUxYldWeWFXTW9LU3dnZFhCdWJ5QTlJRzUxYldWeWFXTW9LU3dnWkc5M2JpQTlJRzUxYldWeWFXTW9LU2xjYmx4dVptOXlLR2tnYVc0Z2MyVnhLREVzSURFd0tTbDdYRzRnSUdSaGRHRWdQQzBnWm5KbFlXUW9hR1Z5WlNoeVpXWkVhWElzSUZ4Y1JIbHNZVzVmYUhWaVgyVnpZeTVqYzNaY1hDa3BYRzRnSUZ4dUlDQmtZWFJoTG1oMVlpQThMU0JrWVhSaElDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHRnNiRjlzWTI5dUlENGdhU2xjYmlBZ2RHVnRjQ0E4TFNCa1lYUmhMbWgxWWlBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoaktERXNJRElzSURNcEtWeHVJQ0JqYjJ4dVlXMWxjeWgwWlcxd0tTQThMU0JqS0Z4Y1kyaHlYRndzSUZ4Y2MzUmhjblJjWEN3Z1hGeGxibVJjWENsY2JpQWdhSFZpTG1GdVkyaHZjaUE4TFNCdFlXdGxSMUpoYm1kbGMwWnliMjFFWVhSaFJuSmhiV1VvZEdWdGNDbGNiaUFnWEc0Z0lGeHVJQ0JjYm14dmIzQXVkWEFnUEMwZ1puSmxZV1FvYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUZ4Y1kyaHliMjF2WDJOdmJuTmZZVzV1YjBocFpYSmhjbU5vZVY5emRISjFZM1IxY21WZlpGUkJSM1p6UkUxVFQxOVZVRjlrYVdabU1DNHlMbUpsWkhCbFhGd3BLVnh1Ykc5dmNDNXVieUE4TFNCbWNtVmhaQ2hvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnWEZ4amFISnZiVzlmWTI5dWMxOWhibTV2U0dsbGNtRnlZMmg1WDNOMGNuVmpkSFZ5WlY5a1ZFRkhkbk5FVFZOUFgwNVBYMlJwWm1Zd0xqSXVZbVZrY0dWY1hDa3BYRzVoYm1Ob2IzSXVkWEJ1YnlBOExTQmxlSFJ5WVdOMFFXNWphRzl5S0dKcGJtUmZjbTkzY3loc2IyOXdMblZ3TENCc2IyOXdMbTV2S1NsY2JseHViRzl2Y0M1a2IzZHVJRHd0SUdaeVpXRmtLR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0JjWEdOb2NtOXRiMTlqYjI1elgyRnVibTlJYVdWeVlYSmphSGxmYzNSeWRXTjBkWEpsWDJSVVFVZDJjMFJOVTA5ZlJFOVhUbDlrYVdabU1DNHlMbUpsWkhCbFhGd3BLVnh1WVc1amFHOXlMbVJ2ZDI0Z1BDMGdaWGgwY21GamRFRnVZMmh2Y2loc2IyOXdMbVJ2ZDI0cFhHNWNiaUFnWEc0Z0lHOTJaWEpzWVhBdWRYQnVieUE4TFNCbWFXNWtUM1psY214aGNITW9ZVzVqYUc5eUxuVndibThzSUdoMVlpNWhibU5vYjNJcFhHNGdJRzkyWlhKc1lYQXVaRzkzYmlBOExTQm1hVzVrVDNabGNteGhjSE1vWVc1amFHOXlMbVJ2ZDI0c0lHaDFZaTVoYm1Ob2IzSXBYRzRnSUZ4dUlDQnVNU0E4TFNCc1pXNW5kR2dvZFc1cGNYVmxLSEYxWlhKNVNHbDBjeWh2ZG1WeWJHRndMblZ3Ym04cEtTbGNiaUFnYmpJZ1BDMGdiR1Z1WjNSb0tIVnVhWEYxWlNoeGRXVnllVWhwZEhNb2IzWmxjbXhoY0M1a2IzZHVLU2twWEc0Z0lGeHVJQ0J3WlhKak1TQThMU0J5YjNWdVpDaHVNUzlzWlc1bmRHZ29iM1psY214aGNDNTFjRzV2S1NveE1EQXNJRElwWEc0Z0lIQmxjbU15SUR3dElISnZkVzVrS0c0eUwyeGxibWQwYUNodmRtVnliR0Z3TG1SdmQyNHBLakV3TUN3Z01pbGNiaUFnWEc0Z0lISmxjM1ZzZEhNZ1BDMGdjbVZ6ZFd4MGN5QWxQaVVnWVdSa1gzSnZkeWhwSUQwZ2FTd2dkWEJ1YnlBOUlIQmxjbU14TENCa2IzZHVJRDBnY0dWeVl6SXBYRzU5WEc1Y2JseHVYRzV5WlhOMWJIUnpYMnh2Ym1jZ1BDMGdjbVZ6ZFd4MGN5QWxQaVZjYmlBZ2NHbDJiM1JmYkc5dVoyVnlLR052YkhNZ1BTQmpLSFZ3Ym04c0lHUnZkMjRwTENCdVlXMWxjMTkwYnlBOUlGeGNSM0p2ZFhCY1hDd2dkbUZzZFdWelgzUnZJRDBnWEZ4UVpYSmpaVzUwWVdkbFhGd3BYRzV5WlhOMWJIUnpYMnh2Ym1ja1IzSnZkWEFnUEMwZ1ptRmpkRzl5S0hKbGMzVnNkSE5mYkc5dVp5UkhjbTkxY0N3Z2JHVjJaV3h6SUQwZ1l5aGNYSFZ3Ym05Y1hDd2dYRnhrYjNkdVhGd3BLVnh1WEc0aklFTnlaV0YwWlNCMGFHVWdZbUZ5SUhCc2IzUmNibWRuY0d4dmRDaHlaWE4xYkhSelgyeHZibWNzSUdGbGN5aDRJRDBnWm1GamRHOXlLR2twTENCNUlEMGdVR1Z5WTJWdWRHRm5aU3dnWm1sc2JDQTlJRWR5YjNWd0tTa2dLMXh1SUNCblpXOXRYMkpoY2loemRHRjBJRDBnWEZ4cFpHVnVkR2wwZVZ4Y0xDQndiM05wZEdsdmJpQTlJRnhjWkc5a1oyVmNYQ2tnSzF4dUlDQnNZV0p6S0Z4dUlDQWdJSFJwZEd4bElEMGdYRnhUZEhKMVkzUjFjbVVnYkc5dmNITmNYQ3hjYmlBZ0lDQjRJRDBnWEZ4UWNtVnpaVzVqWlNCdlppQm9kV0lnWVc1amFHOXlJSGRwZEdnZ1Bta2dZMjl1Ym1WamRHbHZibk5jWEN4Y2JpQWdJQ0I1SUQwZ1hGeFFaWEpqWlc1MFlXZGxYRnhjYmlBZ0tTQXJYRzRnSUhSb1pXMWxYMjFwYm1sdFlXd29LU0FyWEc0Z0lITmpZV3hsWDJacGJHeGZiV0Z1ZFdGc0tIWmhiSFZsY3lBOUlHTW9YRngxY0c1dlhGd2dQU0JjWEdKc2RXVmNYQ3dnWEZ4a2IzZHVYRndnUFNCY1hISmxaRnhjS1NrZ0sxeHVJQ0IwYUdWdFpTaGhlR2x6TG5SbGVIUXVlQ0E5SUdWc1pXMWxiblJmZEdWNGRDaGhibWRzWlNBOUlEUTFMQ0JvYW5WemRDQTlJREVwS1NBcklIbHNhVzBvTUN3Z01UQXdLVnh1WUdCZ1hHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuYGBgclxucmVzdWx0cyA8LSB0aWJibGUoaSA9IG51bWVyaWMoKSwgdXBubyA9IG51bWVyaWMoKSwgZG93biA9IG51bWVyaWMoKSlcblxuZm9yKGkgaW4gc2VxKDEsIDEwKSl7XG4gIGRhdGEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcRHlsYW5faHViX2VzYy5jc3ZcXCkpXG4gIFxuICBkYXRhLmh1YiA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGFsbF9sY29uID4gaSlcbiAgdGVtcCA8LSBkYXRhLmh1YiAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuICBjb2xuYW1lcyh0ZW1wKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbiAgaHViLmFuY2hvciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcbiAgXG4gIFxuICBcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9zdHJ1Y3R1cmVfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3N0cnVjdHVyZV9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXBubyA8LSBleHRyYWN0QW5jaG9yKGJpbmRfcm93cyhsb29wLnVwLCBsb29wLm5vKSlcblxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfc3RydWN0dXJlX2RUQUd2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLmRvd24gPC0gZXh0cmFjdEFuY2hvcihsb29wLmRvd24pXG5cbiAgXG4gIG92ZXJsYXAudXBubyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwbm8sIGh1Yi5hbmNob3IpXG4gIG92ZXJsYXAuZG93biA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmRvd24sIGh1Yi5hbmNob3IpXG4gIFxuICBuMSA8LSBsZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhvdmVybGFwLnVwbm8pKSlcbiAgbjIgPC0gbGVuZ3RoKHVuaXF1ZShxdWVyeUhpdHMob3ZlcmxhcC5kb3duKSkpXG4gIFxuICBwZXJjMSA8LSByb3VuZChuMS9sZW5ndGgob3ZlcmxhcC51cG5vKSoxMDAsIDIpXG4gIHBlcmMyIDwtIHJvdW5kKG4yL2xlbmd0aChvdmVybGFwLmRvd24pKjEwMCwgMilcbiAgXG4gIHJlc3VsdHMgPC0gcmVzdWx0cyAlPiUgYWRkX3JvdyhpID0gaSwgdXBubyA9IHBlcmMxLCBkb3duID0gcGVyYzIpXG59XG5cblxuXG5yZXN1bHRzX2xvbmcgPC0gcmVzdWx0cyAlPiVcbiAgcGl2b3RfbG9uZ2VyKGNvbHMgPSBjKHVwbm8sIGRvd24pLCBuYW1lc190byA9IFxcR3JvdXBcXCwgdmFsdWVzX3RvID0gXFxQZXJjZW50YWdlXFwpXG5yZXN1bHRzX2xvbmckR3JvdXAgPC0gZmFjdG9yKHJlc3VsdHNfbG9uZyRHcm91cCwgbGV2ZWxzID0gYyhcXHVwbm9cXCwgXFxkb3duXFwpKVxuXG4jIENyZWF0ZSB0aGUgYmFyIHBsb3RcbmdncGxvdChyZXN1bHRzX2xvbmcsIGFlcyh4ID0gZmFjdG9yKGkpLCB5ID0gUGVyY2VudGFnZSwgZmlsbCA9IEdyb3VwKSkgK1xuICBnZW9tX2JhcihzdGF0ID0gXFxpZGVudGl0eVxcLCBwb3NpdGlvbiA9IFxcZG9kZ2VcXCkgK1xuICBsYWJzKFxuICAgIHRpdGxlID0gXFxTdHJ1Y3R1cmUgbG9vcHNcXCxcbiAgICB4ID0gXFxQcmVzZW5jZSBvZiBodWIgYW5jaG9yIHdpdGggPmkgY29ubmVjdGlvbnNcXCxcbiAgICB5ID0gXFxQZXJjZW50YWdlXFxcbiAgKSArXG4gIHRoZW1lX21pbmltYWwoKSArXG4gIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGMoXFx1cG5vXFwgPSBcXGJsdWVcXCwgXFxkb3duXFwgPSBcXHJlZFxcKSkgK1xuICB0aGVtZShheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChhbmdsZSA9IDQ1LCBoanVzdCA9IDEpKSArIHlsaW0oMCwgMTAwKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxucmVzdWx0cyA8LSB0aWJibGUoaSA9IG51bWVyaWMoKSwgdXBubyA9IG51bWVyaWMoKSwgZG93biA9IG51bWVyaWMoKSlcblxuZm9yKGkgaW4gc2VxKDEsIDEwKSl7XG4gIGRhdGEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcRHlsYW5faHViX2VzYy5jc3ZcXCkpXG4gIFxuICBkYXRhLmh1YiA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGFsbF9sY29uID4gaSlcbiAgdGVtcCA8LSBkYXRhLmh1YiAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKVxuICBjb2xuYW1lcyh0ZW1wKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbiAgaHViLmFuY2hvciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodGVtcClcbiAgXG4gIFxuICBcbmxvb3AudXAgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeV9zdHJ1Y3R1cmVfZFRBR3ZzRE1TT19VUF9kaWZmMC4yLmJlZHBlXFwpKVxubG9vcC5ubyA8LSBmcmVhZChoZXJlKGNvbnNlbnN1c0RpciwgXFxjaHJvbW9fY29uc19hbm5vSGllcmFyY2h5X3N0cnVjdHVyZV9kVEFHdnNETVNPX05PX2RpZmYwLjIuYmVkcGVcXCkpXG5hbmNob3IudXBubyA8LSBleHRyYWN0QW5jaG9yKGJpbmRfcm93cyhsb29wLnVwLCBsb29wLm5vKSlcblxubG9vcC5kb3duIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlfc3RydWN0dXJlX2RUQUd2c0RNU09fRE9XTl9kaWZmMC4yLmJlZHBlXFwpKVxuYW5jaG9yLmRvd24gPC0gZXh0cmFjdEFuY2hvcihsb29wLmRvd24pXG5cbiAgXG4gIG92ZXJsYXAudXBubyA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLnVwbm8sIGh1Yi5hbmNob3IpXG4gIG92ZXJsYXAuZG93biA8LSBmaW5kT3ZlcmxhcHMoYW5jaG9yLmRvd24sIGh1Yi5hbmNob3IpXG4gIFxuICBuMSA8LSBsZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhvdmVybGFwLnVwbm8pKSlcbiAgbjIgPC0gbGVuZ3RoKHVuaXF1ZShxdWVyeUhpdHMob3ZlcmxhcC5kb3duKSkpXG4gIFxuICBwZXJjMSA8LSByb3VuZChuMS9sZW5ndGgob3ZlcmxhcC51cG5vKSoxMDAsIDIpXG4gIHBlcmMyIDwtIHJvdW5kKG4yL2xlbmd0aChvdmVybGFwLmRvd24pKjEwMCwgMilcbiAgXG4gIHJlc3VsdHMgPC0gcmVzdWx0cyAlPiUgYWRkX3JvdyhpID0gaSwgdXBubyA9IHBlcmMxLCBkb3duID0gcGVyYzIpXG59XG5cblxuXG5yZXN1bHRzX2xvbmcgPC0gcmVzdWx0cyAlPiVcbiAgcGl2b3RfbG9uZ2VyKGNvbHMgPSBjKHVwbm8sIGRvd24pLCBuYW1lc190byA9IFxcR3JvdXBcXCwgdmFsdWVzX3RvID0gXFxQZXJjZW50YWdlXFwpXG5yZXN1bHRzX2xvbmckR3JvdXAgPC0gZmFjdG9yKHJlc3VsdHNfbG9uZyRHcm91cCwgbGV2ZWxzID0gYyhcXHVwbm9cXCwgXFxkb3duXFwpKVxuXG4jIENyZWF0ZSB0aGUgYmFyIHBsb3RcbmdncGxvdChyZXN1bHRzX2xvbmcsIGFlcyh4ID0gZmFjdG9yKGkpLCB5ID0gUGVyY2VudGFnZSwgZmlsbCA9IEdyb3VwKSkgK1xuICBnZW9tX2JhcihzdGF0ID0gXFxpZGVudGl0eVxcLCBwb3NpdGlvbiA9IFxcZG9kZ2VcXCkgK1xuICBsYWJzKFxuICAgIHRpdGxlID0gXFxTdHJ1Y3R1cmUgbG9vcHNcXCxcbiAgICB4ID0gXFxQcmVzZW5jZSBvZiBodWIgYW5jaG9yIHdpdGggPmkgY29ubmVjdGlvbnNcXCxcbiAgICB5ID0gXFxQZXJjZW50YWdlXFxcbiAgKSArXG4gIHRoZW1lX21pbmltYWwoKSArXG4gIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGMoXFx1cG5vXFwgPSBcXGJsdWVcXCwgXFxkb3duXFwgPSBcXHJlZFxcKSkgK1xuICB0aGVtZShheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChhbmdsZSA9IDQ1LCBoanVzdCA9IDEpKSArIHlsaW0oMCwgMTAwKVxuYGBgXG5gYGAifQ== -->

```r
```r
results <- tibble(i = numeric(), upno = numeric(), down = numeric())

for(i in seq(1, 10)){
  data <- fread(here(refDir, \Dylan_hub_esc.csv\))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c(\chr\, \start\, \end\)
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure_dTAGvsDMSO_UP_diff0.2.bedpe\))
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure_dTAGvsDMSO_NO_diff0.2.bedpe\))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_structure_dTAGvsDMSO_DOWN_diff0.2.bedpe\))
anchor.down <- extractAnchor(loop.down)

  
  overlap.upno <- findOverlaps(anchor.upno, hub.anchor)
  overlap.down <- findOverlaps(anchor.down, hub.anchor)
  
  n1 <- length(unique(queryHits(overlap.upno)))
  n2 <- length(unique(queryHits(overlap.down)))
  
  perc1 <- round(n1/length(overlap.upno)*100, 2)
  perc2 <- round(n2/length(overlap.down)*100, 2)
  
  results <- results %>% add_row(i = i, upno = perc1, down = perc2)
}



results_long <- results %>%
  pivot_longer(cols = c(upno, down), names_to = \Group\, values_to = \Percentage\)
results_long$Group <- factor(results_long$Group, levels = c(\upno\, \down\))

# Create the bar plot
ggplot(results_long, aes(x = factor(i), y = Percentage, fill = Group)) +
  geom_bar(stat = \identity\, position = \dodge\) +
  labs(
    title = \Structure loops\,
    x = \Presence of hub anchor with >i connections\,
    y = \Percentage\
  ) +
  theme_minimal() +
  scale_fill_manual(values = c(\upno\ = \blue\, \down\ = \red\)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1)) + ylim(0, 100)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




#### PE-PE loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjbVZ6ZFd4MGN5QThMU0IwYVdKaWJHVW9hU0E5SUc1MWJXVnlhV01vS1N3Z2NHVnlZekVnUFNCdWRXMWxjbWxqS0Nrc0lIQmxjbU15SUQwZ2JuVnRaWEpwWXlncEtWeHVYRzVtYjNJb2FTQnBiaUJ6WlhFb01Td2dNVEFwS1h0Y2JpQWdaR0YwWVNBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYQ0pFZVd4aGJsOW9kV0pmWlhCcGMyTXVZM04yWENJcEtWeHVJQ0JjYmlBZ1pHRjBZUzVvZFdJZ1BDMGdaR0YwWVNBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2loaGJHeGZiR052YmlBK0lHa3BYRzRnSUhSbGJYQWdQQzBnWkdGMFlTNW9kV0lnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWXlneExDQXlMQ0F6S1NsY2JpQWdZMjlzYm1GdFpYTW9kR1Z0Y0NrZ1BDMGdZeWhjSW1Ob2Nsd2lMQ0JjSW5OMFlYSjBYQ0lzSUZ3aVpXNWtYQ0lwWEc0Z0lHaDFZaTVoYm1Ob2IzSWdQQzBnYldGclpVZFNZVzVuWlhOR2NtOXRSR0YwWVVaeVlXMWxLSFJsYlhBcFhHNGdJRnh1SUNCY2JpQWdYRzRnSUNNaklFTm9aV05yYVc1bklHOTJaWEpzWVhBZ2QybDBhQ0JuWlc1bElGUlRVMXh1SUNCMGMzTWdQQzBnWm5KbFlXUW9hR1Z5WlNoeVpXWkVhWElzSUZ3aWJXMHhNRjlIVWtOdE16Z3VjRFpmVkZOVE1pNDFhMkl1WW1Wa1hDSXBLVnh1SUNCY2JpQWdkSE56TG1keWIzVndNU0E4TFNCMGMzTWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9WallnSldsdUpTQm5jbTkxY0RFcElDVStKU0JrY0d4NWNqbzZjMlZzWldOMEtGWXhMQ0JXTWl3Z1ZqTXBYRzRnSUdOdmJHNWhiV1Z6S0hSemN5NW5jbTkxY0RFcElEd3RJR01vWENKamFISmNJaXdnWENKemRHRnlkRndpTENCY0ltVnVaRndpS1Z4dUlDQjBjM011WjNKdmRYQXhMbWR5SUR3dElHMWhhMlZIVW1GdVoyVnpSbkp2YlVSaGRHRkdjbUZ0WlNoMGMzTXVaM0p2ZFhBeEtWeHVJQ0JjYmlBZ2RITnpMbWR5YjNWd01pQThMU0IwYzNNZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1ZqWWdKV2x1SlNCbmNtOTFjRElwSUNVK0pTQmtjR3g1Y2pvNmMyVnNaV04wS0ZZeExDQldNaXdnVmpNcFhHNGdJR052Ykc1aGJXVnpLSFJ6Y3k1bmNtOTFjRElwSUR3dElHTW9YQ0pqYUhKY0lpd2dYQ0p6ZEdGeWRGd2lMQ0JjSW1WdVpGd2lLVnh1SUNCMGMzTXVaM0p2ZFhBeUxtZHlJRHd0SUcxaGEyVkhVbUZ1WjJWelJuSnZiVVJoZEdGR2NtRnRaU2gwYzNNdVozSnZkWEF5S1Z4dUlDQmNiaUFnWEc0Z0lHOTJaWEpzWVhBdVozSnZkWEF4SUR3dElHWnBibVJQZG1WeWJHRndjeWgwYzNNdVozSnZkWEF4TG1keUxDQm9kV0l1WVc1amFHOXlLVnh1SUNCdmRtVnliR0Z3TG1keWIzVndNaUE4TFNCbWFXNWtUM1psY214aGNITW9kSE56TG1keWIzVndNaTVuY2l3Z2FIVmlMbUZ1WTJodmNpbGNiaUFnWEc0Z0lHNHhJRHd0SUd4bGJtZDBhQ2gxYm1seGRXVW9jWFZsY25sSWFYUnpLRzkyWlhKc1lYQXVaM0p2ZFhBeEtTa3BYRzRnSUc0eUlEd3RJR3hsYm1kMGFDaDFibWx4ZFdVb2NYVmxjbmxJYVhSektHOTJaWEpzWVhBdVozSnZkWEF5S1NrcFhHNGdJRnh1SUNCd1pYSmpNU0E4TFNCeWIzVnVaQ2h1TVM5dWNtOTNLSFJ6Y3k1bmNtOTFjREVwS2pFd01Dd2dNaWxjYmlBZ2NHVnlZeklnUEMwZ2NtOTFibVFvYmpJdmJuSnZkeWgwYzNNdVozSnZkWEF5S1NveE1EQXNJRElwWEc0Z0lGeHVJQ0J5WlhOMWJIUnpJRHd0SUhKbGMzVnNkSE1nSlQ0bElHRmtaRjl5YjNjb2FTQTlJR2tzSUhCbGNtTXhJRDBnY0dWeVl6RXNJSEJsY21NeUlEMGdjR1Z5WXpJcFhHNTlYRzVjYmx4dVhHNXlaWE4xYkhSelgyeHZibWNnUEMwZ2NtVnpkV3gwY3lBbFBpVmNiaUFnY0dsMmIzUmZiRzl1WjJWeUtHTnZiSE1nUFNCaktIQmxjbU14TENCd1pYSmpNaWtzSUc1aGJXVnpYM1J2SUQwZ1hDSkhjbTkxY0Z3aUxDQjJZV3gxWlhOZmRHOGdQU0JjSWxCbGNtTmxiblJoWjJWY0lpbGNibHh1SXlCRGNtVmhkR1VnZEdobElHSmhjaUJ3Ykc5MFhHNW5aM0JzYjNRb2NtVnpkV3gwYzE5c2IyNW5MQ0JoWlhNb2VDQTlJR1poWTNSdmNpaHBLU3dnZVNBOUlGQmxjbU5sYm5SaFoyVXNJR1pwYkd3Z1BTQkhjbTkxY0NrcElDdGNiaUFnWjJWdmJWOWlZWElvYzNSaGRDQTlJRndpYVdSbGJuUnBkSGxjSWl3Z2NHOXphWFJwYjI0Z1BTQmNJbVJ2WkdkbFhDSXBJQ3RjYmlBZ2JHRmljeWhjYmlBZ0lDQjBhWFJzWlNBOUlGd2lVR1Z5WTJWdWRHRm5aU0JpZVNBbmFTY2dabTl5SUhCbGNtTXhJR0Z1WkNCd1pYSmpNbHdpTEZ4dUlDQWdJSGdnUFNCY0lsQnlaWE5sYm1ObElHOW1JR2gxWWlCaGJtTm9iM0lnZDJsMGFDQSthU0JqYjI1dVpXTjBhVzl1YzF3aUxGeHVJQ0FnSUhrZ1BTQmNJbEJsY21ObGJuUmhaMlZjSWx4dUlDQXBJQ3RjYmlBZ2RHaGxiV1ZmYldsdWFXMWhiQ2dwSUN0Y2JpQWdjMk5oYkdWZlptbHNiRjl0WVc1MVlXd29kbUZzZFdWeklEMGdZeWhjSW5CbGNtTXhYQ0lnUFNCY0ltSnNkV1ZjSWl3Z1hDSndaWEpqTWx3aUlEMGdYQ0p5WldSY0lpa3BJQ3RjYmlBZ2RHaGxiV1VvWVhocGN5NTBaWGgwTG5nZ1BTQmxiR1Z0Wlc1MFgzUmxlSFFvWVc1bmJHVWdQU0EwTlN3Z2FHcDFjM1FnUFNBeEtTbGNibUJnWUNKOSAtLT5cblxuYGBgclxucmVzdWx0cyA8LSB0aWJibGUoaSA9IG51bWVyaWMoKSwgcGVyYzEgPSBudW1lcmljKCksIHBlcmMyID0gbnVtZXJpYygpKVxuXG5mb3IoaSBpbiBzZXEoMSwgMTApKXtcbiAgZGF0YSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxEeWxhbl9odWJfZXBpc2MuY3N2XFwpKVxuICBcbiAgZGF0YS5odWIgPC0gZGF0YSAlPiUgZHBseXI6OmZpbHRlcihhbGxfbGNvbiA+IGkpXG4gIHRlbXAgPC0gZGF0YS5odWIgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzKSlcbiAgY29sbmFtZXModGVtcCkgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG4gIGh1Yi5hbmNob3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRlbXApXG4gIFxuICBcbiAgXG4gICMjIENoZWNraW5nIG92ZXJsYXAgd2l0aCBnZW5lIFRTU1xuICB0c3MgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfVFNTMi41a2IuYmVkXFwpKVxuICBcbiAgdHNzLmdyb3VwMSA8LSB0c3MgJT4lIGRwbHlyOjpmaWx0ZXIoVjYgJWluJSBncm91cDEpICU+JSBkcGx5cjo6c2VsZWN0KFYxLCBWMiwgVjMpXG4gIGNvbG5hbWVzKHRzcy5ncm91cDEpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuICB0c3MuZ3JvdXAxLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0c3MuZ3JvdXAxKVxuICBcbiAgdHNzLmdyb3VwMiA8LSB0c3MgJT4lIGRwbHlyOjpmaWx0ZXIoVjYgJWluJSBncm91cDIpICU+JSBkcGx5cjo6c2VsZWN0KFYxLCBWMiwgVjMpXG4gIGNvbG5hbWVzKHRzcy5ncm91cDIpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuICB0c3MuZ3JvdXAyLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0c3MuZ3JvdXAyKVxuICBcbiAgXG4gIG92ZXJsYXAuZ3JvdXAxIDwtIGZpbmRPdmVybGFwcyh0c3MuZ3JvdXAxLmdyLCBodWIuYW5jaG9yKVxuICBvdmVybGFwLmdyb3VwMiA8LSBmaW5kT3ZlcmxhcHModHNzLmdyb3VwMi5nciwgaHViLmFuY2hvcilcbiAgXG4gIG4xIDwtIGxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKG92ZXJsYXAuZ3JvdXAxKSkpXG4gIG4yIDwtIGxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKG92ZXJsYXAuZ3JvdXAyKSkpXG4gIFxuICBwZXJjMSA8LSByb3VuZChuMS9ucm93KHRzcy5ncm91cDEpKjEwMCwgMilcbiAgcGVyYzIgPC0gcm91bmQobjIvbnJvdyh0c3MuZ3JvdXAyKSoxMDAsIDIpXG4gIFxuICByZXN1bHRzIDwtIHJlc3VsdHMgJT4lIGFkZF9yb3coaSA9IGksIHBlcmMxID0gcGVyYzEsIHBlcmMyID0gcGVyYzIpXG59XG5cblxuXG5yZXN1bHRzX2xvbmcgPC0gcmVzdWx0cyAlPiVcbiAgcGl2b3RfbG9uZ2VyKGNvbHMgPSBjKHBlcmMxLCBwZXJjMiksIG5hbWVzX3RvID0gXFxHcm91cFxcLCB2YWx1ZXNfdG8gPSBcXFBlcmNlbnRhZ2VcXClcblxuIyBDcmVhdGUgdGhlIGJhciBwbG90XG5nZ3Bsb3QocmVzdWx0c19sb25nLCBhZXMoeCA9IGZhY3RvcihpKSwgeSA9IFBlcmNlbnRhZ2UsIGZpbGwgPSBHcm91cCkpICtcbiAgZ2VvbV9iYXIoc3RhdCA9IFxcaWRlbnRpdHlcXCwgcG9zaXRpb24gPSBcXGRvZGdlXFwpICtcbiAgbGFicyhcbiAgICB0aXRsZSA9IFxcUGVyY2VudGFnZSBieSAnaScgZm9yIHBlcmMxIGFuZCBwZXJjMlxcLFxuICAgIHggPSBcXFByZXNlbmNlIG9mIGh1YiBhbmNob3Igd2l0aCA+aSBjb25uZWN0aW9uc1xcLFxuICAgIHkgPSBcXFBlcmNlbnRhZ2VcXFxuICApICtcbiAgdGhlbWVfbWluaW1hbCgpICtcbiAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcXHBlcmMxXFwgPSBcXGJsdWVcXCwgXFxwZXJjMlxcID0gXFxyZWRcXCkpICtcbiAgdGhlbWUoYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoYW5nbGUgPSA0NSwgaGp1c3QgPSAxKSlcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
results <- tibble(i = numeric(), perc1 = numeric(), perc2 = numeric())

for(i in seq(1, 10)){
  data <- fread(here(refDir, \Dylan_hub_episc.csv\))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c(\chr\, \start\, \end\)
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  
  ## Checking overlap with gene TSS
  tss <- fread(here(refDir, \mm10_GRCm38.p6_TSS2.5kb.bed\))
  
  tss.group1 <- tss %>% dplyr::filter(V6 %in% group1) %>% dplyr::select(V1, V2, V3)
  colnames(tss.group1) <- c(\chr\, \start\, \end\)
  tss.group1.gr <- makeGRangesFromDataFrame(tss.group1)
  
  tss.group2 <- tss %>% dplyr::filter(V6 %in% group2) %>% dplyr::select(V1, V2, V3)
  colnames(tss.group2) <- c(\chr\, \start\, \end\)
  tss.group2.gr <- makeGRangesFromDataFrame(tss.group2)
  
  
  overlap.group1 <- findOverlaps(tss.group1.gr, hub.anchor)
  overlap.group2 <- findOverlaps(tss.group2.gr, hub.anchor)
  
  n1 <- length(unique(queryHits(overlap.group1)))
  n2 <- length(unique(queryHits(overlap.group2)))
  
  perc1 <- round(n1/nrow(tss.group1)*100, 2)
  perc2 <- round(n2/nrow(tss.group2)*100, 2)
  
  results <- results %>% add_row(i = i, perc1 = perc1, perc2 = perc2)
}



results_long <- results %>%
  pivot_longer(cols = c(perc1, perc2), names_to = \Group\, values_to = \Percentage\)

# Create the bar plot
ggplot(results_long, aes(x = factor(i), y = Percentage, fill = Group)) +
  geom_bar(stat = \identity\, position = \dodge\) +
  labs(
    title = \Percentage by 'i' for perc1 and perc2\,
    x = \Presence of hub anchor with >i connections\,
    y = \Percentage\
  ) +
  theme_minimal() +
  scale_fill_manual(values = c(\perc1\ = \blue\, \perc2\ = \red\)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1))



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWNtVnpkV3gwY3lBOExTQjBhV0ppYkdVb2FTQTlJRzUxYldWeWFXTW9LU3dnY0dWeVl6RWdQU0J1ZFcxbGNtbGpLQ2tzSUhCbGNtTXlJRDBnYm5WdFpYSnBZeWdwS1Z4dVhHNW1iM0lvYVNCcGJpQnpaWEVvTVN3Z01UQXBLWHRjYmlBZ1pHRjBZU0E4TFNCbWNtVmhaQ2hvWlhKbEtISmxaa1JwY2l3Z1hGeEVlV3hoYmw5b2RXSmZaWEJwYzJNdVkzTjJYRndwS1Z4dUlDQmNiaUFnWkdGMFlTNW9kV0lnUEMwZ1pHRjBZU0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhoYkd4ZmJHTnZiaUErSUdrcFhHNGdJSFJsYlhBZ1BDMGdaR0YwWVM1b2RXSWdKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9ZeWd4TENBeUxDQXpLU2xjYmlBZ1kyOXNibUZ0WlhNb2RHVnRjQ2tnUEMwZ1l5aGNYR05vY2x4Y0xDQmNYSE4wWVhKMFhGd3NJRnhjWlc1a1hGd3BYRzRnSUdoMVlpNWhibU5vYjNJZ1BDMGdiV0ZyWlVkU1lXNW5aWE5HY205dFJHRjBZVVp5WVcxbEtIUmxiWEFwWEc0Z0lGeHVJQ0JjYmlBZ1hHNGdJQ01qSUVOb1pXTnJhVzVuSUc5MlpYSnNZWEFnZDJsMGFDQm5aVzVsSUZSVFUxeHVJQ0IwYzNNZ1BDMGdabkpsWVdRb2FHVnlaU2h5WldaRWFYSXNJRnhjYlcweE1GOUhVa050TXpndWNEWmZWRk5UTWk0MWEySXVZbVZrWEZ3cEtWeHVJQ0JjYmlBZ2RITnpMbWR5YjNWd01TQThMU0IwYzNNZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1ZqWWdKV2x1SlNCbmNtOTFjREVwSUNVK0pTQmtjR3g1Y2pvNmMyVnNaV04wS0ZZeExDQldNaXdnVmpNcFhHNGdJR052Ykc1aGJXVnpLSFJ6Y3k1bmNtOTFjREVwSUR3dElHTW9YRnhqYUhKY1hDd2dYRnh6ZEdGeWRGeGNMQ0JjWEdWdVpGeGNLVnh1SUNCMGMzTXVaM0p2ZFhBeExtZHlJRHd0SUcxaGEyVkhVbUZ1WjJWelJuSnZiVVJoZEdGR2NtRnRaU2gwYzNNdVozSnZkWEF4S1Z4dUlDQmNiaUFnZEhOekxtZHliM1Z3TWlBOExTQjBjM01nSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvVmpZZ0pXbHVKU0JuY205MWNESXBJQ1UrSlNCa2NHeDVjam82YzJWc1pXTjBLRll4TENCV01pd2dWak1wWEc0Z0lHTnZiRzVoYldWektIUnpjeTVuY205MWNESXBJRHd0SUdNb1hGeGphSEpjWEN3Z1hGeHpkR0Z5ZEZ4Y0xDQmNYR1Z1WkZ4Y0tWeHVJQ0IwYzNNdVozSnZkWEF5TG1keUlEd3RJRzFoYTJWSFVtRnVaMlZ6Um5KdmJVUmhkR0ZHY21GdFpTaDBjM011WjNKdmRYQXlLVnh1SUNCY2JpQWdYRzRnSUc5MlpYSnNZWEF1WjNKdmRYQXhJRHd0SUdacGJtUlBkbVZ5YkdGd2N5aDBjM011WjNKdmRYQXhMbWR5TENCb2RXSXVZVzVqYUc5eUtWeHVJQ0J2ZG1WeWJHRndMbWR5YjNWd01pQThMU0JtYVc1a1QzWmxjbXhoY0hNb2RITnpMbWR5YjNWd01pNW5jaXdnYUhWaUxtRnVZMmh2Y2lsY2JpQWdYRzRnSUc0eElEd3RJR3hsYm1kMGFDaDFibWx4ZFdVb2NYVmxjbmxJYVhSektHOTJaWEpzWVhBdVozSnZkWEF4S1NrcFhHNGdJRzR5SUR3dElHeGxibWQwYUNoMWJtbHhkV1VvY1hWbGNubElhWFJ6S0c5MlpYSnNZWEF1WjNKdmRYQXlLU2twWEc0Z0lGeHVJQ0J3WlhKak1TQThMU0J5YjNWdVpDaHVNUzl1Y205M0tIUnpjeTVuY205MWNERXBLakV3TUN3Z01pbGNiaUFnY0dWeVl6SWdQQzBnY205MWJtUW9iakl2Ym5KdmR5aDBjM011WjNKdmRYQXlLU294TURBc0lESXBYRzRnSUZ4dUlDQnlaWE4xYkhSeklEd3RJSEpsYzNWc2RITWdKVDRsSUdGa1pGOXliM2NvYVNBOUlHa3NJSEJsY21NeElEMGdjR1Z5WXpFc0lIQmxjbU15SUQwZ2NHVnlZeklwWEc1OVhHNWNibHh1WEc1eVpYTjFiSFJ6WDJ4dmJtY2dQQzBnY21WemRXeDBjeUFsUGlWY2JpQWdjR2wyYjNSZmJHOXVaMlZ5S0dOdmJITWdQU0JqS0hCbGNtTXhMQ0J3WlhKak1pa3NJRzVoYldWelgzUnZJRDBnWEZ4SGNtOTFjRnhjTENCMllXeDFaWE5mZEc4Z1BTQmNYRkJsY21ObGJuUmhaMlZjWENsY2JseHVJeUJEY21WaGRHVWdkR2hsSUdKaGNpQndiRzkwWEc1blozQnNiM1FvY21WemRXeDBjMTlzYjI1bkxDQmhaWE1vZUNBOUlHWmhZM1J2Y2locEtTd2dlU0E5SUZCbGNtTmxiblJoWjJVc0lHWnBiR3dnUFNCSGNtOTFjQ2twSUN0Y2JpQWdaMlZ2YlY5aVlYSW9jM1JoZENBOUlGeGNhV1JsYm5ScGRIbGNYQ3dnY0c5emFYUnBiMjRnUFNCY1hHUnZaR2RsWEZ3cElDdGNiaUFnYkdGaWN5aGNiaUFnSUNCMGFYUnNaU0E5SUZ4Y1VHVnlZMlZ1ZEdGblpTQmllU0FuYVNjZ1ptOXlJSEJsY21NeElHRnVaQ0J3WlhKak1seGNMRnh1SUNBZ0lIZ2dQU0JjWEZCeVpYTmxibU5sSUc5bUlHaDFZaUJoYm1Ob2IzSWdkMmwwYUNBK2FTQmpiMjV1WldOMGFXOXVjMXhjTEZ4dUlDQWdJSGtnUFNCY1hGQmxjbU5sYm5SaFoyVmNYRnh1SUNBcElDdGNiaUFnZEdobGJXVmZiV2x1YVcxaGJDZ3BJQ3RjYmlBZ2MyTmhiR1ZmWm1sc2JGOXRZVzUxWVd3b2RtRnNkV1Z6SUQwZ1l5aGNYSEJsY21NeFhGd2dQU0JjWEdKc2RXVmNYQ3dnWEZ4d1pYSmpNbHhjSUQwZ1hGeHlaV1JjWENrcElDdGNiaUFnZEdobGJXVW9ZWGhwY3k1MFpYaDBMbmdnUFNCbGJHVnRaVzUwWDNSbGVIUW9ZVzVuYkdVZ1BTQTBOU3dnYUdwMWMzUWdQU0F4S1NsY2JtQmdZRnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbmBgYHJcbnJlc3VsdHMgPC0gdGliYmxlKGkgPSBudW1lcmljKCksIHBlcmMxID0gbnVtZXJpYygpLCBwZXJjMiA9IG51bWVyaWMoKSlcblxuZm9yKGkgaW4gc2VxKDEsIDEwKSl7XG4gIGRhdGEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcRHlsYW5faHViX2VwaXNjLmNzdlxcKSlcbiAgXG4gIGRhdGEuaHViIDwtIGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoYWxsX2xjb24gPiBpKVxuICB0ZW1wIDwtIGRhdGEuaHViICU+JSBkcGx5cjo6c2VsZWN0KGMoMSwgMiwgMykpXG4gIGNvbG5hbWVzKHRlbXApIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuICBodWIuYW5jaG9yIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxuICBcbiAgXG4gIFxuICAjIyBDaGVja2luZyBvdmVybGFwIHdpdGggZ2VuZSBUU1NcbiAgdHNzIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X1RTUzIuNWtiLmJlZFxcKSlcbiAgXG4gIHRzcy5ncm91cDEgPC0gdHNzICU+JSBkcGx5cjo6ZmlsdGVyKFY2ICVpbiUgZ3JvdXAxKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuICBjb2xuYW1lcyh0c3MuZ3JvdXAxKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbiAgdHNzLmdyb3VwMS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodHNzLmdyb3VwMSlcbiAgXG4gIHRzcy5ncm91cDIgPC0gdHNzICU+JSBkcGx5cjo6ZmlsdGVyKFY2ICVpbiUgZ3JvdXAyKSAlPiUgZHBseXI6OnNlbGVjdChWMSwgVjIsIFYzKVxuICBjb2xuYW1lcyh0c3MuZ3JvdXAyKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbiAgdHNzLmdyb3VwMi5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodHNzLmdyb3VwMilcbiAgXG4gIFxuICBvdmVybGFwLmdyb3VwMSA8LSBmaW5kT3ZlcmxhcHModHNzLmdyb3VwMS5nciwgaHViLmFuY2hvcilcbiAgb3ZlcmxhcC5ncm91cDIgPC0gZmluZE92ZXJsYXBzKHRzcy5ncm91cDIuZ3IsIGh1Yi5hbmNob3IpXG4gIFxuICBuMSA8LSBsZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhvdmVybGFwLmdyb3VwMSkpKVxuICBuMiA8LSBsZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhvdmVybGFwLmdyb3VwMikpKVxuICBcbiAgcGVyYzEgPC0gcm91bmQobjEvbnJvdyh0c3MuZ3JvdXAxKSoxMDAsIDIpXG4gIHBlcmMyIDwtIHJvdW5kKG4yL25yb3codHNzLmdyb3VwMikqMTAwLCAyKVxuICBcbiAgcmVzdWx0cyA8LSByZXN1bHRzICU+JSBhZGRfcm93KGkgPSBpLCBwZXJjMSA9IHBlcmMxLCBwZXJjMiA9IHBlcmMyKVxufVxuXG5cblxucmVzdWx0c19sb25nIDwtIHJlc3VsdHMgJT4lXG4gIHBpdm90X2xvbmdlcihjb2xzID0gYyhwZXJjMSwgcGVyYzIpLCBuYW1lc190byA9IFxcR3JvdXBcXCwgdmFsdWVzX3RvID0gXFxQZXJjZW50YWdlXFwpXG5cbiMgQ3JlYXRlIHRoZSBiYXIgcGxvdFxuZ2dwbG90KHJlc3VsdHNfbG9uZywgYWVzKHggPSBmYWN0b3IoaSksIHkgPSBQZXJjZW50YWdlLCBmaWxsID0gR3JvdXApKSArXG4gIGdlb21fYmFyKHN0YXQgPSBcXGlkZW50aXR5XFwsIHBvc2l0aW9uID0gXFxkb2RnZVxcKSArXG4gIGxhYnMoXG4gICAgdGl0bGUgPSBcXFBlcmNlbnRhZ2UgYnkgJ2knIGZvciBwZXJjMSBhbmQgcGVyYzJcXCxcbiAgICB4ID0gXFxQcmVzZW5jZSBvZiBodWIgYW5jaG9yIHdpdGggPmkgY29ubmVjdGlvbnNcXCxcbiAgICB5ID0gXFxQZXJjZW50YWdlXFxcbiAgKSArXG4gIHRoZW1lX21pbmltYWwoKSArXG4gIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGMoXFxwZXJjMVxcID0gXFxibHVlXFwsIFxccGVyYzJcXCA9IFxccmVkXFwpKSArXG4gIHRoZW1lKGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KGFuZ2xlID0gNDUsIGhqdXN0ID0gMSkpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxucmVzdWx0cyA8LSB0aWJibGUoaSA9IG51bWVyaWMoKSwgcGVyYzEgPSBudW1lcmljKCksIHBlcmMyID0gbnVtZXJpYygpKVxuXG5mb3IoaSBpbiBzZXEoMSwgMTApKXtcbiAgZGF0YSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxEeWxhbl9odWJfZXBpc2MuY3N2XFwpKVxuICBcbiAgZGF0YS5odWIgPC0gZGF0YSAlPiUgZHBseXI6OmZpbHRlcihhbGxfbGNvbiA+IGkpXG4gIHRlbXAgPC0gZGF0YS5odWIgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzKSlcbiAgY29sbmFtZXModGVtcCkgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG4gIGh1Yi5hbmNob3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRlbXApXG4gIFxuICBcbiAgXG4gICMjIENoZWNraW5nIG92ZXJsYXAgd2l0aCBnZW5lIFRTU1xuICB0c3MgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfVFNTMi41a2IuYmVkXFwpKVxuICBcbiAgdHNzLmdyb3VwMSA8LSB0c3MgJT4lIGRwbHlyOjpmaWx0ZXIoVjYgJWluJSBncm91cDEpICU+JSBkcGx5cjo6c2VsZWN0KFYxLCBWMiwgVjMpXG4gIGNvbG5hbWVzKHRzcy5ncm91cDEpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuICB0c3MuZ3JvdXAxLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0c3MuZ3JvdXAxKVxuICBcbiAgdHNzLmdyb3VwMiA8LSB0c3MgJT4lIGRwbHlyOjpmaWx0ZXIoVjYgJWluJSBncm91cDIpICU+JSBkcGx5cjo6c2VsZWN0KFYxLCBWMiwgVjMpXG4gIGNvbG5hbWVzKHRzcy5ncm91cDIpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcKVxuICB0c3MuZ3JvdXAyLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0c3MuZ3JvdXAyKVxuICBcbiAgXG4gIG92ZXJsYXAuZ3JvdXAxIDwtIGZpbmRPdmVybGFwcyh0c3MuZ3JvdXAxLmdyLCBodWIuYW5jaG9yKVxuICBvdmVybGFwLmdyb3VwMiA8LSBmaW5kT3ZlcmxhcHModHNzLmdyb3VwMi5nciwgaHViLmFuY2hvcilcbiAgXG4gIG4xIDwtIGxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKG92ZXJsYXAuZ3JvdXAxKSkpXG4gIG4yIDwtIGxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKG92ZXJsYXAuZ3JvdXAyKSkpXG4gIFxuICBwZXJjMSA8LSByb3VuZChuMS9ucm93KHRzcy5ncm91cDEpKjEwMCwgMilcbiAgcGVyYzIgPC0gcm91bmQobjIvbnJvdyh0c3MuZ3JvdXAyKSoxMDAsIDIpXG4gIFxuICByZXN1bHRzIDwtIHJlc3VsdHMgJT4lIGFkZF9yb3coaSA9IGksIHBlcmMxID0gcGVyYzEsIHBlcmMyID0gcGVyYzIpXG59XG5cblxuXG5yZXN1bHRzX2xvbmcgPC0gcmVzdWx0cyAlPiVcbiAgcGl2b3RfbG9uZ2VyKGNvbHMgPSBjKHBlcmMxLCBwZXJjMiksIG5hbWVzX3RvID0gXFxHcm91cFxcLCB2YWx1ZXNfdG8gPSBcXFBlcmNlbnRhZ2VcXClcblxuIyBDcmVhdGUgdGhlIGJhciBwbG90XG5nZ3Bsb3QocmVzdWx0c19sb25nLCBhZXMoeCA9IGZhY3RvcihpKSwgeSA9IFBlcmNlbnRhZ2UsIGZpbGwgPSBHcm91cCkpICtcbiAgZ2VvbV9iYXIoc3RhdCA9IFxcaWRlbnRpdHlcXCwgcG9zaXRpb24gPSBcXGRvZGdlXFwpICtcbiAgbGFicyhcbiAgICB0aXRsZSA9IFxcUGVyY2VudGFnZSBieSAnaScgZm9yIHBlcmMxIGFuZCBwZXJjMlxcLFxuICAgIHggPSBcXFByZXNlbmNlIG9mIGh1YiBhbmNob3Igd2l0aCA+aSBjb25uZWN0aW9uc1xcLFxuICAgIHkgPSBcXFBlcmNlbnRhZ2VcXFxuICApICtcbiAgdGhlbWVfbWluaW1hbCgpICtcbiAgc2NhbGVfZmlsbF9tYW51YWwodmFsdWVzID0gYyhcXHBlcmMxXFwgPSBcXGJsdWVcXCwgXFxwZXJjMlxcID0gXFxyZWRcXCkpICtcbiAgdGhlbWUoYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoYW5nbGUgPSA0NSwgaGp1c3QgPSAxKSlcbmBgYFxuYGBgIn0= -->

```r
```r
results <- tibble(i = numeric(), perc1 = numeric(), perc2 = numeric())

for(i in seq(1, 10)){
  data <- fread(here(refDir, \Dylan_hub_episc.csv\))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c(\chr\, \start\, \end\)
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  
  ## Checking overlap with gene TSS
  tss <- fread(here(refDir, \mm10_GRCm38.p6_TSS2.5kb.bed\))
  
  tss.group1 <- tss %>% dplyr::filter(V6 %in% group1) %>% dplyr::select(V1, V2, V3)
  colnames(tss.group1) <- c(\chr\, \start\, \end\)
  tss.group1.gr <- makeGRangesFromDataFrame(tss.group1)
  
  tss.group2 <- tss %>% dplyr::filter(V6 %in% group2) %>% dplyr::select(V1, V2, V3)
  colnames(tss.group2) <- c(\chr\, \start\, \end\)
  tss.group2.gr <- makeGRangesFromDataFrame(tss.group2)
  
  
  overlap.group1 <- findOverlaps(tss.group1.gr, hub.anchor)
  overlap.group2 <- findOverlaps(tss.group2.gr, hub.anchor)
  
  n1 <- length(unique(queryHits(overlap.group1)))
  n2 <- length(unique(queryHits(overlap.group2)))
  
  perc1 <- round(n1/nrow(tss.group1)*100, 2)
  perc2 <- round(n2/nrow(tss.group2)*100, 2)
  
  results <- results %>% add_row(i = i, perc1 = perc1, perc2 = perc2)
}



results_long <- results %>%
  pivot_longer(cols = c(perc1, perc2), names_to = \Group\, values_to = \Percentage\)

# Create the bar plot
ggplot(results_long, aes(x = factor(i), y = Percentage, fill = Group)) +
  geom_bar(stat = \identity\, position = \dodge\) +
  labs(
    title = \Percentage by 'i' for perc1 and perc2\,
    x = \Presence of hub anchor with >i connections\,
    y = \Percentage\
  ) +
  theme_minimal() +
  scale_fill_manual(values = c(\perc1\ = \blue\, \perc2\ = \red\)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1))
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



#### Str loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxucHJvY2Vzc19ncm91cCA8LSBmdW5jdGlvbihncm91cF9uYW1lLCBnZW5lX2RhdGEsIGJpbnMpIHtcbiAgIyBGaWx0ZXIgZm9yIHRoZSBzcGVjaWZpYyBncm91cFxuICBUU1NfZ3JvdXAgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKFxuICAgIGdlbmVfZGF0YSAlPiUgZmlsdGVyKGVuc2VtYmwgJWluJSBnZXQoZ3JvdXBfbmFtZSkpLCBcbiAgICBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFXG4gIClcbiAgXG4gICMgUHJvY2VzcyBlYWNoIFRTUyBpbiB0aGUgZ3JvdXBcbiAgYWxsX3Jlc3VsdHMgPC0gbWFwX2RmcihzZXFfbGVuKGxlbmd0aChUU1NfZ3JvdXApKSwgZnVuY3Rpb24oaSkge1xuICAgICMgRmluZCBvdmVybGFwcGluZyBiaW5zXG4gICAgb3ZlcmxhcHBpbmdfYmlucyA8LSBmaW5kT3ZlcmxhcHMoVFNTX2dyb3VwW2ldLCBiaW5zKVxuICAgIGJpbnNfbmVhcl90c3MgPC0gYXNfdGliYmxlKGJpbnNbc3ViamVjdEhpdHMob3ZlcmxhcHBpbmdfYmlucyldKVxuICAgIFxuICAgICMgQ2FsY3VsYXRlIGRpc3RhbmNlIGJpblxuICAgIFRTU2NlbnRlciA8LSAoYXNfdGliYmxlKFRTU19ncm91cFtpXSkgJT4lXG4gICAgICAgICAgICAgICAgICAgIG11dGF0ZShjZW50ZXIgPSAoc3RhcnQgKyBlbmQpIC8gMikpJGNlbnRlclxuICAgIGNlbnRlckJpblN0YXJ0IDwtIGZsb29yKFRTU2NlbnRlciAvIDEwZTMpICogMTBlMyArIDFcbiAgICBiaW5zX25lYXJfdHNzIDwtIGJpbnNfbmVhcl90c3MgJT4lXG4gICAgICBtdXRhdGUoZGlzdGFuY2VCaW4gPSBhYnMoKHN0YXJ0IC0gY2VudGVyQmluU3RhcnQpKSAvIDEwZTMpXG4gICAgXG4gICAgIyBTdW1tYXJpemUgcmVzdWx0c1xuICAgIHJlc3VsdCA8LSBiaW5zX25lYXJfdHNzICU+JVxuICAgICAgZ3JvdXBfYnkoZGlzdGFuY2VCaW4pICU+JVxuICAgICAgc3VtbWFyaXNlKG1lYW5fcGVha19jb3VudHMgPSBtZWFuKHBlYWtfY291bnRzLCBuYS5ybSA9IFRSVUUpLCAuZ3JvdXBzID0gXCJkcm9wXCIpICU+JVxuICAgICAgbXV0YXRlKGdlbmUgPSBUU1NfZ3JvdXBbaV0kZW5zZW1ibClcbiAgICByZXR1cm4ocmVzdWx0KVxuICB9KVxuICBcbiAgIyBDYWxjdWxhdGUgbWVhbiBhbmQgU0QgZm9yIHRoZSBncm91cFxuICBtZWFuX2RhdGEgPC0gYWxsX3Jlc3VsdHMgJT4lXG4gICAgZ3JvdXBfYnkoZGlzdGFuY2VCaW4pICU+JVxuICAgIHN1bW1hcmlzZShtZWFuX3BlYWtfY291bnRzID0gbWVhbihtZWFuX3BlYWtfY291bnRzLCBuYS5ybSA9IFRSVUUpKVxuICBcbiAgc2RfZGF0YSA8LSBhbGxfcmVzdWx0cyAlPiVcbiAgICBncm91cF9ieShkaXN0YW5jZUJpbikgJT4lXG4gICAgc3VtbWFyaXNlKHNkX3BlYWtfY291bnRzID0gc2QobWVhbl9wZWFrX2NvdW50cywgbmEucm0gPSBUUlVFKSlcbiAgXG4gICMgSm9pbiBhbmQgYWRkIGdyb3VwIG5hbWVcbiAgc3VtbWFyeV9kYXRhIDwtIGxlZnRfam9pbihtZWFuX2RhdGEsIHNkX2RhdGEsIGJ5ID0gXCJkaXN0YW5jZUJpblwiKSAlPiVcbiAgICBtdXRhdGUoZ3JvdXAgPSBncm91cF9uYW1lKVxuICBcbiAgcmV0dXJuKHN1bW1hcnlfZGF0YSlcbn1cblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuXG5cblxuIyMgSW1wb3J0IHBlYWtcbnJlZkRpciA8LSBoZXJlKFwiLi4vLi5cIiwgXCJyZWZlcmVuY2VcIilcbiNwZWFrLkgzSzI3YWMgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXCJHU00yNDM4NDc2X0VDLURHLTM0NTgtSDNLMjdBQ19BU1lOXzEubmFycm93UGVhay5iZWRcIikpXG5wZWFrLkgzSzI3YWMgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXCIzMzI1NV9IM0s0bWUzXzA0LTc0NV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcIikpXG4jcGVhay5IM0syN2FjIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFwiMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXCIpKVxuXG4jIyBJbXBvcnQgMTBrYiBiaW5cbnRlbXAgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwibW0xMC5iaW4uMTBrYi5iZWRcIikpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFwiY2hyXCIsIFwic3RhcnRcIiwgXCJlbmRcIilcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShzdGFydCA9IHN0YXJ0KzEpXG5iaW5zLjEwa2IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRlbXApXG5cbiMjIENvdW50IG92ZXJsYXBcbmNvdW50cyA8LSBjb3VudE92ZXJsYXBzKGJpbnMuMTBrYiwgcGVhay5IM0syN2FjKVxubWNvbHMoYmlucy4xMGtiKSRwZWFrX2NvdW50cyA8LSBjb3VudHNcblxuIyMgR2V0dGluZyBUU1NcbmZsYW5rU2l6ZSA8LSAxZTZcbmdlbmUudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwibW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXCIrXCIsIFYyLCBWMyksXG4gICAgICAgICAgICAgICAgVFNTc3RhcnQgPSBUU1MgLSBmbGFua1NpemUsXG4gICAgICAgICAgICAgICAgVFNTZW5kID0gVFNTICsgZmxhbmtTaXplKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWMSwgVFNTc3RhcnQsIFRTU2VuZCwgVjYpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFwiY2hyXCIsIFwic3RhcnRcIiwgXCJlbmRcIiwgXCJlbnNlbWJsXCIpXG5cbmdlbmUuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XCIpKSRnZW5lXG5nZW5lLmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlwiKSkkZ2VuZVxuXG4jVFNTMW1iLmdyb3VwMS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZS50YiAlPiUgZHBseXI6OmZpbHRlcihlbnNlbWJsICVpbiUgZ2VuZS5ncm91cDEpLCBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFKVxuI1RTUzFtYi5ncm91cDIuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGdlbmUudGIgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGdlbmUuZ3JvdXAyKSwga2VlcC5leHRyYS5jb2x1bW5zID0gVFJVRSlcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBMaXN0IG9mIGdyb3VwcyB0byBwcm9jZXNzXG5ncm91cHMgPC0gYyhcImdlbmUuZ3JvdXAxXCIsIFwiZ2VuZS5ncm91cDJcIilcblxuIyBQcm9jZXNzIGVhY2ggZ3JvdXAgYW5kIGNvbWJpbmUgcmVzdWx0c1xuc3VtbWFyeV9kYXRhIDwtIG1hcF9kZnIoZ3JvdXBzLCB+IHByb2Nlc3NfZ3JvdXAoLngsIGdlbmUudGIsIGJpbnMuMTBrYikpXG5cbiMgQWRkIHRoZSBhZGRpdGlvbmFsIHJvd3MgZm9yIGRpc3RhbmNlQmluID0gMFxuc3VtbWFyeV9kYXRhIDwtIHN1bW1hcnlfZGF0YSAlPiVcbiAgbXV0YXRlKGRpc3RhbmNlQmluID0gZGlzdGFuY2VCaW4gKyAxKSAlPiVcbiAgYWRkX3JvdyhkaXN0YW5jZUJpbiA9IDAsIG1lYW5fcGVha19jb3VudHMgPSAwLCBzZF9wZWFrX2NvdW50cyA9IDAsIGdyb3VwID0gXCJnZW5lLmdyb3VwMVwiKSAlPiVcbiAgYWRkX3JvdyhkaXN0YW5jZUJpbiA9IDAsIG1lYW5fcGVha19jb3VudHMgPSAwLCBzZF9wZWFrX2NvdW50cyA9IDAsIGdyb3VwID0gXCJnZW5lLmdyb3VwMlwiKVxuXG4jIFBsb3QgdGhlIHJlc3VsdHNcbnAgPC0gZ2dwbG90KHN1bW1hcnlfZGF0YSwgYWVzKHggPSBkaXN0YW5jZUJpbiwgeSA9IG1lYW5fcGVha19jb3VudHMsIGNvbG9yID0gZ3JvdXApKSArIFxuICBnZW9tX2xpbmUoc2l6ZSA9IDAuNSkgK1xuICBsYWJzKFxuICAgIHggPSBcIkRpc3RhbmNlIGJpbiAoMTBrYilcIixcbiAgICB5ID0gXCJIM0s0bWUzIHBlYWsgY291bnRcIlxuICApICtcbiAgdGhlbWVfY2xhc3NpYygpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCIsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcInNxdWFyZVwiXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFwidHJhbnNwYXJlbnRcIiksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnBvc2l0aW9uID0gYygwLjgsIDAuOCkgICMgTW92ZXMgbGVnZW5kIGluc2lkZSB0aGUgcGxvdCAoeCwgeSByZWxhdGl2ZSBjb29yZGluYXRlcylcbiAgKSArXG4gIGd1aWRlcyhcbiAgICBmaWxsID0gZ3VpZGVfbGVnZW5kKFxuICAgICAga2V5d2lkdGggPSAwLjIsICAjIEFkanVzdCB0aGUgd2lkdGggb2YgdGhlIGxlZ2VuZCBrZXlzXG4gICAgICBrZXloZWlnaHQgPSAwLjIgICMgQWRqdXN0IHRoZSBoZWlnaHQgb2YgdGhlIGxlZ2VuZCBrZXlzXG4gICAgKSkrXG4gIHNjYWxlX2NvbG9yX21hbnVhbCh2YWx1ZXMgPSByZXYoYyhcIiM3Nzc3NzdcIiwgXCIjRjI4RTJDXCIpKSlcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJiaW5QZWFrRGVuc2l0eV9SQUQyMV9iaW5hcnlHcm91cFwiKVxud2lkdGggPC0gMzIqbW1Ub0luY2hcbmhlaWdodCA8LSAzNSptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnBuZ1wiKSksIHJlcyA9IDYwMCwgdW5pdCA9IFwiaW5cIiwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5zdmdcIikpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgIn0= -->\n\n```r\nprocess_group <- function(group_name, gene_data, bins) {\n  # Filter for the specific group\n  TSS_group <- makeGRangesFromDataFrame(\n    gene_data %>% filter(ensembl %in% get(group_name)), \n    keep.extra.columns = TRUE\n  )\n  \n  # Process each TSS in the group\n  all_results <- map_dfr(seq_len(length(TSS_group)), function(i) {\n    # Find overlapping bins\n    overlapping_bins <- findOverlaps(TSS_group[i], bins)\n    bins_near_tss <- as_tibble(bins[subjectHits(overlapping_bins)])\n    \n    # Calculate distance bin\n    TSScenter <- (as_tibble(TSS_group[i]) %>%\n                    mutate(center = (start + end) / 2))$center\n    centerBinStart <- floor(TSScenter / 10e3) * 10e3 + 1\n    bins_near_tss <- bins_near_tss %>%\n      mutate(distanceBin = abs((start - centerBinStart)) / 10e3)\n    \n    # Summarize results\n    result <- bins_near_tss %>%\n      group_by(distanceBin) %>%\n      summarise(mean_peak_counts = mean(peak_counts, na.rm = TRUE), .groups = \\drop\\) %>%\n      mutate(gene = TSS_group[i]$ensembl)\n    return(result)\n  })\n  \n  # Calculate mean and SD for the group\n  mean_data <- all_results %>%\n    group_by(distanceBin) %>%\n    summarise(mean_peak_counts = mean(mean_peak_counts, na.rm = TRUE))\n  \n  sd_data <- all_results %>%\n    group_by(distanceBin) %>%\n    summarise(sd_peak_counts = sd(mean_peak_counts, na.rm = TRUE))\n  \n  # Join and add group name\n  summary_data <- left_join(mean_data, sd_data, by = \\distanceBin\\) %>%\n    mutate(group = group_name)\n  \n  return(summary_data)\n}\n\n##########################################################\n\n\n\n## Import peak\nrefDir <- here(\\../..\\, \\reference\\)\n#peak.H3K27ac <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\npeak.H3K27ac <- importPeak(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\\))\n#peak.H3K27ac <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n\n## Import 10kb bin\ntemp <- fread(here(refDir, \\mm10.bin.10kb.bed\\))\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\ntemp <- temp %>% dplyr::mutate(start = start+1)\nbins.10kb <- makeGRangesFromDataFrame(temp)\n\n## Count overlap\ncounts <- countOverlaps(bins.10kb, peak.H3K27ac)\nmcols(bins.10kb)$peak_counts <- counts\n\n## Getting TSS\nflankSize <- 1e6\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\start\\, \\end\\, \\ensembl\\)\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n#TSS1mb.group1.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group1), keep.extra.columns = TRUE)\n#TSS1mb.group2.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group2), keep.extra.columns = TRUE)\n\n##########################################################\n# List of groups to process\ngroups <- c(\\gene.group1\\, \\gene.group2\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\gene.group1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\gene.group2\\)\n\n# Plot the results\np <- ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 0.5) +\n  labs(\n    x = \\Distance bin (10kb)\\,\n    y = \\H3K4me3 peak count\\\n  ) +\n  theme_classic() +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS),\n    legend.position = c(0.8, 0.8)  # Moves legend inside the plot (x, y relative coordinates)\n  ) +\n  guides(\n    fill = guide_legend(\n      keywidth = 0.2,  # Adjust the width of the legend keys\n      keyheight = 0.2  # Adjust the height of the legend keys\n    ))+\n  scale_color_manual(values = rev(c(\\#777777\\, \\#F28E2C\\)))\n\n##########################################################\n\nfileName <- paste0(\\binPeakDensity_RAD21_binaryGroup\\)\nwidth <- 32*mmToInch\nheight <- 35*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
process_group <- function(group_name, gene_data, bins) {
  # Filter for the specific group
  TSS_group <- makeGRangesFromDataFrame(
    gene_data %>% filter(ensembl %in% get(group_name)), 
    keep.extra.columns = TRUE
  )
  
  # Process each TSS in the group
  all_results <- map_dfr(seq_len(length(TSS_group)), function(i) {
    # Find overlapping bins
    overlapping_bins <- findOverlaps(TSS_group[i], bins)
    bins_near_tss <- as_tibble(bins[subjectHits(overlapping_bins)])
    
    # Calculate distance bin
    TSScenter <- (as_tibble(TSS_group[i]) %>%
                    mutate(center = (start + end) / 2))$center
    centerBinStart <- floor(TSScenter / 10e3) * 10e3 + 1
    bins_near_tss <- bins_near_tss %>%
      mutate(distanceBin = abs((start - centerBinStart)) / 10e3)
    
    # Summarize results
    result <- bins_near_tss %>%
      group_by(distanceBin) %>%
      summarise(mean_peak_counts = mean(peak_counts, na.rm = TRUE), .groups = \drop\) %>%
      mutate(gene = TSS_group[i]$ensembl)
    return(result)
  })
  
  # Calculate mean and SD for the group
  mean_data <- all_results %>%
    group_by(distanceBin) %>%
    summarise(mean_peak_counts = mean(mean_peak_counts, na.rm = TRUE))
  
  sd_data <- all_results %>%
    group_by(distanceBin) %>%
    summarise(sd_peak_counts = sd(mean_peak_counts, na.rm = TRUE))
  
  # Join and add group name
  summary_data <- left_join(mean_data, sd_data, by = \distanceBin\) %>%
    mutate(group = group_name)
  
  return(summary_data)
}

##########################################################



## Import peak
refDir <- here(\../..\, \reference\)
#peak.H3K27ac <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
peak.H3K27ac <- importPeak(here(refDir, \33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\))
#peak.H3K27ac <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))

## Import 10kb bin
temp <- fread(here(refDir, \mm10.bin.10kb.bed\))
colnames(temp) <- c(\chr\, \start\, \end\)
temp <- temp %>% dplyr::mutate(start = start+1)
bins.10kb <- makeGRangesFromDataFrame(temp)

## Count overlap
counts <- countOverlaps(bins.10kb, peak.H3K27ac)
mcols(bins.10kb)$peak_counts <- counts

## Getting TSS
flankSize <- 1e6
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6)
colnames(gene.tb) <- c(\chr\, \start\, \end\, \ensembl\)

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

#TSS1mb.group1.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group1), keep.extra.columns = TRUE)
#TSS1mb.group2.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group2), keep.extra.columns = TRUE)

##########################################################
# List of groups to process
groups <- c(\gene.group1\, \gene.group2\)

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \gene.group1\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \gene.group2\)

# Plot the results
p <- ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 0.5) +
  labs(
    x = \Distance bin (10kb)\,
    y = \H3K4me3 peak count\
  ) +
  theme_classic() +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS),
    legend.position = c(0.8, 0.8)  # Moves legend inside the plot (x, y relative coordinates)
  ) +
  guides(
    fill = guide_legend(
      keywidth = 0.2,  # Adjust the width of the legend keys
      keyheight = 0.2  # Adjust the height of the legend keys
    ))+
  scale_color_manual(values = rev(c(\#777777\, \#F28E2C\)))

##########################################################

fileName <- paste0(\binPeakDensity_RAD21_binaryGroup\)
width <- 32*mmToInch
height <- 35*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxucHJvY2Vzc19ncm91cCA8LSBmdW5jdGlvbihncm91cF9uYW1lLCBnZW5lX2RhdGEsIGJpbnMpIHtcbiAgIyBGaWx0ZXIgZm9yIHRoZSBzcGVjaWZpYyBncm91cFxuICBUU1NfZ3JvdXAgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKFxuICAgIGdlbmVfZGF0YSAlPiUgZmlsdGVyKGVuc2VtYmwgJWluJSBnZXQoZ3JvdXBfbmFtZSkpLCBcbiAgICBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFXG4gIClcbiAgXG4gICMgUHJvY2VzcyBlYWNoIFRTUyBpbiB0aGUgZ3JvdXBcbiAgYWxsX3Jlc3VsdHMgPC0gbWFwX2RmcihzZXFfbGVuKGxlbmd0aChUU1NfZ3JvdXApKSwgZnVuY3Rpb24oaSkge1xuICAgICMgRmluZCBvdmVybGFwcGluZyBiaW5zXG4gICAgb3ZlcmxhcHBpbmdfYmlucyA8LSBmaW5kT3ZlcmxhcHMoVFNTX2dyb3VwW2ldLCBiaW5zKVxuICAgIGJpbnNfbmVhcl90c3MgPC0gYXNfdGliYmxlKGJpbnNbc3ViamVjdEhpdHMob3ZlcmxhcHBpbmdfYmlucyldKVxuICAgIFxuICAgICMgQ2FsY3VsYXRlIGRpc3RhbmNlIGJpblxuICAgIFRTU2NlbnRlciA8LSAoYXNfdGliYmxlKFRTU19ncm91cFtpXSkgJT4lXG4gICAgICAgICAgICAgICAgICAgIG11dGF0ZShjZW50ZXIgPSAoc3RhcnQgKyBlbmQpIC8gMikpJGNlbnRlclxuICAgIGNlbnRlckJpblN0YXJ0IDwtIGZsb29yKFRTU2NlbnRlciAvIDEwZTMpICogMTBlMyArIDFcbiAgICBiaW5zX25lYXJfdHNzIDwtIGJpbnNfbmVhcl90c3MgJT4lXG4gICAgICBtdXRhdGUoZGlzdGFuY2VCaW4gPSBhYnMoKHN0YXJ0IC0gY2VudGVyQmluU3RhcnQpKSAvIDEwZTMpXG4gICAgXG4gICAgIyBTdW1tYXJpemUgcmVzdWx0c1xuICAgIHJlc3VsdCA8LSBiaW5zX25lYXJfdHNzICU+JVxuICAgICAgZ3JvdXBfYnkoZGlzdGFuY2VCaW4pICU+JVxuICAgICAgc3VtbWFyaXNlKG1lYW5fcGVha19jb3VudHMgPSBtZWFuKHBlYWtfY291bnRzLCBuYS5ybSA9IFRSVUUpLCAuZ3JvdXBzID0gXFxkcm9wXFwpICU+JVxuICAgICAgbXV0YXRlKGdlbmUgPSBUU1NfZ3JvdXBbaV0kZW5zZW1ibClcbiAgICByZXR1cm4ocmVzdWx0KVxuICB9KVxuICBcbiAgIyBDYWxjdWxhdGUgbWVhbiBhbmQgU0QgZm9yIHRoZSBncm91cFxuICBtZWFuX2RhdGEgPC0gYWxsX3Jlc3VsdHMgJT4lXG4gICAgZ3JvdXBfYnkoZGlzdGFuY2VCaW4pICU+JVxuICAgIHN1bW1hcmlzZShtZWFuX3BlYWtfY291bnRzID0gbWVhbihtZWFuX3BlYWtfY291bnRzLCBuYS5ybSA9IFRSVUUpKVxuICBcbiAgc2RfZGF0YSA8LSBhbGxfcmVzdWx0cyAlPiVcbiAgICBncm91cF9ieShkaXN0YW5jZUJpbikgJT4lXG4gICAgc3VtbWFyaXNlKHNkX3BlYWtfY291bnRzID0gc2QobWVhbl9wZWFrX2NvdW50cywgbmEucm0gPSBUUlVFKSlcbiAgXG4gICMgSm9pbiBhbmQgYWRkIGdyb3VwIG5hbWVcbiAgc3VtbWFyeV9kYXRhIDwtIGxlZnRfam9pbihtZWFuX2RhdGEsIHNkX2RhdGEsIGJ5ID0gXFxkaXN0YW5jZUJpblxcKSAlPiVcbiAgICBtdXRhdGUoZ3JvdXAgPSBncm91cF9uYW1lKVxuICBcbiAgcmV0dXJuKHN1bW1hcnlfZGF0YSlcbn1cblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuXG5cblxuIyMgSW1wb3J0IHBlYWtcbnJlZkRpciA8LSBoZXJlKFxcLi4vLi5cXCwgXFxyZWZlcmVuY2VcXClcbiNwZWFrLkgzSzI3YWMgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFxHU00yNDM4NDc2X0VDLURHLTM0NTgtSDNLMjdBQ19BU1lOXzEubmFycm93UGVhay5iZWRcXCkpXG5wZWFrLkgzSzI3YWMgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFwzMzI1NV9IM0s0bWUzXzA0LTc0NV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcXCkpXG4jcGVhay5IM0syN2FjIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKVxuXG4jIyBJbXBvcnQgMTBrYiBiaW5cbnRlbXAgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMC5iaW4uMTBrYi5iZWRcXCkpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShzdGFydCA9IHN0YXJ0KzEpXG5iaW5zLjEwa2IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRlbXApXG5cbiMjIENvdW50IG92ZXJsYXBcbmNvdW50cyA8LSBjb3VudE92ZXJsYXBzKGJpbnMuMTBrYiwgcGVhay5IM0syN2FjKVxubWNvbHMoYmlucy4xMGtiKSRwZWFrX2NvdW50cyA8LSBjb3VudHNcblxuIyMgR2V0dGluZyBUU1NcbmZsYW5rU2l6ZSA8LSAxZTZcbmdlbmUudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXFwrXFwsIFYyLCBWMyksXG4gICAgICAgICAgICAgICAgVFNTc3RhcnQgPSBUU1MgLSBmbGFua1NpemUsXG4gICAgICAgICAgICAgICAgVFNTZW5kID0gVFNTICsgZmxhbmtTaXplKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWMSwgVFNTc3RhcnQsIFRTU2VuZCwgVjYpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxlbnNlbWJsXFwpXG5cbmdlbmUuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5nZW5lLmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG4jVFNTMW1iLmdyb3VwMS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZS50YiAlPiUgZHBseXI6OmZpbHRlcihlbnNlbWJsICVpbiUgZ2VuZS5ncm91cDEpLCBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFKVxuI1RTUzFtYi5ncm91cDIuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGdlbmUudGIgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGdlbmUuZ3JvdXAyKSwga2VlcC5leHRyYS5jb2x1bW5zID0gVFJVRSlcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBMaXN0IG9mIGdyb3VwcyB0byBwcm9jZXNzXG5ncm91cHMgPC0gYyhcXGdlbmUuZ3JvdXAxXFwsIFxcZ2VuZS5ncm91cDJcXClcblxuIyBQcm9jZXNzIGVhY2ggZ3JvdXAgYW5kIGNvbWJpbmUgcmVzdWx0c1xuc3VtbWFyeV9kYXRhIDwtIG1hcF9kZnIoZ3JvdXBzLCB+IHByb2Nlc3NfZ3JvdXAoLngsIGdlbmUudGIsIGJpbnMuMTBrYikpXG5cbiMgQWRkIHRoZSBhZGRpdGlvbmFsIHJvd3MgZm9yIGRpc3RhbmNlQmluID0gMFxuc3VtbWFyeV9kYXRhIDwtIHN1bW1hcnlfZGF0YSAlPiVcbiAgbXV0YXRlKGRpc3RhbmNlQmluID0gZGlzdGFuY2VCaW4gKyAxKSAlPiVcbiAgYWRkX3JvdyhkaXN0YW5jZUJpbiA9IDAsIG1lYW5fcGVha19jb3VudHMgPSAwLCBzZF9wZWFrX2NvdW50cyA9IDAsIGdyb3VwID0gXFxnZW5lLmdyb3VwMVxcKSAlPiVcbiAgYWRkX3JvdyhkaXN0YW5jZUJpbiA9IDAsIG1lYW5fcGVha19jb3VudHMgPSAwLCBzZF9wZWFrX2NvdW50cyA9IDAsIGdyb3VwID0gXFxnZW5lLmdyb3VwMlxcKVxuXG4jIFBsb3QgdGhlIHJlc3VsdHNcbnAgPC0gZ2dwbG90KHN1bW1hcnlfZGF0YSwgYWVzKHggPSBkaXN0YW5jZUJpbiwgeSA9IG1lYW5fcGVha19jb3VudHMsIGNvbG9yID0gZ3JvdXApKSArIFxuICBnZW9tX2xpbmUoc2l6ZSA9IDAuNSkgK1xuICBsYWJzKFxuICAgIHggPSBcXERpc3RhbmNlIGJpbiAoMTBrYilcXCxcbiAgICB5ID0gXFxIM0s0bWUzIHBlYWsgY291bnRcXFxuICApICtcbiAgdGhlbWVfY2xhc3NpYygpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnBvc2l0aW9uID0gYygwLjgsIDAuOCkgICMgTW92ZXMgbGVnZW5kIGluc2lkZSB0aGUgcGxvdCAoeCwgeSByZWxhdGl2ZSBjb29yZGluYXRlcylcbiAgKSArXG4gIGd1aWRlcyhcbiAgICBmaWxsID0gZ3VpZGVfbGVnZW5kKFxuICAgICAga2V5d2lkdGggPSAwLjIsICAjIEFkanVzdCB0aGUgd2lkdGggb2YgdGhlIGxlZ2VuZCBrZXlzXG4gICAgICBrZXloZWlnaHQgPSAwLjIgICMgQWRqdXN0IHRoZSBoZWlnaHQgb2YgdGhlIGxlZ2VuZCBrZXlzXG4gICAgKSkrXG4gIHNjYWxlX2NvbG9yX21hbnVhbCh2YWx1ZXMgPSByZXYoYyhcXCM3Nzc3NzdcXCwgXFwjRjI4RTJDXFwpKSlcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxiaW5QZWFrRGVuc2l0eV9SQUQyMV9iaW5hcnlHcm91cFxcKVxud2lkdGggPC0gMzIqbW1Ub0luY2hcbmhlaWdodCA8LSAzNSptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\nprocess_group <- function(group_name, gene_data, bins) {\n  # Filter for the specific group\n  TSS_group <- makeGRangesFromDataFrame(\n    gene_data %>% filter(ensembl %in% get(group_name)), \n    keep.extra.columns = TRUE\n  )\n  \n  # Process each TSS in the group\n  all_results <- map_dfr(seq_len(length(TSS_group)), function(i) {\n    # Find overlapping bins\n    overlapping_bins <- findOverlaps(TSS_group[i], bins)\n    bins_near_tss <- as_tibble(bins[subjectHits(overlapping_bins)])\n    \n    # Calculate distance bin\n    TSScenter <- (as_tibble(TSS_group[i]) %>%\n                    mutate(center = (start + end) / 2))$center\n    centerBinStart <- floor(TSScenter / 10e3) * 10e3 + 1\n    bins_near_tss <- bins_near_tss %>%\n      mutate(distanceBin = abs((start - centerBinStart)) / 10e3)\n    \n    # Summarize results\n    result <- bins_near_tss %>%\n      group_by(distanceBin) %>%\n      summarise(mean_peak_counts = mean(peak_counts, na.rm = TRUE), .groups = \\drop\\) %>%\n      mutate(gene = TSS_group[i]$ensembl)\n    return(result)\n  })\n  \n  # Calculate mean and SD for the group\n  mean_data <- all_results %>%\n    group_by(distanceBin) %>%\n    summarise(mean_peak_counts = mean(mean_peak_counts, na.rm = TRUE))\n  \n  sd_data <- all_results %>%\n    group_by(distanceBin) %>%\n    summarise(sd_peak_counts = sd(mean_peak_counts, na.rm = TRUE))\n  \n  # Join and add group name\n  summary_data <- left_join(mean_data, sd_data, by = \\distanceBin\\) %>%\n    mutate(group = group_name)\n  \n  return(summary_data)\n}\n\n##########################################################\n\n\n\n## Import peak\nrefDir <- here(\\../..\\, \\reference\\)\n#peak.H3K27ac <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\npeak.H3K27ac <- importPeak(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\\))\n#peak.H3K27ac <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n\n## Import 10kb bin\ntemp <- fread(here(refDir, \\mm10.bin.10kb.bed\\))\ncolnames(temp) <- c(\\chr\\, \\start\\, \\end\\)\ntemp <- temp %>% dplyr::mutate(start = start+1)\nbins.10kb <- makeGRangesFromDataFrame(temp)\n\n## Count overlap\ncounts <- countOverlaps(bins.10kb, peak.H3K27ac)\nmcols(bins.10kb)$peak_counts <- counts\n\n## Getting TSS\nflankSize <- 1e6\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6)\ncolnames(gene.tb) <- c(\\chr\\, \\start\\, \\end\\, \\ensembl\\)\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n#TSS1mb.group1.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group1), keep.extra.columns = TRUE)\n#TSS1mb.group2.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group2), keep.extra.columns = TRUE)\n\n##########################################################\n# List of groups to process\ngroups <- c(\\gene.group1\\, \\gene.group2\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\gene.group1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\gene.group2\\)\n\n# Plot the results\np <- ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 0.5) +\n  labs(\n    x = \\Distance bin (10kb)\\,\n    y = \\H3K4me3 peak count\\\n  ) +\n  theme_classic() +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS),\n    legend.position = c(0.8, 0.8)  # Moves legend inside the plot (x, y relative coordinates)\n  ) +\n  guides(\n    fill = guide_legend(\n      keywidth = 0.2,  # Adjust the width of the legend keys\n      keyheight = 0.2  # Adjust the height of the legend keys\n    ))+\n  scale_color_manual(values = rev(c(\\#777777\\, \\#F28E2C\\)))\n\n##########################################################\n\nfileName <- paste0(\\binPeakDensity_RAD21_binaryGroup\\)\nwidth <- 32*mmToInch\nheight <- 35*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxucHJvY2Vzc19ncm91cCA8LSBmdW5jdGlvbihncm91cF9uYW1lLCBnZW5lX2RhdGEsIGJpbnMpIHtcbiAgIyBGaWx0ZXIgZm9yIHRoZSBzcGVjaWZpYyBncm91cFxuICBUU1NfZ3JvdXAgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKFxuICAgIGdlbmVfZGF0YSAlPiUgZmlsdGVyKGVuc2VtYmwgJWluJSBnZXQoZ3JvdXBfbmFtZSkpLCBcbiAgICBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFXG4gIClcbiAgXG4gICMgUHJvY2VzcyBlYWNoIFRTUyBpbiB0aGUgZ3JvdXBcbiAgYWxsX3Jlc3VsdHMgPC0gbWFwX2RmcihzZXFfbGVuKGxlbmd0aChUU1NfZ3JvdXApKSwgZnVuY3Rpb24oaSkge1xuICAgICMgRmluZCBvdmVybGFwcGluZyBiaW5zXG4gICAgb3ZlcmxhcHBpbmdfYmlucyA8LSBmaW5kT3ZlcmxhcHMoVFNTX2dyb3VwW2ldLCBiaW5zKVxuICAgIGJpbnNfbmVhcl90c3MgPC0gYXNfdGliYmxlKGJpbnNbc3ViamVjdEhpdHMob3ZlcmxhcHBpbmdfYmlucyldKVxuICAgIFxuICAgICMgQ2FsY3VsYXRlIGRpc3RhbmNlIGJpblxuICAgIFRTU2NlbnRlciA8LSAoYXNfdGliYmxlKFRTU19ncm91cFtpXSkgJT4lXG4gICAgICAgICAgICAgICAgICAgIG11dGF0ZShjZW50ZXIgPSAoc3RhcnQgKyBlbmQpIC8gMikpJGNlbnRlclxuICAgIGNlbnRlckJpblN0YXJ0IDwtIGZsb29yKFRTU2NlbnRlciAvIDEwZTMpICogMTBlMyArIDFcbiAgICBiaW5zX25lYXJfdHNzIDwtIGJpbnNfbmVhcl90c3MgJT4lXG4gICAgICBtdXRhdGUoZGlzdGFuY2VCaW4gPSBhYnMoKHN0YXJ0IC0gY2VudGVyQmluU3RhcnQpKSAvIDEwZTMpXG4gICAgXG4gICAgIyBTdW1tYXJpemUgcmVzdWx0c1xuICAgIHJlc3VsdCA8LSBiaW5zX25lYXJfdHNzICU+JVxuICAgICAgZ3JvdXBfYnkoZGlzdGFuY2VCaW4pICU+JVxuICAgICAgc3VtbWFyaXNlKG1lYW5fcGVha19jb3VudHMgPSBtZWFuKHBlYWtfY291bnRzLCBuYS5ybSA9IFRSVUUpLCAuZ3JvdXBzID0gXFxkcm9wXFwpICU+JVxuICAgICAgbXV0YXRlKGdlbmUgPSBUU1NfZ3JvdXBbaV0kZW5zZW1ibClcbiAgICByZXR1cm4ocmVzdWx0KVxuICB9KVxuICBcbiAgIyBDYWxjdWxhdGUgbWVhbiBhbmQgU0QgZm9yIHRoZSBncm91cFxuICBtZWFuX2RhdGEgPC0gYWxsX3Jlc3VsdHMgJT4lXG4gICAgZ3JvdXBfYnkoZGlzdGFuY2VCaW4pICU+JVxuICAgIHN1bW1hcmlzZShtZWFuX3BlYWtfY291bnRzID0gbWVhbihtZWFuX3BlYWtfY291bnRzLCBuYS5ybSA9IFRSVUUpKVxuICBcbiAgc2RfZGF0YSA8LSBhbGxfcmVzdWx0cyAlPiVcbiAgICBncm91cF9ieShkaXN0YW5jZUJpbikgJT4lXG4gICAgc3VtbWFyaXNlKHNkX3BlYWtfY291bnRzID0gc2QobWVhbl9wZWFrX2NvdW50cywgbmEucm0gPSBUUlVFKSlcbiAgXG4gICMgSm9pbiBhbmQgYWRkIGdyb3VwIG5hbWVcbiAgc3VtbWFyeV9kYXRhIDwtIGxlZnRfam9pbihtZWFuX2RhdGEsIHNkX2RhdGEsIGJ5ID0gXFxkaXN0YW5jZUJpblxcKSAlPiVcbiAgICBtdXRhdGUoZ3JvdXAgPSBncm91cF9uYW1lKVxuICBcbiAgcmV0dXJuKHN1bW1hcnlfZGF0YSlcbn1cblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuXG5cblxuIyMgSW1wb3J0IHBlYWtcbnJlZkRpciA8LSBoZXJlKFxcLi4vLi5cXCwgXFxyZWZlcmVuY2VcXClcbiNwZWFrLkgzSzI3YWMgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFxHU00yNDM4NDc2X0VDLURHLTM0NTgtSDNLMjdBQ19BU1lOXzEubmFycm93UGVhay5iZWRcXCkpXG5wZWFrLkgzSzI3YWMgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFwzMzI1NV9IM0s0bWUzXzA0LTc0NV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcXCkpXG4jcGVhay5IM0syN2FjIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKVxuXG4jIyBJbXBvcnQgMTBrYiBiaW5cbnRlbXAgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMC5iaW4uMTBrYi5iZWRcXCkpXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShzdGFydCA9IHN0YXJ0KzEpXG5iaW5zLjEwa2IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRlbXApXG5cbiMjIENvdW50IG92ZXJsYXBcbmNvdW50cyA8LSBjb3VudE92ZXJsYXBzKGJpbnMuMTBrYiwgcGVhay5IM0syN2FjKVxubWNvbHMoYmlucy4xMGtiKSRwZWFrX2NvdW50cyA8LSBjb3VudHNcblxuIyMgR2V0dGluZyBUU1NcbmZsYW5rU2l6ZSA8LSAxZTZcbmdlbmUudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXFwrXFwsIFYyLCBWMyksXG4gICAgICAgICAgICAgICAgVFNTc3RhcnQgPSBUU1MgLSBmbGFua1NpemUsXG4gICAgICAgICAgICAgICAgVFNTZW5kID0gVFNTICsgZmxhbmtTaXplKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWMSwgVFNTc3RhcnQsIFRTU2VuZCwgVjYpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxlbnNlbWJsXFwpXG5cbmdlbmUuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5nZW5lLmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG4jVFNTMW1iLmdyb3VwMS5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZS50YiAlPiUgZHBseXI6OmZpbHRlcihlbnNlbWJsICVpbiUgZ2VuZS5ncm91cDEpLCBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFKVxuI1RTUzFtYi5ncm91cDIuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGdlbmUudGIgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGdlbmUuZ3JvdXAyKSwga2VlcC5leHRyYS5jb2x1bW5zID0gVFJVRSlcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuIyBMaXN0IG9mIGdyb3VwcyB0byBwcm9jZXNzXG5ncm91cHMgPC0gYyhcXGdlbmUuZ3JvdXAxXFwsIFxcZ2VuZS5ncm91cDJcXClcblxuIyBQcm9jZXNzIGVhY2ggZ3JvdXAgYW5kIGNvbWJpbmUgcmVzdWx0c1xuc3VtbWFyeV9kYXRhIDwtIG1hcF9kZnIoZ3JvdXBzLCB+IHByb2Nlc3NfZ3JvdXAoLngsIGdlbmUudGIsIGJpbnMuMTBrYikpXG5cbiMgQWRkIHRoZSBhZGRpdGlvbmFsIHJvd3MgZm9yIGRpc3RhbmNlQmluID0gMFxuc3VtbWFyeV9kYXRhIDwtIHN1bW1hcnlfZGF0YSAlPiVcbiAgbXV0YXRlKGRpc3RhbmNlQmluID0gZGlzdGFuY2VCaW4gKyAxKSAlPiVcbiAgYWRkX3JvdyhkaXN0YW5jZUJpbiA9IDAsIG1lYW5fcGVha19jb3VudHMgPSAwLCBzZF9wZWFrX2NvdW50cyA9IDAsIGdyb3VwID0gXFxnZW5lLmdyb3VwMVxcKSAlPiVcbiAgYWRkX3JvdyhkaXN0YW5jZUJpbiA9IDAsIG1lYW5fcGVha19jb3VudHMgPSAwLCBzZF9wZWFrX2NvdW50cyA9IDAsIGdyb3VwID0gXFxnZW5lLmdyb3VwMlxcKVxuXG4jIFBsb3QgdGhlIHJlc3VsdHNcbnAgPC0gZ2dwbG90KHN1bW1hcnlfZGF0YSwgYWVzKHggPSBkaXN0YW5jZUJpbiwgeSA9IG1lYW5fcGVha19jb3VudHMsIGNvbG9yID0gZ3JvdXApKSArIFxuICBnZW9tX2xpbmUoc2l6ZSA9IDAuNSkgK1xuICBsYWJzKFxuICAgIHggPSBcXERpc3RhbmNlIGJpbiAoMTBrYilcXCxcbiAgICB5ID0gXFxIM0s0bWUzIHBlYWsgY291bnRcXFxuICApICtcbiAgdGhlbWVfY2xhc3NpYygpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnBvc2l0aW9uID0gYygwLjgsIDAuOCkgICMgTW92ZXMgbGVnZW5kIGluc2lkZSB0aGUgcGxvdCAoeCwgeSByZWxhdGl2ZSBjb29yZGluYXRlcylcbiAgKSArXG4gIGd1aWRlcyhcbiAgICBmaWxsID0gZ3VpZGVfbGVnZW5kKFxuICAgICAga2V5d2lkdGggPSAwLjIsICAjIEFkanVzdCB0aGUgd2lkdGggb2YgdGhlIGxlZ2VuZCBrZXlzXG4gICAgICBrZXloZWlnaHQgPSAwLjIgICMgQWRqdXN0IHRoZSBoZWlnaHQgb2YgdGhlIGxlZ2VuZCBrZXlzXG4gICAgKSkrXG4gIHNjYWxlX2NvbG9yX21hbnVhbCh2YWx1ZXMgPSByZXYoYyhcXCM3Nzc3NzdcXCwgXFwjRjI4RTJDXFwpKSlcblxuIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjI1xuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxiaW5QZWFrRGVuc2l0eV9SQUQyMV9iaW5hcnlHcm91cFxcKVxud2lkdGggPC0gMzIqbW1Ub0luY2hcbmhlaWdodCA8LSAzNSptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
process_group <- function(group_name, gene_data, bins) {
  # Filter for the specific group
  TSS_group <- makeGRangesFromDataFrame(
    gene_data %>% filter(ensembl %in% get(group_name)), 
    keep.extra.columns = TRUE
  )
  
  # Process each TSS in the group
  all_results <- map_dfr(seq_len(length(TSS_group)), function(i) {
    # Find overlapping bins
    overlapping_bins <- findOverlaps(TSS_group[i], bins)
    bins_near_tss <- as_tibble(bins[subjectHits(overlapping_bins)])
    
    # Calculate distance bin
    TSScenter <- (as_tibble(TSS_group[i]) %>%
                    mutate(center = (start + end) / 2))$center
    centerBinStart <- floor(TSScenter / 10e3) * 10e3 + 1
    bins_near_tss <- bins_near_tss %>%
      mutate(distanceBin = abs((start - centerBinStart)) / 10e3)
    
    # Summarize results
    result <- bins_near_tss %>%
      group_by(distanceBin) %>%
      summarise(mean_peak_counts = mean(peak_counts, na.rm = TRUE), .groups = \drop\) %>%
      mutate(gene = TSS_group[i]$ensembl)
    return(result)
  })
  
  # Calculate mean and SD for the group
  mean_data <- all_results %>%
    group_by(distanceBin) %>%
    summarise(mean_peak_counts = mean(mean_peak_counts, na.rm = TRUE))
  
  sd_data <- all_results %>%
    group_by(distanceBin) %>%
    summarise(sd_peak_counts = sd(mean_peak_counts, na.rm = TRUE))
  
  # Join and add group name
  summary_data <- left_join(mean_data, sd_data, by = \distanceBin\) %>%
    mutate(group = group_name)
  
  return(summary_data)
}

##########################################################



## Import peak
refDir <- here(\../..\, \reference\)
#peak.H3K27ac <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
peak.H3K27ac <- importPeak(here(refDir, \33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\))
#peak.H3K27ac <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))

## Import 10kb bin
temp <- fread(here(refDir, \mm10.bin.10kb.bed\))
colnames(temp) <- c(\chr\, \start\, \end\)
temp <- temp %>% dplyr::mutate(start = start+1)
bins.10kb <- makeGRangesFromDataFrame(temp)

## Count overlap
counts <- countOverlaps(bins.10kb, peak.H3K27ac)
mcols(bins.10kb)$peak_counts <- counts

## Getting TSS
flankSize <- 1e6
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6)
colnames(gene.tb) <- c(\chr\, \start\, \end\, \ensembl\)

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

#TSS1mb.group1.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group1), keep.extra.columns = TRUE)
#TSS1mb.group2.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group2), keep.extra.columns = TRUE)

##########################################################
# List of groups to process
groups <- c(\gene.group1\, \gene.group2\)

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \gene.group1\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \gene.group2\)

# Plot the results
p <- ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 0.5) +
  labs(
    x = \Distance bin (10kb)\,
    y = \H3K4me3 peak count\
  ) +
  theme_classic() +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS),
    legend.position = c(0.8, 0.8)  # Moves legend inside the plot (x, y relative coordinates)
  ) +
  guides(
    fill = guide_legend(
      keywidth = 0.2,  # Adjust the width of the legend keys
      keyheight = 0.2  # Adjust the height of the legend keys
    ))+
  scale_color_manual(values = rev(c(\#777777\, \#F28E2C\)))

##########################################################

fileName <- paste0(\binPeakDensity_RAD21_binaryGroup\)
width <- 32*mmToInch
height <- 35*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### TSS

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n\n####### DOing this for P-S groups\nresultDir <- here(\"../../result\")\ntemp2 <- readRDS(here(resultDir, \"gene_loop_link.rds\"))\n\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\n# List of groups to process\ngroups <- c(\"psOver0\", \"psOver1\", \"psOver2\", \"psOver3\", \"psOver4\")\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"psOver0\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"psOver1\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"psOver2\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"psOver3\")%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"psOver4\")\n\n# Plot the results\np <- ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 0.5) +\n  labs(\n    x = \"Distance bin (10kb)\",\n    y = \"H3K4me3 peak count\"\n  ) +\n  theme_classic() +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS),\n    legend.position = c(0.8, 0.8)  # Moves legend inside the plot (x, y relative coordinates)\n  ) +\n  guides(\n    fill = guide_legend(\n      keywidth = 0.2,  # Adjust the width of the legend keys\n      keyheight = 0.2  # Adjust the height of the legend keys\n    ))+\n  scale_color_manual(values = c(\"#777777\", \"#8B7E65\", \"#A28452\", \"#C2884D\", \"#F28E2C\"))\n\nfileName <- paste0(\"binPeakDensity_RAD21_psGroup11\")\nwidth <- 32*mmToInch\nheight <- 35*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n### PE\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\n# List of groups to process\ngroups <- c(\"peOver0\", \"peOver1\", \"peOver2\", \"peOver3\", \"peOver4\")\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"peOver0\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"peOver1\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"peOver2\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"peOver3\")%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"peOver4\")\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) + xlim(0, 10)+\n  labs(\n    title = \"Mean Peak Counts\",\n    x = \"Distance Bin (10 kb)\",\n    y = \"Mean Peak Counts\"\n  ) +\n  theme_minimal() +\n  theme(\n    plot.title = element_text(hjust = 0.5, size = 14, face = \"bold\"),\n    axis.text = element_text(size = 12),\n    axis.title = element_text(size = 13)\n  )\n\n###############\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\n# List of groups to process\ngroups <- c(\"ppOver0\", \"ppOver1\", \"ppOver2\", \"ppOver3\", \"ppOver4\")\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"ppOver0\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"ppOver1\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"ppOver2\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"ppOver3\")%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"ppOver4\")\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) +\n  labs(\n    title = \"Mean Peak Counts\",\n    x = \"Distance Bin (10 kb)\",\n    y = \"Mean Peak Counts\"\n  ) +\n  theme_minimal() +\n  theme(\n    plot.title = element_text(hjust = 0.5, size = 14, face = \"bold\"),\n    axis.text = element_text(size = 12),\n    axis.title = element_text(size = 13)\n  )\n```"} -->\n\n```r\n\n####### DOing this for P-S groups\nresultDir <- here(\\../../result\\)\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\n# List of groups to process\ngroups <- c(\\psOver0\\, \\psOver1\\, \\psOver2\\, \\psOver3\\, \\psOver4\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver0\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver2\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver3\\)%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver4\\)\n\n# Plot the results\np <- ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 0.5) +\n  labs(\n    x = \\Distance bin (10kb)\\,\n    y = \\H3K4me3 peak count\\\n  ) +\n  theme_classic() +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS),\n    legend.position = c(0.8, 0.8)  # Moves legend inside the plot (x, y relative coordinates)\n  ) +\n  guides(\n    fill = guide_legend(\n      keywidth = 0.2,  # Adjust the width of the legend keys\n      keyheight = 0.2  # Adjust the height of the legend keys\n    ))+\n  scale_color_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))\n\nfileName <- paste0(\\binPeakDensity_RAD21_psGroup11\\)\nwidth <- 32*mmToInch\nheight <- 35*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n### PE\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\n# List of groups to process\ngroups <- c(\\peOver0\\, \\peOver1\\, \\peOver2\\, \\peOver3\\, \\peOver4\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver0\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver2\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver3\\)%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver4\\)\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) + xlim(0, 10)+\n  labs(\n    title = \\Mean Peak Counts\\,\n    x = \\Distance Bin (10 kb)\\,\n    y = \\Mean Peak Counts\\\n  ) +\n  theme_minimal() +\n  theme(\n    plot.title = element_text(hjust = 0.5, size = 14, face = \\bold\\),\n    axis.text = element_text(size = 12),\n    axis.title = element_text(size = 13)\n  )\n\n###############\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\n# List of groups to process\ngroups <- c(\\ppOver0\\, \\ppOver1\\, \\ppOver2\\, \\ppOver3\\, \\ppOver4\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver0\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver2\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver3\\)%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver4\\)\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) +\n  labs(\n    title = \\Mean Peak Counts\\,\n    x = \\Distance Bin (10 kb)\\,\n    y = \\Mean Peak Counts\\\n  ) +\n  theme_minimal() +\n  theme(\n    plot.title = element_text(hjust = 0.5, size = 14, face = \\bold\\),\n    axis.text = element_text(size = 12),\n    axis.title = element_text(size = 13)\n  )\n```\n\n<!-- rnb-source-end -->\n"} -->

####### DOing this for P-S groups
resultDir <- here(\../../result\)
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene

# List of groups to process
groups <- c(\psOver0\, \psOver1\, \psOver2\, \psOver3\, \psOver4\)

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \psOver0\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \psOver1\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \psOver2\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \psOver3\)%>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \psOver4\)

# Plot the results
p <- ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 0.5) +
  labs(
    x = \Distance bin (10kb)\,
    y = \H3K4me3 peak count\
  ) +
  theme_classic() +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS),
    legend.position = c(0.8, 0.8)  # Moves legend inside the plot (x, y relative coordinates)
  ) +
  guides(
    fill = guide_legend(
      keywidth = 0.2,  # Adjust the width of the legend keys
      keyheight = 0.2  # Adjust the height of the legend keys
    ))+
  scale_color_manual(values = c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\))

fileName <- paste0(\binPeakDensity_RAD21_psGroup11\)
width <- 32*mmToInch
height <- 35*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

### PE
peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene

# List of groups to process
groups <- c(\peOver0\, \peOver1\, \peOver2\, \peOver3\, \peOver4\)

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \peOver0\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \peOver1\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \peOver2\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \peOver3\)%>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \peOver4\)

# Plot the results
ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 1) + xlim(0, 10)+
  labs(
    title = \Mean Peak Counts\,
    x = \Distance Bin (10 kb)\,
    y = \Mean Peak Counts\
  ) +
  theme_minimal() +
  theme(
    plot.title = element_text(hjust = 0.5, size = 14, face = \bold\),
    axis.text = element_text(size = 12),
    axis.title = element_text(size = 13)
  )

###############
ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene

# List of groups to process
groups <- c(\ppOver0\, \ppOver1\, \ppOver2\, \ppOver3\, \ppOver4\)

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \ppOver0\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \ppOver1\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \ppOver2\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \ppOver3\)%>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \ppOver4\)

# Plot the results
ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 1) +
  labs(
    title = \Mean Peak Counts\,
    x = \Distance Bin (10 kb)\,
    y = \Mean Peak Counts\
  ) +
  theme_minimal() +
  theme(
    plot.title = element_text(hjust = 0.5, size = 14, face = \bold\),
    axis.text = element_text(size = 12),
    axis.title = element_text(size = 13)
  )



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n\n####### DOing this for P-S groups\nresultDir <- here(\\../../result\\)\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\n# List of groups to process\ngroups <- c(\\psOver0\\, \\psOver1\\, \\psOver2\\, \\psOver3\\, \\psOver4\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver0\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver2\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver3\\)%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver4\\)\n\n# Plot the results\np <- ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 0.5) +\n  labs(\n    x = \\Distance bin (10kb)\\,\n    y = \\H3K4me3 peak count\\\n  ) +\n  theme_classic() +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS),\n    legend.position = c(0.8, 0.8)  # Moves legend inside the plot (x, y relative coordinates)\n  ) +\n  guides(\n    fill = guide_legend(\n      keywidth = 0.2,  # Adjust the width of the legend keys\n      keyheight = 0.2  # Adjust the height of the legend keys\n    ))+\n  scale_color_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))\n\nfileName <- paste0(\\binPeakDensity_RAD21_psGroup11\\)\nwidth <- 32*mmToInch\nheight <- 35*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n### PE\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\n# List of groups to process\ngroups <- c(\\peOver0\\, \\peOver1\\, \\peOver2\\, \\peOver3\\, \\peOver4\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver0\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver2\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver3\\)%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver4\\)\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) + xlim(0, 10)+\n  labs(\n    title = \\Mean Peak Counts\\,\n    x = \\Distance Bin (10 kb)\\,\n    y = \\Mean Peak Counts\\\n  ) +\n  theme_minimal() +\n  theme(\n    plot.title = element_text(hjust = 0.5, size = 14, face = \\bold\\),\n    axis.text = element_text(size = 12),\n    axis.title = element_text(size = 13)\n  )\n\n###############\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\n# List of groups to process\ngroups <- c(\\ppOver0\\, \\ppOver1\\, \\ppOver2\\, \\ppOver3\\, \\ppOver4\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver0\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver2\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver3\\)%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver4\\)\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) +\n  labs(\n    title = \\Mean Peak Counts\\,\n    x = \\Distance Bin (10 kb)\\,\n    y = \\Mean Peak Counts\\\n  ) +\n  theme_minimal() +\n  theme(\n    plot.title = element_text(hjust = 0.5, size = 14, face = \\bold\\),\n    axis.text = element_text(size = 12),\n    axis.title = element_text(size = 13)\n  )\n```\n```"} -->\n\n```r\n```r\n\n####### DOing this for P-S groups\nresultDir <- here(\\../../result\\)\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\n# List of groups to process\ngroups <- c(\\psOver0\\, \\psOver1\\, \\psOver2\\, \\psOver3\\, \\psOver4\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver0\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver2\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver3\\)%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver4\\)\n\n# Plot the results\np <- ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 0.5) +\n  labs(\n    x = \\Distance bin (10kb)\\,\n    y = \\H3K4me3 peak count\\\n  ) +\n  theme_classic() +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS),\n    legend.position = c(0.8, 0.8)  # Moves legend inside the plot (x, y relative coordinates)\n  ) +\n  guides(\n    fill = guide_legend(\n      keywidth = 0.2,  # Adjust the width of the legend keys\n      keyheight = 0.2  # Adjust the height of the legend keys\n    ))+\n  scale_color_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))\n\nfileName <- paste0(\\binPeakDensity_RAD21_psGroup11\\)\nwidth <- 32*mmToInch\nheight <- 35*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n### PE\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\n# List of groups to process\ngroups <- c(\\peOver0\\, \\peOver1\\, \\peOver2\\, \\peOver3\\, \\peOver4\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver0\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver2\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver3\\)%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver4\\)\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) + xlim(0, 10)+\n  labs(\n    title = \\Mean Peak Counts\\,\n    x = \\Distance Bin (10 kb)\\,\n    y = \\Mean Peak Counts\\\n  ) +\n  theme_minimal() +\n  theme(\n    plot.title = element_text(hjust = 0.5, size = 14, face = \\bold\\),\n    axis.text = element_text(size = 12),\n    axis.title = element_text(size = 13)\n  )\n\n###############\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\n# List of groups to process\ngroups <- c(\\ppOver0\\, \\ppOver1\\, \\ppOver2\\, \\ppOver3\\, \\ppOver4\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver0\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver2\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver3\\)%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver4\\)\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) +\n  labs(\n    title = \\Mean Peak Counts\\,\n    x = \\Distance Bin (10 kb)\\,\n    y = \\Mean Peak Counts\\\n  ) +\n  theme_minimal() +\n  theme(\n    plot.title = element_text(hjust = 0.5, size = 14, face = \\bold\\),\n    axis.text = element_text(size = 12),\n    axis.title = element_text(size = 13)\n  )\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n\n####### DOing this for P-S groups\nresultDir <- here(\\../../result\\)\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\n# List of groups to process\ngroups <- c(\\psOver0\\, \\psOver1\\, \\psOver2\\, \\psOver3\\, \\psOver4\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver0\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver2\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver3\\)%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\psOver4\\)\n\n# Plot the results\np <- ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 0.5) +\n  labs(\n    x = \\Distance bin (10kb)\\,\n    y = \\H3K4me3 peak count\\\n  ) +\n  theme_classic() +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS),\n    legend.position = c(0.8, 0.8)  # Moves legend inside the plot (x, y relative coordinates)\n  ) +\n  guides(\n    fill = guide_legend(\n      keywidth = 0.2,  # Adjust the width of the legend keys\n      keyheight = 0.2  # Adjust the height of the legend keys\n    ))+\n  scale_color_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\))\n\nfileName <- paste0(\\binPeakDensity_RAD21_psGroup11\\)\nwidth <- 32*mmToInch\nheight <- 35*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n### PE\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\n# List of groups to process\ngroups <- c(\\peOver0\\, \\peOver1\\, \\peOver2\\, \\peOver3\\, \\peOver4\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver0\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver2\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver3\\)%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\peOver4\\)\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) + xlim(0, 10)+\n  labs(\n    title = \\Mean Peak Counts\\,\n    x = \\Distance Bin (10 kb)\\,\n    y = \\Mean Peak Counts\\\n  ) +\n  theme_minimal() +\n  theme(\n    plot.title = element_text(hjust = 0.5, size = 14, face = \\bold\\),\n    axis.text = element_text(size = 12),\n    axis.title = element_text(size = 13)\n  )\n\n###############\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\n# List of groups to process\ngroups <- c(\\ppOver0\\, \\ppOver1\\, \\ppOver2\\, \\ppOver3\\, \\ppOver4\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver0\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver1\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver2\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver3\\)%>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\ppOver4\\)\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) +\n  labs(\n    title = \\Mean Peak Counts\\,\n    x = \\Distance Bin (10 kb)\\,\n    y = \\Mean Peak Counts\\\n  ) +\n  theme_minimal() +\n  theme(\n    plot.title = element_text(hjust = 0.5, size = 14, face = \\bold\\),\n    axis.text = element_text(size = 12),\n    axis.title = element_text(size = 13)\n  )\n```\n```"} -->

```r
```r

####### DOing this for P-S groups
resultDir <- here(\../../result\)
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene

# List of groups to process
groups <- c(\psOver0\, \psOver1\, \psOver2\, \psOver3\, \psOver4\)

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \psOver0\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \psOver1\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \psOver2\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \psOver3\)%>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \psOver4\)

# Plot the results
p <- ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 0.5) +
  labs(
    x = \Distance bin (10kb)\,
    y = \H3K4me3 peak count\
  ) +
  theme_classic() +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS),
    legend.position = c(0.8, 0.8)  # Moves legend inside the plot (x, y relative coordinates)
  ) +
  guides(
    fill = guide_legend(
      keywidth = 0.2,  # Adjust the width of the legend keys
      keyheight = 0.2  # Adjust the height of the legend keys
    ))+
  scale_color_manual(values = c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\))

fileName <- paste0(\binPeakDensity_RAD21_psGroup11\)
width <- 32*mmToInch
height <- 35*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

### PE
peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene

# List of groups to process
groups <- c(\peOver0\, \peOver1\, \peOver2\, \peOver3\, \peOver4\)

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \peOver0\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \peOver1\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \peOver2\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \peOver3\)%>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \peOver4\)

# Plot the results
ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 1) + xlim(0, 10)+
  labs(
    title = \Mean Peak Counts\,
    x = \Distance Bin (10 kb)\,
    y = \Mean Peak Counts\
  ) +
  theme_minimal() +
  theme(
    plot.title = element_text(hjust = 0.5, size = 14, face = \bold\),
    axis.text = element_text(size = 12),
    axis.title = element_text(size = 13)
  )

###############
ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene

# List of groups to process
groups <- c(\ppOver0\, \ppOver1\, \ppOver2\, \ppOver3\, \ppOver4\)

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \ppOver0\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \ppOver1\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \ppOver2\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \ppOver3\)%>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \ppOver4\)

# Plot the results
ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 1) +
  labs(
    title = \Mean Peak Counts\,
    x = \Distance Bin (10 kb)\,
    y = \Mean Peak Counts\
  ) +
  theme_minimal() +
  theme(
    plot.title = element_text(hjust = 0.5, size = 14, face = \bold\),
    axis.text = element_text(size = 12),
    axis.title = element_text(size = 13)
  )
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


###[2.30] H3K27ac peak number per 10kb

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\npeak.Whyte.SE <- importPeak(here(refDir, \"superEnhancer_Whyte_ESC_mm10.bed\"))\npeak.Dylan.SE <- importPeak(here(refDir, \"superEnhancer_Dylan_ESC.bed\"))\n\n\n\nflankSize <- 0.5e6\ngene.tb <- fread(here(refDir, \"mm10_GRCm38.p6_gene_sorted.bed\")) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \"+\", V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6, V5)\ncolnames(gene.tb) <- c(\"chr\", \"start\", \"end\", \"ensembl\", \"gene\")\n\ngene.group1 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\"))$gene\ngene.group2 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\"))$gene\n\nTSS1mb.group1.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group1), keep.extra.columns = TRUE)\nTSS1mb.group2.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group2), keep.extra.columns = TRUE)\n\n\nlength(unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Whyte.SE))))/length(gene.group1)*100\nlength(unique(queryHits(findOverlaps(TSS1mb.group2.gr, peak.Whyte.SE))))/length(gene.group2)*100\n\nlength(unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE))))/length(gene.group1)*100\nlength(unique(queryHits(findOverlaps(TSS1mb.group2.gr, peak.Dylan.SE))))/length(gene.group2)*100\n\n#View(as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Whyte.SE)))]))\n#View(as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE)))]))\n\ngene.group1.SE <- (as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE)))]))$ensembl\ngene.group1.noSE <- gene.group1[!(gene.group1 %in% gene.group1.SE)]\n\noverlaps <- findOverlaps(TSS1mb.group2.gr, peak.Dylan.SE)\nunique_hits <- unique(queryHits(overlaps))\ngene.group2.SE <- as_tibble(TSS1mb.group2.gr[unique_hits])$ensembl\ngene.group2.noSE <- as_tibble(TSS1mb.group2.gr[-unique_hits])$ensembl\n\n\n##########################################################\ngene.tb <- fread(here(refDir, \"mm10_GRCm38.p6_gene_sorted.bed\")) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \"+\", V2, V3),\n                TSSstart = TSS - 1e6,\n                TSSend = TSS + 1e6) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6, V5)\ncolnames(gene.tb) <- c(\"chr\", \"start\", \"end\", \"ensembl\", \"gene\")\n\n##########################################################\n# List of groups to process\ngroups <- c(\"gene.group1.SE\", \"gene.group1.noSE\")\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"gene.group1.SE\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"gene.group1.noSE\")\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) +\n  labs(\n    title = paste0(\"Mean Peak Counts, +-\", flankSize, \"bp, Whyte SE\"),\n    x = \"Distance Bin (10 kb)\",\n    y = \"Mean Peak Counts\"\n  ) +\n  theme_minimal() +\n  theme(\n    plot.title = element_text(hjust = 0.5, size = 14, face = \"bold\"),\n    axis.text = element_text(size = 12),\n    axis.title = element_text(size = 13)\n  )\n\n##########################################################\n# List of groups to process\ngroups <- c(\"gene.group1.SE\", \"gene.group1.noSE\", \"gene.group2.SE\", \"gene.group2.noSE\")\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n    add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"gene.group1.SE\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"gene.group1.noSE\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"gene.group2.SE\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"gene.group2.noSE\")\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) +\n  labs(\n    title = paste0(\"Mean Peak Counts, +-\", flankSize, \"bp, Whyte SE\"),\n    x = \"Distance Bin (10 kb)\",\n    y = \"Mean Peak Counts\"\n  ) +\n  theme_minimal() +\n  theme(\n    plot.title = element_text(hjust = 0.5, size = 14, face = \"bold\"),\n    axis.text = element_text(size = 12),\n    axis.title = element_text(size = 13)\n  )\n##########################################################\n# List of groups to process\ngroups <- c(\"gene.group2.SE\", \"gene.group2.noSE\")\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"gene.group2.SE\") %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \"gene.group2.noSE\")\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) +\n  labs(\n    title = paste0(\"Mean Peak Counts, +-\", flankSize, \"bp, Whyte SE\"),\n    x = \"Distance Bin (10 kb)\",\n    y = \"Mean Peak Counts\"\n  ) +\n  theme_minimal() +\n  theme(\n    plot.title = element_text(hjust = 0.5, size = 14, face = \"bold\"),\n    axis.text = element_text(size = 12),\n    axis.title = element_text(size = 13)\n  )\n\n## Checking P-S in the subset of genes\n\nresultDir <- here(\"../../result\")\ntemp2 <- readRDS(here(resultDir, \"gene_loop_link.rds\"))\n\ntemp3 <- temp2 %>% dplyr::filter(gene %in% c(gene.group1)) %>%\n  dplyr::mutate(group = case_when(gene %in% gene.group1.SE ~ \"SE\",\n                                  TRUE ~ \"noSE\"))\n\n\nggplot(temp3, aes(x = group, y = num_ps)) + geom_violin(aes(fill = group)) + geom_boxplot(width = 0.1) + theme_classic()\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$num_pp\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$num_pp\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\ngetPvalWilcox(temp3, \"noSE\", \"SE\")\n```"} -->\n\n```r\npeak.Whyte.SE <- importPeak(here(refDir, \\superEnhancer_Whyte_ESC_mm10.bed\\))\npeak.Dylan.SE <- importPeak(here(refDir, \\superEnhancer_Dylan_ESC.bed\\))\n\n\n\nflankSize <- 0.5e6\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6, V5)\ncolnames(gene.tb) <- c(\\chr\\, \\start\\, \\end\\, \\ensembl\\, \\gene\\)\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nTSS1mb.group1.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group1), keep.extra.columns = TRUE)\nTSS1mb.group2.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group2), keep.extra.columns = TRUE)\n\n\nlength(unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Whyte.SE))))/length(gene.group1)*100\nlength(unique(queryHits(findOverlaps(TSS1mb.group2.gr, peak.Whyte.SE))))/length(gene.group2)*100\n\nlength(unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE))))/length(gene.group1)*100\nlength(unique(queryHits(findOverlaps(TSS1mb.group2.gr, peak.Dylan.SE))))/length(gene.group2)*100\n\n#View(as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Whyte.SE)))]))\n#View(as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE)))]))\n\ngene.group1.SE <- (as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE)))]))$ensembl\ngene.group1.noSE <- gene.group1[!(gene.group1 %in% gene.group1.SE)]\n\noverlaps <- findOverlaps(TSS1mb.group2.gr, peak.Dylan.SE)\nunique_hits <- unique(queryHits(overlaps))\ngene.group2.SE <- as_tibble(TSS1mb.group2.gr[unique_hits])$ensembl\ngene.group2.noSE <- as_tibble(TSS1mb.group2.gr[-unique_hits])$ensembl\n\n\n##########################################################\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - 1e6,\n                TSSend = TSS + 1e6) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6, V5)\ncolnames(gene.tb) <- c(\\chr\\, \\start\\, \\end\\, \\ensembl\\, \\gene\\)\n\n##########################################################\n# List of groups to process\ngroups <- c(\\gene.group1.SE\\, \\gene.group1.noSE\\)\n\n# Process each group and combine results\nsummary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))\n\n# Add the additional rows for distanceBin = 0\nsummary_data <- summary_data %>%\n  mutate(distanceBin = distanceBin + 1) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\gene.group1.SE\\) %>%\n  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \\gene.group1.noSE\\)\n\n# Plot the results\nggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + \n  geom_line(size = 1) +\n  labs(\n    title = paste0(\\Mean Peak Counts\n"} -->
peak.Whyte.SE <- importPeak(here(refDir, \superEnhancer_Whyte_ESC_mm10.bed\))
peak.Dylan.SE <- importPeak(here(refDir, \superEnhancer_Dylan_ESC.bed\))



flankSize <- 0.5e6
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c(\chr\, \start\, \end\, \ensembl\, \gene\)

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

TSS1mb.group1.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group1), keep.extra.columns = TRUE)
TSS1mb.group2.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group2), keep.extra.columns = TRUE)


length(unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Whyte.SE))))/length(gene.group1)*100
length(unique(queryHits(findOverlaps(TSS1mb.group2.gr, peak.Whyte.SE))))/length(gene.group2)*100

length(unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE))))/length(gene.group1)*100
length(unique(queryHits(findOverlaps(TSS1mb.group2.gr, peak.Dylan.SE))))/length(gene.group2)*100

#View(as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Whyte.SE)))]))
#View(as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE)))]))

gene.group1.SE <- (as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE)))]))$ensembl
gene.group1.noSE <- gene.group1[!(gene.group1 %in% gene.group1.SE)]

overlaps <- findOverlaps(TSS1mb.group2.gr, peak.Dylan.SE)
unique_hits <- unique(queryHits(overlaps))
gene.group2.SE <- as_tibble(TSS1mb.group2.gr[unique_hits])$ensembl
gene.group2.noSE <- as_tibble(TSS1mb.group2.gr[-unique_hits])$ensembl


##########################################################
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - 1e6,
                TSSend = TSS + 1e6) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c(\chr\, \start\, \end\, \ensembl\, \gene\)

##########################################################
# List of groups to process
groups <- c(\gene.group1.SE\, \gene.group1.noSE\)

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \gene.group1.SE\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \gene.group1.noSE\)

# Plot the results
ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 1) +
  labs(
    title = paste0(\Mean Peak Counts
```r
peak.Whyte.SE <- importPeak(here(refDir, \superEnhancer_Whyte_ESC_mm10.bed\))
peak.Dylan.SE <- importPeak(here(refDir, \superEnhancer_Dylan_ESC.bed\))



flankSize <- 0.5e6
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c(\chr\, \start\, \end\, \ensembl\, \gene\)

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

TSS1mb.group1.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group1), keep.extra.columns = TRUE)
TSS1mb.group2.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group2), keep.extra.columns = TRUE)


length(unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Whyte.SE))))/length(gene.group1)*100
length(unique(queryHits(findOverlaps(TSS1mb.group2.gr, peak.Whyte.SE))))/length(gene.group2)*100

length(unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE))))/length(gene.group1)*100
length(unique(queryHits(findOverlaps(TSS1mb.group2.gr, peak.Dylan.SE))))/length(gene.group2)*100

#View(as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Whyte.SE)))]))
#View(as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE)))]))

gene.group1.SE <- (as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE)))]))$ensembl
gene.group1.noSE <- gene.group1[!(gene.group1 %in% gene.group1.SE)]

overlaps <- findOverlaps(TSS1mb.group2.gr, peak.Dylan.SE)
unique_hits <- unique(queryHits(overlaps))
gene.group2.SE <- as_tibble(TSS1mb.group2.gr[unique_hits])$ensembl
gene.group2.noSE <- as_tibble(TSS1mb.group2.gr[-unique_hits])$ensembl


##########################################################
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - 1e6,
                TSSend = TSS + 1e6) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c(\chr\, \start\, \end\, \ensembl\, \gene\)

##########################################################
# List of groups to process
groups <- c(\gene.group1.SE\, \gene.group1.noSE\)

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \gene.group1.SE\) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = \gene.group1.noSE\)

# Plot the results
ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 1) +
  labs(
    title = paste0(\Mean Peak Counts

<!-- rnb-source-begin {"data":"```r\nname <- \"chromo_cons_annoHierarchy\"\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = diffCutoff)%>% \n  dplyr::mutate(distance = start2 - start1)\n\n\ngeneAnnoData <- geneAnnoData %>% unnest(gene)\n\n\ngene.tb <- fread(here(refDir, \"mm10_GRCm38.p6_gene_sorted.bed\")) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \"+\", V2, V3)) %>%\n  dplyr::select(V6, TSS)\ncolnames(gene.tb) <- c(\"ensembl\", \"TSS\")\n\n\ngeneAnnoData  <- geneAnnoData %>% dplyr::left_join(gene.tb, by = c(\"gene\" = \"ensembl\"))\n\ndata <- geneAnnoData %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 29, 31, 35)) %>%\n  rowwise() %>%\n  dplyr::mutate(distToAnchor1 = (start1 + end1)/2 - TSS,\n                distToAnchor2 = (start2 + end2)/2 - TSS,\n                distToAnchor = if_else(abs(distToAnchor1) > abs(distToAnchor2), distToAnchor1, distToAnchor2),\n                direction = if_else(distToAnchor > 0, \"right\", \"left\"))\n\ndata.directionality <- data %>% group_by(gene) %>%\n  summarise(count = n(),\n            n_right = sum(direction == \"right\"),\n            n_left = sum(direction == \"left\")) %>%\n  dplyr::filter(count > 1) %>%\n  dplyr::mutate(n = n_right + n_left,\n                directionality = abs((n_right - n_left)/n))\n\n\n#ggplot(data.directionality, aes(x = directionality)) + geom_histogram() + theme_classic()\n\n\ngene.group1 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\"))$gene\ngene.group2 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\"))$gene\n\ntemp <- data.directionality %>% dplyr::filter(gene %in% c(gene.group1, gene.group2)) %>%\n  dplyr::mutate(group = if_else(gene %in% gene.group1, \"group1\", \"group2\"))\n\n\nggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + \n  geom_hline(yintercept = 0) + theme_classic() + ggtitle(\"P-S\") +\n  stat_summary(aes(group = group), fun = mean, geom = \"point\", shape = 21, size = 2, fill = \"red\", color = \"black\")\n\n\n#########################PS\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$directionality\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$directionality\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n\nresultDir <- here(\"../../result\")\ntemp2 <- readRDS(here(resultDir, \"gene_loop_link.rds\"))\n#####################\n\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\ntemp <- data.directionality %>% dplyr::filter(gene %in% c(psOver0, psOver1, psOver2, psOver3, psOver4)) %>%\n  dplyr::mutate(group = case_when(gene %in% psOver0 ~ \"psOver0\",\n                                  gene %in% psOver1 ~ \"psOver1\",\n                                  gene %in% psOver2 ~ \"psOver2\",\n                                  gene %in% psOver3 ~ \"psOver3\",\n                                  gene %in% psOver4 ~ \"psOver4\"))\n\np34 <- round(getPvalWilcox(temp, \"psOver3\", \"psOver4\"), 5)\np23 <- round(getPvalWilcox(temp, \"psOver2\", \"psOver3\"), 5)\np12 <- round(getPvalWilcox(temp, \"psOver1\", \"psOver2\"), 5)\np01 <- round(getPvalWilcox(temp, \"psOver0\", \"psOver1\"), 5)\np04 <- round(getPvalWilcox(temp, \"psOver0\", \"psOver4\"), 5)\n\n\n\nggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + \n  geom_hline(yintercept = 0) + theme_classic() + ggtitle(\"P-N\") +\n  stat_summary(aes(group = group), fun = mean, geom = \"point\", shape = 21, size = 2, fill = \"red\", color = \"black\") +\n  annotate(\"text\", x = 1, y = 0.5, label = paste0(\"p34: \", convPvalue(p34), \"\\n\",\n                                                \"p23: \", convPvalue(p23), \"\\n\",\n                                                \"p12: \", convPvalue(p12), \"\\n\",\n                                                \"p01: \", convPvalue(p01), \"\\n\",\n                                                \"p04: \", convPvalue(p04), \"\\n\"),\n           color = \"black\", hjust = 0, size = 3)\n\n\n#################### pe\n\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\ntemp <- data.directionality %>% dplyr::filter(gene %in% c(peOver0, peOver1, peOver2, peOver3, peOver4)) %>%\n  dplyr::mutate(group = case_when(gene %in% peOver0 ~ \"peOver0\",\n                                  gene %in% peOver1 ~ \"peOver1\",\n                                  gene %in% peOver2 ~ \"peOver2\",\n                                  gene %in% peOver3 ~ \"peOver3\",\n                                  gene %in% peOver4 ~ \"peOver4\"))\n\np34 <- round(getPvalWilcox(temp, \"peOver3\", \"peOver4\"), 5)\np23 <- round(getPvalWilcox(temp, \"peOver2\", \"peOver3\"), 5)\np12 <- round(getPvalWilcox(temp, \"peOver1\", \"peOver2\"), 5)\np01 <- round(getPvalWilcox(temp, \"peOver0\", \"peOver1\"), 5)\np04 <- round(getPvalWilcox(temp, \"peOver0\", \"peOver4\"), 5)\n\n\n\nggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + \n  geom_hline(yintercept = 0) + theme_classic() + ggtitle(\"P-N\") +\n  stat_summary(aes(group = group), fun = mean, geom = \"point\", shape = 21, size = 2, fill = \"red\", color = \"black\") +\n  annotate(\"text\", x = 1, y = 0.5, label = paste0(\"p34: \", convPvalue(p34), \"\\n\",\n                                                \"p23: \", convPvalue(p23), \"\\n\",\n                                                \"p12: \", convPvalue(p12), \"\\n\",\n                                                \"p01: \", convPvalue(p01), \"\\n\",\n                                                \"p04: \", convPvalue(p04), \"\\n\"),\n           color = \"black\", hjust = 0, size = 3)\n\n\n#################### pp\n\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\ntemp <- data.directionality %>% dplyr::filter(gene %in% c(ppOver0, ppOver1, ppOver2, ppOver3, ppOver4)) %>%\n  dplyr::mutate(group = case_when(gene %in% ppOver0 ~ \"ppOver0\",\n                                  gene %in% ppOver1 ~ \"ppOver1\",\n                                  gene %in% ppOver2 ~ \"ppOver2\",\n                                  gene %in% ppOver3 ~ \"ppOver3\",\n                                  gene %in% ppOver4 ~ \"ppOver4\"))\n\np34 <- round(getPvalWilcox(temp, \"ppOver3\", \"ppOver4\"), 5)\np23 <- round(getPvalWilcox(temp, \"ppOver2\", \"ppOver3\"), 5)\np12 <- round(getPvalWilcox(temp, \"ppOver1\", \"ppOver2\"), 5)\np01 <- round(getPvalWilcox(temp, \"ppOver0\", \"ppOver1\"), 5)\np04 <- round(getPvalWilcox(temp, \"ppOver0\", \"ppOver4\"), 5)\n\n\n\nggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + \n  geom_hline(yintercept = 0) + theme_classic() + ggtitle(\"P-N\") +\n  stat_summary(aes(group = group), fun = mean, geom = \"point\", shape = 21, size = 2, fill = \"red\", color = \"black\") +\n  annotate(\"text\", x = 1, y = 0.5, label = paste0(\"p34: \", convPvalue(p34), \"\\n\",\n                                                \"p23: \", convPvalue(p23), \"\\n\",\n                                                \"p12: \", convPvalue(p12), \"\\n\",\n                                                \"p01: \", convPvalue(p01), \"\\n\",\n                                                \"p04: \", convPvalue(p04), \"\\n\"),\n           color = \"black\", hjust = 0, size = 3)\n\n\n```"} -->

```r
name <- \chromo_cons_annoHierarchy\
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff)%>% 
  dplyr::mutate(distance = start2 - start1)


geneAnnoData <- geneAnnoData %>% unnest(gene)


gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, TSS)
colnames(gene.tb) <- c(\ensembl\, \TSS\)


geneAnnoData  <- geneAnnoData %>% dplyr::left_join(gene.tb, by = c(\gene\ = \ensembl\))

data <- geneAnnoData %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 29, 31, 35)) %>%
  rowwise() %>%
  dplyr::mutate(distToAnchor1 = (start1 + end1)/2 - TSS,
                distToAnchor2 = (start2 + end2)/2 - TSS,
                distToAnchor = if_else(abs(distToAnchor1) > abs(distToAnchor2), distToAnchor1, distToAnchor2),
                direction = if_else(distToAnchor > 0, \right\, \left\))

data.directionality <- data %>% group_by(gene) %>%
  summarise(count = n(),
            n_right = sum(direction == \right\),
            n_left = sum(direction == \left\)) %>%
  dplyr::filter(count > 1) %>%
  dplyr::mutate(n = n_right + n_left,
                directionality = abs((n_right - n_left)/n))


#ggplot(data.directionality, aes(x = directionality)) + geom_histogram() + theme_classic()


gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

temp <- data.directionality %>% dplyr::filter(gene %in% c(gene.group1, gene.group2)) %>%
  dplyr::mutate(group = if_else(gene %in% gene.group1, \group1\, \group2\))


ggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + 
  geom_hline(yintercept = 0) + theme_classic() + ggtitle(\P-S\) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)


#########################PS

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$directionality
  distance2 <- (data %>% dplyr::filter(group ==group2) )$directionality
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


resultDir <- here(\../../result\)
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))
#####################

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene

temp <- data.directionality %>% dplyr::filter(gene %in% c(psOver0, psOver1, psOver2, psOver3, psOver4)) %>%
  dplyr::mutate(group = case_when(gene %in% psOver0 ~ \psOver0\,
                                  gene %in% psOver1 ~ \psOver1\,
                                  gene %in% psOver2 ~ \psOver2\,
                                  gene %in% psOver3 ~ \psOver3\,
                                  gene %in% psOver4 ~ \psOver4\))

p34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
p23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
p12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
p01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
p04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)



ggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + 
  geom_hline(yintercept = 0) + theme_classic() + ggtitle(\P-N\) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  annotate(\text\, x = 1, y = 0.5, label = paste0(\p34: \, convPvalue(p34), \\n\,
                                                \p23: \, convPvalue(p23), \\n\,
                                                \p12: \, convPvalue(p12), \\n\,
                                                \p01: \, convPvalue(p01), \\n\,
                                                \p04: \, convPvalue(p04), \\n\),
           color = \black\, hjust = 0, size = 3)


#################### pe

peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene

temp <- data.directionality %>% dplyr::filter(gene %in% c(peOver0, peOver1, peOver2, peOver3, peOver4)) %>%
  dplyr::mutate(group = case_when(gene %in% peOver0 ~ \peOver0\,
                                  gene %in% peOver1 ~ \peOver1\,
                                  gene %in% peOver2 ~ \peOver2\,
                                  gene %in% peOver3 ~ \peOver3\,
                                  gene %in% peOver4 ~ \peOver4\))

p34 <- round(getPvalWilcox(temp, \peOver3\, \peOver4\), 5)
p23 <- round(getPvalWilcox(temp, \peOver2\, \peOver3\), 5)
p12 <- round(getPvalWilcox(temp, \peOver1\, \peOver2\), 5)
p01 <- round(getPvalWilcox(temp, \peOver0\, \peOver1\), 5)
p04 <- round(getPvalWilcox(temp, \peOver0\, \peOver4\), 5)



ggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + 
  geom_hline(yintercept = 0) + theme_classic() + ggtitle(\P-N\) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  annotate(\text\, x = 1, y = 0.5, label = paste0(\p34: \, convPvalue(p34), \\n\,
                                                \p23: \, convPvalue(p23), \\n\,
                                                \p12: \, convPvalue(p12), \\n\,
                                                \p01: \, convPvalue(p01), \\n\,
                                                \p04: \, convPvalue(p04), \\n\),
           color = \black\, hjust = 0, size = 3)


#################### pp

ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene

temp <- data.directionality %>% dplyr::filter(gene %in% c(ppOver0, ppOver1, ppOver2, ppOver3, ppOver4)) %>%
  dplyr::mutate(group = case_when(gene %in% ppOver0 ~ \ppOver0\,
                                  gene %in% ppOver1 ~ \ppOver1\,
                                  gene %in% ppOver2 ~ \ppOver2\,
                                  gene %in% ppOver3 ~ \ppOver3\,
                                  gene %in% ppOver4 ~ \ppOver4\))

p34 <- round(getPvalWilcox(temp, \ppOver3\, \ppOver4\), 5)
p23 <- round(getPvalWilcox(temp, \ppOver2\, \ppOver3\), 5)
p12 <- round(getPvalWilcox(temp, \ppOver1\, \ppOver2\), 5)
p01 <- round(getPvalWilcox(temp, \ppOver0\, \ppOver1\), 5)
p04 <- round(getPvalWilcox(temp, \ppOver0\, \ppOver4\), 5)



ggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + 
  geom_hline(yintercept = 0) + theme_classic() + ggtitle(\P-N\) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  annotate(\text\, x = 1, y = 0.5, label = paste0(\p34: \, convPvalue(p34), \\n\,
                                                \p23: \, convPvalue(p23), \\n\,
                                                \p12: \, convPvalue(p12), \\n\,
                                                \p01: \, convPvalue(p01), \\n\,
                                                \p04: \, convPvalue(p04), \\n\),
           color = \black\, hjust = 0, size = 3)

```

<!-- rnb-source-end -->
```r
name <- \chromo_cons_annoHierarchy\
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff)%>% 
  dplyr::mutate(distance = start2 - start1)


geneAnnoData <- geneAnnoData %>% unnest(gene)


gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, TSS)
colnames(gene.tb) <- c(\ensembl\, \TSS\)


geneAnnoData  <- geneAnnoData %>% dplyr::left_join(gene.tb, by = c(\gene\ = \ensembl\))

data <- geneAnnoData %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 29, 31, 35)) %>%
  rowwise() %>%
  dplyr::mutate(distToAnchor1 = (start1 + end1)/2 - TSS,
                distToAnchor2 = (start2 + end2)/2 - TSS,
                distToAnchor = if_else(abs(distToAnchor1) > abs(distToAnchor2), distToAnchor1, distToAnchor2),
                direction = if_else(distToAnchor > 0, \right\, \left\))

data.directionality <- data %>% group_by(gene) %>%
  summarise(count = n(),
            n_right = sum(direction == \right\),
            n_left = sum(direction == \left\)) %>%
  dplyr::filter(count > 1) %>%
  dplyr::mutate(n = n_right + n_left,
                directionality = abs((n_right - n_left)/n))


#ggplot(data.directionality, aes(x = directionality)) + geom_histogram() + theme_classic()


gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

temp <- data.directionality %>% dplyr::filter(gene %in% c(gene.group1, gene.group2)) %>%
  dplyr::mutate(group = if_else(gene %in% gene.group1, \group1\, \group2\))


ggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + 
  geom_hline(yintercept = 0) + theme_classic() + ggtitle(\P-S\) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)


#########################PS

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$directionality
  distance2 <- (data %>% dplyr::filter(group ==group2) )$directionality
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


resultDir <- here(\../../result\)
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))
#####################

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene

temp <- data.directionality %>% dplyr::filter(gene %in% c(psOver0, psOver1, psOver2, psOver3, psOver4)) %>%
  dplyr::mutate(group = case_when(gene %in% psOver0 ~ \psOver0\,
                                  gene %in% psOver1 ~ \psOver1\,
                                  gene %in% psOver2 ~ \psOver2\,
                                  gene %in% psOver3 ~ \psOver3\,
                                  gene %in% psOver4 ~ \psOver4\))

p34 <- round(getPvalWilcox(temp, \psOver3\, \psOver4\), 5)
p23 <- round(getPvalWilcox(temp, \psOver2\, \psOver3\), 5)
p12 <- round(getPvalWilcox(temp, \psOver1\, \psOver2\), 5)
p01 <- round(getPvalWilcox(temp, \psOver0\, \psOver1\), 5)
p04 <- round(getPvalWilcox(temp, \psOver0\, \psOver4\), 5)



ggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + 
  geom_hline(yintercept = 0) + theme_classic() + ggtitle(\P-N\) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  annotate(\text\, x = 1, y = 0.5, label = paste0(\p34: \, convPvalue(p34), \\n\,
                                                \p23: \, convPvalue(p23), \\n\,
                                                \p12: \, convPvalue(p12), \\n\,
                                                \p01: \, convPvalue(p01), \\n\,
                                                \p04: \, convPvalue(p04), \\n\),
           color = \black\, hjust = 0, size = 3)


#################### pe

peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene

temp <- data.directionality %>% dplyr::filter(gene %in% c(peOver0, peOver1, peOver2, peOver3, peOver4)) %>%
  dplyr::mutate(group = case_when(gene %in% peOver0 ~ \peOver0\,
                                  gene %in% peOver1 ~ \peOver1\,
                                  gene %in% peOver2 ~ \peOver2\,
                                  gene %in% peOver3 ~ \peOver3\,
                                  gene %in% peOver4 ~ \peOver4\))

p34 <- round(getPvalWilcox(temp, \peOver3\, \peOver4\), 5)
p23 <- round(getPvalWilcox(temp, \peOver2\, \peOver3\), 5)
p12 <- round(getPvalWilcox(temp, \peOver1\, \peOver2\), 5)
p01 <- round(getPvalWilcox(temp, \peOver0\, \peOver1\), 5)
p04 <- round(getPvalWilcox(temp, \peOver0\, \peOver4\), 5)



ggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + 
  geom_hline(yintercept = 0) + theme_classic() + ggtitle(\P-N\) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  annotate(\text\, x = 1, y = 0.5, label = paste0(\p34: \, convPvalue(p34), \\n\,
                                                \p23: \, convPvalue(p23), \\n\,
                                                \p12: \, convPvalue(p12), \\n\,
                                                \p01: \, convPvalue(p01), \\n\,
                                                \p04: \, convPvalue(p04), \\n\),
           color = \black\, hjust = 0, size = 3)


#################### pp

ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene

temp <- data.directionality %>% dplyr::filter(gene %in% c(ppOver0, ppOver1, ppOver2, ppOver3, ppOver4)) %>%
  dplyr::mutate(group = case_when(gene %in% ppOver0 ~ \ppOver0\,
                                  gene %in% ppOver1 ~ \ppOver1\,
                                  gene %in% ppOver2 ~ \ppOver2\,
                                  gene %in% ppOver3 ~ \ppOver3\,
                                  gene %in% ppOver4 ~ \ppOver4\))

p34 <- round(getPvalWilcox(temp, \ppOver3\, \ppOver4\), 5)
p23 <- round(getPvalWilcox(temp, \ppOver2\, \ppOver3\), 5)
p12 <- round(getPvalWilcox(temp, \ppOver1\, \ppOver2\), 5)
p01 <- round(getPvalWilcox(temp, \ppOver0\, \ppOver1\), 5)
p04 <- round(getPvalWilcox(temp, \ppOver0\, \ppOver4\), 5)



ggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + 
  geom_hline(yintercept = 0) + theme_classic() + ggtitle(\P-N\) +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  annotate(\text\, x = 1, y = 0.5, label = paste0(\p34: \, convPvalue(p34), \\n\,
                                                \p23: \, convPvalue(p23), \\n\,
                                                \p12: \, convPvalue(p12), \\n\,
                                                \p01: \, convPvalue(p01), \\n\,
                                                \p04: \, convPvalue(p04), \\n\),
           color = \black\, hjust = 0, size = 3)

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

### [2.31] Testing SEs?

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuZGlmZkN1dG9mZiA8LSAwLjJcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXCJfcC1uX2Vuc2VtYmxMaXN0LnRzdlwiKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSBkaWZmQ3V0b2ZmKSU+JSBcbiAgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSlcblxuZ2VuZUFubm9EYXRhIDwtIGdlbmVBbm5vRGF0YSAlPiUgdW5uZXN0KGdlbmUpXG5cbmdlbmUudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwibW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXCIpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXCIrXCIsIFYyLCBWMykpICU+JVxuICBkcGx5cjo6c2VsZWN0KFY2LCBUU1MpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFwiZW5zZW1ibFwiLCBcIlRTU1wiKVxuXG5cbmdlbmVBbm5vRGF0YSAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6bGVmdF9qb2luKGdlbmUudGIsIGJ5ID0gYyhcImdlbmVcIiA9IFwiZW5zZW1ibFwiKSlcblxuZGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzLCA0LCA1LCA2LCAyOSwgMzEsIDM1KSkgJT4lXG4gIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShkaXN0VG9BbmNob3IxID0gKHN0YXJ0MSArIGVuZDEpLzIgLSBUU1MsXG4gICAgICAgICAgICAgICAgZGlzdFRvQW5jaG9yMiA9IChzdGFydDIgKyBlbmQyKS8yIC0gVFNTLFxuICAgICAgICAgICAgICAgIGRpc3RUb0FuY2hvciA9IGlmX2Vsc2UoYWJzKGRpc3RUb0FuY2hvcjEpID4gYWJzKGRpc3RUb0FuY2hvcjIpLCBkaXN0VG9BbmNob3IxLCBkaXN0VG9BbmNob3IyKSxcbiAgICAgICAgICAgICAgICBkaXJlY3Rpb24gPSBpZl9lbHNlKGRpc3RUb0FuY2hvciA+IDAsIFwicmlnaHRcIiwgXCJsZWZ0XCIpKVxuXG5cbnJlc3VsdCA8LSBkYXRhICU+JVxuICBncm91cF9ieShnZW5lLCBkaXJlY3Rpb24pICU+JVxuICBtdXRhdGUoZGlzdFRvQW5jaG9yID0gYWJzKGRpc3RUb0FuY2hvcikpICU+JVxuICBtdXRhdGUobWF4X2Rpc3RfUF9TID0gaWZlbHNlKGFueShBbm5vMiA9PSBcIlAtU1wiKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbWF4KGRpc3RUb0FuY2hvcltBbm5vMiA9PSBcIlAtU1wiXSwgbmEucm0gPSBUUlVFKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgTkEpKSAlPiVcbiAgbXV0YXRlKGlzX3NtYWxsZXIgPSBpZmVsc2UoaXMubmEobWF4X2Rpc3RfUF9TKSwgTkEsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlzdFRvQW5jaG9yID09IG1heF9kaXN0X1BfUywgTkEsIGRpc3RUb0FuY2hvciA8IG1heF9kaXN0X1BfUykpKSAlPiVcbiAgdW5ncm91cCgpXG5cblxuXG5yZXN1bHQyIDwtIHJlc3VsdCAlPiUgZHBseXI6OmZpbHRlcighaXMubmEoaXNfc21hbGxlcikpXG5cbnJlc3VsdDMgPC0gcmVzdWx0MiAlPiUgZ3JvdXBfYnkoZ2VuZSwgZGlyZWN0aW9uKSAlPiVcbiAgc3VtbWFyaXplKGNvdW50X3RydWUgPSBzdW0oaXNfc21hbGxlciwgbmEucm0gPSBUUlVFKSxcbiAgICAgICAgICAgIGNvdW50X2ZhbHNlID0gc3VtKGlzX3NtYWxsZXIgPT0gRkFMU0UsIG5hLnJtID0gVFJVRSkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGNvdW50ID0gY291bnRfdHJ1ZSArIGNvdW50X2ZhbHNlLFxuICAgICAgICAgICAgICAgIHBlcmMgPSBjb3VudF90cnVlL2NvdW50KjEwMCkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZ2VuZSwgZGlyZWN0aW9uLCBwZXJjKVxuXG5yZXN1bHQzIDwtIHJlc3VsdDMgJT4lIGdyb3VwX2J5KGdlbmUpICU+JSBzdW1tYXJpemUocGVyYyA9IG1lYW4ocGVyYykpXG5cbiMjIyMjIyMgRE9pbmcgdGhpcyBmb3IgUC1TIGdyb3Vwc1xucmVzdWx0RGlyIDwtIGhlcmUoXCIuLi8uLi9yZXN1bHRcIilcbnRlbXAyIDwtIHJlYWRSRFMoaGVyZShyZXN1bHREaXIsIFwiZ2VuZV9sb29wX2xpbmsucmRzXCIpKVxuXG5wc092ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gNCkpJGdlbmVcbnBzT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAzLCBudW1fcHMgPCA0KSkkZ2VuZVxucHNPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDIsIG51bV9wcyA8IDMpKSRnZW5lXG5wc092ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMSwgbnVtX3BzIDwgMikpJGdlbmVcbnBzT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA8IDEpKSRnZW5lXG5cblxucmVzdWx0NCA8LSByZXN1bHQzICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gY2FzZV93aGVuKGdlbmUgJWluJSBwc092ZXIwIH4gXCJwc092ZXIwXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwc092ZXIxIH4gXCJwc092ZXIxXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwc092ZXIyIH4gXCJwc092ZXIyXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwc092ZXIzIH4gXCJwc092ZXIzXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwc092ZXI0IH4gXCJwc092ZXI0XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cblxuZ2dwbG90KHJlc3VsdDQsIGFlcyh4ID0gIGdyb3VwLCB5ID0gcGVyYykpICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMDUpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcInJlZFwiLCBjb2xvciA9IFwiYmxhY2tcIilcblxuIyMjIyMjIyBET2luZyB0aGlzIGZvciBQLUUgZ3JvdXBzXG5wZU92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gNCkpJGdlbmVcbnBlT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAzLCBudW1fcGUgPCA0KSkkZ2VuZVxucGVPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDIsIG51bV9wZSA8IDMpKSRnZW5lXG5wZU92ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMSwgbnVtX3BlIDwgMikpJGdlbmVcbnBlT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA8IDEpKSRnZW5lXG5cblxucmVzdWx0NCA8LSByZXN1bHQzICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gY2FzZV93aGVuKGdlbmUgJWluJSBwZU92ZXIwIH4gXCJwZU92ZXIwXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwZU92ZXIxIH4gXCJwZU92ZXIxXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwZU92ZXIyIH4gXCJwZU92ZXIyXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwZU92ZXIzIH4gXCJwZU92ZXIzXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwZU92ZXI0IH4gXCJwZU92ZXI0XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cblxuZ2dwbG90KHJlc3VsdDQsIGFlcyh4ID0gIGdyb3VwLCB5ID0gcGVyYykpICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMDUpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcInJlZFwiLCBjb2xvciA9IFwiYmxhY2tcIilcblxuIyMjIyMjIyBET2luZyB0aGlzIGZvciBQLVAgZ3JvdXBzXG5cbnBwT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSA0KSkkZ2VuZVxucHBPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDMsIG51bV9wcCA8IDQpKSRnZW5lXG5wcE92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMiwgbnVtX3BwIDwgMykpJGdlbmVcbnBwT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAxLCBudW1fcHAgPCAyKSkkZ2VuZVxucHBPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwIDwgMSkpJGdlbmVcblxuXG5yZXN1bHQ0IDwtIHJlc3VsdDMgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBjYXNlX3doZW4oZ2VuZSAlaW4lIHBwT3ZlcjAgfiBcInBwT3ZlcjBcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZ2VuZSAlaW4lIHBwT3ZlcjEgfiBcInBwT3ZlcjFcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZ2VuZSAlaW4lIHBwT3ZlcjIgfiBcInBwT3ZlcjJcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZ2VuZSAlaW4lIHBwT3ZlcjMgfiBcInBwT3ZlcjNcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZ2VuZSAlaW4lIHBwT3ZlcjQgfiBcInBwT3ZlcjRcIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BKSkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSlcblxuXG5nZ3Bsb3QocmVzdWx0NCwgYWVzKHggPSAgZ3JvdXAsIHkgPSBwZXJjKSkgKyBnZW9tX3Zpb2xpbigpICsgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4wNSkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFwicmVkXCIsIGNvbG9yID0gXCJibGFja1wiKVxuXG5cbmBgYCJ9 -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff)%>% \n  dplyr::mutate(distance = start2 - start1)\n\ngeneAnnoData <- geneAnnoData %>% unnest(gene)\n\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V6, TSS)\ncolnames(gene.tb) <- c(\\ensembl\\, \\TSS\\)\n\n\ngeneAnnoData  <- geneAnnoData %>% dplyr::left_join(gene.tb, by = c(\\gene\\ = \\ensembl\\))\n\ndata <- geneAnnoData %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 29, 31, 35)) %>%\n  rowwise() %>%\n  dplyr::mutate(distToAnchor1 = (start1 + end1)/2 - TSS,\n                distToAnchor2 = (start2 + end2)/2 - TSS,\n                distToAnchor = if_else(abs(distToAnchor1) > abs(distToAnchor2), distToAnchor1, distToAnchor2),\n                direction = if_else(distToAnchor > 0, \\right\\, \\left\\))\n\n\nresult <- data %>%\n  group_by(gene, direction) %>%\n  mutate(distToAnchor = abs(distToAnchor)) %>%\n  mutate(max_dist_P_S = ifelse(any(Anno2 == \\P-S\\), \n                               max(distToAnchor[Anno2 == \\P-S\\], na.rm = TRUE), \n                               NA)) %>%\n  mutate(is_smaller = ifelse(is.na(max_dist_P_S), NA, \n                             ifelse(distToAnchor == max_dist_P_S, NA, distToAnchor < max_dist_P_S))) %>%\n  ungroup()\n\n\n\nresult2 <- result %>% dplyr::filter(!is.na(is_smaller))\n\nresult3 <- result2 %>% group_by(gene, direction) %>%\n  summarize(count_true = sum(is_smaller, na.rm = TRUE),\n            count_false = sum(is_smaller == FALSE, na.rm = TRUE)) %>%\n  dplyr::mutate(count = count_true + count_false,\n                perc = count_true/count*100) %>%\n  dplyr::select(gene, direction, perc)\n\nresult3 <- result3 %>% group_by(gene) %>% summarize(perc = mean(perc))\n\n####### DOing this for P-S groups\nresultDir <- here(\\../../result\\)\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\n\nresult4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% psOver0 ~ \\psOver0\\,\n                                            gene %in% psOver1 ~ \\psOver1\\,\n                                            gene %in% psOver2 ~ \\psOver2\\,\n                                            gene %in% psOver3 ~ \\psOver3\\,\n                                            gene %in% psOver4 ~ \\psOver4\\,\n                                            TRUE ~ NA)) %>%\n  dplyr::filter(!is.na(group))\n\n\nggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)\n\n####### DOing this for P-E groups\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\n\nresult4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% peOver0 ~ \\peOver0\\,\n                                            gene %in% peOver1 ~ \\peOver1\\,\n                                            gene %in% peOver2 ~ \\peOver2\\,\n                                            gene %in% peOver3 ~ \\peOver3\\,\n                                            gene %in% peOver4 ~ \\peOver4\\,\n                                            TRUE ~ NA)) %>%\n  dplyr::filter(!is.na(group))\n\n\nggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)\n\n####### DOing this for P-P groups\n\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\n\nresult4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% ppOver0 ~ \\ppOver0\\,\n                                            gene %in% ppOver1 ~ \\ppOver1\\,\n                                            gene %in% ppOver2 ~ \\ppOver2\\,\n                                            gene %in% ppOver3 ~ \\ppOver3\\,\n                                            gene %in% ppOver4 ~ \\ppOver4\\,\n                                            TRUE ~ NA)) %>%\n  dplyr::filter(!is.na(group))\n\n\nggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff)%>% 
  dplyr::mutate(distance = start2 - start1)

geneAnnoData <- geneAnnoData %>% unnest(gene)

gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, TSS)
colnames(gene.tb) <- c(\ensembl\, \TSS\)


geneAnnoData  <- geneAnnoData %>% dplyr::left_join(gene.tb, by = c(\gene\ = \ensembl\))

data <- geneAnnoData %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 29, 31, 35)) %>%
  rowwise() %>%
  dplyr::mutate(distToAnchor1 = (start1 + end1)/2 - TSS,
                distToAnchor2 = (start2 + end2)/2 - TSS,
                distToAnchor = if_else(abs(distToAnchor1) > abs(distToAnchor2), distToAnchor1, distToAnchor2),
                direction = if_else(distToAnchor > 0, \right\, \left\))


result <- data %>%
  group_by(gene, direction) %>%
  mutate(distToAnchor = abs(distToAnchor)) %>%
  mutate(max_dist_P_S = ifelse(any(Anno2 == \P-S\), 
                               max(distToAnchor[Anno2 == \P-S\], na.rm = TRUE), 
                               NA)) %>%
  mutate(is_smaller = ifelse(is.na(max_dist_P_S), NA, 
                             ifelse(distToAnchor == max_dist_P_S, NA, distToAnchor < max_dist_P_S))) %>%
  ungroup()



result2 <- result %>% dplyr::filter(!is.na(is_smaller))

result3 <- result2 %>% group_by(gene, direction) %>%
  summarize(count_true = sum(is_smaller, na.rm = TRUE),
            count_false = sum(is_smaller == FALSE, na.rm = TRUE)) %>%
  dplyr::mutate(count = count_true + count_false,
                perc = count_true/count*100) %>%
  dplyr::select(gene, direction, perc)

result3 <- result3 %>% group_by(gene) %>% summarize(perc = mean(perc))

####### DOing this for P-S groups
resultDir <- here(\../../result\)
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% psOver0 ~ \psOver0\,
                                            gene %in% psOver1 ~ \psOver1\,
                                            gene %in% psOver2 ~ \psOver2\,
                                            gene %in% psOver3 ~ \psOver3\,
                                            gene %in% psOver4 ~ \psOver4\,
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)

####### DOing this for P-E groups
peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% peOver0 ~ \peOver0\,
                                            gene %in% peOver1 ~ \peOver1\,
                                            gene %in% peOver2 ~ \peOver2\,
                                            gene %in% peOver3 ~ \peOver3\,
                                            gene %in% peOver4 ~ \peOver4\,
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)

####### DOing this for P-P groups

ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% ppOver0 ~ \ppOver0\,
                                            gene %in% ppOver1 ~ \ppOver1\,
                                            gene %in% ppOver2 ~ \ppOver2\,
                                            gene %in% ppOver3 ~ \ppOver3\,
                                            gene %in% ppOver4 ~ \ppOver4\,
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGlmZkN1dG9mZiA8LSAwLjJcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1uX2Vuc2VtYmxMaXN0LnRzdlxcKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSBkaWZmQ3V0b2ZmKSU+JSBcbiAgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSlcblxuZ2VuZUFubm9EYXRhIDwtIGdlbmVBbm5vRGF0YSAlPiUgdW5uZXN0KGdlbmUpXG5cbmdlbmUudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXFwrXFwsIFYyLCBWMykpICU+JVxuICBkcGx5cjo6c2VsZWN0KFY2LCBUU1MpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFxcZW5zZW1ibFxcLCBcXFRTU1xcKVxuXG5cbmdlbmVBbm5vRGF0YSAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6bGVmdF9qb2luKGdlbmUudGIsIGJ5ID0gYyhcXGdlbmVcXCA9IFxcZW5zZW1ibFxcKSlcblxuZGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzLCA0LCA1LCA2LCAyOSwgMzEsIDM1KSkgJT4lXG4gIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShkaXN0VG9BbmNob3IxID0gKHN0YXJ0MSArIGVuZDEpLzIgLSBUU1MsXG4gICAgICAgICAgICAgICAgZGlzdFRvQW5jaG9yMiA9IChzdGFydDIgKyBlbmQyKS8yIC0gVFNTLFxuICAgICAgICAgICAgICAgIGRpc3RUb0FuY2hvciA9IGlmX2Vsc2UoYWJzKGRpc3RUb0FuY2hvcjEpID4gYWJzKGRpc3RUb0FuY2hvcjIpLCBkaXN0VG9BbmNob3IxLCBkaXN0VG9BbmNob3IyKSxcbiAgICAgICAgICAgICAgICBkaXJlY3Rpb24gPSBpZl9lbHNlKGRpc3RUb0FuY2hvciA+IDAsIFxccmlnaHRcXCwgXFxsZWZ0XFwpKVxuXG5cbnJlc3VsdCA8LSBkYXRhICU+JVxuICBncm91cF9ieShnZW5lLCBkaXJlY3Rpb24pICU+JVxuICBtdXRhdGUoZGlzdFRvQW5jaG9yID0gYWJzKGRpc3RUb0FuY2hvcikpICU+JVxuICBtdXRhdGUobWF4X2Rpc3RfUF9TID0gaWZlbHNlKGFueShBbm5vMiA9PSBcXFAtU1xcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbWF4KGRpc3RUb0FuY2hvcltBbm5vMiA9PSBcXFAtU1xcXSwgbmEucm0gPSBUUlVFKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgTkEpKSAlPiVcbiAgbXV0YXRlKGlzX3NtYWxsZXIgPSBpZmVsc2UoaXMubmEobWF4X2Rpc3RfUF9TKSwgTkEsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlzdFRvQW5jaG9yID09IG1heF9kaXN0X1BfUywgTkEsIGRpc3RUb0FuY2hvciA8IG1heF9kaXN0X1BfUykpKSAlPiVcbiAgdW5ncm91cCgpXG5cblxuXG5yZXN1bHQyIDwtIHJlc3VsdCAlPiUgZHBseXI6OmZpbHRlcighaXMubmEoaXNfc21hbGxlcikpXG5cbnJlc3VsdDMgPC0gcmVzdWx0MiAlPiUgZ3JvdXBfYnkoZ2VuZSwgZGlyZWN0aW9uKSAlPiVcbiAgc3VtbWFyaXplKGNvdW50X3RydWUgPSBzdW0oaXNfc21hbGxlciwgbmEucm0gPSBUUlVFKSxcbiAgICAgICAgICAgIGNvdW50X2ZhbHNlID0gc3VtKGlzX3NtYWxsZXIgPT0gRkFMU0UsIG5hLnJtID0gVFJVRSkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGNvdW50ID0gY291bnRfdHJ1ZSArIGNvdW50X2ZhbHNlLFxuICAgICAgICAgICAgICAgIHBlcmMgPSBjb3VudF90cnVlL2NvdW50KjEwMCkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZ2VuZSwgZGlyZWN0aW9uLCBwZXJjKVxuXG5yZXN1bHQzIDwtIHJlc3VsdDMgJT4lIGdyb3VwX2J5KGdlbmUpICU+JSBzdW1tYXJpemUocGVyYyA9IG1lYW4ocGVyYykpXG5cbiMjIyMjIyMgRE9pbmcgdGhpcyBmb3IgUC1TIGdyb3Vwc1xucmVzdWx0RGlyIDwtIGhlcmUoXFwuLi8uLi9yZXN1bHRcXClcbnRlbXAyIDwtIHJlYWRSRFMoaGVyZShyZXN1bHREaXIsIFxcZ2VuZV9sb29wX2xpbmsucmRzXFwpKVxuXG5wc092ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gNCkpJGdlbmVcbnBzT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAzLCBudW1fcHMgPCA0KSkkZ2VuZVxucHNPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDIsIG51bV9wcyA8IDMpKSRnZW5lXG5wc092ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMSwgbnVtX3BzIDwgMikpJGdlbmVcbnBzT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA8IDEpKSRnZW5lXG5cblxucmVzdWx0NCA8LSByZXN1bHQzICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gY2FzZV93aGVuKGdlbmUgJWluJSBwc092ZXIwIH4gXFxwc092ZXIwXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwc092ZXIxIH4gXFxwc092ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwc092ZXIyIH4gXFxwc092ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwc092ZXIzIH4gXFxwc092ZXIzXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwc092ZXI0IH4gXFxwc092ZXI0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cblxuZ2dwbG90KHJlc3VsdDQsIGFlcyh4ID0gIGdyb3VwLCB5ID0gcGVyYykpICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMDUpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXClcblxuIyMjIyMjIyBET2luZyB0aGlzIGZvciBQLUUgZ3JvdXBzXG5wZU92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gNCkpJGdlbmVcbnBlT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAzLCBudW1fcGUgPCA0KSkkZ2VuZVxucGVPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDIsIG51bV9wZSA8IDMpKSRnZW5lXG5wZU92ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMSwgbnVtX3BlIDwgMikpJGdlbmVcbnBlT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA8IDEpKSRnZW5lXG5cblxucmVzdWx0NCA8LSByZXN1bHQzICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gY2FzZV93aGVuKGdlbmUgJWluJSBwZU92ZXIwIH4gXFxwZU92ZXIwXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwZU92ZXIxIH4gXFxwZU92ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwZU92ZXIyIH4gXFxwZU92ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwZU92ZXIzIH4gXFxwZU92ZXIzXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwZU92ZXI0IH4gXFxwZU92ZXI0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cblxuZ2dwbG90KHJlc3VsdDQsIGFlcyh4ID0gIGdyb3VwLCB5ID0gcGVyYykpICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMDUpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXClcblxuIyMjIyMjIyBET2luZyB0aGlzIGZvciBQLVAgZ3JvdXBzXG5cbnBwT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSA0KSkkZ2VuZVxucHBPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDMsIG51bV9wcCA8IDQpKSRnZW5lXG5wcE92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMiwgbnVtX3BwIDwgMykpJGdlbmVcbnBwT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAxLCBudW1fcHAgPCAyKSkkZ2VuZVxucHBPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwIDwgMSkpJGdlbmVcblxuXG5yZXN1bHQ0IDwtIHJlc3VsdDMgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBjYXNlX3doZW4oZ2VuZSAlaW4lIHBwT3ZlcjAgfiBcXHBwT3ZlcjBcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZ2VuZSAlaW4lIHBwT3ZlcjEgfiBcXHBwT3ZlcjFcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZ2VuZSAlaW4lIHBwT3ZlcjIgfiBcXHBwT3ZlcjJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZ2VuZSAlaW4lIHBwT3ZlcjMgfiBcXHBwT3ZlcjNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZ2VuZSAlaW4lIHBwT3ZlcjQgfiBcXHBwT3ZlcjRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BKSkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSlcblxuXG5nZ3Bsb3QocmVzdWx0NCwgYWVzKHggPSAgZ3JvdXAsIHkgPSBwZXJjKSkgKyBnZW9tX3Zpb2xpbigpICsgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4wNSkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKVxuXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff)%>% \n  dplyr::mutate(distance = start2 - start1)\n\ngeneAnnoData <- geneAnnoData %>% unnest(gene)\n\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V6, TSS)\ncolnames(gene.tb) <- c(\\ensembl\\, \\TSS\\)\n\n\ngeneAnnoData  <- geneAnnoData %>% dplyr::left_join(gene.tb, by = c(\\gene\\ = \\ensembl\\))\n\ndata <- geneAnnoData %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 29, 31, 35)) %>%\n  rowwise() %>%\n  dplyr::mutate(distToAnchor1 = (start1 + end1)/2 - TSS,\n                distToAnchor2 = (start2 + end2)/2 - TSS,\n                distToAnchor = if_else(abs(distToAnchor1) > abs(distToAnchor2), distToAnchor1, distToAnchor2),\n                direction = if_else(distToAnchor > 0, \\right\\, \\left\\))\n\n\nresult <- data %>%\n  group_by(gene, direction) %>%\n  mutate(distToAnchor = abs(distToAnchor)) %>%\n  mutate(max_dist_P_S = ifelse(any(Anno2 == \\P-S\\), \n                               max(distToAnchor[Anno2 == \\P-S\\], na.rm = TRUE), \n                               NA)) %>%\n  mutate(is_smaller = ifelse(is.na(max_dist_P_S), NA, \n                             ifelse(distToAnchor == max_dist_P_S, NA, distToAnchor < max_dist_P_S))) %>%\n  ungroup()\n\n\n\nresult2 <- result %>% dplyr::filter(!is.na(is_smaller))\n\nresult3 <- result2 %>% group_by(gene, direction) %>%\n  summarize(count_true = sum(is_smaller, na.rm = TRUE),\n            count_false = sum(is_smaller == FALSE, na.rm = TRUE)) %>%\n  dplyr::mutate(count = count_true + count_false,\n                perc = count_true/count*100) %>%\n  dplyr::select(gene, direction, perc)\n\nresult3 <- result3 %>% group_by(gene) %>% summarize(perc = mean(perc))\n\n####### DOing this for P-S groups\nresultDir <- here(\\../../result\\)\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\n\nresult4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% psOver0 ~ \\psOver0\\,\n                                            gene %in% psOver1 ~ \\psOver1\\,\n                                            gene %in% psOver2 ~ \\psOver2\\,\n                                            gene %in% psOver3 ~ \\psOver3\\,\n                                            gene %in% psOver4 ~ \\psOver4\\,\n                                            TRUE ~ NA)) %>%\n  dplyr::filter(!is.na(group))\n\n\nggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)\n\n####### DOing this for P-E groups\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\n\nresult4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% peOver0 ~ \\peOver0\\,\n                                            gene %in% peOver1 ~ \\peOver1\\,\n                                            gene %in% peOver2 ~ \\peOver2\\,\n                                            gene %in% peOver3 ~ \\peOver3\\,\n                                            gene %in% peOver4 ~ \\peOver4\\,\n                                            TRUE ~ NA)) %>%\n  dplyr::filter(!is.na(group))\n\n\nggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)\n\n####### DOing this for P-P groups\n\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\n\nresult4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% ppOver0 ~ \\ppOver0\\,\n                                            gene %in% ppOver1 ~ \\ppOver1\\,\n                                            gene %in% ppOver2 ~ \\ppOver2\\,\n                                            gene %in% ppOver3 ~ \\ppOver3\\,\n                                            gene %in% ppOver4 ~ \\ppOver4\\,\n                                            TRUE ~ NA)) %>%\n  dplyr::filter(!is.na(group))\n\n\nggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGlmZkN1dG9mZiA8LSAwLjJcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1uX2Vuc2VtYmxMaXN0LnRzdlxcKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSBkaWZmQ3V0b2ZmKSU+JSBcbiAgZHBseXI6Om11dGF0ZShkaXN0YW5jZSA9IHN0YXJ0MiAtIHN0YXJ0MSlcblxuZ2VuZUFubm9EYXRhIDwtIGdlbmVBbm5vRGF0YSAlPiUgdW5uZXN0KGdlbmUpXG5cbmdlbmUudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXFwrXFwsIFYyLCBWMykpICU+JVxuICBkcGx5cjo6c2VsZWN0KFY2LCBUU1MpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFxcZW5zZW1ibFxcLCBcXFRTU1xcKVxuXG5cbmdlbmVBbm5vRGF0YSAgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6bGVmdF9qb2luKGdlbmUudGIsIGJ5ID0gYyhcXGdlbmVcXCA9IFxcZW5zZW1ibFxcKSlcblxuZGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzLCA0LCA1LCA2LCAyOSwgMzEsIDM1KSkgJT4lXG4gIHJvd3dpc2UoKSAlPiVcbiAgZHBseXI6Om11dGF0ZShkaXN0VG9BbmNob3IxID0gKHN0YXJ0MSArIGVuZDEpLzIgLSBUU1MsXG4gICAgICAgICAgICAgICAgZGlzdFRvQW5jaG9yMiA9IChzdGFydDIgKyBlbmQyKS8yIC0gVFNTLFxuICAgICAgICAgICAgICAgIGRpc3RUb0FuY2hvciA9IGlmX2Vsc2UoYWJzKGRpc3RUb0FuY2hvcjEpID4gYWJzKGRpc3RUb0FuY2hvcjIpLCBkaXN0VG9BbmNob3IxLCBkaXN0VG9BbmNob3IyKSxcbiAgICAgICAgICAgICAgICBkaXJlY3Rpb24gPSBpZl9lbHNlKGRpc3RUb0FuY2hvciA+IDAsIFxccmlnaHRcXCwgXFxsZWZ0XFwpKVxuXG5cbnJlc3VsdCA8LSBkYXRhICU+JVxuICBncm91cF9ieShnZW5lLCBkaXJlY3Rpb24pICU+JVxuICBtdXRhdGUoZGlzdFRvQW5jaG9yID0gYWJzKGRpc3RUb0FuY2hvcikpICU+JVxuICBtdXRhdGUobWF4X2Rpc3RfUF9TID0gaWZlbHNlKGFueShBbm5vMiA9PSBcXFAtU1xcKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbWF4KGRpc3RUb0FuY2hvcltBbm5vMiA9PSBcXFAtU1xcXSwgbmEucm0gPSBUUlVFKSwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgTkEpKSAlPiVcbiAgbXV0YXRlKGlzX3NtYWxsZXIgPSBpZmVsc2UoaXMubmEobWF4X2Rpc3RfUF9TKSwgTkEsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZmVsc2UoZGlzdFRvQW5jaG9yID09IG1heF9kaXN0X1BfUywgTkEsIGRpc3RUb0FuY2hvciA8IG1heF9kaXN0X1BfUykpKSAlPiVcbiAgdW5ncm91cCgpXG5cblxuXG5yZXN1bHQyIDwtIHJlc3VsdCAlPiUgZHBseXI6OmZpbHRlcighaXMubmEoaXNfc21hbGxlcikpXG5cbnJlc3VsdDMgPC0gcmVzdWx0MiAlPiUgZ3JvdXBfYnkoZ2VuZSwgZGlyZWN0aW9uKSAlPiVcbiAgc3VtbWFyaXplKGNvdW50X3RydWUgPSBzdW0oaXNfc21hbGxlciwgbmEucm0gPSBUUlVFKSxcbiAgICAgICAgICAgIGNvdW50X2ZhbHNlID0gc3VtKGlzX3NtYWxsZXIgPT0gRkFMU0UsIG5hLnJtID0gVFJVRSkpICU+JVxuICBkcGx5cjo6bXV0YXRlKGNvdW50ID0gY291bnRfdHJ1ZSArIGNvdW50X2ZhbHNlLFxuICAgICAgICAgICAgICAgIHBlcmMgPSBjb3VudF90cnVlL2NvdW50KjEwMCkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoZ2VuZSwgZGlyZWN0aW9uLCBwZXJjKVxuXG5yZXN1bHQzIDwtIHJlc3VsdDMgJT4lIGdyb3VwX2J5KGdlbmUpICU+JSBzdW1tYXJpemUocGVyYyA9IG1lYW4ocGVyYykpXG5cbiMjIyMjIyMgRE9pbmcgdGhpcyBmb3IgUC1TIGdyb3Vwc1xucmVzdWx0RGlyIDwtIGhlcmUoXFwuLi8uLi9yZXN1bHRcXClcbnRlbXAyIDwtIHJlYWRSRFMoaGVyZShyZXN1bHREaXIsIFxcZ2VuZV9sb29wX2xpbmsucmRzXFwpKVxuXG5wc092ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gNCkpJGdlbmVcbnBzT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAzLCBudW1fcHMgPCA0KSkkZ2VuZVxucHNPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDIsIG51bV9wcyA8IDMpKSRnZW5lXG5wc092ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMSwgbnVtX3BzIDwgMikpJGdlbmVcbnBzT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA8IDEpKSRnZW5lXG5cblxucmVzdWx0NCA8LSByZXN1bHQzICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gY2FzZV93aGVuKGdlbmUgJWluJSBwc092ZXIwIH4gXFxwc092ZXIwXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwc092ZXIxIH4gXFxwc092ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwc092ZXIyIH4gXFxwc092ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwc092ZXIzIH4gXFxwc092ZXIzXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwc092ZXI0IH4gXFxwc092ZXI0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cblxuZ2dwbG90KHJlc3VsdDQsIGFlcyh4ID0gIGdyb3VwLCB5ID0gcGVyYykpICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMDUpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXClcblxuIyMjIyMjIyBET2luZyB0aGlzIGZvciBQLUUgZ3JvdXBzXG5wZU92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gNCkpJGdlbmVcbnBlT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAzLCBudW1fcGUgPCA0KSkkZ2VuZVxucGVPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDIsIG51bV9wZSA8IDMpKSRnZW5lXG5wZU92ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMSwgbnVtX3BlIDwgMikpJGdlbmVcbnBlT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA8IDEpKSRnZW5lXG5cblxucmVzdWx0NCA8LSByZXN1bHQzICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gY2FzZV93aGVuKGdlbmUgJWluJSBwZU92ZXIwIH4gXFxwZU92ZXIwXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwZU92ZXIxIH4gXFxwZU92ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwZU92ZXIyIH4gXFxwZU92ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwZU92ZXIzIH4gXFxwZU92ZXIzXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwZU92ZXI0IH4gXFxwZU92ZXI0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cblxuZ2dwbG90KHJlc3VsdDQsIGFlcyh4ID0gIGdyb3VwLCB5ID0gcGVyYykpICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMDUpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXClcblxuIyMjIyMjIyBET2luZyB0aGlzIGZvciBQLVAgZ3JvdXBzXG5cbnBwT3ZlcjQgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSA0KSkkZ2VuZVxucHBPdmVyMyA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDMsIG51bV9wcCA8IDQpKSRnZW5lXG5wcE92ZXIyIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMiwgbnVtX3BwIDwgMykpJGdlbmVcbnBwT3ZlcjEgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAxLCBudW1fcHAgPCAyKSkkZ2VuZVxucHBPdmVyMCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwIDwgMSkpJGdlbmVcblxuXG5yZXN1bHQ0IDwtIHJlc3VsdDMgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBjYXNlX3doZW4oZ2VuZSAlaW4lIHBwT3ZlcjAgfiBcXHBwT3ZlcjBcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZ2VuZSAlaW4lIHBwT3ZlcjEgfiBcXHBwT3ZlcjFcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZ2VuZSAlaW4lIHBwT3ZlcjIgfiBcXHBwT3ZlcjJcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZ2VuZSAlaW4lIHBwT3ZlcjMgfiBcXHBwT3ZlcjNcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZ2VuZSAlaW4lIHBwT3ZlcjQgfiBcXHBwT3ZlcjRcXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgVFJVRSB+IE5BKSkgJT4lXG4gIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGdyb3VwKSlcblxuXG5nZ3Bsb3QocmVzdWx0NCwgYWVzKHggPSAgZ3JvdXAsIHkgPSBwZXJjKSkgKyBnZW9tX3Zpb2xpbigpICsgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4wNSkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICBzdGF0X3N1bW1hcnkoYWVzKGdyb3VwID0gZ3JvdXApLCBmdW4gPSBtZWFuLCBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKVxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
name <- \chromo_cons_annoHierarchy\
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff)%>% 
  dplyr::mutate(distance = start2 - start1)

geneAnnoData <- geneAnnoData %>% unnest(gene)

gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, TSS)
colnames(gene.tb) <- c(\ensembl\, \TSS\)


geneAnnoData  <- geneAnnoData %>% dplyr::left_join(gene.tb, by = c(\gene\ = \ensembl\))

data <- geneAnnoData %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 29, 31, 35)) %>%
  rowwise() %>%
  dplyr::mutate(distToAnchor1 = (start1 + end1)/2 - TSS,
                distToAnchor2 = (start2 + end2)/2 - TSS,
                distToAnchor = if_else(abs(distToAnchor1) > abs(distToAnchor2), distToAnchor1, distToAnchor2),
                direction = if_else(distToAnchor > 0, \right\, \left\))


result <- data %>%
  group_by(gene, direction) %>%
  mutate(distToAnchor = abs(distToAnchor)) %>%
  mutate(max_dist_P_S = ifelse(any(Anno2 == \P-S\), 
                               max(distToAnchor[Anno2 == \P-S\], na.rm = TRUE), 
                               NA)) %>%
  mutate(is_smaller = ifelse(is.na(max_dist_P_S), NA, 
                             ifelse(distToAnchor == max_dist_P_S, NA, distToAnchor < max_dist_P_S))) %>%
  ungroup()



result2 <- result %>% dplyr::filter(!is.na(is_smaller))

result3 <- result2 %>% group_by(gene, direction) %>%
  summarize(count_true = sum(is_smaller, na.rm = TRUE),
            count_false = sum(is_smaller == FALSE, na.rm = TRUE)) %>%
  dplyr::mutate(count = count_true + count_false,
                perc = count_true/count*100) %>%
  dplyr::select(gene, direction, perc)

result3 <- result3 %>% group_by(gene) %>% summarize(perc = mean(perc))

####### DOing this for P-S groups
resultDir <- here(\../../result\)
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% psOver0 ~ \psOver0\,
                                            gene %in% psOver1 ~ \psOver1\,
                                            gene %in% psOver2 ~ \psOver2\,
                                            gene %in% psOver3 ~ \psOver3\,
                                            gene %in% psOver4 ~ \psOver4\,
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)

####### DOing this for P-E groups
peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% peOver0 ~ \peOver0\,
                                            gene %in% peOver1 ~ \peOver1\,
                                            gene %in% peOver2 ~ \peOver2\,
                                            gene %in% peOver3 ~ \peOver3\,
                                            gene %in% peOver4 ~ \peOver4\,
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)

####### DOing this for P-P groups

ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% ppOver0 ~ \ppOver0\,
                                            gene %in% ppOver1 ~ \ppOver1\,
                                            gene %in% ppOver2 ~ \ppOver2\,
                                            gene %in% ppOver3 ~ \ppOver3\,
                                            gene %in% ppOver4 ~ \ppOver4\,
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [2.32] Checking directionality

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5yZXN1bHQgPC0gZGF0YSAlPiVcbiAgZ3JvdXBfYnkoZ2VuZSwgZGlyZWN0aW9uKSAlPiVcbiAgbXV0YXRlKGRpc3RUb0FuY2hvciA9IGFicyhkaXN0VG9BbmNob3IpKSAlPiVcbiAgbXV0YXRlKG1heF9kaXN0X1BfUyA9IGlmZWxzZShhbnkoQW5ubzIgPT0gXCJQLVNcIiksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG1heChkaXN0VG9BbmNob3JbQW5ubzIgPT0gXCJQLVNcIl0sIG5hLnJtID0gVFJVRSksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5BKSlcbnJlc3VsdCA8LSByZXN1bHQgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgIT0gXCJQLVNcIikgJT4lXG4gIG11dGF0ZShpc19zbWFsbGVyID0gaWZlbHNlKGlzLm5hKG1heF9kaXN0X1BfUyksIE5BLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGRpc3RUb0FuY2hvciA9PSBtYXhfZGlzdF9QX1MsIE5BLCBkaXN0VG9BbmNob3IgPCBtYXhfZGlzdF9QX1MpKSkgJT4lXG4gIHVuZ3JvdXAoKVxuXG5cblxucmVzdWx0MiA8LSByZXN1bHQgJT4lIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGlzX3NtYWxsZXIpKVxuXG5yZXN1bHQzIDwtIHJlc3VsdDIgJT4lIGdyb3VwX2J5KGdlbmUsIGRpcmVjdGlvbikgJT4lXG4gIHN1bW1hcml6ZShjb3VudF90cnVlID0gc3VtKGlzX3NtYWxsZXIsIG5hLnJtID0gVFJVRSksXG4gICAgICAgICAgICBjb3VudF9mYWxzZSA9IHN1bShpc19zbWFsbGVyID09IEZBTFNFLCBuYS5ybSA9IFRSVUUpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjb3VudCA9IGNvdW50X3RydWUgKyBjb3VudF9mYWxzZSxcbiAgICAgICAgICAgICAgICBwZXJjID0gY291bnRfdHJ1ZS9jb3VudCoxMDApICU+JVxuICBkcGx5cjo6c2VsZWN0KGdlbmUsIGRpcmVjdGlvbiwgcGVyYylcblxucmVzdWx0MyA8LSByZXN1bHQzICU+JSBncm91cF9ieShnZW5lKSAlPiUgc3VtbWFyaXplKHBlcmMgPSBtZWFuKHBlcmMpKVxuXG4jIyMjIyMjIERPaW5nIHRoaXMgZm9yIFAtUyBncm91cHNcbnJlc3VsdERpciA8LSBoZXJlKFwiLi4vLi4vcmVzdWx0XCIpXG50ZW1wMiA8LSByZWFkUkRTKGhlcmUocmVzdWx0RGlyLCBcImdlbmVfbG9vcF9saW5rLnJkc1wiKSlcblxucHNPdmVyNCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDQpKSRnZW5lXG5wc092ZXIzIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMywgbnVtX3BzIDwgNCkpJGdlbmVcbnBzT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAyLCBudW1fcHMgPCAzKSkkZ2VuZVxucHNPdmVyMSA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDEsIG51bV9wcyA8IDIpKSRnZW5lXG5wc092ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPCAxKSkkZ2VuZVxuXG5cbnJlc3VsdDQgPC0gcmVzdWx0MyAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihnZW5lICVpbiUgcHNPdmVyMCB+IFwicHNPdmVyMFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcHNPdmVyMSB+IFwicHNPdmVyMVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcHNPdmVyMiB+IFwicHNPdmVyMlwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcHNPdmVyMyB+IFwicHNPdmVyM1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcHNPdmVyNCB+IFwicHNPdmVyNFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbmdncGxvdChyZXN1bHQ0LCBhZXMoeCA9ICBncm91cCwgeSA9IHBlcmMpKSArIGdlb21fdmlvbGluKCkgKyBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjA1KSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcInBvaW50XCIsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCIpXG5cbiMjIyMjIyMgRE9pbmcgdGhpcyBmb3IgUC1FIGdyb3Vwc1xucGVPdmVyNCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDQpKSRnZW5lXG5wZU92ZXIzIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMywgbnVtX3BlIDwgNCkpJGdlbmVcbnBlT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAyLCBudW1fcGUgPCAzKSkkZ2VuZVxucGVPdmVyMSA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDEsIG51bV9wZSA8IDIpKSRnZW5lXG5wZU92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPCAxKSkkZ2VuZVxuXG5cbnJlc3VsdDQgPC0gcmVzdWx0MyAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihnZW5lICVpbiUgcGVPdmVyMCB+IFwicGVPdmVyMFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcGVPdmVyMSB+IFwicGVPdmVyMVwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcGVPdmVyMiB+IFwicGVPdmVyMlwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcGVPdmVyMyB+IFwicGVPdmVyM1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcGVPdmVyNCB+IFwicGVPdmVyNFwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbmdncGxvdChyZXN1bHQ0LCBhZXMoeCA9ICBncm91cCwgeSA9IHBlcmMpKSArIGdlb21fdmlvbGluKCkgKyBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjA1KSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcInBvaW50XCIsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCIpXG5cbiMjIyMjIyMgRE9pbmcgdGhpcyBmb3IgUC1QIGdyb3Vwc1xuXG5wcE92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gNCkpJGdlbmVcbnBwT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAzLCBudW1fcHAgPCA0KSkkZ2VuZVxucHBPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDIsIG51bV9wcCA8IDMpKSRnZW5lXG5wcE92ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMSwgbnVtX3BwIDwgMikpJGdlbmVcbnBwT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA8IDEpKSRnZW5lXG5cblxucmVzdWx0NCA8LSByZXN1bHQzICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gY2FzZV93aGVuKGdlbmUgJWluJSBwcE92ZXIwIH4gXCJwcE92ZXIwXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwcE92ZXIxIH4gXCJwcE92ZXIxXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwcE92ZXIyIH4gXCJwcE92ZXIyXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwcE92ZXIzIH4gXCJwcE92ZXIzXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwcE92ZXI0IH4gXCJwcE92ZXI0XCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cblxuZ2dwbG90KHJlc3VsdDQsIGFlcyh4ID0gIGdyb3VwLCB5ID0gcGVyYykpICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMDUpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcInJlZFwiLCBjb2xvciA9IFwiYmxhY2tcIilcblxuYGBgIn0= -->\n\n```r\n\nresult <- data %>%\n  group_by(gene, direction) %>%\n  mutate(distToAnchor = abs(distToAnchor)) %>%\n  mutate(max_dist_P_S = ifelse(any(Anno2 == \\P-S\\), \n                               max(distToAnchor[Anno2 == \\P-S\\], na.rm = TRUE), \n                               NA))\nresult <- result %>% dplyr::filter(Anno2 != \\P-S\\) %>%\n  mutate(is_smaller = ifelse(is.na(max_dist_P_S), NA, \n                             ifelse(distToAnchor == max_dist_P_S, NA, distToAnchor < max_dist_P_S))) %>%\n  ungroup()\n\n\n\nresult2 <- result %>% dplyr::filter(!is.na(is_smaller))\n\nresult3 <- result2 %>% group_by(gene, direction) %>%\n  summarize(count_true = sum(is_smaller, na.rm = TRUE),\n            count_false = sum(is_smaller == FALSE, na.rm = TRUE)) %>%\n  dplyr::mutate(count = count_true + count_false,\n                perc = count_true/count*100) %>%\n  dplyr::select(gene, direction, perc)\n\nresult3 <- result3 %>% group_by(gene) %>% summarize(perc = mean(perc))\n\n####### DOing this for P-S groups\nresultDir <- here(\\../../result\\)\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\n\nresult4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% psOver0 ~ \\psOver0\\,\n                                            gene %in% psOver1 ~ \\psOver1\\,\n                                            gene %in% psOver2 ~ \\psOver2\\,\n                                            gene %in% psOver3 ~ \\psOver3\\,\n                                            gene %in% psOver4 ~ \\psOver4\\,\n                                            TRUE ~ NA)) %>%\n  dplyr::filter(!is.na(group))\n\n\nggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)\n\n####### DOing this for P-E groups\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\n\nresult4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% peOver0 ~ \\peOver0\\,\n                                            gene %in% peOver1 ~ \\peOver1\\,\n                                            gene %in% peOver2 ~ \\peOver2\\,\n                                            gene %in% peOver3 ~ \\peOver3\\,\n                                            gene %in% peOver4 ~ \\peOver4\\,\n                                            TRUE ~ NA)) %>%\n  dplyr::filter(!is.na(group))\n\n\nggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)\n\n####### DOing this for P-P groups\n\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\n\nresult4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% ppOver0 ~ \\ppOver0\\,\n                                            gene %in% ppOver1 ~ \\ppOver1\\,\n                                            gene %in% ppOver2 ~ \\ppOver2\\,\n                                            gene %in% ppOver3 ~ \\ppOver3\\,\n                                            gene %in% ppOver4 ~ \\ppOver4\\,\n                                            TRUE ~ NA)) %>%\n  dplyr::filter(!is.na(group))\n\n\nggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)\n\n```\n\n<!-- rnb-source-end -->\n"} -->

result <- data %>%
  group_by(gene, direction) %>%
  mutate(distToAnchor = abs(distToAnchor)) %>%
  mutate(max_dist_P_S = ifelse(any(Anno2 == \P-S\), 
                               max(distToAnchor[Anno2 == \P-S\], na.rm = TRUE), 
                               NA))
result <- result %>% dplyr::filter(Anno2 != \P-S\) %>%
  mutate(is_smaller = ifelse(is.na(max_dist_P_S), NA, 
                             ifelse(distToAnchor == max_dist_P_S, NA, distToAnchor < max_dist_P_S))) %>%
  ungroup()



result2 <- result %>% dplyr::filter(!is.na(is_smaller))

result3 <- result2 %>% group_by(gene, direction) %>%
  summarize(count_true = sum(is_smaller, na.rm = TRUE),
            count_false = sum(is_smaller == FALSE, na.rm = TRUE)) %>%
  dplyr::mutate(count = count_true + count_false,
                perc = count_true/count*100) %>%
  dplyr::select(gene, direction, perc)

result3 <- result3 %>% group_by(gene) %>% summarize(perc = mean(perc))

####### DOing this for P-S groups
resultDir <- here(\../../result\)
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% psOver0 ~ \psOver0\,
                                            gene %in% psOver1 ~ \psOver1\,
                                            gene %in% psOver2 ~ \psOver2\,
                                            gene %in% psOver3 ~ \psOver3\,
                                            gene %in% psOver4 ~ \psOver4\,
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)

####### DOing this for P-E groups
peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% peOver0 ~ \peOver0\,
                                            gene %in% peOver1 ~ \peOver1\,
                                            gene %in% peOver2 ~ \peOver2\,
                                            gene %in% peOver3 ~ \peOver3\,
                                            gene %in% peOver4 ~ \peOver4\,
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)

####### DOing this for P-P groups

ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% ppOver0 ~ \ppOver0\,
                                            gene %in% ppOver1 ~ \ppOver1\,
                                            gene %in% ppOver2 ~ \ppOver2\,
                                            gene %in% ppOver3 ~ \ppOver3\,
                                            gene %in% ppOver4 ~ \ppOver4\,
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5yZXN1bHQgPC0gZGF0YSAlPiVcbiAgZ3JvdXBfYnkoZ2VuZSwgZGlyZWN0aW9uKSAlPiVcbiAgbXV0YXRlKGRpc3RUb0FuY2hvciA9IGFicyhkaXN0VG9BbmNob3IpKSAlPiVcbiAgbXV0YXRlKG1heF9kaXN0X1BfUyA9IGlmZWxzZShhbnkoQW5ubzIgPT0gXFxQLVNcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG1heChkaXN0VG9BbmNob3JbQW5ubzIgPT0gXFxQLVNcXF0sIG5hLnJtID0gVFJVRSksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5BKSlcbnJlc3VsdCA8LSByZXN1bHQgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgIT0gXFxQLVNcXCkgJT4lXG4gIG11dGF0ZShpc19zbWFsbGVyID0gaWZlbHNlKGlzLm5hKG1heF9kaXN0X1BfUyksIE5BLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGRpc3RUb0FuY2hvciA9PSBtYXhfZGlzdF9QX1MsIE5BLCBkaXN0VG9BbmNob3IgPCBtYXhfZGlzdF9QX1MpKSkgJT4lXG4gIHVuZ3JvdXAoKVxuXG5cblxucmVzdWx0MiA8LSByZXN1bHQgJT4lIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGlzX3NtYWxsZXIpKVxuXG5yZXN1bHQzIDwtIHJlc3VsdDIgJT4lIGdyb3VwX2J5KGdlbmUsIGRpcmVjdGlvbikgJT4lXG4gIHN1bW1hcml6ZShjb3VudF90cnVlID0gc3VtKGlzX3NtYWxsZXIsIG5hLnJtID0gVFJVRSksXG4gICAgICAgICAgICBjb3VudF9mYWxzZSA9IHN1bShpc19zbWFsbGVyID09IEZBTFNFLCBuYS5ybSA9IFRSVUUpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjb3VudCA9IGNvdW50X3RydWUgKyBjb3VudF9mYWxzZSxcbiAgICAgICAgICAgICAgICBwZXJjID0gY291bnRfdHJ1ZS9jb3VudCoxMDApICU+JVxuICBkcGx5cjo6c2VsZWN0KGdlbmUsIGRpcmVjdGlvbiwgcGVyYylcblxucmVzdWx0MyA8LSByZXN1bHQzICU+JSBncm91cF9ieShnZW5lKSAlPiUgc3VtbWFyaXplKHBlcmMgPSBtZWFuKHBlcmMpKVxuXG4jIyMjIyMjIERPaW5nIHRoaXMgZm9yIFAtUyBncm91cHNcbnJlc3VsdERpciA8LSBoZXJlKFxcLi4vLi4vcmVzdWx0XFwpXG50ZW1wMiA8LSByZWFkUkRTKGhlcmUocmVzdWx0RGlyLCBcXGdlbmVfbG9vcF9saW5rLnJkc1xcKSlcblxucHNPdmVyNCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDQpKSRnZW5lXG5wc092ZXIzIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMywgbnVtX3BzIDwgNCkpJGdlbmVcbnBzT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAyLCBudW1fcHMgPCAzKSkkZ2VuZVxucHNPdmVyMSA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDEsIG51bV9wcyA8IDIpKSRnZW5lXG5wc092ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPCAxKSkkZ2VuZVxuXG5cbnJlc3VsdDQgPC0gcmVzdWx0MyAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihnZW5lICVpbiUgcHNPdmVyMCB+IFxccHNPdmVyMFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcHNPdmVyMSB+IFxccHNPdmVyMVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcHNPdmVyMiB+IFxccHNPdmVyMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcHNPdmVyMyB+IFxccHNPdmVyM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcHNPdmVyNCB+IFxccHNPdmVyNFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbmdncGxvdChyZXN1bHQ0LCBhZXMoeCA9ICBncm91cCwgeSA9IHBlcmMpKSArIGdlb21fdmlvbGluKCkgKyBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjA1KSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpXG5cbiMjIyMjIyMgRE9pbmcgdGhpcyBmb3IgUC1FIGdyb3Vwc1xucGVPdmVyNCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDQpKSRnZW5lXG5wZU92ZXIzIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMywgbnVtX3BlIDwgNCkpJGdlbmVcbnBlT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAyLCBudW1fcGUgPCAzKSkkZ2VuZVxucGVPdmVyMSA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDEsIG51bV9wZSA8IDIpKSRnZW5lXG5wZU92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPCAxKSkkZ2VuZVxuXG5cbnJlc3VsdDQgPC0gcmVzdWx0MyAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihnZW5lICVpbiUgcGVPdmVyMCB+IFxccGVPdmVyMFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcGVPdmVyMSB+IFxccGVPdmVyMVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcGVPdmVyMiB+IFxccGVPdmVyMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcGVPdmVyMyB+IFxccGVPdmVyM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcGVPdmVyNCB+IFxccGVPdmVyNFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbmdncGxvdChyZXN1bHQ0LCBhZXMoeCA9ICBncm91cCwgeSA9IHBlcmMpKSArIGdlb21fdmlvbGluKCkgKyBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjA1KSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpXG5cbiMjIyMjIyMgRE9pbmcgdGhpcyBmb3IgUC1QIGdyb3Vwc1xuXG5wcE92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gNCkpJGdlbmVcbnBwT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAzLCBudW1fcHAgPCA0KSkkZ2VuZVxucHBPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDIsIG51bV9wcCA8IDMpKSRnZW5lXG5wcE92ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMSwgbnVtX3BwIDwgMikpJGdlbmVcbnBwT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA8IDEpKSRnZW5lXG5cblxucmVzdWx0NCA8LSByZXN1bHQzICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gY2FzZV93aGVuKGdlbmUgJWluJSBwcE92ZXIwIH4gXFxwcE92ZXIwXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwcE92ZXIxIH4gXFxwcE92ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwcE92ZXIyIH4gXFxwcE92ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwcE92ZXIzIH4gXFxwcE92ZXIzXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwcE92ZXI0IH4gXFxwcE92ZXI0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cblxuZ2dwbG90KHJlc3VsdDQsIGFlcyh4ID0gIGdyb3VwLCB5ID0gcGVyYykpICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMDUpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXClcblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n\nresult <- data %>%\n  group_by(gene, direction) %>%\n  mutate(distToAnchor = abs(distToAnchor)) %>%\n  mutate(max_dist_P_S = ifelse(any(Anno2 == \\P-S\\), \n                               max(distToAnchor[Anno2 == \\P-S\\], na.rm = TRUE), \n                               NA))\nresult <- result %>% dplyr::filter(Anno2 != \\P-S\\) %>%\n  mutate(is_smaller = ifelse(is.na(max_dist_P_S), NA, \n                             ifelse(distToAnchor == max_dist_P_S, NA, distToAnchor < max_dist_P_S))) %>%\n  ungroup()\n\n\n\nresult2 <- result %>% dplyr::filter(!is.na(is_smaller))\n\nresult3 <- result2 %>% group_by(gene, direction) %>%\n  summarize(count_true = sum(is_smaller, na.rm = TRUE),\n            count_false = sum(is_smaller == FALSE, na.rm = TRUE)) %>%\n  dplyr::mutate(count = count_true + count_false,\n                perc = count_true/count*100) %>%\n  dplyr::select(gene, direction, perc)\n\nresult3 <- result3 %>% group_by(gene) %>% summarize(perc = mean(perc))\n\n####### DOing this for P-S groups\nresultDir <- here(\\../../result\\)\ntemp2 <- readRDS(here(resultDir, \\gene_loop_link.rds\\))\n\npsOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene\npsOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene\npsOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene\npsOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene\npsOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene\n\n\nresult4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% psOver0 ~ \\psOver0\\,\n                                            gene %in% psOver1 ~ \\psOver1\\,\n                                            gene %in% psOver2 ~ \\psOver2\\,\n                                            gene %in% psOver3 ~ \\psOver3\\,\n                                            gene %in% psOver4 ~ \\psOver4\\,\n                                            TRUE ~ NA)) %>%\n  dplyr::filter(!is.na(group))\n\n\nggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)\n\n####### DOing this for P-E groups\npeOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene\npeOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene\npeOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene\npeOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene\npeOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene\n\n\nresult4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% peOver0 ~ \\peOver0\\,\n                                            gene %in% peOver1 ~ \\peOver1\\,\n                                            gene %in% peOver2 ~ \\peOver2\\,\n                                            gene %in% peOver3 ~ \\peOver3\\,\n                                            gene %in% peOver4 ~ \\peOver4\\,\n                                            TRUE ~ NA)) %>%\n  dplyr::filter(!is.na(group))\n\n\nggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)\n\n####### DOing this for P-P groups\n\nppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene\nppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene\nppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene\nppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene\nppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene\n\n\nresult4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% ppOver0 ~ \\ppOver0\\,\n                                            gene %in% ppOver1 ~ \\ppOver1\\,\n                                            gene %in% ppOver2 ~ \\ppOver2\\,\n                                            gene %in% ppOver3 ~ \\ppOver3\\,\n                                            gene %in% ppOver4 ~ \\ppOver4\\,\n                                            TRUE ~ NA)) %>%\n  dplyr::filter(!is.na(group))\n\n\nggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +\n  stat_summary(aes(group = group), fun = mean, geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\)\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5yZXN1bHQgPC0gZGF0YSAlPiVcbiAgZ3JvdXBfYnkoZ2VuZSwgZGlyZWN0aW9uKSAlPiVcbiAgbXV0YXRlKGRpc3RUb0FuY2hvciA9IGFicyhkaXN0VG9BbmNob3IpKSAlPiVcbiAgbXV0YXRlKG1heF9kaXN0X1BfUyA9IGlmZWxzZShhbnkoQW5ubzIgPT0gXFxQLVNcXCksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG1heChkaXN0VG9BbmNob3JbQW5ubzIgPT0gXFxQLVNcXF0sIG5hLnJtID0gVFJVRSksIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5BKSlcbnJlc3VsdCA8LSByZXN1bHQgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgIT0gXFxQLVNcXCkgJT4lXG4gIG11dGF0ZShpc19zbWFsbGVyID0gaWZlbHNlKGlzLm5hKG1heF9kaXN0X1BfUyksIE5BLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaWZlbHNlKGRpc3RUb0FuY2hvciA9PSBtYXhfZGlzdF9QX1MsIE5BLCBkaXN0VG9BbmNob3IgPCBtYXhfZGlzdF9QX1MpKSkgJT4lXG4gIHVuZ3JvdXAoKVxuXG5cblxucmVzdWx0MiA8LSByZXN1bHQgJT4lIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGlzX3NtYWxsZXIpKVxuXG5yZXN1bHQzIDwtIHJlc3VsdDIgJT4lIGdyb3VwX2J5KGdlbmUsIGRpcmVjdGlvbikgJT4lXG4gIHN1bW1hcml6ZShjb3VudF90cnVlID0gc3VtKGlzX3NtYWxsZXIsIG5hLnJtID0gVFJVRSksXG4gICAgICAgICAgICBjb3VudF9mYWxzZSA9IHN1bShpc19zbWFsbGVyID09IEZBTFNFLCBuYS5ybSA9IFRSVUUpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShjb3VudCA9IGNvdW50X3RydWUgKyBjb3VudF9mYWxzZSxcbiAgICAgICAgICAgICAgICBwZXJjID0gY291bnRfdHJ1ZS9jb3VudCoxMDApICU+JVxuICBkcGx5cjo6c2VsZWN0KGdlbmUsIGRpcmVjdGlvbiwgcGVyYylcblxucmVzdWx0MyA8LSByZXN1bHQzICU+JSBncm91cF9ieShnZW5lKSAlPiUgc3VtbWFyaXplKHBlcmMgPSBtZWFuKHBlcmMpKVxuXG4jIyMjIyMjIERPaW5nIHRoaXMgZm9yIFAtUyBncm91cHNcbnJlc3VsdERpciA8LSBoZXJlKFxcLi4vLi4vcmVzdWx0XFwpXG50ZW1wMiA8LSByZWFkUkRTKGhlcmUocmVzdWx0RGlyLCBcXGdlbmVfbG9vcF9saW5rLnJkc1xcKSlcblxucHNPdmVyNCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDQpKSRnZW5lXG5wc092ZXIzIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPj0gMywgbnVtX3BzIDwgNCkpJGdlbmVcbnBzT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcyA+PSAyLCBudW1fcHMgPCAzKSkkZ2VuZVxucHNPdmVyMSA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BzID49IDEsIG51bV9wcyA8IDIpKSRnZW5lXG5wc092ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHMgPCAxKSkkZ2VuZVxuXG5cbnJlc3VsdDQgPC0gcmVzdWx0MyAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihnZW5lICVpbiUgcHNPdmVyMCB+IFxccHNPdmVyMFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcHNPdmVyMSB+IFxccHNPdmVyMVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcHNPdmVyMiB+IFxccHNPdmVyMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcHNPdmVyMyB+IFxccHNPdmVyM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcHNPdmVyNCB+IFxccHNPdmVyNFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbmdncGxvdChyZXN1bHQ0LCBhZXMoeCA9ICBncm91cCwgeSA9IHBlcmMpKSArIGdlb21fdmlvbGluKCkgKyBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjA1KSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpXG5cbiMjIyMjIyMgRE9pbmcgdGhpcyBmb3IgUC1FIGdyb3Vwc1xucGVPdmVyNCA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDQpKSRnZW5lXG5wZU92ZXIzIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPj0gMywgbnVtX3BlIDwgNCkpJGdlbmVcbnBlT3ZlcjIgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wZSA+PSAyLCBudW1fcGUgPCAzKSkkZ2VuZVxucGVPdmVyMSA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BlID49IDEsIG51bV9wZSA8IDIpKSRnZW5lXG5wZU92ZXIwIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcGUgPCAxKSkkZ2VuZVxuXG5cbnJlc3VsdDQgPC0gcmVzdWx0MyAlPiUgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihnZW5lICVpbiUgcGVPdmVyMCB+IFxccGVPdmVyMFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcGVPdmVyMSB+IFxccGVPdmVyMVxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcGVPdmVyMiB+IFxccGVPdmVyMlxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcGVPdmVyMyB+IFxccGVPdmVyM1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnZW5lICVpbiUgcGVPdmVyNCB+IFxccGVPdmVyNFxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFIH4gTkEpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighaXMubmEoZ3JvdXApKVxuXG5cbmdncGxvdChyZXN1bHQ0LCBhZXMoeCA9ICBncm91cCwgeSA9IHBlcmMpKSArIGdlb21fdmlvbGluKCkgKyBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjA1KSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBncm91cCksIGZ1biA9IG1lYW4sIGdlb20gPSBcXHBvaW50XFwsIHNoYXBlID0gMjEsIHNpemUgPSAyLCBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFwpXG5cbiMjIyMjIyMgRE9pbmcgdGhpcyBmb3IgUC1QIGdyb3Vwc1xuXG5wcE92ZXI0IDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gNCkpJGdlbmVcbnBwT3ZlcjMgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA+PSAzLCBudW1fcHAgPCA0KSkkZ2VuZVxucHBPdmVyMiA8LSAodGVtcDIgJT4lIGRwbHlyOjpmaWx0ZXIobnVtX3BwID49IDIsIG51bV9wcCA8IDMpKSRnZW5lXG5wcE92ZXIxIDwtICh0ZW1wMiAlPiUgZHBseXI6OmZpbHRlcihudW1fcHAgPj0gMSwgbnVtX3BwIDwgMikpJGdlbmVcbnBwT3ZlcjAgPC0gKHRlbXAyICU+JSBkcGx5cjo6ZmlsdGVyKG51bV9wcCA8IDEpKSRnZW5lXG5cblxucmVzdWx0NCA8LSByZXN1bHQzICU+JSBkcGx5cjo6bXV0YXRlKGdyb3VwID0gY2FzZV93aGVuKGdlbmUgJWluJSBwcE92ZXIwIH4gXFxwcE92ZXIwXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwcE92ZXIxIH4gXFxwcE92ZXIxXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwcE92ZXIyIH4gXFxwcE92ZXIyXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwcE92ZXIzIH4gXFxwcE92ZXIzXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGdlbmUgJWluJSBwcE92ZXI0IH4gXFxwcE92ZXI0XFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRSVUUgfiBOQSkpICU+JVxuICBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cblxuZ2dwbG90KHJlc3VsdDQsIGFlcyh4ID0gIGdyb3VwLCB5ID0gcGVyYykpICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMDUpICsgdGhlbWVfY2xhc3NpYygpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXClcblxuYGBgXG5gYGAifQ== -->

```r
```r

result <- data %>%
  group_by(gene, direction) %>%
  mutate(distToAnchor = abs(distToAnchor)) %>%
  mutate(max_dist_P_S = ifelse(any(Anno2 == \P-S\), 
                               max(distToAnchor[Anno2 == \P-S\], na.rm = TRUE), 
                               NA))
result <- result %>% dplyr::filter(Anno2 != \P-S\) %>%
  mutate(is_smaller = ifelse(is.na(max_dist_P_S), NA, 
                             ifelse(distToAnchor == max_dist_P_S, NA, distToAnchor < max_dist_P_S))) %>%
  ungroup()



result2 <- result %>% dplyr::filter(!is.na(is_smaller))

result3 <- result2 %>% group_by(gene, direction) %>%
  summarize(count_true = sum(is_smaller, na.rm = TRUE),
            count_false = sum(is_smaller == FALSE, na.rm = TRUE)) %>%
  dplyr::mutate(count = count_true + count_false,
                perc = count_true/count*100) %>%
  dplyr::select(gene, direction, perc)

result3 <- result3 %>% group_by(gene) %>% summarize(perc = mean(perc))

####### DOing this for P-S groups
resultDir <- here(\../../result\)
temp2 <- readRDS(here(resultDir, \gene_loop_link.rds\))

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% psOver0 ~ \psOver0\,
                                            gene %in% psOver1 ~ \psOver1\,
                                            gene %in% psOver2 ~ \psOver2\,
                                            gene %in% psOver3 ~ \psOver3\,
                                            gene %in% psOver4 ~ \psOver4\,
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)

####### DOing this for P-E groups
peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% peOver0 ~ \peOver0\,
                                            gene %in% peOver1 ~ \peOver1\,
                                            gene %in% peOver2 ~ \peOver2\,
                                            gene %in% peOver3 ~ \peOver3\,
                                            gene %in% peOver4 ~ \peOver4\,
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)

####### DOing this for P-P groups

ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% ppOver0 ~ \ppOver0\,
                                            gene %in% ppOver1 ~ \ppOver1\,
                                            gene %in% ppOver2 ~ \ppOver2\,
                                            gene %in% ppOver3 ~ \ppOver3\,
                                            gene %in% ppOver4 ~ \ppOver4\,
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [2.33] Checking guidance

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVjR1ZoYXk1RFZFTkdJRHd0SUdsdGNHOXlkRkJsWVdzb2FHVnlaU2h5WldaRWFYSXNJRndpTXpNeU5EaGZRMVJEUmw4d055MDNNamxmUW5KMVkyVXRORjl3WldGcmN5NXRaWEpuWlZCbFlXc3VZbVZrWENJcEtWeHVYRzVzYVdKeVlYSjVLRUpUWjJWdWIyMWxMazF0ZFhOamRXeDFjeTVWUTFORExtMXRNVEFwWEc1Y2JpTWdSWGgwY21GamRDQnpaWEYxWlc1alpYTmNibk5sY1hWbGJtTmxjeUE4TFNCblpYUlRaWEVvUWxOblpXNXZiV1V1VFcxMWMyTjFiSFZ6TGxWRFUwTXViVzB4TUN3Z2NHVmhheTVEVkVOR0tWeHVYRzVjYmlNZ1IyVjBJSFJvWlNCRFZFTkdJRzF2ZEdsbUlDaHZjaUJ3Y205MmFXUmxJSGx2ZFhJZ2IzZHVJRkJYVFNsY2JtTjBZMlpmYlc5MGFXWWdQQzBnY1hWbGNua29UVzkwYVdaRVlpd2dZeWhjSWtOVVEwWmNJaXdnWENKTmJYVnpZM1ZzZFhOY0lpa3BXMXN4WFYxY2JseHVJeUJUWTJGdUlHWnZjaUIwYUdVZ2JXOTBhV1pjYm0xdmRHbG1YMmhwZEhNZ1BDMGdiR0Z3Y0d4NUtITmxjWFZsYm1ObGN5d2dablZ1WTNScGIyNG9jMlZ4S1NCN1hHNGdJQ0FnYldGMFkyaFFWMDBvWTNSalpsOXRiM1JwWml3Z2MyVnhMQ0J0YVc0dWMyTnZjbVVnUFNCY0lqZ3dKVndpS1NBaklFRmthblZ6ZENCdGFXNHVjMk52Y21VZ1lYTWdibVZsWkdWa1hHNTlLVnh1WEc1dGIzUnBabDlvYVhSelgzSmxkbVZ5YzJVZ1BDMGdiR0Z3Y0d4NUtITmxjWFZsYm1ObGN5d2dablZ1WTNScGIyNG9jMlZ4S1NCN1hHNGdJQ0FnYldGMFkyaFFWMDBvWTNSalpsOXRiM1JwWml3Z2NtVjJaWEp6WlVOdmJYQnNaVzFsYm5Rb2MyVnhLU3dnYldsdUxuTmpiM0psSUQwZ1hDSTRNQ1ZjSWlsY2JuMHBYRzVjYmlNZ1EyOXRZbWx1WlNCeVpYTjFiSFJ6WEc1eVpYTjFiSFFnUEMwZ2JXRndjR3g1S0daMWJtTjBhVzl1S0daM1pDd2djbVYyS1NCN1hHNGdJQ0FnYkdsemRDaG1iM0ozWVhKa0lEMGdabmRrTENCeVpYWmxjbk5sSUQwZ2NtVjJLVnh1ZlN3Z2JXOTBhV1pmYUdsMGN5d2diVzkwYVdaZmFHbDBjMTl5WlhabGNuTmxMQ0JUU1UxUVRFbEdXU0E5SUVaQlRGTkZLVnh1WEc1Y2JuSmxjM1ZzZEZ0Yk5WMWRYRzVjYmx4dWNtVnpkV3gwWDNScFltSnNaU0E4TFNCMGFXSmliR1VvWEc0Z0lDQWdjR1ZoYTE5cFpDQTlJSE5sY1Y5aGJHOXVaeWh5WlhOMWJIUXBMQ0FqSUVOeVpXRjBaU0JoYmlCcFpHVnVkR2xtYVdWeUlHWnZjaUJsWVdOb0lIQmxZV3RjYmlBZ0lDQmhiR2xuYm0xbGJuUWdQU0J0WVhCZlkyaHlLSEpsYzNWc2RDd2dablZ1WTNScGIyNG9jbVZ6S1NCN1hHNGdJQ0FnSUNBZ0lHaGhjMTltZDJRZ1BDMGdiR1Z1WjNSb0tISmxjeVJtYjNKM1lYSmtLU0ErSURCY2JpQWdJQ0FnSUNBZ2FHRnpYM0psZGlBOExTQnNaVzVuZEdnb2NtVnpKSEpsZG1WeWMyVXBJRDRnTUZ4dUlDQWdJQ0FnSUNCY2JpQWdJQ0FnSUNBZ2FXWWdLR2hoYzE5bWQyUWdKaVlnYUdGelgzSmxkaWtnWENKbWQyUnlaWFpjSWx4dUlDQWdJQ0FnSUNCbGJITmxJR2xtSUNob1lYTmZabmRrS1NCY0ltWjNaRndpWEc0Z0lDQWdJQ0FnSUdWc2MyVWdhV1lnS0doaGMxOXlaWFlwSUZ3aWNtVjJYQ0pjYmlBZ0lDQWdJQ0FnWld4elpTQmNJbTV2Ym1WY0lseHVJQ0FnSUgwcFhHNHBYRzVjYm5SbGJYQWdQQzBnWVhOZmRHbGlZbXhsS0hCbFlXc3VRMVJEUmlrZ0pUNGxJR0pwYm1SZlkyOXNjeWh5WlhOMWJIUmZkR2xpWW14bEtTQWxQaVZjYmlBZ1pIQnNlWEk2T25ObGJHVmpkQ2h6WlhGdVlXMWxjeXdnYzNSaGNuUXNJR1Z1WkN3Z1lXeHBaMjV0Wlc1MEtWeHVYRzVtZDNKcGRHVW9kR1Z0Y0N3Z2FHVnlaU2h5WldaRWFYSXNJRndpTXpNeU5EaGZRMVJEUmw4d055MDNNamxmUW5KMVkyVXRORjl3WldGcmN5NXRaWEpuWlZCbFlXc3ViVzkwYVdaQmJtNXZkR0YwWldRdVltVmtYQ0lwTENCamIyd3VibUZ0WlhNZ1BTQkdRVXhUUlN3Z2MyVndJRDBnWENKY1hIUmNJaWxjYm1CZ1lDSjkgLS0+XG5cbmBgYHJcbnBlYWsuQ1RDRiA8LSBpbXBvcnRQZWFrKGhlcmUocmVmRGlyLCBcXDMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLmJlZFxcKSlcblxubGlicmFyeShCU2dlbm9tZS5NbXVzY3VsdXMuVUNTQy5tbTEwKVxuXG4jIEV4dHJhY3Qgc2VxdWVuY2VzXG5zZXF1ZW5jZXMgPC0gZ2V0U2VxKEJTZ2Vub21lLk1tdXNjdWx1cy5VQ1NDLm1tMTAsIHBlYWsuQ1RDRilcblxuXG4jIEdldCB0aGUgQ1RDRiBtb3RpZiAob3IgcHJvdmlkZSB5b3VyIG93biBQV00pXG5jdGNmX21vdGlmIDwtIHF1ZXJ5KE1vdGlmRGIsIGMoXFxDVENGXFwsIFxcTW11c2N1bHVzXFwpKVtbMV1dXG5cbiMgU2NhbiBmb3IgdGhlIG1vdGlmXG5tb3RpZl9oaXRzIDwtIGxhcHBseShzZXF1ZW5jZXMsIGZ1bmN0aW9uKHNlcSkge1xuICAgIG1hdGNoUFdNKGN0Y2ZfbW90aWYsIHNlcSwgbWluLnNjb3JlID0gXFw4MCVcXCkgIyBBZGp1c3QgbWluLnNjb3JlIGFzIG5lZWRlZFxufSlcblxubW90aWZfaGl0c19yZXZlcnNlIDwtIGxhcHBseShzZXF1ZW5jZXMsIGZ1bmN0aW9uKHNlcSkge1xuICAgIG1hdGNoUFdNKGN0Y2ZfbW90aWYsIHJldmVyc2VDb21wbGVtZW50KHNlcSksIG1pbi5zY29yZSA9IFxcODAlXFwpXG59KVxuXG4jIENvbWJpbmUgcmVzdWx0c1xucmVzdWx0IDwtIG1hcHBseShmdW5jdGlvbihmd2QsIHJldikge1xuICAgIGxpc3QoZm9yd2FyZCA9IGZ3ZCwgcmV2ZXJzZSA9IHJldilcbn0sIG1vdGlmX2hpdHMsIG1vdGlmX2hpdHNfcmV2ZXJzZSwgU0lNUExJRlkgPSBGQUxTRSlcblxuXG5yZXN1bHRbWzVdXVxuXG5cbnJlc3VsdF90aWJibGUgPC0gdGliYmxlKFxuICAgIHBlYWtfaWQgPSBzZXFfYWxvbmcocmVzdWx0KSwgIyBDcmVhdGUgYW4gaWRlbnRpZmllciBmb3IgZWFjaCBwZWFrXG4gICAgYWxpZ25tZW50ID0gbWFwX2NocihyZXN1bHQsIGZ1bmN0aW9uKHJlcykge1xuICAgICAgICBoYXNfZndkIDwtIGxlbmd0aChyZXMkZm9yd2FyZCkgPiAwXG4gICAgICAgIGhhc19yZXYgPC0gbGVuZ3RoKHJlcyRyZXZlcnNlKSA+IDBcbiAgICAgICAgXG4gICAgICAgIGlmIChoYXNfZndkICYmIGhhc19yZXYpIFxcZndkcmV2XFxcbiAgICAgICAgZWxzZSBpZiAoaGFzX2Z3ZCkgXFxmd2RcXFxuICAgICAgICBlbHNlIGlmIChoYXNfcmV2KSBcXHJldlxcXG4gICAgICAgIGVsc2UgXFxub25lXFxcbiAgICB9KVxuKVxuXG50ZW1wIDwtIGFzX3RpYmJsZShwZWFrLkNUQ0YpICU+JSBiaW5kX2NvbHMocmVzdWx0X3RpYmJsZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3Qoc2VxbmFtZXMsIHN0YXJ0LCBlbmQsIGFsaWdubWVudClcblxuZndyaXRlKHRlbXAsIGhlcmUocmVmRGlyLCBcXDMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLm1vdGlmQW5ub3RhdGVkLmJlZFxcKSwgY29sLm5hbWVzID0gRkFMU0UsIHNlcCA9IFxcXFx0XFwpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
peak.CTCF <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))

library(BSgenome.Mmusculus.UCSC.mm10)

# Extract sequences
sequences <- getSeq(BSgenome.Mmusculus.UCSC.mm10, peak.CTCF)


# Get the CTCF motif (or provide your own PWM)
ctcf_motif <- query(MotifDb, c(\CTCF\, \Mmusculus\))[[1]]

# Scan for the motif
motif_hits <- lapply(sequences, function(seq) {
    matchPWM(ctcf_motif, seq, min.score = \80%\) # Adjust min.score as needed
})

motif_hits_reverse <- lapply(sequences, function(seq) {
    matchPWM(ctcf_motif, reverseComplement(seq), min.score = \80%\)
})

# Combine results
result <- mapply(function(fwd, rev) {
    list(forward = fwd, reverse = rev)
}, motif_hits, motif_hits_reverse, SIMPLIFY = FALSE)


result[[5]]


result_tibble <- tibble(
    peak_id = seq_along(result), # Create an identifier for each peak
    alignment = map_chr(result, function(res) {
        has_fwd <- length(res$forward) > 0
        has_rev <- length(res$reverse) > 0
        
        if (has_fwd && has_rev) \fwdrev\
        else if (has_fwd) \fwd\
        else if (has_rev) \rev\
        else \none\
    })
)

temp <- as_tibble(peak.CTCF) %>% bind_cols(result_tibble) %>%
  dplyr::select(seqnames, start, end, alignment)

fwrite(temp, here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed\), col.names = FALSE, sep = \\t\)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWNHVmhheTVEVkVOR0lEd3RJR2x0Y0c5eWRGQmxZV3NvYUdWeVpTaHlaV1pFYVhJc0lGeGNNek15TkRoZlExUkRSbDh3TnkwM01qbGZRbkoxWTJVdE5GOXdaV0ZyY3k1dFpYSm5aVkJsWVdzdVltVmtYRndwS1Z4dVhHNXNhV0p5WVhKNUtFSlRaMlZ1YjIxbExrMXRkWE5qZFd4MWN5NVZRMU5ETG0xdE1UQXBYRzVjYmlNZ1JYaDBjbUZqZENCelpYRjFaVzVqWlhOY2JuTmxjWFZsYm1ObGN5QThMU0JuWlhSVFpYRW9RbE5uWlc1dmJXVXVUVzExYzJOMWJIVnpMbFZEVTBNdWJXMHhNQ3dnY0dWaGF5NURWRU5HS1Z4dVhHNWNiaU1nUjJWMElIUm9aU0JEVkVOR0lHMXZkR2xtSUNodmNpQndjbTkyYVdSbElIbHZkWElnYjNkdUlGQlhUU2xjYm1OMFkyWmZiVzkwYVdZZ1BDMGdjWFZsY25rb1RXOTBhV1pFWWl3Z1l5aGNYRU5VUTBaY1hDd2dYRnhOYlhWelkzVnNkWE5jWENrcFcxc3hYVjFjYmx4dUl5QlRZMkZ1SUdadmNpQjBhR1VnYlc5MGFXWmNibTF2ZEdsbVgyaHBkSE1nUEMwZ2JHRndjR3g1S0hObGNYVmxibU5sY3l3Z1puVnVZM1JwYjI0b2MyVnhLU0I3WEc0Z0lDQWdiV0YwWTJoUVYwMG9ZM1JqWmw5dGIzUnBaaXdnYzJWeExDQnRhVzR1YzJOdmNtVWdQU0JjWERnd0pWeGNLU0FqSUVGa2FuVnpkQ0J0YVc0dWMyTnZjbVVnWVhNZ2JtVmxaR1ZrWEc1OUtWeHVYRzV0YjNScFpsOW9hWFJ6WDNKbGRtVnljMlVnUEMwZ2JHRndjR3g1S0hObGNYVmxibU5sY3l3Z1puVnVZM1JwYjI0b2MyVnhLU0I3WEc0Z0lDQWdiV0YwWTJoUVYwMG9ZM1JqWmw5dGIzUnBaaXdnY21WMlpYSnpaVU52YlhCc1pXMWxiblFvYzJWeEtTd2diV2x1TG5OamIzSmxJRDBnWEZ3NE1DVmNYQ2xjYm4wcFhHNWNiaU1nUTI5dFltbHVaU0J5WlhOMWJIUnpYRzV5WlhOMWJIUWdQQzBnYldGd2NHeDVLR1oxYm1OMGFXOXVLR1ozWkN3Z2NtVjJLU0I3WEc0Z0lDQWdiR2x6ZENobWIzSjNZWEprSUQwZ1puZGtMQ0J5WlhabGNuTmxJRDBnY21WMktWeHVmU3dnYlc5MGFXWmZhR2wwY3l3Z2JXOTBhV1pmYUdsMGMxOXlaWFpsY25ObExDQlRTVTFRVEVsR1dTQTlJRVpCVEZORktWeHVYRzVjYm5KbGMzVnNkRnRiTlYxZFhHNWNibHh1Y21WemRXeDBYM1JwWW1Kc1pTQThMU0IwYVdKaWJHVW9YRzRnSUNBZ2NHVmhhMTlwWkNBOUlITmxjVjloYkc5dVp5aHlaWE4xYkhRcExDQWpJRU55WldGMFpTQmhiaUJwWkdWdWRHbG1hV1Z5SUdadmNpQmxZV05vSUhCbFlXdGNiaUFnSUNCaGJHbG5ibTFsYm5RZ1BTQnRZWEJmWTJoeUtISmxjM1ZzZEN3Z1puVnVZM1JwYjI0b2NtVnpLU0I3WEc0Z0lDQWdJQ0FnSUdoaGMxOW1kMlFnUEMwZ2JHVnVaM1JvS0hKbGN5Um1iM0ozWVhKa0tTQStJREJjYmlBZ0lDQWdJQ0FnYUdGelgzSmxkaUE4TFNCc1pXNW5kR2dvY21WekpISmxkbVZ5YzJVcElENGdNRnh1SUNBZ0lDQWdJQ0JjYmlBZ0lDQWdJQ0FnYVdZZ0tHaGhjMTltZDJRZ0ppWWdhR0Z6WDNKbGRpa2dYRnhtZDJSeVpYWmNYRnh1SUNBZ0lDQWdJQ0JsYkhObElHbG1JQ2hvWVhOZlpuZGtLU0JjWEdaM1pGeGNYRzRnSUNBZ0lDQWdJR1ZzYzJVZ2FXWWdLR2hoYzE5eVpYWXBJRnhjY21WMlhGeGNiaUFnSUNBZ0lDQWdaV3h6WlNCY1hHNXZibVZjWEZ4dUlDQWdJSDBwWEc0cFhHNWNiblJsYlhBZ1BDMGdZWE5mZEdsaVlteGxLSEJsWVdzdVExUkRSaWtnSlQ0bElHSnBibVJmWTI5c2N5aHlaWE4xYkhSZmRHbGlZbXhsS1NBbFBpVmNiaUFnWkhCc2VYSTZPbk5sYkdWamRDaHpaWEZ1WVcxbGN5d2djM1JoY25Rc0lHVnVaQ3dnWVd4cFoyNXRaVzUwS1Z4dVhHNW1kM0pwZEdVb2RHVnRjQ3dnYUdWeVpTaHlaV1pFYVhJc0lGeGNNek15TkRoZlExUkRSbDh3TnkwM01qbGZRbkoxWTJVdE5GOXdaV0ZyY3k1dFpYSm5aVkJsWVdzdWJXOTBhV1pCYm01dmRHRjBaV1F1WW1Wa1hGd3BMQ0JqYjJ3dWJtRnRaWE1nUFNCR1FVeFRSU3dnYzJWd0lEMGdYRnhjWEhSY1hDbGNibUJnWUZ4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG5gYGByXG5wZWFrLkNUQ0YgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFwzMzI0OF9DVENGXzA3LTcyOV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcXCkpXG5cbmxpYnJhcnkoQlNnZW5vbWUuTW11c2N1bHVzLlVDU0MubW0xMClcblxuIyBFeHRyYWN0IHNlcXVlbmNlc1xuc2VxdWVuY2VzIDwtIGdldFNlcShCU2dlbm9tZS5NbXVzY3VsdXMuVUNTQy5tbTEwLCBwZWFrLkNUQ0YpXG5cblxuIyBHZXQgdGhlIENUQ0YgbW90aWYgKG9yIHByb3ZpZGUgeW91ciBvd24gUFdNKVxuY3RjZl9tb3RpZiA8LSBxdWVyeShNb3RpZkRiLCBjKFxcQ1RDRlxcLCBcXE1tdXNjdWx1c1xcKSlbWzFdXVxuXG4jIFNjYW4gZm9yIHRoZSBtb3RpZlxubW90aWZfaGl0cyA8LSBsYXBwbHkoc2VxdWVuY2VzLCBmdW5jdGlvbihzZXEpIHtcbiAgICBtYXRjaFBXTShjdGNmX21vdGlmLCBzZXEsIG1pbi5zY29yZSA9IFxcODAlXFwpICMgQWRqdXN0IG1pbi5zY29yZSBhcyBuZWVkZWRcbn0pXG5cbm1vdGlmX2hpdHNfcmV2ZXJzZSA8LSBsYXBwbHkoc2VxdWVuY2VzLCBmdW5jdGlvbihzZXEpIHtcbiAgICBtYXRjaFBXTShjdGNmX21vdGlmLCByZXZlcnNlQ29tcGxlbWVudChzZXEpLCBtaW4uc2NvcmUgPSBcXDgwJVxcKVxufSlcblxuIyBDb21iaW5lIHJlc3VsdHNcbnJlc3VsdCA8LSBtYXBwbHkoZnVuY3Rpb24oZndkLCByZXYpIHtcbiAgICBsaXN0KGZvcndhcmQgPSBmd2QsIHJldmVyc2UgPSByZXYpXG59LCBtb3RpZl9oaXRzLCBtb3RpZl9oaXRzX3JldmVyc2UsIFNJTVBMSUZZID0gRkFMU0UpXG5cblxucmVzdWx0W1s1XV1cblxuXG5yZXN1bHRfdGliYmxlIDwtIHRpYmJsZShcbiAgICBwZWFrX2lkID0gc2VxX2Fsb25nKHJlc3VsdCksICMgQ3JlYXRlIGFuIGlkZW50aWZpZXIgZm9yIGVhY2ggcGVha1xuICAgIGFsaWdubWVudCA9IG1hcF9jaHIocmVzdWx0LCBmdW5jdGlvbihyZXMpIHtcbiAgICAgICAgaGFzX2Z3ZCA8LSBsZW5ndGgocmVzJGZvcndhcmQpID4gMFxuICAgICAgICBoYXNfcmV2IDwtIGxlbmd0aChyZXMkcmV2ZXJzZSkgPiAwXG4gICAgICAgIFxuICAgICAgICBpZiAoaGFzX2Z3ZCAmJiBoYXNfcmV2KSBcXGZ3ZHJldlxcXG4gICAgICAgIGVsc2UgaWYgKGhhc19md2QpIFxcZndkXFxcbiAgICAgICAgZWxzZSBpZiAoaGFzX3JldikgXFxyZXZcXFxuICAgICAgICBlbHNlIFxcbm9uZVxcXG4gICAgfSlcbilcblxudGVtcCA8LSBhc190aWJibGUocGVhay5DVENGKSAlPiUgYmluZF9jb2xzKHJlc3VsdF90aWJibGUpICU+JVxuICBkcGx5cjo6c2VsZWN0KHNlcW5hbWVzLCBzdGFydCwgZW5kLCBhbGlnbm1lbnQpXG5cbmZ3cml0ZSh0ZW1wLCBoZXJlKHJlZkRpciwgXFwzMzI0OF9DVENGXzA3LTcyOV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5tb3RpZkFubm90YXRlZC5iZWRcXCksIGNvbC5uYW1lcyA9IEZBTFNFLCBzZXAgPSBcXFxcdFxcKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxucGVhay5DVENGIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcMzMyNDhfQ1RDRl8wNy03MjlfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKVxuXG5saWJyYXJ5KEJTZ2Vub21lLk1tdXNjdWx1cy5VQ1NDLm1tMTApXG5cbiMgRXh0cmFjdCBzZXF1ZW5jZXNcbnNlcXVlbmNlcyA8LSBnZXRTZXEoQlNnZW5vbWUuTW11c2N1bHVzLlVDU0MubW0xMCwgcGVhay5DVENGKVxuXG5cbiMgR2V0IHRoZSBDVENGIG1vdGlmIChvciBwcm92aWRlIHlvdXIgb3duIFBXTSlcbmN0Y2ZfbW90aWYgPC0gcXVlcnkoTW90aWZEYiwgYyhcXENUQ0ZcXCwgXFxNbXVzY3VsdXNcXCkpW1sxXV1cblxuIyBTY2FuIGZvciB0aGUgbW90aWZcbm1vdGlmX2hpdHMgPC0gbGFwcGx5KHNlcXVlbmNlcywgZnVuY3Rpb24oc2VxKSB7XG4gICAgbWF0Y2hQV00oY3RjZl9tb3RpZiwgc2VxLCBtaW4uc2NvcmUgPSBcXDgwJVxcKSAjIEFkanVzdCBtaW4uc2NvcmUgYXMgbmVlZGVkXG59KVxuXG5tb3RpZl9oaXRzX3JldmVyc2UgPC0gbGFwcGx5KHNlcXVlbmNlcywgZnVuY3Rpb24oc2VxKSB7XG4gICAgbWF0Y2hQV00oY3RjZl9tb3RpZiwgcmV2ZXJzZUNvbXBsZW1lbnQoc2VxKSwgbWluLnNjb3JlID0gXFw4MCVcXClcbn0pXG5cbiMgQ29tYmluZSByZXN1bHRzXG5yZXN1bHQgPC0gbWFwcGx5KGZ1bmN0aW9uKGZ3ZCwgcmV2KSB7XG4gICAgbGlzdChmb3J3YXJkID0gZndkLCByZXZlcnNlID0gcmV2KVxufSwgbW90aWZfaGl0cywgbW90aWZfaGl0c19yZXZlcnNlLCBTSU1QTElGWSA9IEZBTFNFKVxuXG5cbnJlc3VsdFtbNV1dXG5cblxucmVzdWx0X3RpYmJsZSA8LSB0aWJibGUoXG4gICAgcGVha19pZCA9IHNlcV9hbG9uZyhyZXN1bHQpLCAjIENyZWF0ZSBhbiBpZGVudGlmaWVyIGZvciBlYWNoIHBlYWtcbiAgICBhbGlnbm1lbnQgPSBtYXBfY2hyKHJlc3VsdCwgZnVuY3Rpb24ocmVzKSB7XG4gICAgICAgIGhhc19md2QgPC0gbGVuZ3RoKHJlcyRmb3J3YXJkKSA+IDBcbiAgICAgICAgaGFzX3JldiA8LSBsZW5ndGgocmVzJHJldmVyc2UpID4gMFxuICAgICAgICBcbiAgICAgICAgaWYgKGhhc19md2QgJiYgaGFzX3JldikgXFxmd2RyZXZcXFxuICAgICAgICBlbHNlIGlmIChoYXNfZndkKSBcXGZ3ZFxcXG4gICAgICAgIGVsc2UgaWYgKGhhc19yZXYpIFxccmV2XFxcbiAgICAgICAgZWxzZSBcXG5vbmVcXFxuICAgIH0pXG4pXG5cbnRlbXAgPC0gYXNfdGliYmxlKHBlYWsuQ1RDRikgJT4lIGJpbmRfY29scyhyZXN1bHRfdGliYmxlKSAlPiVcbiAgZHBseXI6OnNlbGVjdChzZXFuYW1lcywgc3RhcnQsIGVuZCwgYWxpZ25tZW50KVxuXG5md3JpdGUodGVtcCwgaGVyZShyZWZEaXIsIFxcMzMyNDhfQ1RDRl8wNy03MjlfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsubW90aWZBbm5vdGF0ZWQuYmVkXFwpLCBjb2wubmFtZXMgPSBGQUxTRSwgc2VwID0gXFxcXHRcXClcbmBgYFxuYGBgIn0= -->

```r
```r
peak.CTCF <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))

library(BSgenome.Mmusculus.UCSC.mm10)

# Extract sequences
sequences <- getSeq(BSgenome.Mmusculus.UCSC.mm10, peak.CTCF)


# Get the CTCF motif (or provide your own PWM)
ctcf_motif <- query(MotifDb, c(\CTCF\, \Mmusculus\))[[1]]

# Scan for the motif
motif_hits <- lapply(sequences, function(seq) {
    matchPWM(ctcf_motif, seq, min.score = \80%\) # Adjust min.score as needed
})

motif_hits_reverse <- lapply(sequences, function(seq) {
    matchPWM(ctcf_motif, reverseComplement(seq), min.score = \80%\)
})

# Combine results
result <- mapply(function(fwd, rev) {
    list(forward = fwd, reverse = rev)
}, motif_hits, motif_hits_reverse, SIMPLIFY = FALSE)


result[[5]]


result_tibble <- tibble(
    peak_id = seq_along(result), # Create an identifier for each peak
    alignment = map_chr(result, function(res) {
        has_fwd <- length(res$forward) > 0
        has_rev <- length(res$reverse) > 0
        
        if (has_fwd && has_rev) \fwdrev\
        else if (has_fwd) \fwd\
        else if (has_rev) \rev\
        else \none\
    })
)

temp <- as_tibble(peak.CTCF) %>% bind_cols(result_tibble) %>%
  dplyr::select(seqnames, start, end, alignment)

fwrite(temp, here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed\), col.names = FALSE, sep = \\t\)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuY3RjZi5wZWFrIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcIjMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLm1vdGlmQW5ub3RhdGVkLmJlZFwiKSlcbmNvbG5hbWVzKGN0Y2YucGVhaykgPC0gYyhcImNoclwiLCBcInN0YXJ0XCIsIFwiZW5kXCIsIFwibW90aWZcIilcbmN0Y2YucGVhay5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoY3RjZi5wZWFrLCBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFKVxuXG5cbmZsYW5rU2l6ZSA8LSAxXG5nZW5lLlRTUy50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcIitcIiwgVjIsIFYzKSxcbiAgICAgICAgICAgICAgICBUU1NzdGFydCA9IFRTUyAtIGZsYW5rU2l6ZSxcbiAgICAgICAgICAgICAgICBUU1NlbmQgPSBUU1MgKyBmbGFua1NpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBUU1NzdGFydCwgVFNTZW5kLCBWNCwgVjUsIFY2KVxuY29sbmFtZXMoZ2VuZS5UU1MudGIpIDwtIGMoXCJjaHJcIiwgXCJzdGFydFwiLCBcImVuZFwiLCBcInN0cmFuZFwiLCBcImdlbmVcIiwgXCJlbnNlbWJsXCIpXG5cbnRzcy5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZS5UU1MudGIsIGtlZXAuZXh0cmEuY29sdW1ucyA9IFRSVUUpXG5cbmZ3ZF9wZWFrcyA8LSBjdGNmLnBlYWsuZ3JbY3RjZi5wZWFrLmdyJG1vdGlmICVpbiUgYyhcImZ3ZFwiLCBcImZ3ZHJldlwiKV1cbnJldl9wZWFrcyA8LSBjdGNmLnBlYWsuZ3JbY3RjZi5wZWFrLmdyJG1vdGlmICVpbiUgYyhcInJldlwiLCBcImZ3ZHJldlwiKV1cblxuIyBGaW5kIGNvbnZlcmdlbnQgQ1RDRiBwYWlycyBmb3IgZWFjaCBUU1NcbmNvbnZlcmdlbnRfcGFpcnMgPC0gbGFwcGx5KHNlcV9hbG9uZyh0c3MuZ3IpLCBmdW5jdGlvbihpKSB7XG4gICAgY3VycmVudF90c3MgPC0gdHNzLmdyW2ldXG4gICAgXG4gICAgIyBGaWx0ZXIgcGVha3Mgb24gdGhlIHNhbWUgY2hyb21vc29tZSBhcyB0aGUgVFNTXG4gICAgZndkX3BlYWtzX2NociA8LSBmd2RfcGVha3NbYXMuY2hhcmFjdGVyKHNlcW5hbWVzKGZ3ZF9wZWFrcykpID09IGFzLmNoYXJhY3RlcihzZXFuYW1lcyhjdXJyZW50X3RzcykpXVxuICAgIHJldl9wZWFrc19jaHIgPC0gcmV2X3BlYWtzW2FzLmNoYXJhY3RlcihzZXFuYW1lcyhyZXZfcGVha3MpKSA9PSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMoY3VycmVudF90c3MpKV1cbiAgICBcbiAgICAjIEZpbmQgdGhlIGNsb3Nlc3QgZm9yd2FyZCBwZWFrIHRvIHRoZSBsZWZ0IG9mIHRoZSBUU1NcbiAgICBsZWZ0X2Z3ZCA8LSBmd2RfcGVha3NfY2hyW3N0YXJ0KGZ3ZF9wZWFrc19jaHIpIDwgc3RhcnQoY3VycmVudF90c3MpXVxuICAgIGNsb3Nlc3RfZndkIDwtIGlmIChsZW5ndGgobGVmdF9md2QpID4gMCkge1xuICAgICAgbGVmdF9md2Rbd2hpY2gubWF4KHN0YXJ0KGxlZnRfZndkKSldXG4gICAgfSBlbHNlIHtcbiAgICAgIE5BXG4gICAgfVxuICAgIFxuICAgICMgRmluZCB0aGUgY2xvc2VzdCByZXZlcnNlIHBlYWsgdG8gdGhlIHJpZ2h0IG9mIHRoZSBUU1NcbiAgICByaWdodF9yZXYgPC0gcmV2X3BlYWtzX2NocltzdGFydChyZXZfcGVha3NfY2hyKSA+IHN0YXJ0KGN1cnJlbnRfdHNzKV1cbiAgICBjbG9zZXN0X3JldiA8LSBpZiAobGVuZ3RoKHJpZ2h0X3JldikgPiAwKSB7XG4gICAgICByaWdodF9yZXZbd2hpY2gubWluKHN0YXJ0KHJpZ2h0X3JldikpXVxuICAgIH0gZWxzZSB7XG4gICAgICBOQVxuICAgIH1cbiAgICBcbiAgICAjIENvbWJpbmUgcmVzdWx0cyBpZiBib3RoIGNsb3Nlc3QgcGVha3MgZXhpc3RcbiAgICBpZiAoIWlzLm5hKGNsb3Nlc3RfZndkKSAmJiAhaXMubmEoY2xvc2VzdF9yZXYpKSB7XG4gICAgICAgIHRpYmJsZShcbiAgICAgICAgICBjaHJvbTEgPSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMoY2xvc2VzdF9md2QpKSxcbiAgICAgICAgICBzdGFydDEgPSBzdGFydChjbG9zZXN0X2Z3ZCksXG4gICAgICAgICAgZW5kMSA9IGVuZChjbG9zZXN0X2Z3ZCksXG4gICAgICAgICAgY2hyb20yID0gYXMuY2hhcmFjdGVyKHNlcW5hbWVzKGNsb3Nlc3RfcmV2KSksXG4gICAgICAgICAgc3RhcnQyID0gc3RhcnQoY2xvc2VzdF9yZXYpLFxuICAgICAgICAgIGVuZDIgPSBlbmQoY2xvc2VzdF9yZXYpLFxuICAgICAgICAgIGVuc2VtYmwgPSBjdXJyZW50X3RzcyRlbnNlbWJsLFxuICAgICAgICApXG4gICAgfSBlbHNlIHtcbiAgICAgICAgTlVMTFxuICAgIH1cbn0pXG5cbiMgQ29tYmluZSByZXN1bHRzIGludG8gYSB0aWJibGVcbnJlc3VsdF90aWJibGUgPC0gYmluZF9yb3dzKGNvbnZlcmdlbnRfcGFpcnMpXG5cbmZ3cml0ZShyZXN1bHRfdGliYmxlLCBoZXJlKHJlZkRpciwgXCJ0c3NfY29udmVyZ2VudF9jdGNmX21vdGlmX3BhaXJzLmJlZHBlXCIpLCBzZXAgPSBcIlxcdFwiLCBjb2wubmFtZXMgPSBGQUxTRSlcbmZ3cml0ZShnZW5lLlRTUy50YiAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMsIDUpKSwgaGVyZShyZWZEaXIsIFwidHNzXzJicC5iZWRcIiksIHNlcCA9IFwiXFx0XCIsIGNvbC5uYW1lcyA9IEZBTFNFKVxuXG50ZW1wIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcInRzc19jb252ZXJnZW50X2N0Y2ZfbW90aWZfcGFpcnMuYmVkcGVcIikpICU+JSBkcGx5cjo6ZmlsdGVyKFY3ID09IFwiS2xmNFwiKVxuXG5md3JpdGUoYXNfdGliYmxlKHRlbXApLCBoZXJlKHJlZkRpciwgXCJ0c3NfY29udmVyZ2VudF9jdGNmX21vdGlmX3BhaXJzX2tsZjQuYmVkcGVcIiksIHNlcCA9IFwiXFx0XCIsIGNvbC5uYW1lcyA9IEZBTFNFKVxuXG4jIENoZWNraW5nIHNpemUgZGlzdHJpYnV0aW9uIG9mIGN0Y2YgcGFpclxudGVtcCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJ0c3NfY29udmVyZ2VudF9jdGNmX21vdGlmX3BhaXJzLmJlZHBlXCIpKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6bXV0YXRlKHNpemUgPSAoVjYgKyBWNSkvMiAtIChWMyArIFYyKS8yLFxuICAgICAgICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBWMiwgVjMsIFY1LCBWNiwgc2VwID0gXCJfXCIpKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6c2VsZWN0KGlkLCBzaXplKSAlPiUgZGlzdGluY3QoKVxuXG5nZ3Bsb3QodGVtcCwgYWVzKHggPSBzaXplKSkgKyBnZW9tX2hpc3RvZ3JhbSgpICsgc2NhbGVfeF9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iLCBsaW1pdHMgPSBjKDAsIDFlNikpICsgc2NhbGVfeV9sb2cxMCgpICsgdGhlbWVfY2xhc3NpYygpICsgZ2d0aXRsZShcInNpemUgZGlzdHJpYnV0aW9uIG9mIHNtYWxsZXN0IGNvbnZlcmdlbnQgY3RjZiBwYWlycyBhcm91bmQgZ2VuZVwiKVxuYGBgIn0= -->\n\n```r\nctcf.peak <- fread(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed\\))\ncolnames(ctcf.peak) <- c(\\chr\\, \\start\\, \\end\\, \\motif\\)\nctcf.peak.gr <- makeGRangesFromDataFrame(ctcf.peak, keep.extra.columns = TRUE)\n\n\nflankSize <- 1\ngene.TSS.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)\ncolnames(gene.TSS.tb) <- c(\\chr\\, \\start\\, \\end\\, \\strand\\, \\gene\\, \\ensembl\\)\n\ntss.gr <- makeGRangesFromDataFrame(gene.TSS.tb, keep.extra.columns = TRUE)\n\nfwd_peaks <- ctcf.peak.gr[ctcf.peak.gr$motif %in% c(\\fwd\\, \\fwdrev\\)]\nrev_peaks <- ctcf.peak.gr[ctcf.peak.gr$motif %in% c(\\rev\\, \\fwdrev\\)]\n\n# Find convergent CTCF pairs for each TSS\nconvergent_pairs <- lapply(seq_along(tss.gr), function(i) {\n    current_tss <- tss.gr[i]\n    \n    # Filter peaks on the same chromosome as the TSS\n    fwd_peaks_chr <- fwd_peaks[as.character(seqnames(fwd_peaks)) == as.character(seqnames(current_tss))]\n    rev_peaks_chr <- rev_peaks[as.character(seqnames(rev_peaks)) == as.character(seqnames(current_tss))]\n    \n    # Find the closest forward peak to the left of the TSS\n    left_fwd <- fwd_peaks_chr[start(fwd_peaks_chr) < start(current_tss)]\n    closest_fwd <- if (length(left_fwd) > 0) {\n      left_fwd[which.max(start(left_fwd))]\n    } else {\n      NA\n    }\n    \n    # Find the closest reverse peak to the right of the TSS\n    right_rev <- rev_peaks_chr[start(rev_peaks_chr) > start(current_tss)]\n    closest_rev <- if (length(right_rev) > 0) {\n      right_rev[which.min(start(right_rev))]\n    } else {\n      NA\n    }\n    \n    # Combine results if both closest peaks exist\n    if (!is.na(closest_fwd) && !is.na(closest_rev)) {\n        tibble(\n          chrom1 = as.character(seqnames(closest_fwd)),\n          start1 = start(closest_fwd),\n          end1 = end(closest_fwd),\n          chrom2 = as.character(seqnames(closest_rev)),\n          start2 = start(closest_rev),\n          end2 = end(closest_rev),\n          ensembl = current_tss$ensembl,\n        )\n    } else {\n        NULL\n    }\n})\n\n# Combine results into a tibble\nresult_tibble <- bind_rows(convergent_pairs)\n\nfwrite(result_tibble, here(refDir, \\tss_convergent_ctcf_motif_pairs.bedpe\\), sep = \\\\t\\, col.names = FALSE)\nfwrite(gene.TSS.tb %>% dplyr::select(c(1, 2, 3, 5)), here(refDir, \\tss_2bp.bed\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- fread(here(refDir, \\tss_convergent_ctcf_motif_pairs.bedpe\\)) %>% dplyr::filter(V7 == \\Klf4\\)\n\nfwrite(as_tibble(temp), here(refDir, \\tss_convergent_ctcf_motif_pairs_klf4.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\n# Checking size distribution of ctcf pair\ntemp <- fread(here(refDir, \\tss_convergent_ctcf_motif_pairs.bedpe\\))\ntemp <- temp %>% dplyr::mutate(size = (V6 + V5)/2 - (V3 + V2)/2,\n                       id = paste(V1, V2, V3, V5, V6, sep = \\_\\))\ntemp <- temp %>% dplyr::select(id, size) %>% distinct()\n\nggplot(temp, aes(x = size)) + geom_histogram() + scale_x_continuous(labels = label_kb_mb, limits = c(0, 1e6)) + scale_y_log10() + theme_classic() + ggtitle(\\size distribution of smallest convergent ctcf pairs around gene\\)\n```\n\n<!-- rnb-source-end -->\n"} -->
ctcf.peak <- fread(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed\))
colnames(ctcf.peak) <- c(\chr\, \start\, \end\, \motif\)
ctcf.peak.gr <- makeGRangesFromDataFrame(ctcf.peak, keep.extra.columns = TRUE)


flankSize <- 1
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)
colnames(gene.TSS.tb) <- c(\chr\, \start\, \end\, \strand\, \gene\, \ensembl\)

tss.gr <- makeGRangesFromDataFrame(gene.TSS.tb, keep.extra.columns = TRUE)

fwd_peaks <- ctcf.peak.gr[ctcf.peak.gr$motif %in% c(\fwd\, \fwdrev\)]
rev_peaks <- ctcf.peak.gr[ctcf.peak.gr$motif %in% c(\rev\, \fwdrev\)]

# Find convergent CTCF pairs for each TSS
convergent_pairs <- lapply(seq_along(tss.gr), function(i) {
    current_tss <- tss.gr[i]
    
    # Filter peaks on the same chromosome as the TSS
    fwd_peaks_chr <- fwd_peaks[as.character(seqnames(fwd_peaks)) == as.character(seqnames(current_tss))]
    rev_peaks_chr <- rev_peaks[as.character(seqnames(rev_peaks)) == as.character(seqnames(current_tss))]
    
    # Find the closest forward peak to the left of the TSS
    left_fwd <- fwd_peaks_chr[start(fwd_peaks_chr) < start(current_tss)]
    closest_fwd <- if (length(left_fwd) > 0) {
      left_fwd[which.max(start(left_fwd))]
    } else {
      NA
    }
    
    # Find the closest reverse peak to the right of the TSS
    right_rev <- rev_peaks_chr[start(rev_peaks_chr) > start(current_tss)]
    closest_rev <- if (length(right_rev) > 0) {
      right_rev[which.min(start(right_rev))]
    } else {
      NA
    }
    
    # Combine results if both closest peaks exist
    if (!is.na(closest_fwd) && !is.na(closest_rev)) {
        tibble(
          chrom1 = as.character(seqnames(closest_fwd)),
          start1 = start(closest_fwd),
          end1 = end(closest_fwd),
          chrom2 = as.character(seqnames(closest_rev)),
          start2 = start(closest_rev),
          end2 = end(closest_rev),
          ensembl = current_tss$ensembl,
        )
    } else {
        NULL
    }
})

# Combine results into a tibble
result_tibble <- bind_rows(convergent_pairs)

fwrite(result_tibble, here(refDir, \tss_convergent_ctcf_motif_pairs.bedpe\), sep = \\t\, col.names = FALSE)
fwrite(gene.TSS.tb %>% dplyr::select(c(1, 2, 3, 5)), here(refDir, \tss_2bp.bed\), sep = \\t\, col.names = FALSE)

temp <- fread(here(refDir, \tss_convergent_ctcf_motif_pairs.bedpe\)) %>% dplyr::filter(V7 == \Klf4\)

fwrite(as_tibble(temp), here(refDir, \tss_convergent_ctcf_motif_pairs_klf4.bedpe\), sep = \\t\, col.names = FALSE)

# Checking size distribution of ctcf pair
temp <- fread(here(refDir, \tss_convergent_ctcf_motif_pairs.bedpe\))
temp <- temp %>% dplyr::mutate(size = (V6 + V5)/2 - (V3 + V2)/2,
                       id = paste(V1, V2, V3, V5, V6, sep = \_\))
temp <- temp %>% dplyr::select(id, size) %>% distinct()

ggplot(temp, aes(x = size)) + geom_histogram() + scale_x_continuous(labels = label_kb_mb, limits = c(0, 1e6)) + scale_y_log10() + theme_classic() + ggtitle(\size distribution of smallest convergent ctcf pairs around gene\)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuY3RjZi5wZWFrIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXDMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLm1vdGlmQW5ub3RhdGVkLmJlZFxcKSlcbmNvbG5hbWVzKGN0Y2YucGVhaykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcbW90aWZcXClcbmN0Y2YucGVhay5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoY3RjZi5wZWFrLCBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFKVxuXG5cbmZsYW5rU2l6ZSA8LSAxXG5nZW5lLlRTUy50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSxcbiAgICAgICAgICAgICAgICBUU1NzdGFydCA9IFRTUyAtIGZsYW5rU2l6ZSxcbiAgICAgICAgICAgICAgICBUU1NlbmQgPSBUU1MgKyBmbGFua1NpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBUU1NzdGFydCwgVFNTZW5kLCBWNCwgVjUsIFY2KVxuY29sbmFtZXMoZ2VuZS5UU1MudGIpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXHN0cmFuZFxcLCBcXGdlbmVcXCwgXFxlbnNlbWJsXFwpXG5cbnRzcy5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZS5UU1MudGIsIGtlZXAuZXh0cmEuY29sdW1ucyA9IFRSVUUpXG5cbmZ3ZF9wZWFrcyA8LSBjdGNmLnBlYWsuZ3JbY3RjZi5wZWFrLmdyJG1vdGlmICVpbiUgYyhcXGZ3ZFxcLCBcXGZ3ZHJldlxcKV1cbnJldl9wZWFrcyA8LSBjdGNmLnBlYWsuZ3JbY3RjZi5wZWFrLmdyJG1vdGlmICVpbiUgYyhcXHJldlxcLCBcXGZ3ZHJldlxcKV1cblxuIyBGaW5kIGNvbnZlcmdlbnQgQ1RDRiBwYWlycyBmb3IgZWFjaCBUU1NcbmNvbnZlcmdlbnRfcGFpcnMgPC0gbGFwcGx5KHNlcV9hbG9uZyh0c3MuZ3IpLCBmdW5jdGlvbihpKSB7XG4gICAgY3VycmVudF90c3MgPC0gdHNzLmdyW2ldXG4gICAgXG4gICAgIyBGaWx0ZXIgcGVha3Mgb24gdGhlIHNhbWUgY2hyb21vc29tZSBhcyB0aGUgVFNTXG4gICAgZndkX3BlYWtzX2NociA8LSBmd2RfcGVha3NbYXMuY2hhcmFjdGVyKHNlcW5hbWVzKGZ3ZF9wZWFrcykpID09IGFzLmNoYXJhY3RlcihzZXFuYW1lcyhjdXJyZW50X3RzcykpXVxuICAgIHJldl9wZWFrc19jaHIgPC0gcmV2X3BlYWtzW2FzLmNoYXJhY3RlcihzZXFuYW1lcyhyZXZfcGVha3MpKSA9PSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMoY3VycmVudF90c3MpKV1cbiAgICBcbiAgICAjIEZpbmQgdGhlIGNsb3Nlc3QgZm9yd2FyZCBwZWFrIHRvIHRoZSBsZWZ0IG9mIHRoZSBUU1NcbiAgICBsZWZ0X2Z3ZCA8LSBmd2RfcGVha3NfY2hyW3N0YXJ0KGZ3ZF9wZWFrc19jaHIpIDwgc3RhcnQoY3VycmVudF90c3MpXVxuICAgIGNsb3Nlc3RfZndkIDwtIGlmIChsZW5ndGgobGVmdF9md2QpID4gMCkge1xuICAgICAgbGVmdF9md2Rbd2hpY2gubWF4KHN0YXJ0KGxlZnRfZndkKSldXG4gICAgfSBlbHNlIHtcbiAgICAgIE5BXG4gICAgfVxuICAgIFxuICAgICMgRmluZCB0aGUgY2xvc2VzdCByZXZlcnNlIHBlYWsgdG8gdGhlIHJpZ2h0IG9mIHRoZSBUU1NcbiAgICByaWdodF9yZXYgPC0gcmV2X3BlYWtzX2NocltzdGFydChyZXZfcGVha3NfY2hyKSA+IHN0YXJ0KGN1cnJlbnRfdHNzKV1cbiAgICBjbG9zZXN0X3JldiA8LSBpZiAobGVuZ3RoKHJpZ2h0X3JldikgPiAwKSB7XG4gICAgICByaWdodF9yZXZbd2hpY2gubWluKHN0YXJ0KHJpZ2h0X3JldikpXVxuICAgIH0gZWxzZSB7XG4gICAgICBOQVxuICAgIH1cbiAgICBcbiAgICAjIENvbWJpbmUgcmVzdWx0cyBpZiBib3RoIGNsb3Nlc3QgcGVha3MgZXhpc3RcbiAgICBpZiAoIWlzLm5hKGNsb3Nlc3RfZndkKSAmJiAhaXMubmEoY2xvc2VzdF9yZXYpKSB7XG4gICAgICAgIHRpYmJsZShcbiAgICAgICAgICBjaHJvbTEgPSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMoY2xvc2VzdF9md2QpKSxcbiAgICAgICAgICBzdGFydDEgPSBzdGFydChjbG9zZXN0X2Z3ZCksXG4gICAgICAgICAgZW5kMSA9IGVuZChjbG9zZXN0X2Z3ZCksXG4gICAgICAgICAgY2hyb20yID0gYXMuY2hhcmFjdGVyKHNlcW5hbWVzKGNsb3Nlc3RfcmV2KSksXG4gICAgICAgICAgc3RhcnQyID0gc3RhcnQoY2xvc2VzdF9yZXYpLFxuICAgICAgICAgIGVuZDIgPSBlbmQoY2xvc2VzdF9yZXYpLFxuICAgICAgICAgIGVuc2VtYmwgPSBjdXJyZW50X3RzcyRlbnNlbWJsLFxuICAgICAgICApXG4gICAgfSBlbHNlIHtcbiAgICAgICAgTlVMTFxuICAgIH1cbn0pXG5cbiMgQ29tYmluZSByZXN1bHRzIGludG8gYSB0aWJibGVcbnJlc3VsdF90aWJibGUgPC0gYmluZF9yb3dzKGNvbnZlcmdlbnRfcGFpcnMpXG5cbmZ3cml0ZShyZXN1bHRfdGliYmxlLCBoZXJlKHJlZkRpciwgXFx0c3NfY29udmVyZ2VudF9jdGNmX21vdGlmX3BhaXJzLmJlZHBlXFwpLCBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBGQUxTRSlcbmZ3cml0ZShnZW5lLlRTUy50YiAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMsIDUpKSwgaGVyZShyZWZEaXIsIFxcdHNzXzJicC5iZWRcXCksIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IEZBTFNFKVxuXG50ZW1wIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXHRzc19jb252ZXJnZW50X2N0Y2ZfbW90aWZfcGFpcnMuYmVkcGVcXCkpICU+JSBkcGx5cjo6ZmlsdGVyKFY3ID09IFxcS2xmNFxcKVxuXG5md3JpdGUoYXNfdGliYmxlKHRlbXApLCBoZXJlKHJlZkRpciwgXFx0c3NfY29udmVyZ2VudF9jdGNmX21vdGlmX3BhaXJzX2tsZjQuYmVkcGVcXCksIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IEZBTFNFKVxuXG4jIENoZWNraW5nIHNpemUgZGlzdHJpYnV0aW9uIG9mIGN0Y2YgcGFpclxudGVtcCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFx0c3NfY29udmVyZ2VudF9jdGNmX21vdGlmX3BhaXJzLmJlZHBlXFwpKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6bXV0YXRlKHNpemUgPSAoVjYgKyBWNSkvMiAtIChWMyArIFYyKS8yLFxuICAgICAgICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBWMiwgVjMsIFY1LCBWNiwgc2VwID0gXFxfXFwpKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6c2VsZWN0KGlkLCBzaXplKSAlPiUgZGlzdGluY3QoKVxuXG5nZ3Bsb3QodGVtcCwgYWVzKHggPSBzaXplKSkgKyBnZW9tX2hpc3RvZ3JhbSgpICsgc2NhbGVfeF9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iLCBsaW1pdHMgPSBjKDAsIDFlNikpICsgc2NhbGVfeV9sb2cxMCgpICsgdGhlbWVfY2xhc3NpYygpICsgZ2d0aXRsZShcXHNpemUgZGlzdHJpYnV0aW9uIG9mIHNtYWxsZXN0IGNvbnZlcmdlbnQgY3RjZiBwYWlycyBhcm91bmQgZ2VuZVxcKVxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\nctcf.peak <- fread(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed\\))\ncolnames(ctcf.peak) <- c(\\chr\\, \\start\\, \\end\\, \\motif\\)\nctcf.peak.gr <- makeGRangesFromDataFrame(ctcf.peak, keep.extra.columns = TRUE)\n\n\nflankSize <- 1\ngene.TSS.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)\ncolnames(gene.TSS.tb) <- c(\\chr\\, \\start\\, \\end\\, \\strand\\, \\gene\\, \\ensembl\\)\n\ntss.gr <- makeGRangesFromDataFrame(gene.TSS.tb, keep.extra.columns = TRUE)\n\nfwd_peaks <- ctcf.peak.gr[ctcf.peak.gr$motif %in% c(\\fwd\\, \\fwdrev\\)]\nrev_peaks <- ctcf.peak.gr[ctcf.peak.gr$motif %in% c(\\rev\\, \\fwdrev\\)]\n\n# Find convergent CTCF pairs for each TSS\nconvergent_pairs <- lapply(seq_along(tss.gr), function(i) {\n    current_tss <- tss.gr[i]\n    \n    # Filter peaks on the same chromosome as the TSS\n    fwd_peaks_chr <- fwd_peaks[as.character(seqnames(fwd_peaks)) == as.character(seqnames(current_tss))]\n    rev_peaks_chr <- rev_peaks[as.character(seqnames(rev_peaks)) == as.character(seqnames(current_tss))]\n    \n    # Find the closest forward peak to the left of the TSS\n    left_fwd <- fwd_peaks_chr[start(fwd_peaks_chr) < start(current_tss)]\n    closest_fwd <- if (length(left_fwd) > 0) {\n      left_fwd[which.max(start(left_fwd))]\n    } else {\n      NA\n    }\n    \n    # Find the closest reverse peak to the right of the TSS\n    right_rev <- rev_peaks_chr[start(rev_peaks_chr) > start(current_tss)]\n    closest_rev <- if (length(right_rev) > 0) {\n      right_rev[which.min(start(right_rev))]\n    } else {\n      NA\n    }\n    \n    # Combine results if both closest peaks exist\n    if (!is.na(closest_fwd) && !is.na(closest_rev)) {\n        tibble(\n          chrom1 = as.character(seqnames(closest_fwd)),\n          start1 = start(closest_fwd),\n          end1 = end(closest_fwd),\n          chrom2 = as.character(seqnames(closest_rev)),\n          start2 = start(closest_rev),\n          end2 = end(closest_rev),\n          ensembl = current_tss$ensembl,\n        )\n    } else {\n        NULL\n    }\n})\n\n# Combine results into a tibble\nresult_tibble <- bind_rows(convergent_pairs)\n\nfwrite(result_tibble, here(refDir, \\tss_convergent_ctcf_motif_pairs.bedpe\\), sep = \\\\t\\, col.names = FALSE)\nfwrite(gene.TSS.tb %>% dplyr::select(c(1, 2, 3, 5)), here(refDir, \\tss_2bp.bed\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- fread(here(refDir, \\tss_convergent_ctcf_motif_pairs.bedpe\\)) %>% dplyr::filter(V7 == \\Klf4\\)\n\nfwrite(as_tibble(temp), here(refDir, \\tss_convergent_ctcf_motif_pairs_klf4.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\n# Checking size distribution of ctcf pair\ntemp <- fread(here(refDir, \\tss_convergent_ctcf_motif_pairs.bedpe\\))\ntemp <- temp %>% dplyr::mutate(size = (V6 + V5)/2 - (V3 + V2)/2,\n                       id = paste(V1, V2, V3, V5, V6, sep = \\_\\))\ntemp <- temp %>% dplyr::select(id, size) %>% distinct()\n\nggplot(temp, aes(x = size)) + geom_histogram() + scale_x_continuous(labels = label_kb_mb, limits = c(0, 1e6)) + scale_y_log10() + theme_classic() + ggtitle(\\size distribution of smallest convergent ctcf pairs around gene\\)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuY3RjZi5wZWFrIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXDMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLm1vdGlmQW5ub3RhdGVkLmJlZFxcKSlcbmNvbG5hbWVzKGN0Y2YucGVhaykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcbW90aWZcXClcbmN0Y2YucGVhay5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoY3RjZi5wZWFrLCBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFKVxuXG5cbmZsYW5rU2l6ZSA8LSAxXG5nZW5lLlRTUy50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSxcbiAgICAgICAgICAgICAgICBUU1NzdGFydCA9IFRTUyAtIGZsYW5rU2l6ZSxcbiAgICAgICAgICAgICAgICBUU1NlbmQgPSBUU1MgKyBmbGFua1NpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBUU1NzdGFydCwgVFNTZW5kLCBWNCwgVjUsIFY2KVxuY29sbmFtZXMoZ2VuZS5UU1MudGIpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXHN0cmFuZFxcLCBcXGdlbmVcXCwgXFxlbnNlbWJsXFwpXG5cbnRzcy5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZS5UU1MudGIsIGtlZXAuZXh0cmEuY29sdW1ucyA9IFRSVUUpXG5cbmZ3ZF9wZWFrcyA8LSBjdGNmLnBlYWsuZ3JbY3RjZi5wZWFrLmdyJG1vdGlmICVpbiUgYyhcXGZ3ZFxcLCBcXGZ3ZHJldlxcKV1cbnJldl9wZWFrcyA8LSBjdGNmLnBlYWsuZ3JbY3RjZi5wZWFrLmdyJG1vdGlmICVpbiUgYyhcXHJldlxcLCBcXGZ3ZHJldlxcKV1cblxuIyBGaW5kIGNvbnZlcmdlbnQgQ1RDRiBwYWlycyBmb3IgZWFjaCBUU1NcbmNvbnZlcmdlbnRfcGFpcnMgPC0gbGFwcGx5KHNlcV9hbG9uZyh0c3MuZ3IpLCBmdW5jdGlvbihpKSB7XG4gICAgY3VycmVudF90c3MgPC0gdHNzLmdyW2ldXG4gICAgXG4gICAgIyBGaWx0ZXIgcGVha3Mgb24gdGhlIHNhbWUgY2hyb21vc29tZSBhcyB0aGUgVFNTXG4gICAgZndkX3BlYWtzX2NociA8LSBmd2RfcGVha3NbYXMuY2hhcmFjdGVyKHNlcW5hbWVzKGZ3ZF9wZWFrcykpID09IGFzLmNoYXJhY3RlcihzZXFuYW1lcyhjdXJyZW50X3RzcykpXVxuICAgIHJldl9wZWFrc19jaHIgPC0gcmV2X3BlYWtzW2FzLmNoYXJhY3RlcihzZXFuYW1lcyhyZXZfcGVha3MpKSA9PSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMoY3VycmVudF90c3MpKV1cbiAgICBcbiAgICAjIEZpbmQgdGhlIGNsb3Nlc3QgZm9yd2FyZCBwZWFrIHRvIHRoZSBsZWZ0IG9mIHRoZSBUU1NcbiAgICBsZWZ0X2Z3ZCA8LSBmd2RfcGVha3NfY2hyW3N0YXJ0KGZ3ZF9wZWFrc19jaHIpIDwgc3RhcnQoY3VycmVudF90c3MpXVxuICAgIGNsb3Nlc3RfZndkIDwtIGlmIChsZW5ndGgobGVmdF9md2QpID4gMCkge1xuICAgICAgbGVmdF9md2Rbd2hpY2gubWF4KHN0YXJ0KGxlZnRfZndkKSldXG4gICAgfSBlbHNlIHtcbiAgICAgIE5BXG4gICAgfVxuICAgIFxuICAgICMgRmluZCB0aGUgY2xvc2VzdCByZXZlcnNlIHBlYWsgdG8gdGhlIHJpZ2h0IG9mIHRoZSBUU1NcbiAgICByaWdodF9yZXYgPC0gcmV2X3BlYWtzX2NocltzdGFydChyZXZfcGVha3NfY2hyKSA+IHN0YXJ0KGN1cnJlbnRfdHNzKV1cbiAgICBjbG9zZXN0X3JldiA8LSBpZiAobGVuZ3RoKHJpZ2h0X3JldikgPiAwKSB7XG4gICAgICByaWdodF9yZXZbd2hpY2gubWluKHN0YXJ0KHJpZ2h0X3JldikpXVxuICAgIH0gZWxzZSB7XG4gICAgICBOQVxuICAgIH1cbiAgICBcbiAgICAjIENvbWJpbmUgcmVzdWx0cyBpZiBib3RoIGNsb3Nlc3QgcGVha3MgZXhpc3RcbiAgICBpZiAoIWlzLm5hKGNsb3Nlc3RfZndkKSAmJiAhaXMubmEoY2xvc2VzdF9yZXYpKSB7XG4gICAgICAgIHRpYmJsZShcbiAgICAgICAgICBjaHJvbTEgPSBhcy5jaGFyYWN0ZXIoc2VxbmFtZXMoY2xvc2VzdF9md2QpKSxcbiAgICAgICAgICBzdGFydDEgPSBzdGFydChjbG9zZXN0X2Z3ZCksXG4gICAgICAgICAgZW5kMSA9IGVuZChjbG9zZXN0X2Z3ZCksXG4gICAgICAgICAgY2hyb20yID0gYXMuY2hhcmFjdGVyKHNlcW5hbWVzKGNsb3Nlc3RfcmV2KSksXG4gICAgICAgICAgc3RhcnQyID0gc3RhcnQoY2xvc2VzdF9yZXYpLFxuICAgICAgICAgIGVuZDIgPSBlbmQoY2xvc2VzdF9yZXYpLFxuICAgICAgICAgIGVuc2VtYmwgPSBjdXJyZW50X3RzcyRlbnNlbWJsLFxuICAgICAgICApXG4gICAgfSBlbHNlIHtcbiAgICAgICAgTlVMTFxuICAgIH1cbn0pXG5cbiMgQ29tYmluZSByZXN1bHRzIGludG8gYSB0aWJibGVcbnJlc3VsdF90aWJibGUgPC0gYmluZF9yb3dzKGNvbnZlcmdlbnRfcGFpcnMpXG5cbmZ3cml0ZShyZXN1bHRfdGliYmxlLCBoZXJlKHJlZkRpciwgXFx0c3NfY29udmVyZ2VudF9jdGNmX21vdGlmX3BhaXJzLmJlZHBlXFwpLCBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBGQUxTRSlcbmZ3cml0ZShnZW5lLlRTUy50YiAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMsIDUpKSwgaGVyZShyZWZEaXIsIFxcdHNzXzJicC5iZWRcXCksIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IEZBTFNFKVxuXG50ZW1wIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXHRzc19jb252ZXJnZW50X2N0Y2ZfbW90aWZfcGFpcnMuYmVkcGVcXCkpICU+JSBkcGx5cjo6ZmlsdGVyKFY3ID09IFxcS2xmNFxcKVxuXG5md3JpdGUoYXNfdGliYmxlKHRlbXApLCBoZXJlKHJlZkRpciwgXFx0c3NfY29udmVyZ2VudF9jdGNmX21vdGlmX3BhaXJzX2tsZjQuYmVkcGVcXCksIHNlcCA9IFxcXFx0XFwsIGNvbC5uYW1lcyA9IEZBTFNFKVxuXG4jIENoZWNraW5nIHNpemUgZGlzdHJpYnV0aW9uIG9mIGN0Y2YgcGFpclxudGVtcCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFx0c3NfY29udmVyZ2VudF9jdGNmX21vdGlmX3BhaXJzLmJlZHBlXFwpKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6bXV0YXRlKHNpemUgPSAoVjYgKyBWNSkvMiAtIChWMyArIFYyKS8yLFxuICAgICAgICAgICAgICAgICAgICAgICBpZCA9IHBhc3RlKFYxLCBWMiwgVjMsIFY1LCBWNiwgc2VwID0gXFxfXFwpKVxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6c2VsZWN0KGlkLCBzaXplKSAlPiUgZGlzdGluY3QoKVxuXG5nZ3Bsb3QodGVtcCwgYWVzKHggPSBzaXplKSkgKyBnZW9tX2hpc3RvZ3JhbSgpICsgc2NhbGVfeF9jb250aW51b3VzKGxhYmVscyA9IGxhYmVsX2tiX21iLCBsaW1pdHMgPSBjKDAsIDFlNikpICsgc2NhbGVfeV9sb2cxMCgpICsgdGhlbWVfY2xhc3NpYygpICsgZ2d0aXRsZShcXHNpemUgZGlzdHJpYnV0aW9uIG9mIHNtYWxsZXN0IGNvbnZlcmdlbnQgY3RjZiBwYWlycyBhcm91bmQgZ2VuZVxcKVxuYGBgXG5gYGAifQ== -->

```r
```r
ctcf.peak <- fread(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed\))
colnames(ctcf.peak) <- c(\chr\, \start\, \end\, \motif\)
ctcf.peak.gr <- makeGRangesFromDataFrame(ctcf.peak, keep.extra.columns = TRUE)


flankSize <- 1
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)
colnames(gene.TSS.tb) <- c(\chr\, \start\, \end\, \strand\, \gene\, \ensembl\)

tss.gr <- makeGRangesFromDataFrame(gene.TSS.tb, keep.extra.columns = TRUE)

fwd_peaks <- ctcf.peak.gr[ctcf.peak.gr$motif %in% c(\fwd\, \fwdrev\)]
rev_peaks <- ctcf.peak.gr[ctcf.peak.gr$motif %in% c(\rev\, \fwdrev\)]

# Find convergent CTCF pairs for each TSS
convergent_pairs <- lapply(seq_along(tss.gr), function(i) {
    current_tss <- tss.gr[i]
    
    # Filter peaks on the same chromosome as the TSS
    fwd_peaks_chr <- fwd_peaks[as.character(seqnames(fwd_peaks)) == as.character(seqnames(current_tss))]
    rev_peaks_chr <- rev_peaks[as.character(seqnames(rev_peaks)) == as.character(seqnames(current_tss))]
    
    # Find the closest forward peak to the left of the TSS
    left_fwd <- fwd_peaks_chr[start(fwd_peaks_chr) < start(current_tss)]
    closest_fwd <- if (length(left_fwd) > 0) {
      left_fwd[which.max(start(left_fwd))]
    } else {
      NA
    }
    
    # Find the closest reverse peak to the right of the TSS
    right_rev <- rev_peaks_chr[start(rev_peaks_chr) > start(current_tss)]
    closest_rev <- if (length(right_rev) > 0) {
      right_rev[which.min(start(right_rev))]
    } else {
      NA
    }
    
    # Combine results if both closest peaks exist
    if (!is.na(closest_fwd) && !is.na(closest_rev)) {
        tibble(
          chrom1 = as.character(seqnames(closest_fwd)),
          start1 = start(closest_fwd),
          end1 = end(closest_fwd),
          chrom2 = as.character(seqnames(closest_rev)),
          start2 = start(closest_rev),
          end2 = end(closest_rev),
          ensembl = current_tss$ensembl,
        )
    } else {
        NULL
    }
})

# Combine results into a tibble
result_tibble <- bind_rows(convergent_pairs)

fwrite(result_tibble, here(refDir, \tss_convergent_ctcf_motif_pairs.bedpe\), sep = \\t\, col.names = FALSE)
fwrite(gene.TSS.tb %>% dplyr::select(c(1, 2, 3, 5)), here(refDir, \tss_2bp.bed\), sep = \\t\, col.names = FALSE)

temp <- fread(here(refDir, \tss_convergent_ctcf_motif_pairs.bedpe\)) %>% dplyr::filter(V7 == \Klf4\)

fwrite(as_tibble(temp), here(refDir, \tss_convergent_ctcf_motif_pairs_klf4.bedpe\), sep = \\t\, col.names = FALSE)

# Checking size distribution of ctcf pair
temp <- fread(here(refDir, \tss_convergent_ctcf_motif_pairs.bedpe\))
temp <- temp %>% dplyr::mutate(size = (V6 + V5)/2 - (V3 + V2)/2,
                       id = paste(V1, V2, V3, V5, V6, sep = \_\))
temp <- temp %>% dplyr::select(id, size) %>% distinct()

ggplot(temp, aes(x = size)) + geom_histogram() + scale_x_continuous(labels = label_kb_mb, limits = c(0, 1e6)) + scale_y_log10() + theme_classic() + ggtitle(\size distribution of smallest convergent ctcf pairs around gene\)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [2.34] Checking CTCF motif orientation
#### Calculating CTCF motif

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZmxhbmtTaXplIDwtIDFcbmdlbmUuVFNTLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcIm1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFwiK1wiLCBWMiwgVjMpLFxuICAgICAgICAgICAgICAgIFRTU3N0YXJ0ID0gVFNTIC0gZmxhbmtTaXplLFxuICAgICAgICAgICAgICAgIFRTU2VuZCA9IFRTUyArIGZsYW5rU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTU3N0YXJ0LCBUU1NlbmQsIFY0LCBWNSwgVjYpXG5jb2xuYW1lcyhnZW5lLlRTUy50YikgPC0gYyhcImNoclwiLCBcInN0YXJ0XCIsIFwiZW5kXCIsIFwic3RyYW5kXCIsIFwiZ2VuZVwiLCBcImVuc2VtYmxcIilcbmdlbmVFbnNlbWJsUGFpciA8LSBnZW5lLlRTUy50YiAlPiUgZHBseXI6OnNlbGVjdChnZW5lLCBlbnNlbWJsKVxuXG5ib3VuZGFyeS5wYWlyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcInRzc19jb252ZXJnZW50X2N0Y2ZfbW90aWZfcGFpcnMuYmVkcGVcIikpXG5jb2xuYW1lcyhib3VuZGFyeS5wYWlyKSA8LSBjKFwiYm91bmRhcnlfY2hyb20xXCIsIFwiYm91bmRhcnlfc3RhcnQxXCIsIFwiYm91bmRhcnlfZW5kMVwiLCBcImJvdW5kYXJ5X2Nocm9tMlwiLCBcImJvdW5kYXJ5X3N0YXJ0MlwiLCBcImJvdW5kYXJ5X2VuZDJcIiwgXCJlbnNlbWJsXCIpXG5ib3VuZGFyeS5wYWlyIDwtIGJvdW5kYXJ5LnBhaXIgJT4lIGRwbHlyOjpsZWZ0X2pvaW4oZ2VuZUVuc2VtYmxQYWlyLCBieSA9IGMoXCJlbnNlbWJsXCIpKVxuXG5cbiMgSW1wb3J0aW5nIGxvb3AgZ2VuZSBhbm5vdGF0aW9uXG5uYW1lIDwtIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVwiXG5kaWZmQ3V0b2ZmIDwtIDAuMlxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcIl9wLW5fZW5zZW1ibExpc3QudHN2XCIpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IGRpZmZDdXRvZmYsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9MaXN0ID0gYyhcIlAtUFwiLCBcIlAtRVwiKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzLCA0LCA1LCA2LCAxMSwgMTIsIDI0LCAyOSwgMzEpKSAlPiUgdW5uZXN0KGdlbmUpXG5cblxuZGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4oYm91bmRhcnkucGFpciwgYnkgPSBjKFwiZ2VuZVwiID0gXCJlbnNlbWJsXCIpKVxuXG5kYXRhIDwtIGRhdGEgJT4lIHJvd3dpc2UoKSAlPiUgZHBseXI6Om11dGF0ZShpc1dpdGhpbkxlZnRCZCA9IChib3VuZGFyeV9zdGFydDEgPD0gbWluKGVuZDEsIGVuZDIpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgaXNXaXRoaW5SaWdodEJkID0gKGJvdW5kYXJ5X2VuZDIgPj0gbWF4KHN0YXJ0MSwgc3RhcnQyKSksXG4gICAgICAgICAgICAgICAgICAgICAgIGlzV2l0aGluQmQgPSBpc1dpdGhpbkxlZnRCZCAmIGlzV2l0aGluUmlnaHRCZClcbmRhdGEgPC0gZGF0YSAlPiUgZHJvcF9uYSgpXG5cblxuZ2dwbG90KGRhdGEsIGFlcyh4ID0gRE1TTywgeSA9IGRUQUcpKSArIGdlb21fcG9pbnQoKSArIGNvb3JkX2ZpeGVkKCkgKyAgXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCwgY29sID0gXCJncmV5NTBcIiwgbGluZXR5cGUgPSBcImRhc2hlZFwiKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFwiZ3JleVwiKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFwiZ3JleVwiKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGZhY2V0X3dyYXAofiBpc1dpdGhpbkJkKVxuXG5nZ3Bsb3QoZGF0YSwgYWVzKHggPSBpc1dpdGhpbkJkLCB5ID0gZGlmZl9kVEFHX0RNU08sIGZpbGwgPSBpc1dpdGhpbkJkKSkgKyBnZW9tX3Zpb2xpbigpICsgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApXG5cblxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihpc1dpdGhpbkJkID09Z3JvdXAxKSApJGRpZmZfZFRBR19ETVNPXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihpc1dpdGhpbkJkID09Z3JvdXAyKSApJGRpZmZfZFRBR19ETVNPXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5nZXRQdmFsV2lsY294KGRhdGEsIFRSVUUsIEZBTFNFKVxuXG5cbiMgUHJvcG9ydGlvbiBvZiB0aG9zZSBnZW5lIGJldHdlZW4gZ3JvdXAxIGFuZCBncm91cDJcbmRhdGEuaXNXaXRoaW5CZCA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGlzV2l0aGluQmQpXG5cbmdlbmUuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XCIpKSRnZW5lXG5nZW5lLmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlwiKSkkZ2VuZVxuXG5zdW0oZ2VuZS5ncm91cDEgJWluJSBkYXRhLmlzV2l0aGluQmQkZ2VuZSkvbGVuZ3RoKGdlbmUuZ3JvdXAxKSoxMDBcblxuc3VtKGdlbmUuZ3JvdXAyICVpbiUgZGF0YS5pc1dpdGhpbkJkJGdlbmUpL2xlbmd0aChnZW5lLmdyb3VwMikqMTAwXG5cbiMgQ2hlY2tpbmcgc2l6ZSBvZiB0aG9zZSBsb29wc1xuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKVxuXG5nZ3Bsb3QoZGF0YSwgYWVzKHggPSBpc1dpdGhpbkJkLCB5ID0gZGlzdGFuY2UsIGZpbGwgPSBpc1dpdGhpbkJkKSkgKyBnZW9tX3Zpb2xpbigpICsgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xKSArIHRoZW1lX2NsYXNzaWMoKVxuXG5cblxuYGBgIn0= -->\n\n```r\nflankSize <- 1\ngene.TSS.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)\ncolnames(gene.TSS.tb) <- c(\\chr\\, \\start\\, \\end\\, \\strand\\, \\gene\\, \\ensembl\\)\ngeneEnsemblPair <- gene.TSS.tb %>% dplyr::select(gene, ensembl)\n\nboundary.pair <- fread(here(refDir, \\tss_convergent_ctcf_motif_pairs.bedpe\\))\ncolnames(boundary.pair) <- c(\\boundary_chrom1\\, \\boundary_start1\\, \\boundary_end1\\, \\boundary_chrom2\\, \\boundary_start2\\, \\boundary_end2\\, \\ensembl\\)\nboundary.pair <- boundary.pair %>% dplyr::left_join(geneEnsemblPair, by = c(\\ensembl\\))\n\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\)) %>%\n  dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 24, 29, 31)) %>% unnest(gene)\n\n\ndata <- geneAnnoData %>% dplyr::left_join(boundary.pair, by = c(\\gene\\ = \\ensembl\\))\n\ndata <- data %>% rowwise() %>% dplyr::mutate(isWithinLeftBd = (boundary_start1 <= min(end1, end2)),\n                       isWithinRightBd = (boundary_end2 >= max(start1, start2)),\n                       isWithinBd = isWithinLeftBd & isWithinRightBd)\ndata <- data %>% drop_na()\n\n\nggplot(data, aes(x = DMSO, y = dTAG)) + geom_point() + coord_fixed() +  \n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  theme_classic() + facet_wrap(~ isWithinBd)\n\nggplot(data, aes(x = isWithinBd, y = diff_dTAG_DMSO, fill = isWithinBd)) + geom_violin() + geom_boxplot(width = 0.1) + theme_classic() +\n  geom_hline(yintercept = 0)\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(isWithinBd ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(isWithinBd ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ngetPvalWilcox(data, TRUE, FALSE)\n\n\n# Proportion of those gene between group1 and group2\ndata.isWithinBd <- data %>% dplyr::filter(isWithinBd)\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nsum(gene.group1 %in% data.isWithinBd$gene)/length(gene.group1)*100\n\nsum(gene.group2 %in% data.isWithinBd$gene)/length(gene.group2)*100\n\n# Checking size of those loops\ndata <- data %>% dplyr::mutate(distance = start2 - start1)\n\nggplot(data, aes(x = isWithinBd, y = distance, fill = isWithinBd)) + geom_violin() + geom_boxplot(width = 0.1) + theme_classic()\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
flankSize <- 1
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)
colnames(gene.TSS.tb) <- c(\chr\, \start\, \end\, \strand\, \gene\, \ensembl\)
geneEnsemblPair <- gene.TSS.tb %>% dplyr::select(gene, ensembl)

boundary.pair <- fread(here(refDir, \tss_convergent_ctcf_motif_pairs.bedpe\))
colnames(boundary.pair) <- c(\boundary_chrom1\, \boundary_start1\, \boundary_end1\, \boundary_chrom2\, \boundary_start2\, \boundary_end2\, \ensembl\)
boundary.pair <- boundary.pair %>% dplyr::left_join(geneEnsemblPair, by = c(\ensembl\))


# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\)) %>%
  dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 24, 29, 31)) %>% unnest(gene)


data <- geneAnnoData %>% dplyr::left_join(boundary.pair, by = c(\gene\ = \ensembl\))

data <- data %>% rowwise() %>% dplyr::mutate(isWithinLeftBd = (boundary_start1 <= min(end1, end2)),
                       isWithinRightBd = (boundary_end2 >= max(start1, start2)),
                       isWithinBd = isWithinLeftBd & isWithinRightBd)
data <- data %>% drop_na()


ggplot(data, aes(x = DMSO, y = dTAG)) + geom_point() + coord_fixed() +  
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  theme_classic() + facet_wrap(~ isWithinBd)

ggplot(data, aes(x = isWithinBd, y = diff_dTAG_DMSO, fill = isWithinBd)) + geom_violin() + geom_boxplot(width = 0.1) + theme_classic() +
  geom_hline(yintercept = 0)


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(isWithinBd ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(isWithinBd ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

getPvalWilcox(data, TRUE, FALSE)


# Proportion of those gene between group1 and group2
data.isWithinBd <- data %>% dplyr::filter(isWithinBd)

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

sum(gene.group1 %in% data.isWithinBd$gene)/length(gene.group1)*100

sum(gene.group2 %in% data.isWithinBd$gene)/length(gene.group2)*100

# Checking size of those loops
data <- data %>% dplyr::mutate(distance = start2 - start1)

ggplot(data, aes(x = isWithinBd, y = distance, fill = isWithinBd)) + geom_violin() + geom_boxplot(width = 0.1) + theme_classic()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZmxhbmtTaXplIDwtIDFcbmdlbmUuVFNTLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpLFxuICAgICAgICAgICAgICAgIFRTU3N0YXJ0ID0gVFNTIC0gZmxhbmtTaXplLFxuICAgICAgICAgICAgICAgIFRTU2VuZCA9IFRTUyArIGZsYW5rU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTU3N0YXJ0LCBUU1NlbmQsIFY0LCBWNSwgVjYpXG5jb2xuYW1lcyhnZW5lLlRTUy50YikgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcc3RyYW5kXFwsIFxcZ2VuZVxcLCBcXGVuc2VtYmxcXClcbmdlbmVFbnNlbWJsUGFpciA8LSBnZW5lLlRTUy50YiAlPiUgZHBseXI6OnNlbGVjdChnZW5lLCBlbnNlbWJsKVxuXG5ib3VuZGFyeS5wYWlyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXHRzc19jb252ZXJnZW50X2N0Y2ZfbW90aWZfcGFpcnMuYmVkcGVcXCkpXG5jb2xuYW1lcyhib3VuZGFyeS5wYWlyKSA8LSBjKFxcYm91bmRhcnlfY2hyb20xXFwsIFxcYm91bmRhcnlfc3RhcnQxXFwsIFxcYm91bmRhcnlfZW5kMVxcLCBcXGJvdW5kYXJ5X2Nocm9tMlxcLCBcXGJvdW5kYXJ5X3N0YXJ0MlxcLCBcXGJvdW5kYXJ5X2VuZDJcXCwgXFxlbnNlbWJsXFwpXG5ib3VuZGFyeS5wYWlyIDwtIGJvdW5kYXJ5LnBhaXIgJT4lIGRwbHlyOjpsZWZ0X2pvaW4oZ2VuZUVuc2VtYmxQYWlyLCBieSA9IGMoXFxlbnNlbWJsXFwpKVxuXG5cbiMgSW1wb3J0aW5nIGxvb3AgZ2VuZSBhbm5vdGF0aW9uXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kaWZmQ3V0b2ZmIDwtIDAuMlxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLW5fZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IGRpZmZDdXRvZmYsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9MaXN0ID0gYyhcXFAtUFxcLCBcXFAtRVxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzLCA0LCA1LCA2LCAxMSwgMTIsIDI0LCAyOSwgMzEpKSAlPiUgdW5uZXN0KGdlbmUpXG5cblxuZGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4oYm91bmRhcnkucGFpciwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsXFwpKVxuXG5kYXRhIDwtIGRhdGEgJT4lIHJvd3dpc2UoKSAlPiUgZHBseXI6Om11dGF0ZShpc1dpdGhpbkxlZnRCZCA9IChib3VuZGFyeV9zdGFydDEgPD0gbWluKGVuZDEsIGVuZDIpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgaXNXaXRoaW5SaWdodEJkID0gKGJvdW5kYXJ5X2VuZDIgPj0gbWF4KHN0YXJ0MSwgc3RhcnQyKSksXG4gICAgICAgICAgICAgICAgICAgICAgIGlzV2l0aGluQmQgPSBpc1dpdGhpbkxlZnRCZCAmIGlzV2l0aGluUmlnaHRCZClcbmRhdGEgPC0gZGF0YSAlPiUgZHJvcF9uYSgpXG5cblxuZ2dwbG90KGRhdGEsIGFlcyh4ID0gRE1TTywgeSA9IGRUQUcpKSArIGdlb21fcG9pbnQoKSArIGNvb3JkX2ZpeGVkKCkgKyAgXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCwgY29sID0gXFxncmV5NTBcXCwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGZhY2V0X3dyYXAofiBpc1dpdGhpbkJkKVxuXG5nZ3Bsb3QoZGF0YSwgYWVzKHggPSBpc1dpdGhpbkJkLCB5ID0gZGlmZl9kVEFHX0RNU08sIGZpbGwgPSBpc1dpdGhpbkJkKSkgKyBnZW9tX3Zpb2xpbigpICsgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApXG5cblxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihpc1dpdGhpbkJkID09Z3JvdXAxKSApJGRpZmZfZFRBR19ETVNPXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihpc1dpdGhpbkJkID09Z3JvdXAyKSApJGRpZmZfZFRBR19ETVNPXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5nZXRQdmFsV2lsY294KGRhdGEsIFRSVUUsIEZBTFNFKVxuXG5cbiMgUHJvcG9ydGlvbiBvZiB0aG9zZSBnZW5lIGJldHdlZW4gZ3JvdXAxIGFuZCBncm91cDJcbmRhdGEuaXNXaXRoaW5CZCA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGlzV2l0aGluQmQpXG5cbmdlbmUuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5nZW5lLmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG5zdW0oZ2VuZS5ncm91cDEgJWluJSBkYXRhLmlzV2l0aGluQmQkZ2VuZSkvbGVuZ3RoKGdlbmUuZ3JvdXAxKSoxMDBcblxuc3VtKGdlbmUuZ3JvdXAyICVpbiUgZGF0YS5pc1dpdGhpbkJkJGdlbmUpL2xlbmd0aChnZW5lLmdyb3VwMikqMTAwXG5cbiMgQ2hlY2tpbmcgc2l6ZSBvZiB0aG9zZSBsb29wc1xuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKVxuXG5nZ3Bsb3QoZGF0YSwgYWVzKHggPSBpc1dpdGhpbkJkLCB5ID0gZGlzdGFuY2UsIGZpbGwgPSBpc1dpdGhpbkJkKSkgKyBnZW9tX3Zpb2xpbigpICsgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xKSArIHRoZW1lX2NsYXNzaWMoKVxuXG5cblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\nflankSize <- 1\ngene.TSS.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)\ncolnames(gene.TSS.tb) <- c(\\chr\\, \\start\\, \\end\\, \\strand\\, \\gene\\, \\ensembl\\)\ngeneEnsemblPair <- gene.TSS.tb %>% dplyr::select(gene, ensembl)\n\nboundary.pair <- fread(here(refDir, \\tss_convergent_ctcf_motif_pairs.bedpe\\))\ncolnames(boundary.pair) <- c(\\boundary_chrom1\\, \\boundary_start1\\, \\boundary_end1\\, \\boundary_chrom2\\, \\boundary_start2\\, \\boundary_end2\\, \\ensembl\\)\nboundary.pair <- boundary.pair %>% dplyr::left_join(geneEnsemblPair, by = c(\\ensembl\\))\n\n\n# Importing loop gene annotation\nname <- \\chromo_cons_annoHierarchy\\\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\)) %>%\n  dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 24, 29, 31)) %>% unnest(gene)\n\n\ndata <- geneAnnoData %>% dplyr::left_join(boundary.pair, by = c(\\gene\\ = \\ensembl\\))\n\ndata <- data %>% rowwise() %>% dplyr::mutate(isWithinLeftBd = (boundary_start1 <= min(end1, end2)),\n                       isWithinRightBd = (boundary_end2 >= max(start1, start2)),\n                       isWithinBd = isWithinLeftBd & isWithinRightBd)\ndata <- data %>% drop_na()\n\n\nggplot(data, aes(x = DMSO, y = dTAG)) + geom_point() + coord_fixed() +  \n  geom_abline(slope = 1, intercept = 0, col = \\grey50\\, linetype = \\dashed\\) +\n  geom_hline(yintercept = 0, alpha = 0.5, color = \\grey\\) +\n  geom_vline(xintercept = 0, alpha = 0.5, color = \\grey\\) +\n  theme_classic() + facet_wrap(~ isWithinBd)\n\nggplot(data, aes(x = isWithinBd, y = diff_dTAG_DMSO, fill = isWithinBd)) + geom_violin() + geom_boxplot(width = 0.1) + theme_classic() +\n  geom_hline(yintercept = 0)\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(isWithinBd ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(isWithinBd ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ngetPvalWilcox(data, TRUE, FALSE)\n\n\n# Proportion of those gene between group1 and group2\ndata.isWithinBd <- data %>% dplyr::filter(isWithinBd)\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nsum(gene.group1 %in% data.isWithinBd$gene)/length(gene.group1)*100\n\nsum(gene.group2 %in% data.isWithinBd$gene)/length(gene.group2)*100\n\n# Checking size of those loops\ndata <- data %>% dplyr::mutate(distance = start2 - start1)\n\nggplot(data, aes(x = isWithinBd, y = distance, fill = isWithinBd)) + geom_violin() + geom_boxplot(width = 0.1) + theme_classic()\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZmxhbmtTaXplIDwtIDFcbmdlbmUuVFNTLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpLFxuICAgICAgICAgICAgICAgIFRTU3N0YXJ0ID0gVFNTIC0gZmxhbmtTaXplLFxuICAgICAgICAgICAgICAgIFRTU2VuZCA9IFRTUyArIGZsYW5rU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTU3N0YXJ0LCBUU1NlbmQsIFY0LCBWNSwgVjYpXG5jb2xuYW1lcyhnZW5lLlRTUy50YikgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcc3RyYW5kXFwsIFxcZ2VuZVxcLCBcXGVuc2VtYmxcXClcbmdlbmVFbnNlbWJsUGFpciA8LSBnZW5lLlRTUy50YiAlPiUgZHBseXI6OnNlbGVjdChnZW5lLCBlbnNlbWJsKVxuXG5ib3VuZGFyeS5wYWlyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXHRzc19jb252ZXJnZW50X2N0Y2ZfbW90aWZfcGFpcnMuYmVkcGVcXCkpXG5jb2xuYW1lcyhib3VuZGFyeS5wYWlyKSA8LSBjKFxcYm91bmRhcnlfY2hyb20xXFwsIFxcYm91bmRhcnlfc3RhcnQxXFwsIFxcYm91bmRhcnlfZW5kMVxcLCBcXGJvdW5kYXJ5X2Nocm9tMlxcLCBcXGJvdW5kYXJ5X3N0YXJ0MlxcLCBcXGJvdW5kYXJ5X2VuZDJcXCwgXFxlbnNlbWJsXFwpXG5ib3VuZGFyeS5wYWlyIDwtIGJvdW5kYXJ5LnBhaXIgJT4lIGRwbHlyOjpsZWZ0X2pvaW4oZ2VuZUVuc2VtYmxQYWlyLCBieSA9IGMoXFxlbnNlbWJsXFwpKVxuXG5cbiMgSW1wb3J0aW5nIGxvb3AgZ2VuZSBhbm5vdGF0aW9uXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5kaWZmQ3V0b2ZmIDwtIDAuMlxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLW5fZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IGRpZmZDdXRvZmYsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9MaXN0ID0gYyhcXFAtUFxcLCBcXFAtRVxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoYygxLCAyLCAzLCA0LCA1LCA2LCAxMSwgMTIsIDI0LCAyOSwgMzEpKSAlPiUgdW5uZXN0KGdlbmUpXG5cblxuZGF0YSA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4oYm91bmRhcnkucGFpciwgYnkgPSBjKFxcZ2VuZVxcID0gXFxlbnNlbWJsXFwpKVxuXG5kYXRhIDwtIGRhdGEgJT4lIHJvd3dpc2UoKSAlPiUgZHBseXI6Om11dGF0ZShpc1dpdGhpbkxlZnRCZCA9IChib3VuZGFyeV9zdGFydDEgPD0gbWluKGVuZDEsIGVuZDIpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgaXNXaXRoaW5SaWdodEJkID0gKGJvdW5kYXJ5X2VuZDIgPj0gbWF4KHN0YXJ0MSwgc3RhcnQyKSksXG4gICAgICAgICAgICAgICAgICAgICAgIGlzV2l0aGluQmQgPSBpc1dpdGhpbkxlZnRCZCAmIGlzV2l0aGluUmlnaHRCZClcbmRhdGEgPC0gZGF0YSAlPiUgZHJvcF9uYSgpXG5cblxuZ2dwbG90KGRhdGEsIGFlcyh4ID0gRE1TTywgeSA9IGRUQUcpKSArIGdlb21fcG9pbnQoKSArIGNvb3JkX2ZpeGVkKCkgKyAgXG4gIGdlb21fYWJsaW5lKHNsb3BlID0gMSwgaW50ZXJjZXB0ID0gMCwgY29sID0gXFxncmV5NTBcXCwgbGluZXR5cGUgPSBcXGRhc2hlZFxcKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIGdlb21fdmxpbmUoeGludGVyY2VwdCA9IDAsIGFscGhhID0gMC41LCBjb2xvciA9IFxcZ3JleVxcKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGZhY2V0X3dyYXAofiBpc1dpdGhpbkJkKVxuXG5nZ3Bsb3QoZGF0YSwgYWVzKHggPSBpc1dpdGhpbkJkLCB5ID0gZGlmZl9kVEFHX0RNU08sIGZpbGwgPSBpc1dpdGhpbkJkKSkgKyBnZW9tX3Zpb2xpbigpICsgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xKSArIHRoZW1lX2NsYXNzaWMoKSArXG4gIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApXG5cblxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihpc1dpdGhpbkJkID09Z3JvdXAxKSApJGRpZmZfZFRBR19ETVNPXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihpc1dpdGhpbkJkID09Z3JvdXAyKSApJGRpZmZfZFRBR19ETVNPXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5nZXRQdmFsV2lsY294KGRhdGEsIFRSVUUsIEZBTFNFKVxuXG5cbiMgUHJvcG9ydGlvbiBvZiB0aG9zZSBnZW5lIGJldHdlZW4gZ3JvdXAxIGFuZCBncm91cDJcbmRhdGEuaXNXaXRoaW5CZCA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGlzV2l0aGluQmQpXG5cbmdlbmUuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5nZW5lLmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG5zdW0oZ2VuZS5ncm91cDEgJWluJSBkYXRhLmlzV2l0aGluQmQkZ2VuZSkvbGVuZ3RoKGdlbmUuZ3JvdXAxKSoxMDBcblxuc3VtKGdlbmUuZ3JvdXAyICVpbiUgZGF0YS5pc1dpdGhpbkJkJGdlbmUpL2xlbmd0aChnZW5lLmdyb3VwMikqMTAwXG5cbiMgQ2hlY2tpbmcgc2l6ZSBvZiB0aG9zZSBsb29wc1xuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKGRpc3RhbmNlID0gc3RhcnQyIC0gc3RhcnQxKVxuXG5nZ3Bsb3QoZGF0YSwgYWVzKHggPSBpc1dpdGhpbkJkLCB5ID0gZGlzdGFuY2UsIGZpbGwgPSBpc1dpdGhpbkJkKSkgKyBnZW9tX3Zpb2xpbigpICsgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xKSArIHRoZW1lX2NsYXNzaWMoKVxuXG5cblxuYGBgXG5gYGAifQ== -->

```r
```r
flankSize <- 1
gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)
colnames(gene.TSS.tb) <- c(\chr\, \start\, \end\, \strand\, \gene\, \ensembl\)
geneEnsemblPair <- gene.TSS.tb %>% dplyr::select(gene, ensembl)

boundary.pair <- fread(here(refDir, \tss_convergent_ctcf_motif_pairs.bedpe\))
colnames(boundary.pair) <- c(\boundary_chrom1\, \boundary_start1\, \boundary_end1\, \boundary_chrom2\, \boundary_start2\, \boundary_end2\, \ensembl\)
boundary.pair <- boundary.pair %>% dplyr::left_join(geneEnsemblPair, by = c(\ensembl\))


# Importing loop gene annotation
name <- \chromo_cons_annoHierarchy\
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\)) %>%
  dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 24, 29, 31)) %>% unnest(gene)


data <- geneAnnoData %>% dplyr::left_join(boundary.pair, by = c(\gene\ = \ensembl\))

data <- data %>% rowwise() %>% dplyr::mutate(isWithinLeftBd = (boundary_start1 <= min(end1, end2)),
                       isWithinRightBd = (boundary_end2 >= max(start1, start2)),
                       isWithinBd = isWithinLeftBd & isWithinRightBd)
data <- data %>% drop_na()


ggplot(data, aes(x = DMSO, y = dTAG)) + geom_point() + coord_fixed() +  
  geom_abline(slope = 1, intercept = 0, col = \grey50\, linetype = \dashed\) +
  geom_hline(yintercept = 0, alpha = 0.5, color = \grey\) +
  geom_vline(xintercept = 0, alpha = 0.5, color = \grey\) +
  theme_classic() + facet_wrap(~ isWithinBd)

ggplot(data, aes(x = isWithinBd, y = diff_dTAG_DMSO, fill = isWithinBd)) + geom_violin() + geom_boxplot(width = 0.1) + theme_classic() +
  geom_hline(yintercept = 0)


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(isWithinBd ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(isWithinBd ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

getPvalWilcox(data, TRUE, FALSE)


# Proportion of those gene between group1 and group2
data.isWithinBd <- data %>% dplyr::filter(isWithinBd)

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

sum(gene.group1 %in% data.isWithinBd$gene)/length(gene.group1)*100

sum(gene.group2 %in% data.isWithinBd$gene)/length(gene.group2)*100

# Checking size of those loops
data <- data %>% dplyr::mutate(distance = start2 - start1)

ggplot(data, aes(x = isWithinBd, y = distance, fill = isWithinBd)) + geom_violin() + geom_boxplot(width = 0.1) + theme_classic()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Comparing it to TSS

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVabXhoYm10VGFYcGxJRHd0SURJdU5XVXpYRzVuWlc1bExuUmlJRHd0SUdaeVpXRmtLR2hsY21Vb2NtVm1SR2x5TENCY0ltMXRNVEJmUjFKRGJUTTRMbkEyWDJkbGJtVmZjMjl5ZEdWa0xtSmxaRndpS1NrZ0pUNGxYRzRnSUdSd2JIbHlPanB0ZFhSaGRHVW9WRk5USUQwZ2FXWmxiSE5sS0ZZMElEMDlJRndpSzF3aUxDQldNaXdnVmpNcExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGUlRVM04wWVhKMElEMGdWRk5USUMwZ1pteGhibXRUYVhwbExGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lGUlRVMlZ1WkNBOUlGUlRVeUFySUdac1lXNXJVMmw2WlNrZ0pUNGxYRzRnSUdSd2JIbHlPanB6Wld4bFkzUW9WakVzSUZSVFUzTjBZWEowTENCVVUxTmxibVFzSUZZMkxDQldOU2xjYm1OdmJHNWhiV1Z6S0dkbGJtVXVkR0lwSUR3dElHTW9YQ0pqYUhKY0lpd2dYQ0p6ZEdGeWRGd2lMQ0JjSW1WdVpGd2lMQ0JjSW1WdWMyVnRZbXhjSWl3Z1hDSm5aVzVsWENJcFhHNWNibWRsYm1VdVozSnZkWEF4SUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNJbWRsYm1WTWFYTjBYMlJVUVVkZmRuTmZSRTFUVDE5U1RrRmZiRzl2Y0Y5aWFXNWhjbmxIY205MWNERXVkSE4yWENJcEtTUm5aVzVsWEc1blpXNWxMbWR5YjNWd01pQThMU0JtY21WaFpDaG9aWEpsS0hKbFprUnBjaXdnWENKblpXNWxUR2x6ZEY5a1ZFRkhYM1p6WDBSTlUwOWZVazVCWDJ4dmIzQmZZbWx1WVhKNVIzSnZkWEF5TG5SemRsd2lLU2trWjJWdVpWeHVYRzVVVTFNeGJXSXVaM0p2ZFhBeExtZHlJRHd0SUcxaGEyVkhVbUZ1WjJWelJuSnZiVVJoZEdGR2NtRnRaU2huWlc1bExuUmlJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLR1Z1YzJWdFltd2dKV2x1SlNCblpXNWxMbWR5YjNWd01Ta3NJR3RsWlhBdVpYaDBjbUV1WTI5c2RXMXVjeUE5SUZSU1ZVVXBYRzVVVTFNeGJXSXVaM0p2ZFhBeUxtZHlJRHd0SUcxaGEyVkhVbUZ1WjJWelJuSnZiVVJoZEdGR2NtRnRaU2huWlc1bExuUmlJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLR1Z1YzJWdFltd2dKV2x1SlNCblpXNWxMbWR5YjNWd01pa3NJR3RsWlhBdVpYaDBjbUV1WTI5c2RXMXVjeUE5SUZSU1ZVVXBYRzVjYmx4dVkzUmpaaTV3WldGcklEd3RJR1p5WldGa0tHaGxjbVVvY21WbVJHbHlMQ0JjSWpNek1qUTRYME5VUTBaZk1EY3ROekk1WDBKeWRXTmxMVFJmY0dWaGEzTXViV1Z5WjJWUVpXRnJMbTF2ZEdsbVFXNXViM1JoZEdWa0xtSmxaRndpS1NsY2JtTnZiRzVoYldWektHTjBZMll1Y0dWaGF5a2dQQzBnWXloY0ltTm9jbHdpTENCY0luTjBZWEowWENJc0lGd2laVzVrWENJc0lGd2liVzkwYVdaY0lpbGNibU4wWTJZdWNHVmhheTVuY2lBOExTQnRZV3RsUjFKaGJtZGxjMFp5YjIxRVlYUmhSbkpoYldVb1kzUmpaaTV3WldGcktWeHVYRzVjYm5CeWFXNTBLRndpS3kweUxqVnJZaUJVVTFNZ2IzWmxjbXhoSUhkcGRHZ2dRMVJEUmlCd1pXRnJYQ0lwWEc1c1pXNW5kR2dvZFc1cGNYVmxLSEYxWlhKNVNHbDBjeWhtYVc1a1QzWmxjbXhoY0hNb1ZGTlRNVzFpTG1keWIzVndNUzVuY2l3Z1kzUmpaaTV3WldGckxtZHlLU2twS1M5c1pXNW5kR2dvWjJWdVpTNW5jbTkxY0RFcEtqRXdNRnh1YkdWdVozUm9LSFZ1YVhGMVpTaHhkV1Z5ZVVocGRITW9abWx1WkU5MlpYSnNZWEJ6S0ZSVFV6RnRZaTVuY205MWNESXVaM0lzSUdOMFkyWXVjR1ZoYXk1bmNpa3BLU2t2YkdWdVozUm9LR2RsYm1VdVozSnZkWEF5S1NveE1EQmNibHh1WEc1Y2JtTjBZMll1Y0dWaGF5NW5jaUE4TFNCdFlXdGxSMUpoYm1kbGMwWnliMjFFWVhSaFJuSmhiV1VvWTNSalppNXdaV0ZySUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0cxdmRHbG1JQ0U5SUZ3aWJtOXVaVndpS1NsY2JuQnlhVzUwS0Z3aUt5MHlMalZyWWlCVVUxTWdiM1psY214aElIZHBkR2dnUTFSRFJpQndaV0ZySUhkcGRHZ2diVzkwYVdaY0lpbGNibXhsYm1kMGFDaDFibWx4ZFdVb2NYVmxjbmxJYVhSektHWnBibVJQZG1WeWJHRndjeWhVVTFNeGJXSXVaM0p2ZFhBeExtZHlMQ0JqZEdObUxuQmxZV3N1WjNJcEtTa3BMMnhsYm1kMGFDaG5aVzVsTG1keWIzVndNU2txTVRBd1hHNXNaVzVuZEdnb2RXNXBjWFZsS0hGMVpYSjVTR2wwY3lobWFXNWtUM1psY214aGNITW9WRk5UTVcxaUxtZHliM1Z3TWk1bmNpd2dZM1JqWmk1d1pXRnJMbWR5S1NrcEtTOXNaVzVuZEdnb1oyVnVaUzVuY205MWNESXBLakV3TUZ4dVhHNWNibHh1WEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5mbGFua1NpemUgPC0gMi41ZTNcbmdlbmUudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXFwrXFwsIFYyLCBWMyksXG4gICAgICAgICAgICAgICAgVFNTc3RhcnQgPSBUU1MgLSBmbGFua1NpemUsXG4gICAgICAgICAgICAgICAgVFNTZW5kID0gVFNTICsgZmxhbmtTaXplKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWMSwgVFNTc3RhcnQsIFRTU2VuZCwgVjYsIFY1KVxuY29sbmFtZXMoZ2VuZS50YikgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcZW5zZW1ibFxcLCBcXGdlbmVcXClcblxuZ2VuZS5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdlbmUuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XFwpKSRnZW5lXG5cblRTUzFtYi5ncm91cDEuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGdlbmUudGIgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGdlbmUuZ3JvdXAxKSwga2VlcC5leHRyYS5jb2x1bW5zID0gVFJVRSlcblRTUzFtYi5ncm91cDIuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGdlbmUudGIgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGdlbmUuZ3JvdXAyKSwga2VlcC5leHRyYS5jb2x1bW5zID0gVFJVRSlcblxuXG5jdGNmLnBlYWsgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcMzMyNDhfQ1RDRl8wNy03MjlfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsubW90aWZBbm5vdGF0ZWQuYmVkXFwpKVxuY29sbmFtZXMoY3RjZi5wZWFrKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxtb3RpZlxcKVxuY3RjZi5wZWFrLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShjdGNmLnBlYWspXG5cblxucHJpbnQoXFwrLTIuNWtiIFRTUyBvdmVybGEgd2l0aCBDVENGIHBlYWtcXClcbmxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyhUU1MxbWIuZ3JvdXAxLmdyLCBjdGNmLnBlYWsuZ3IpKSkpL2xlbmd0aChnZW5lLmdyb3VwMSkqMTAwXG5sZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhmaW5kT3ZlcmxhcHMoVFNTMW1iLmdyb3VwMi5nciwgY3RjZi5wZWFrLmdyKSkpKS9sZW5ndGgoZ2VuZS5ncm91cDIpKjEwMFxuXG5cblxuY3RjZi5wZWFrLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShjdGNmLnBlYWsgJT4lIGRwbHlyOjpmaWx0ZXIobW90aWYgIT0gXFxub25lXFwpKVxucHJpbnQoXFwrLTIuNWtiIFRTUyBvdmVybGEgd2l0aCBDVENGIHBlYWsgd2l0aCBtb3RpZlxcKVxubGVuZ3RoKHVuaXF1ZShxdWVyeUhpdHMoZmluZE92ZXJsYXBzKFRTUzFtYi5ncm91cDEuZ3IsIGN0Y2YucGVhay5ncikpKSkvbGVuZ3RoKGdlbmUuZ3JvdXAxKSoxMDBcbmxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyhUU1MxbWIuZ3JvdXAyLmdyLCBjdGNmLnBlYWsuZ3IpKSkpL2xlbmd0aChnZW5lLmdyb3VwMikqMTAwXG5cblxuXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
flankSize <- 2.5e3
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c(\chr\, \start\, \end\, \ensembl\, \gene\)

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

TSS1mb.group1.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group1), keep.extra.columns = TRUE)
TSS1mb.group2.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group2), keep.extra.columns = TRUE)


ctcf.peak <- fread(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed\))
colnames(ctcf.peak) <- c(\chr\, \start\, \end\, \motif\)
ctcf.peak.gr <- makeGRangesFromDataFrame(ctcf.peak)


print(\+-2.5kb TSS overla with CTCF peak\)
length(unique(queryHits(findOverlaps(TSS1mb.group1.gr, ctcf.peak.gr))))/length(gene.group1)*100
length(unique(queryHits(findOverlaps(TSS1mb.group2.gr, ctcf.peak.gr))))/length(gene.group2)*100



ctcf.peak.gr <- makeGRangesFromDataFrame(ctcf.peak %>% dplyr::filter(motif != \none\))
print(\+-2.5kb TSS overla with CTCF peak with motif\)
length(unique(queryHits(findOverlaps(TSS1mb.group1.gr, ctcf.peak.gr))))/length(gene.group1)*100
length(unique(queryHits(findOverlaps(TSS1mb.group2.gr, ctcf.peak.gr))))/length(gene.group2)*100



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dVpteGhibXRUYVhwbElEd3RJREl1TldVelhHNW5aVzVsTG5SaUlEd3RJR1p5WldGa0tHaGxjbVVvY21WbVJHbHlMQ0JjWEcxdE1UQmZSMUpEYlRNNExuQTJYMmRsYm1WZmMyOXlkR1ZrTG1KbFpGeGNLU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHRkWFJoZEdVb1ZGTlRJRDBnYVdabGJITmxLRlkwSUQwOUlGeGNLMXhjTENCV01pd2dWak1wTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZSVFUzTjBZWEowSUQwZ1ZGTlRJQzBnWm14aGJtdFRhWHBsTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUZSVFUyVnVaQ0E5SUZSVFV5QXJJR1pzWVc1clUybDZaU2tnSlQ0bFhHNGdJR1J3YkhseU9qcHpaV3hsWTNRb1ZqRXNJRlJUVTNOMFlYSjBMQ0JVVTFObGJtUXNJRlkyTENCV05TbGNibU52Ykc1aGJXVnpLR2RsYm1VdWRHSXBJRHd0SUdNb1hGeGphSEpjWEN3Z1hGeHpkR0Z5ZEZ4Y0xDQmNYR1Z1WkZ4Y0xDQmNYR1Z1YzJWdFlteGNYQ3dnWEZ4blpXNWxYRndwWEc1Y2JtZGxibVV1WjNKdmRYQXhJRHd0SUdaeVpXRmtLR2hsY21Vb2NtVm1SR2x5TENCY1hHZGxibVZNYVhOMFgyUlVRVWRmZG5OZlJFMVRUMTlTVGtGZmJHOXZjRjlpYVc1aGNubEhjbTkxY0RFdWRITjJYRndwS1NSblpXNWxYRzVuWlc1bExtZHliM1Z3TWlBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYRnhuWlc1bFRHbHpkRjlrVkVGSFgzWnpYMFJOVTA5ZlVrNUJYMnh2YjNCZlltbHVZWEo1UjNKdmRYQXlMblJ6ZGx4Y0tTa2taMlZ1WlZ4dVhHNVVVMU14YldJdVozSnZkWEF4TG1keUlEd3RJRzFoYTJWSFVtRnVaMlZ6Um5KdmJVUmhkR0ZHY21GdFpTaG5aVzVsTG5SaUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHVnVjMlZ0WW13Z0pXbHVKU0JuWlc1bExtZHliM1Z3TVNrc0lHdGxaWEF1WlhoMGNtRXVZMjlzZFcxdWN5QTlJRlJTVlVVcFhHNVVVMU14YldJdVozSnZkWEF5TG1keUlEd3RJRzFoYTJWSFVtRnVaMlZ6Um5KdmJVUmhkR0ZHY21GdFpTaG5aVzVsTG5SaUlDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtHVnVjMlZ0WW13Z0pXbHVKU0JuWlc1bExtZHliM1Z3TWlrc0lHdGxaWEF1WlhoMGNtRXVZMjlzZFcxdWN5QTlJRlJTVlVVcFhHNWNibHh1WTNSalppNXdaV0ZySUR3dElHWnlaV0ZrS0dobGNtVW9jbVZtUkdseUxDQmNYRE16TWpRNFgwTlVRMFpmTURjdE56STVYMEp5ZFdObExUUmZjR1ZoYTNNdWJXVnlaMlZRWldGckxtMXZkR2xtUVc1dWIzUmhkR1ZrTG1KbFpGeGNLU2xjYm1OdmJHNWhiV1Z6S0dOMFkyWXVjR1ZoYXlrZ1BDMGdZeWhjWEdOb2NseGNMQ0JjWEhOMFlYSjBYRndzSUZ4Y1pXNWtYRndzSUZ4Y2JXOTBhV1pjWENsY2JtTjBZMll1Y0dWaGF5NW5jaUE4TFNCdFlXdGxSMUpoYm1kbGMwWnliMjFFWVhSaFJuSmhiV1VvWTNSalppNXdaV0ZyS1Z4dVhHNWNibkJ5YVc1MEtGeGNLeTB5TGpWcllpQlVVMU1nYjNabGNteGhJSGRwZEdnZ1ExUkRSaUJ3WldGclhGd3BYRzVzWlc1bmRHZ29kVzVwY1hWbEtIRjFaWEo1U0dsMGN5aG1hVzVrVDNabGNteGhjSE1vVkZOVE1XMWlMbWR5YjNWd01TNW5jaXdnWTNSalppNXdaV0ZyTG1keUtTa3BLUzlzWlc1bmRHZ29aMlZ1WlM1bmNtOTFjREVwS2pFd01GeHViR1Z1WjNSb0tIVnVhWEYxWlNoeGRXVnllVWhwZEhNb1ptbHVaRTkyWlhKc1lYQnpLRlJUVXpGdFlpNW5jbTkxY0RJdVozSXNJR04wWTJZdWNHVmhheTVuY2lrcEtTa3ZiR1Z1WjNSb0tHZGxibVV1WjNKdmRYQXlLU294TURCY2JseHVYRzVjYm1OMFkyWXVjR1ZoYXk1bmNpQThMU0J0WVd0bFIxSmhibWRsYzBaeWIyMUVZWFJoUm5KaGJXVW9ZM1JqWmk1d1pXRnJJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLRzF2ZEdsbUlDRTlJRnhjYm05dVpWeGNLU2xjYm5CeWFXNTBLRnhjS3kweUxqVnJZaUJVVTFNZ2IzWmxjbXhoSUhkcGRHZ2dRMVJEUmlCd1pXRnJJSGRwZEdnZ2JXOTBhV1pjWENsY2JteGxibWQwYUNoMWJtbHhkV1VvY1hWbGNubElhWFJ6S0dacGJtUlBkbVZ5YkdGd2N5aFVVMU14YldJdVozSnZkWEF4TG1keUxDQmpkR05tTG5CbFlXc3VaM0lwS1NrcEwyeGxibWQwYUNoblpXNWxMbWR5YjNWd01Ta3FNVEF3WEc1c1pXNW5kR2dvZFc1cGNYVmxLSEYxWlhKNVNHbDBjeWhtYVc1a1QzWmxjbXhoY0hNb1ZGTlRNVzFpTG1keWIzVndNaTVuY2l3Z1kzUmpaaTV3WldGckxtZHlLU2twS1M5c1pXNW5kR2dvWjJWdVpTNW5jbTkxY0RJcEtqRXdNRnh1WEc1Y2JseHVYRzVnWUdCY2JtQmdZQ0o5IC0tPlxuXG5gYGByXG5gYGByXG5mbGFua1NpemUgPC0gMi41ZTNcbmdlbmUudGIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcbW0xMF9HUkNtMzgucDZfZ2VuZV9zb3J0ZWQuYmVkXFwpKSAlPiVcbiAgZHBseXI6Om11dGF0ZShUU1MgPSBpZmVsc2UoVjQgPT0gXFwrXFwsIFYyLCBWMyksXG4gICAgICAgICAgICAgICAgVFNTc3RhcnQgPSBUU1MgLSBmbGFua1NpemUsXG4gICAgICAgICAgICAgICAgVFNTZW5kID0gVFNTICsgZmxhbmtTaXplKSAlPiVcbiAgZHBseXI6OnNlbGVjdChWMSwgVFNTc3RhcnQsIFRTU2VuZCwgVjYsIFY1KVxuY29sbmFtZXMoZ2VuZS50YikgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcZW5zZW1ibFxcLCBcXGdlbmVcXClcblxuZ2VuZS5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdlbmUuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XFwpKSRnZW5lXG5cblRTUzFtYi5ncm91cDEuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGdlbmUudGIgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGdlbmUuZ3JvdXAxKSwga2VlcC5leHRyYS5jb2x1bW5zID0gVFJVRSlcblRTUzFtYi5ncm91cDIuZ3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGdlbmUudGIgJT4lIGRwbHlyOjpmaWx0ZXIoZW5zZW1ibCAlaW4lIGdlbmUuZ3JvdXAyKSwga2VlcC5leHRyYS5jb2x1bW5zID0gVFJVRSlcblxuXG5jdGNmLnBlYWsgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcMzMyNDhfQ1RDRl8wNy03MjlfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsubW90aWZBbm5vdGF0ZWQuYmVkXFwpKVxuY29sbmFtZXMoY3RjZi5wZWFrKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxtb3RpZlxcKVxuY3RjZi5wZWFrLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShjdGNmLnBlYWspXG5cblxucHJpbnQoXFwrLTIuNWtiIFRTUyBvdmVybGEgd2l0aCBDVENGIHBlYWtcXClcbmxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyhUU1MxbWIuZ3JvdXAxLmdyLCBjdGNmLnBlYWsuZ3IpKSkpL2xlbmd0aChnZW5lLmdyb3VwMSkqMTAwXG5sZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhmaW5kT3ZlcmxhcHMoVFNTMW1iLmdyb3VwMi5nciwgY3RjZi5wZWFrLmdyKSkpKS9sZW5ndGgoZ2VuZS5ncm91cDIpKjEwMFxuXG5cblxuY3RjZi5wZWFrLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShjdGNmLnBlYWsgJT4lIGRwbHlyOjpmaWx0ZXIobW90aWYgIT0gXFxub25lXFwpKVxucHJpbnQoXFwrLTIuNWtiIFRTUyBvdmVybGEgd2l0aCBDVENGIHBlYWsgd2l0aCBtb3RpZlxcKVxubGVuZ3RoKHVuaXF1ZShxdWVyeUhpdHMoZmluZE92ZXJsYXBzKFRTUzFtYi5ncm91cDEuZ3IsIGN0Y2YucGVhay5ncikpKSkvbGVuZ3RoKGdlbmUuZ3JvdXAxKSoxMDBcbmxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyhUU1MxbWIuZ3JvdXAyLmdyLCBjdGNmLnBlYWsuZ3IpKSkpL2xlbmd0aChnZW5lLmdyb3VwMikqMTAwXG5cblxuXG5cbmBgYFxuYGBgXG5cbjwhLS0gcm5iLXNvdXJjZS1lbmQgLS0+XG4ifQ== -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZmxhbmtTaXplIDwtIDIuNWUzXG5nZW5lLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpLFxuICAgICAgICAgICAgICAgIFRTU3N0YXJ0ID0gVFNTIC0gZmxhbmtTaXplLFxuICAgICAgICAgICAgICAgIFRTU2VuZCA9IFRTUyArIGZsYW5rU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTU3N0YXJ0LCBUU1NlbmQsIFY2LCBWNSlcbmNvbG5hbWVzKGdlbmUudGIpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGVuc2VtYmxcXCwgXFxnZW5lXFwpXG5cbmdlbmUuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5nZW5lLmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAyLnRzdlxcKSkkZ2VuZVxuXG5UU1MxbWIuZ3JvdXAxLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShnZW5lLnRiICU+JSBkcGx5cjo6ZmlsdGVyKGVuc2VtYmwgJWluJSBnZW5lLmdyb3VwMSksIGtlZXAuZXh0cmEuY29sdW1ucyA9IFRSVUUpXG5UU1MxbWIuZ3JvdXAyLmdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShnZW5lLnRiICU+JSBkcGx5cjo6ZmlsdGVyKGVuc2VtYmwgJWluJSBnZW5lLmdyb3VwMiksIGtlZXAuZXh0cmEuY29sdW1ucyA9IFRSVUUpXG5cblxuY3RjZi5wZWFrIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXDMzMjQ4X0NUQ0ZfMDctNzI5X0JydWNlLTRfcGVha3MubWVyZ2VQZWFrLm1vdGlmQW5ub3RhdGVkLmJlZFxcKSlcbmNvbG5hbWVzKGN0Y2YucGVhaykgPC0gYyhcXGNoclxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcbW90aWZcXClcbmN0Y2YucGVhay5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoY3RjZi5wZWFrKVxuXG5cbnByaW50KFxcKy0yLjVrYiBUU1Mgb3ZlcmxhIHdpdGggQ1RDRiBwZWFrXFwpXG5sZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhmaW5kT3ZlcmxhcHMoVFNTMW1iLmdyb3VwMS5nciwgY3RjZi5wZWFrLmdyKSkpKS9sZW5ndGgoZ2VuZS5ncm91cDEpKjEwMFxubGVuZ3RoKHVuaXF1ZShxdWVyeUhpdHMoZmluZE92ZXJsYXBzKFRTUzFtYi5ncm91cDIuZ3IsIGN0Y2YucGVhay5ncikpKSkvbGVuZ3RoKGdlbmUuZ3JvdXAyKSoxMDBcblxuXG5cbmN0Y2YucGVhay5nciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoY3RjZi5wZWFrICU+JSBkcGx5cjo6ZmlsdGVyKG1vdGlmICE9IFxcbm9uZVxcKSlcbnByaW50KFxcKy0yLjVrYiBUU1Mgb3ZlcmxhIHdpdGggQ1RDRiBwZWFrIHdpdGggbW90aWZcXClcbmxlbmd0aCh1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyhUU1MxbWIuZ3JvdXAxLmdyLCBjdGNmLnBlYWsuZ3IpKSkpL2xlbmd0aChnZW5lLmdyb3VwMSkqMTAwXG5sZW5ndGgodW5pcXVlKHF1ZXJ5SGl0cyhmaW5kT3ZlcmxhcHMoVFNTMW1iLmdyb3VwMi5nciwgY3RjZi5wZWFrLmdyKSkpKS9sZW5ndGgoZ2VuZS5ncm91cDIpKjEwMFxuXG5cblxuXG5gYGBcbmBgYCJ9 -->

```r
```r
flankSize <- 2.5e3
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c(\chr\, \start\, \end\, \ensembl\, \gene\)

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

TSS1mb.group1.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group1), keep.extra.columns = TRUE)
TSS1mb.group2.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group2), keep.extra.columns = TRUE)


ctcf.peak <- fread(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed\))
colnames(ctcf.peak) <- c(\chr\, \start\, \end\, \motif\)
ctcf.peak.gr <- makeGRangesFromDataFrame(ctcf.peak)


print(\+-2.5kb TSS overla with CTCF peak\)
length(unique(queryHits(findOverlaps(TSS1mb.group1.gr, ctcf.peak.gr))))/length(gene.group1)*100
length(unique(queryHits(findOverlaps(TSS1mb.group2.gr, ctcf.peak.gr))))/length(gene.group2)*100



ctcf.peak.gr <- makeGRangesFromDataFrame(ctcf.peak %>% dplyr::filter(motif != \none\))
print(\+-2.5kb TSS overla with CTCF peak with motif\)
length(unique(queryHits(findOverlaps(TSS1mb.group1.gr, ctcf.peak.gr))))/length(gene.group1)*100
length(unique(queryHits(findOverlaps(TSS1mb.group2.gr, ctcf.peak.gr))))/length(gene.group2)*100

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->

#### Filtering loops that fall within CTCF boundaries

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\nname <- \"chromo_cons_annoHierarchy\"\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\"P-P\", \"P-E\", \"P-S\", \"P-X\")) %>%\n  dplyr::select(c(1, 2, 3, 4, 5, 6, 7, 11, 12, 24, 29, 31)) %>% unnest(gene)\n\n\ngene.TSS.tb <- fread(here(refDir, \"mm10_GRCm38.p6_gene_sorted.bed\")) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \"+\", V2, V3)) %>%\n  dplyr::select(V6, TSS)\ncolnames(gene.TSS.tb) <- c(\"ensembl\", \"TSS\")\n\n\ngeneAnnoData <- geneAnnoData %>% dplyr::left_join(gene.TSS.tb, by = c(\"gene\" = \"ensembl\"))\n\ngeneAnnoData <- geneAnnoData %>% \n  dplyr::mutate(distance1 = (start1 + end1)/2 - TSS,\n                distance2 = (start2 + end2)/2 - TSS,\n                distance = if_else(abs(distance1) > abs(distance2), distance1, distance2))\n\nresult <- geneAnnoData %>%\n  filter(Anno2 == \"P-S\") %>%\n  group_by(gene) %>%\n  summarise(\n    farRight = if (any(distance > 0)) max(distance[distance > 0]) else 0,  # Return 0 if no positive distance\n    farLeft = if (any(distance < 0)) min(distance[distance < 0]) else 0  # Return 0 if no negative distance\n  ) %>%\n  ungroup()\n\ngeneAnnoData <- geneAnnoData %>% left_join(result, by = c(\"gene\"))\n\ngeneAnnoData <- geneAnnoData %>% dplyr::filter(Anno2 %in% c(\"P-P\", \"P-E\")) %>%\n  dplyr::mutate(group = case_when(is.na(farRight) ~ \"No\",\n                                  (distance > farLeft) & (distance < farRight) ~ \"Within\",\n                                  TRUE ~ \"Outside\"),\n                size = start2 - start1)\n\ndata <- geneAnnoData %>% dplyr::select(group, id, size) %>% distinct()\nanchor.data <- geneAnnoData %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()\n\ntemp1 <- anchor.data %>% dplyr::filter(group == \"No\") %>% dplyr::select(-group)\nfwrite(temp1, here(consensusDir, \"insulated_domain_ps_no.bedpe\"), sep = \"\\t\", col.names = FALSE)\ntemp2 <- anchor.data %>% dplyr::filter(group == \"Within\") %>% dplyr::select(-group)\nfwrite(temp2, here(consensusDir, \"insulated_domain_ps_within.bedpe\"), sep = \"\\t\", col.names = FALSE)\ntemp3 <- anchor.data %>% dplyr::filter(group == \"Outside\") %>% dplyr::select(-group)\nfwrite(temp3, here(consensusDir, \"insulated_domain_ps_outside.bedpe\"), sep = \"\\t\", col.names = FALSE)\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$size\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$size\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n# convPvalue(getPvalWilcox(data, \"noBoundary\", \"withinBoundary\"))\n# convPvalue(getPvalWilcox(data, \"noBoundary\", \"outsideBoundary\"))\n# convPvalue(getPvalWilcox(data, \"outsideBoundary\", \"withinBoundary\"))\n\n\np <- ggplot(data, aes(x = group, y = size, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \"square\", alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \"black\",\n                 linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n  stat_summary(\n      aes(group = group), fun = mean,\n      geom = \"point\", shape = 21, size = 0.5,\n      fill = \"black\", color = \"black\", position = position_dodge(.3)\n    ) +\n  scale_fill_manual(values = c(\"grey50\", \"#5EC962\", \"#5EC962\")) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \"Loop size\")\n\nfileName <- paste0(\"insulationBoundary_size\")\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n  \n########################\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ndata <- geneAnnoData %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()\n\n# convPvalue(getPvalWilcox(data, \"noBoundary\", \"withinBoundary\"))\n# convPvalue(getPvalWilcox(data, \"noBoundary\", \"outsideBoundary\"))\n# convPvalue(getPvalWilcox(data, \"outsideBoundary\", \"withinBoundary\"))\n\np <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \"square\", alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \"point\", shape = 21, size = 0.5,\n    fill = \"black\", color = \"black\", position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\"grey50\", \"#5EC962\", \"#5EC962\")) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \"Δ loop score\")  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\") + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\", linetype = \"dashed\") +\n  coord_cartesian(ylim = c(-0.8, 0.5))\n    \nfileName <- paste0(\"insulationBoundary_delta\")\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()  \n  \n  \n ###################### \n    \n    minValue <- -4\n  obsexp <- fread(here(consensusDir, paste0(\"loopScore_cons_obsexp.tsv\"))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\"id\"))\n\ndata <- geneAnnoData %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n# convPvalue(getPvalWilcox(data, \"noBoundary\", \"withinBoundary\"))\n# convPvalue(getPvalWilcox(data, \"noBoundary\", \"outsideBoundary\"))\n# convPvalue(getPvalWilcox(data, \"outsideBoundary\", \"withinBoundary\"))\n# \n\np <- ggplot(data, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \"square\", alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \"point\", shape = 21, size = 0.5,\n    fill = \"black\", color = \"black\", position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\"grey50\", \"#5EC962\", \"#5EC962\")) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \"log2(fc of obs/exp)\")  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\") + \n  coord_cartesian(ylim = c(-2, 2))\n    \nfileName <- paste0(\"insulationBoundary_obsexp\")\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n\n\n\n#####################\n\n\ngene.withinBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \"withinBoundary\"))$gene)\ngene.outsideBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \"outsideBoundary\"))$gene)\ngene.noBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \"noBoundary\"))$gene)\n\ngene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))\n\ngene.group1 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\"))$gene\ngene.group2 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\"))$gene\n\nprint(\"perc of gene with loop within Boundary\")\nsum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100\n\nprint(\"perc of gene with loop outside Boundary\")\nsum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100\n\nprint(\"perc of gene with loop with no Boundary\")\nsum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100\n\n\ndiff.RNA <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%\n  dplyr::mutate(group = case_when(\n    ensembl_gene_id %in% gene.wBoundary ~ \"withinBoundary\",\n    ensembl_gene_id %in% gene.noBoundary ~ \"noBoundary\",\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group)) %>%\n  dplyr::mutate(absLog2FC = abs(log2FoldChange))\n\n\nggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\nconvPvalue(getPvalWilcox(diff.RNA, \"withinBoundary\", \"noBoundary\"))\n\n\n# Create the CDF plot\np <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +\nstat_ecdf(size = 0.4 ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \"Absolute log2(fold change)\",\n    y = \"Cumulative Probability\"\n  ) + coord_cartesian(xlim = c(0, 0.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\nfileName <- paste0(\"log2FC_cdf_insulationBoundary\")\nwidth <- panelSize(2.5)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Checking characterstics of anchors\ntemp1 <- anchor.data %>% dplyr::filter(group == \"noBoundary\") %>% dplyr::select(-group)\nanchor.noBoundary <- extractAnchor(temp1)\n\ntemp2 <- anchor.data %>% dplyr::filter(group == \"withinBoundary\") %>% dplyr::select(-group)\nanchor.withinBoundary <- extractAnchor(temp2)\n\ntemp3 <- anchor.data %>% dplyr::filter(group == \"outsideBoundary\") %>% dplyr::select(-group)\nanchor.outsideBoundary <- extractAnchor(temp3)\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore\n  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ngetSumScores <- function(track, anchor) {\n  # Find overlaps between all anchors and track regions at once\n  overlaps <- findOverlaps(anchor, track)\n  \n  # Extract the scores and corresponding anchor indices\n  anchor_indices <- queryHits(overlaps)\n  track_scores <- score(track)[subjectHits(overlaps)]\n  \n  # Use tapply to calculate the median scores for each anchor\n  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)\n  \n  # Initialize a numeric vector to store the median scores for each anchor\n  all_median_scores <- rep(NA, length(anchor))\n  \n  # Populate the median scores for the anchors that have overlaps\n  all_median_scores[as.numeric(names(median_scores))] <- median_scores\n  \n  return(all_median_scores)\n}\n\nplotSumScoresBinary <- function(track, peak, name, anchor1, anchor2, anchor3){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor1)\n  b <- getSumScores(peakTrack, anchor2)\n  c <- getSumScores(peakTrack, anchor3)\n  a.tb <- tibble(loop = \"noBoundary\",\n                 sumScore = a)\n  b.tb <- tibble(loop = \"withBoundary\",\n                 sumScore = b)\n  c.tb <- tibble(loop = \"outsideBoundary\",\n                 sumScore = c)\n  \n  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\n  data$loop <- factor(data$loop, levels = c(\"noBoundary\", \"withBoundary\", \"outsideBoundary\"))\n  \n  p12 <- getPvalWilcox(data, \"noBoundary\", \"withBoundary\")\n  p13 <- getPvalWilcox(data, \"noBoundary\", \"outsideBoundary\")\n  p23 <- getPvalWilcox(data, \"withBoundary\", \"outsideBoundary\")\n  p <-  ggplot(data, aes(x = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(name, \"\\nlog(avg peak score per anchor)\")) +\n    geom_violin(aes(fill = loop), color = \"black\",\n                linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n                show.legend = FALSE) +\n    geom_boxplot(width = 0.1, color = \"black\",\n                 linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \"point\", shape = 21, size = 1,\n      fill = \"red\", color = \"black\"\n    ) + theme(\n      axis.title = element_text(\n        size = fontSizeS, family = fontType, color = \"#000000\"\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \"#000000\"\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n      ),\n      axis.ticks = element_line(\n        color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n      ),\n      panel.background = element_rect(fill = \"transparent\"),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + \n    #coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.99))) + \n    annotate(\n      \"text\", x = 1, y = quantile(data$sumScore, 0.5),\n      label = paste0(\"p12: \", convPvalue(p12), \"\\n\",\n                     \"p13: \", convPvalue(p13), \"\\n\",\n                     \"p23: \", convPvalue(p23)),\n      color = \"black\", hjust = 0, size = 3\n    ) \n  #+ scale_y_continuous(trans = \"log10\")\n  \n  fileName <- paste0(\"ChIP_peak_avgPeakScore_boundaryAnchor_\", name)\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  png(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \"33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\"), format = \"BigWig\")\npeak <- importPeak(here(refDir, \"33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\"))\nplotSumScoresBinary(track, peak, \"H3K4me3\", anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \"GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\"), format = \"BigWig\")\npeak <- importPeak(here(refDir, \"GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\"))\n#plotSumScores(track, peak, \"H3K27ac\")\nplotSumScoresBinary(track, peak, \"H3K27ac\", anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \"GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\"), format = \"BigWig\")\npeak <- importPeak(here(refDir, \"GSM2683440_J1_H3K14ac_mm10Lifted.bed\"))\n#plotSumScores(track, peak, \"H3K14ac\")\nplotSumScoresBinary(track, peak, \"H3K14ac\", anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \"33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\"), format = \"BigWig\")\npeak <- importPeak(here(refDir, \"33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\"))\n#plotSumScores(track, peak, \"CTCF\")\nplotSumScoresBinary(track, peak, \"CTCF\", anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \"33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\"), format = \"BigWig\")\npeak <- importPeak(here(refDir, \"33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\"))\n#plotSumScores(track, peak, \"RAD21\")\nplotSumScoresBinary(track, peak, \"RAD21\", anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\n\n\n######## LOLA\natac <- fread(here(refDir, \"GSM3106257_ATAC_ESC_1.bed\")) %>% dplyr::select(V1, V2, V3)\ncolnames(atac) <- c(\"chr\", \"start\", \"end\")\natac.gr <- makeGRangesFromDataFrame(atac)\n\n# LOADING LOOPS\nloop.all <- fread(here(consensusDir, \"chromo_cons_annoHierarchy.tsv\")) %>% dplyr::filter(Anno2 %in% c(\"P-P\", \"P-E\", \"E-E\"))\nanchor.all <- (extractAnchor(loop.all))\noverlaps <- findOverlaps(anchor.all, atac.gr)\nanchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\noverlaps <- findOverlaps(anchor.noBoundary, atac.gr)\nanchor.noBoundary <- pintersect(anchor.noBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\noverlaps <- findOverlaps(anchor.withinBoundary, atac.gr)\nanchor.withinBoundary <- pintersect(anchor.withinBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\noverlaps <- findOverlaps(anchor.outsideBoundary, atac.gr)\nanchor.outsideBoundary <- pintersect(anchor.outsideBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\n\n\nanchors <- list(anchor.noBoundary, anchor.withBoundary, anchor.outsideBoundary)\ntbs <- list()\ntemps <- list()\n\nalpha <- 0.05\n\n# Process clusters c1 to c8\nfor (i in 1:3) {\n  \n  anchor <- anchors[[i]]\n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \"embryonic stem cell\") %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\"target\", paste0(\"OR_c\", i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \"target\"), temps) %>%\n  mutate_all(~replace_na(., 1))\ncolnames(temp) <- c(\"target\", \"noBoundary\", \"withinBoundary\", \"outsideBoundary\")\ndata <- temp %>% column_to_rownames(\"target\") %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\"white\", \"red\"))\n\n\n#fviz_nbclust(data, kmeans, method = \"wss\")\n\np <- Heatmap(\n  data,\n  name = \"Odds Ratio\",                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```"} -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>%\n  dplyr::select(c(1, 2, 3, 4, 5, 6, 7, 11, 12, 24, 29, 31)) %>% unnest(gene)\n\n\ngene.TSS.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V6, TSS)\ncolnames(gene.TSS.tb) <- c(\\ensembl\\, \\TSS\\)\n\n\ngeneAnnoData <- geneAnnoData %>% dplyr::left_join(gene.TSS.tb, by = c(\\gene\\ = \\ensembl\\))\n\ngeneAnnoData <- geneAnnoData %>% \n  dplyr::mutate(distance1 = (start1 + end1)/2 - TSS,\n                distance2 = (start2 + end2)/2 - TSS,\n                distance = if_else(abs(distance1) > abs(distance2), distance1, distance2))\n\nresult <- geneAnnoData %>%\n  filter(Anno2 == \\P-S\\) %>%\n  group_by(gene) %>%\n  summarise(\n    farRight = if (any(distance > 0)) max(distance[distance > 0]) else 0,  # Return 0 if no positive distance\n    farLeft = if (any(distance < 0)) min(distance[distance < 0]) else 0  # Return 0 if no negative distance\n  ) %>%\n  ungroup()\n\ngeneAnnoData <- geneAnnoData %>% left_join(result, by = c(\\gene\\))\n\ngeneAnnoData <- geneAnnoData %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\)) %>%\n  dplyr::mutate(group = case_when(is.na(farRight) ~ \\No\\,\n                                  (distance > farLeft) & (distance < farRight) ~ \\Within\\,\n                                  TRUE ~ \\Outside\\),\n                size = start2 - start1)\n\ndata <- geneAnnoData %>% dplyr::select(group, id, size) %>% distinct()\nanchor.data <- geneAnnoData %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()\n\ntemp1 <- anchor.data %>% dplyr::filter(group == \\No\\) %>% dplyr::select(-group)\nfwrite(temp1, here(consensusDir, \\insulated_domain_ps_no.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp2 <- anchor.data %>% dplyr::filter(group == \\Within\\) %>% dplyr::select(-group)\nfwrite(temp2, here(consensusDir, \\insulated_domain_ps_within.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp3 <- anchor.data %>% dplyr::filter(group == \\Outside\\) %>% dplyr::select(-group)\nfwrite(temp3, here(consensusDir, \\insulated_domain_ps_outside.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$size\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$size\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\withinBoundary\\))\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\))\n# convPvalue(getPvalWilcox(data, \\outsideBoundary\\, \\withinBoundary\\))\n\n\np <- ggplot(data, aes(x = group, y = size, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n  stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n  scale_fill_manual(values = c(\\grey50\\, \\#5EC962\\, \\#5EC962\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Loop size\\)\n\nfileName <- paste0(\\insulationBoundary_size\\)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n  \n########################\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ndata <- geneAnnoData %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()\n\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\withinBoundary\\))\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\))\n# convPvalue(getPvalWilcox(data, \\outsideBoundary\\, \\withinBoundary\\))\n\np <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\#5EC962\\, \\#5EC962\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.8, 0.5))\n    \nfileName <- paste0(\\insulationBoundary_delta\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n  \n  \n ###################### \n    \n    minValue <- -4\n  obsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\ndata <- geneAnnoData %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\withinBoundary\\))\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\))\n# convPvalue(getPvalWilcox(data, \\outsideBoundary\\, \\withinBoundary\\))\n# \n\np <- ggplot(data, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\#5EC962\\, \\#5EC962\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n    \nfileName <- paste0(\\insulationBoundary_obsexp\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n\n\n\n#####################\n\n\ngene.withinBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \\withinBoundary\\))$gene)\ngene.outsideBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \\outsideBoundary\\))$gene)\ngene.noBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \\noBoundary\\))$gene)\n\ngene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nprint(\\perc of gene with loop within Boundary\\)\nsum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop outside Boundary\\)\nsum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop with no Boundary\\)\nsum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100\n\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%\n  dplyr::mutate(group = case_when(\n    ensembl_gene_id %in% gene.wBoundary ~ \\withinBoundary\\,\n    ensembl_gene_id %in% gene.noBoundary ~ \\noBoundary\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group)) %>%\n  dplyr::mutate(absLog2FC = abs(log2FoldChange))\n\n\nggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\nconvPvalue(getPvalWilcox(diff.RNA, \\withinBoundary\\, \\noBoundary\\))\n\n\n# Create the CDF plot\np <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +\nstat_ecdf(size = 0.4 ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Absolute log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 0.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\nfileName <- paste0(\\log2FC_cdf_insulationBoundary\\)\nwidth <- panelSize(2.5)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Checking characterstics of anchors\ntemp1 <- anchor.data %>% dplyr::filter(group == \\noBoundary\\) %>% dplyr::select(-group)\nanchor.noBoundary <- extractAnchor(temp1)\n\ntemp2 <- anchor.data %>% dplyr::filter(group == \\withinBoundary\\) %>% dplyr::select(-group)\nanchor.withinBoundary <- extractAnchor(temp2)\n\ntemp3 <- anchor.data %>% dplyr::filter(group == \\outsideBoundary\\) %>% dplyr::select(-group)\nanchor.outsideBoundary <- extractAnchor(temp3)\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore\n  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ngetSumScores <- function(track, anchor) {\n  # Find overlaps between all anchors and track regions at once\n  overlaps <- findOverlaps(anchor, track)\n  \n  # Extract the scores and corresponding anchor indices\n  anchor_indices <- queryHits(overlaps)\n  track_scores <- score(track)[subjectHits(overlaps)]\n  \n  # Use tapply to calculate the median scores for each anchor\n  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)\n  \n  # Initialize a numeric vector to store the median scores for each anchor\n  all_median_scores <- rep(NA, length(anchor))\n  \n  # Populate the median scores for the anchors that have overlaps\n  all_median_scores[as.numeric(names(median_scores))] <- median_scores\n  \n  return(all_median_scores)\n}\n\nplotSumScoresBinary <- function(track, peak, name, anchor1, anchor2, anchor3){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor1)\n  b <- getSumScores(peakTrack, anchor2)\n  c <- getSumScores(peakTrack, anchor3)\n  a.tb <- tibble(loop = \\noBoundary\\,\n                 sumScore = a)\n  b.tb <- tibble(loop = \\withBoundary\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\outsideBoundary\\,\n                 sumScore = c)\n  \n  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\n  data$loop <- factor(data$loop, levels = c(\\noBoundary\\, \\withBoundary\\, \\outsideBoundary\\))\n  \n  p12 <- getPvalWilcox(data, \\noBoundary\\, \\withBoundary\\)\n  p13 <- getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\)\n  p23 <- getPvalWilcox(data, \\withBoundary\\, \\outsideBoundary\\)\n  p <-  ggplot(data, aes(x = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(name, \\\\nlog(avg peak score per anchor)\\)) +\n    geom_violin(aes(fill = loop), color = \\black\\,\n                linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                show.legend = FALSE) +\n    geom_boxplot(width = 0.1, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 1,\n      fill = \\red\\, color = \\black\\\n    ) + theme(\n      axis.title = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + \n    #coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.99))) + \n    annotate(\n      \\text\\, x = 1, y = quantile(data$sumScore, 0.5),\n      label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                     \\p13: \\, convPvalue(p13), \\\\n\\,\n                     \\p23: \\, convPvalue(p23)),\n      color = \\black\\, hjust = 0, size = 3\n    ) \n  #+ scale_y_continuous(trans = \\log10\\)\n  \n  fileName <- paste0(\\ChIP_peak_avgPeakScore_boundaryAnchor_\\, name)\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\\))\nplotSumScoresBinary(track, peak, \\H3K4me3\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\n#plotSumScores(track, peak, \\H3K27ac\\)\nplotSumScoresBinary(track, peak, \\H3K27ac\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.bed\\))\n#plotSumScores(track, peak, \\H3K14ac\\)\nplotSumScoresBinary(track, peak, \\H3K14ac\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\CTCF\\)\nplotSumScoresBinary(track, peak, \\CTCF\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\RAD21\\)\nplotSumScoresBinary(track, peak, \\RAD21\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\n\n\n######## LOLA\natac <- fread(here(refDir, \\GSM3106257_ATAC_ESC_1.bed\\)) %>% dplyr::select(V1, V2, V3)\ncolnames(atac) <- c(\\chr\\, \\start\\, \\end\\)\natac.gr <- makeGRangesFromDataFrame(atac)\n\n# LOADING LOOPS\nloop.all <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\)) %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\))\nanchor.all <- (extractAnchor(loop.all))\noverlaps <- findOverlaps(anchor.all, atac.gr)\nanchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\noverlaps <- findOverlaps(anchor.noBoundary, atac.gr)\nanchor.noBoundary <- pintersect(anchor.noBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\noverlaps <- findOverlaps(anchor.withinBoundary, atac.gr)\nanchor.withinBoundary <- pintersect(anchor.withinBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\noverlaps <- findOverlaps(anchor.outsideBoundary, atac.gr)\nanchor.outsideBoundary <- pintersect(anchor.outsideBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\n\n\nanchors <- list(anchor.noBoundary, anchor.withBoundary, anchor.outsideBoundary)\ntbs <- list()\ntemps <- list()\n\nalpha <- 0.05\n\n# Process clusters c1 to c8\nfor (i in 1:3) {\n  \n  anchor <- anchors[[i]]\n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ncolnames(temp) <- c(\\target\\, \\noBoundary\\, \\withinBoundary\\, \\outsideBoundary\\)\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\)) %>%
  dplyr::select(c(1, 2, 3, 4, 5, 6, 7, 11, 12, 24, 29, 31)) %>% unnest(gene)


gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, TSS)
colnames(gene.TSS.tb) <- c(\ensembl\, \TSS\)


geneAnnoData <- geneAnnoData %>% dplyr::left_join(gene.TSS.tb, by = c(\gene\ = \ensembl\))

geneAnnoData <- geneAnnoData %>% 
  dplyr::mutate(distance1 = (start1 + end1)/2 - TSS,
                distance2 = (start2 + end2)/2 - TSS,
                distance = if_else(abs(distance1) > abs(distance2), distance1, distance2))

result <- geneAnnoData %>%
  filter(Anno2 == \P-S\) %>%
  group_by(gene) %>%
  summarise(
    farRight = if (any(distance > 0)) max(distance[distance > 0]) else 0,  # Return 0 if no positive distance
    farLeft = if (any(distance < 0)) min(distance[distance < 0]) else 0  # Return 0 if no negative distance
  ) %>%
  ungroup()

geneAnnoData <- geneAnnoData %>% left_join(result, by = c(\gene\))

geneAnnoData <- geneAnnoData %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\)) %>%
  dplyr::mutate(group = case_when(is.na(farRight) ~ \No\,
                                  (distance > farLeft) & (distance < farRight) ~ \Within\,
                                  TRUE ~ \Outside\),
                size = start2 - start1)

data <- geneAnnoData %>% dplyr::select(group, id, size) %>% distinct()
anchor.data <- geneAnnoData %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()

temp1 <- anchor.data %>% dplyr::filter(group == \No\) %>% dplyr::select(-group)
fwrite(temp1, here(consensusDir, \insulated_domain_ps_no.bedpe\), sep = \\t\, col.names = FALSE)
temp2 <- anchor.data %>% dplyr::filter(group == \Within\) %>% dplyr::select(-group)
fwrite(temp2, here(consensusDir, \insulated_domain_ps_within.bedpe\), sep = \\t\, col.names = FALSE)
temp3 <- anchor.data %>% dplyr::filter(group == \Outside\) %>% dplyr::select(-group)
fwrite(temp3, here(consensusDir, \insulated_domain_ps_outside.bedpe\), sep = \\t\, col.names = FALSE)


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$size
  distance2 <- (data %>% dplyr::filter(group ==group2) )$size
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

# convPvalue(getPvalWilcox(data, \noBoundary\, \withinBoundary\))
# convPvalue(getPvalWilcox(data, \noBoundary\, \outsideBoundary\))
# convPvalue(getPvalWilcox(data, \outsideBoundary\, \withinBoundary\))


p <- ggplot(data, aes(x = group, y = size, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\,
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  stat_summary(
      aes(group = group), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) +
  scale_fill_manual(values = c(\grey50\, \#5EC962\, \#5EC962\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \Loop size\)

fileName <- paste0(\insulationBoundary_size\)
width <- panelSize(1.5)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
  
########################
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

data <- geneAnnoData %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()

# convPvalue(getPvalWilcox(data, \noBoundary\, \withinBoundary\))
# convPvalue(getPvalWilcox(data, \noBoundary\, \outsideBoundary\))
# convPvalue(getPvalWilcox(data, \outsideBoundary\, \withinBoundary\))

p <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c(\grey50\, \#5EC962\, \#5EC962\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \Δ loop score\)  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  geom_hline(yintercept = -0.2,
             alpha = 0.5, 
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\, linetype = \dashed\) +
  coord_cartesian(ylim = c(-0.8, 0.5))
    
fileName <- paste0(\insulationBoundary_delta\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()  
  
  
 ###################### 
    
    minValue <- -4
  obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\id\))

data <- geneAnnoData %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

# convPvalue(getPvalWilcox(data, \noBoundary\, \withinBoundary\))
# convPvalue(getPvalWilcox(data, \noBoundary\, \outsideBoundary\))
# convPvalue(getPvalWilcox(data, \outsideBoundary\, \withinBoundary\))
# 

p <- ggplot(data, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c(\grey50\, \#5EC962\, \#5EC962\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \log2(fc of obs/exp)\)  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  coord_cartesian(ylim = c(-2, 2))
    
fileName <- paste0(\insulationBoundary_obsexp\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()  





#####################


gene.withinBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \withinBoundary\))$gene)
gene.outsideBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \outsideBoundary\))$gene)
gene.noBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \noBoundary\))$gene)

gene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

print(\perc of gene with loop within Boundary\)
sum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100

print(\perc of gene with loop outside Boundary\)
sum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100

print(\perc of gene with loop with no Boundary\)
sum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100


diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%
  dplyr::mutate(group = case_when(
    ensembl_gene_id %in% gene.wBoundary ~ \withinBoundary\,
    ensembl_gene_id %in% gene.noBoundary ~ \noBoundary\,
    TRUE ~ NA
  )) %>%
  dplyr::filter(!is.na(group)) %>%
  dplyr::mutate(absLog2FC = abs(log2FoldChange))


ggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC
  distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
convPvalue(getPvalWilcox(diff.RNA, \withinBoundary\, \noBoundary\))


# Create the CDF plot
p <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +
stat_ecdf(size = 0.4 ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Absolute log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 0.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )

fileName <- paste0(\log2FC_cdf_insulationBoundary\)
width <- panelSize(2.5)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



### Checking characterstics of anchors
temp1 <- anchor.data %>% dplyr::filter(group == \noBoundary\) %>% dplyr::select(-group)
anchor.noBoundary <- extractAnchor(temp1)

temp2 <- anchor.data %>% dplyr::filter(group == \withinBoundary\) %>% dplyr::select(-group)
anchor.withinBoundary <- extractAnchor(temp2)

temp3 <- anchor.data %>% dplyr::filter(group == \outsideBoundary\) %>% dplyr::select(-group)
anchor.outsideBoundary <- extractAnchor(temp3)


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore
  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

getSumScores <- function(track, anchor) {
  # Find overlaps between all anchors and track regions at once
  overlaps <- findOverlaps(anchor, track)
  
  # Extract the scores and corresponding anchor indices
  anchor_indices <- queryHits(overlaps)
  track_scores <- score(track)[subjectHits(overlaps)]
  
  # Use tapply to calculate the median scores for each anchor
  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)
  
  # Initialize a numeric vector to store the median scores for each anchor
  all_median_scores <- rep(NA, length(anchor))
  
  # Populate the median scores for the anchors that have overlaps
  all_median_scores[as.numeric(names(median_scores))] <- median_scores
  
  return(all_median_scores)
}

plotSumScoresBinary <- function(track, peak, name, anchor1, anchor2, anchor3){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  a <- getSumScores(peakTrack, anchor1)
  b <- getSumScores(peakTrack, anchor2)
  c <- getSumScores(peakTrack, anchor3)
  a.tb <- tibble(loop = \noBoundary\,
                 sumScore = a)
  b.tb <- tibble(loop = \withBoundary\,
                 sumScore = b)
  c.tb <- tibble(loop = \outsideBoundary\,
                 sumScore = c)
  
  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()
  data$loop <- factor(data$loop, levels = c(\noBoundary\, \withBoundary\, \outsideBoundary\))
  
  p12 <- getPvalWilcox(data, \noBoundary\, \withBoundary\)
  p13 <- getPvalWilcox(data, \noBoundary\, \outsideBoundary\)
  p23 <- getPvalWilcox(data, \withBoundary\, \outsideBoundary\)
  p <-  ggplot(data, aes(x = loop, y = sumScore)) + 
    labs(x = NULL, y = paste0(name, \\nlog(avg peak score per anchor)\)) +
    geom_violin(aes(fill = loop), color = \black\,
                linewidth = lineThick * mmToLineUnit, lineend = \square\,
                show.legend = FALSE) +
    geom_boxplot(width = 0.1, color = \black\,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\,
                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +
    stat_summary(
      aes(group = loop), fun = mean,
      geom = \point\, shape = 21, size = 1,
      fill = \red\, color = \black\
    ) + theme(
      axis.title = element_text(
        size = fontSizeS, family = fontType, color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS, family = fontType, color = \#000000\
      ),
      axis.text.x = element_text(
        angle = 45, hjust = 1, vjust = 1
      ),
      axis.line = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    ) + 
    #coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.99))) + 
    annotate(
      \text\, x = 1, y = quantile(data$sumScore, 0.5),
      label = paste0(\p12: \, convPvalue(p12), \\n\,
                     \p13: \, convPvalue(p13), \\n\,
                     \p23: \, convPvalue(p23)),
      color = \black\, hjust = 0, size = 3
    ) 
  #+ scale_y_continuous(trans = \log10\)
  
  fileName <- paste0(\ChIP_peak_avgPeakScore_boundaryAnchor_\, name)
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# Sum peak score
####
track <- import(here(refDir, \33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\))
plotSumScoresBinary(track, peak, \H3K4me3\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)

track <- import(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
#plotSumScores(track, peak, \H3K27ac\)
plotSumScoresBinary(track, peak, \H3K27ac\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)

track <- import(here(refDir, \GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM2683440_J1_H3K14ac_mm10Lifted.bed\))
#plotSumScores(track, peak, \H3K14ac\)
plotSumScoresBinary(track, peak, \H3K14ac\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)

track <- import(here(refDir, \33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))
#plotSumScores(track, peak, \CTCF\)
plotSumScoresBinary(track, peak, \CTCF\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)

track <- import(here(refDir, \33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))
#plotSumScores(track, peak, \RAD21\)
plotSumScoresBinary(track, peak, \RAD21\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)



######## LOLA
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\)) %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

overlaps <- findOverlaps(anchor.noBoundary, atac.gr)
anchor.noBoundary <- pintersect(anchor.noBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
overlaps <- findOverlaps(anchor.withinBoundary, atac.gr)
anchor.withinBoundary <- pintersect(anchor.withinBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
overlaps <- findOverlaps(anchor.outsideBoundary, atac.gr)
anchor.outsideBoundary <- pintersect(anchor.outsideBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



anchors <- list(anchor.noBoundary, anchor.withBoundary, anchor.outsideBoundary)
tbs <- list()
temps <- list()

alpha <- 0.05

# Process clusters c1 to c8
for (i in 1:3) {
  
  anchor <- anchors[[i]]
  # Run LOLA
  result <- runLOLA(anchor, anchor.all, lolaDB)
  tb <- as_tibble(result)
  
  # Filter and summarize
  tb <- tb %>%
    dplyr::mutate(target = toupper(antibody)) %>%
    filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
    dplyr::filter(qValue < alpha) %>%
    dplyr::group_by(target) %>%
    slice_min(meanRnk, with_ties = FALSE)
  
  # Store tb
  tbs[[i]] <- tb
  
  # Select and rename oddsRatio
  temp <- tb %>% dplyr::select(target, oddsRatio)
  colnames(temp) <- c(\target\, paste0(\OR_c\, i))
  
  # Store temp
  temps[[i]] <- temp
}

# Merge all temp tables into one
temp <- Reduce(function(x, y) full_join(x, y, by = \target\), temps) %>%
  mutate_all(~replace_na(., 1))
colnames(temp) <- c(\target\, \noBoundary\, \withinBoundary\, \outsideBoundary\)
data <- temp %>% column_to_rownames(\target\) %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>%\n  dplyr::select(c(1, 2, 3, 4, 5, 6, 7, 11, 12, 24, 29, 31)) %>% unnest(gene)\n\n\ngene.TSS.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V6, TSS)\ncolnames(gene.TSS.tb) <- c(\\ensembl\\, \\TSS\\)\n\n\ngeneAnnoData <- geneAnnoData %>% dplyr::left_join(gene.TSS.tb, by = c(\\gene\\ = \\ensembl\\))\n\ngeneAnnoData <- geneAnnoData %>% \n  dplyr::mutate(distance1 = (start1 + end1)/2 - TSS,\n                distance2 = (start2 + end2)/2 - TSS,\n                distance = if_else(abs(distance1) > abs(distance2), distance1, distance2))\n\nresult <- geneAnnoData %>%\n  filter(Anno2 == \\P-S\\) %>%\n  group_by(gene) %>%\n  summarise(\n    farRight = if (any(distance > 0)) max(distance[distance > 0]) else 0,  # Return 0 if no positive distance\n    farLeft = if (any(distance < 0)) min(distance[distance < 0]) else 0  # Return 0 if no negative distance\n  ) %>%\n  ungroup()\n\ngeneAnnoData <- geneAnnoData %>% left_join(result, by = c(\\gene\\))\n\ngeneAnnoData <- geneAnnoData %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\)) %>%\n  dplyr::mutate(group = case_when(is.na(farRight) ~ \\No\\,\n                                  (distance > farLeft) & (distance < farRight) ~ \\Within\\,\n                                  TRUE ~ \\Outside\\),\n                size = start2 - start1)\n\ndata <- geneAnnoData %>% dplyr::select(group, id, size) %>% distinct()\nanchor.data <- geneAnnoData %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()\n\ntemp1 <- anchor.data %>% dplyr::filter(group == \\No\\) %>% dplyr::select(-group)\nfwrite(temp1, here(consensusDir, \\insulated_domain_ps_no.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp2 <- anchor.data %>% dplyr::filter(group == \\Within\\) %>% dplyr::select(-group)\nfwrite(temp2, here(consensusDir, \\insulated_domain_ps_within.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp3 <- anchor.data %>% dplyr::filter(group == \\Outside\\) %>% dplyr::select(-group)\nfwrite(temp3, here(consensusDir, \\insulated_domain_ps_outside.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$size\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$size\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\withinBoundary\\))\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\))\n# convPvalue(getPvalWilcox(data, \\outsideBoundary\\, \\withinBoundary\\))\n\n\np <- ggplot(data, aes(x = group, y = size, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n  stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n  scale_fill_manual(values = c(\\grey50\\, \\#5EC962\\, \\#5EC962\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Loop size\\)\n\nfileName <- paste0(\\insulationBoundary_size\\)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n  \n########################\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ndata <- geneAnnoData %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()\n\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\withinBoundary\\))\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\))\n# convPvalue(getPvalWilcox(data, \\outsideBoundary\\, \\withinBoundary\\))\n\np <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\#5EC962\\, \\#5EC962\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.8, 0.5))\n    \nfileName <- paste0(\\insulationBoundary_delta\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n  \n  \n ###################### \n    \n    minValue <- -4\n  obsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\ndata <- geneAnnoData %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\withinBoundary\\))\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\))\n# convPvalue(getPvalWilcox(data, \\outsideBoundary\\, \\withinBoundary\\))\n# \n\np <- ggplot(data, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\#5EC962\\, \\#5EC962\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n    \nfileName <- paste0(\\insulationBoundary_obsexp\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n\n\n\n#####################\n\n\ngene.withinBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \\withinBoundary\\))$gene)\ngene.outsideBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \\outsideBoundary\\))$gene)\ngene.noBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \\noBoundary\\))$gene)\n\ngene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nprint(\\perc of gene with loop within Boundary\\)\nsum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop outside Boundary\\)\nsum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop with no Boundary\\)\nsum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100\n\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%\n  dplyr::mutate(group = case_when(\n    ensembl_gene_id %in% gene.wBoundary ~ \\withinBoundary\\,\n    ensembl_gene_id %in% gene.noBoundary ~ \\noBoundary\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group)) %>%\n  dplyr::mutate(absLog2FC = abs(log2FoldChange))\n\n\nggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\nconvPvalue(getPvalWilcox(diff.RNA, \\withinBoundary\\, \\noBoundary\\))\n\n\n# Create the CDF plot\np <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +\nstat_ecdf(size = 0.4 ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Absolute log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 0.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\nfileName <- paste0(\\log2FC_cdf_insulationBoundary\\)\nwidth <- panelSize(2.5)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Checking characterstics of anchors\ntemp1 <- anchor.data %>% dplyr::filter(group == \\noBoundary\\) %>% dplyr::select(-group)\nanchor.noBoundary <- extractAnchor(temp1)\n\ntemp2 <- anchor.data %>% dplyr::filter(group == \\withinBoundary\\) %>% dplyr::select(-group)\nanchor.withinBoundary <- extractAnchor(temp2)\n\ntemp3 <- anchor.data %>% dplyr::filter(group == \\outsideBoundary\\) %>% dplyr::select(-group)\nanchor.outsideBoundary <- extractAnchor(temp3)\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore\n  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ngetSumScores <- function(track, anchor) {\n  # Find overlaps between all anchors and track regions at once\n  overlaps <- findOverlaps(anchor, track)\n  \n  # Extract the scores and corresponding anchor indices\n  anchor_indices <- queryHits(overlaps)\n  track_scores <- score(track)[subjectHits(overlaps)]\n  \n  # Use tapply to calculate the median scores for each anchor\n  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)\n  \n  # Initialize a numeric vector to store the median scores for each anchor\n  all_median_scores <- rep(NA, length(anchor))\n  \n  # Populate the median scores for the anchors that have overlaps\n  all_median_scores[as.numeric(names(median_scores))] <- median_scores\n  \n  return(all_median_scores)\n}\n\nplotSumScoresBinary <- function(track, peak, name, anchor1, anchor2, anchor3){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor1)\n  b <- getSumScores(peakTrack, anchor2)\n  c <- getSumScores(peakTrack, anchor3)\n  a.tb <- tibble(loop = \\noBoundary\\,\n                 sumScore = a)\n  b.tb <- tibble(loop = \\withBoundary\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\outsideBoundary\\,\n                 sumScore = c)\n  \n  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\n  data$loop <- factor(data$loop, levels = c(\\noBoundary\\, \\withBoundary\\, \\outsideBoundary\\))\n  \n  p12 <- getPvalWilcox(data, \\noBoundary\\, \\withBoundary\\)\n  p13 <- getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\)\n  p23 <- getPvalWilcox(data, \\withBoundary\\, \\outsideBoundary\\)\n  p <-  ggplot(data, aes(x = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(name, \\\\nlog(avg peak score per anchor)\\)) +\n    geom_violin(aes(fill = loop), color = \\black\\,\n                linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                show.legend = FALSE) +\n    geom_boxplot(width = 0.1, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 1,\n      fill = \\red\\, color = \\black\\\n    ) + theme(\n      axis.title = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + \n    #coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.99))) + \n    annotate(\n      \\text\\, x = 1, y = quantile(data$sumScore, 0.5),\n      label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                     \\p13: \\, convPvalue(p13), \\\\n\\,\n                     \\p23: \\, convPvalue(p23)),\n      color = \\black\\, hjust = 0, size = 3\n    ) \n  #+ scale_y_continuous(trans = \\log10\\)\n  \n  fileName <- paste0(\\ChIP_peak_avgPeakScore_boundaryAnchor_\\, name)\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\\))\nplotSumScoresBinary(track, peak, \\H3K4me3\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\n#plotSumScores(track, peak, \\H3K27ac\\)\nplotSumScoresBinary(track, peak, \\H3K27ac\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.bed\\))\n#plotSumScores(track, peak, \\H3K14ac\\)\nplotSumScoresBinary(track, peak, \\H3K14ac\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\CTCF\\)\nplotSumScoresBinary(track, peak, \\CTCF\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\RAD21\\)\nplotSumScoresBinary(track, peak, \\RAD21\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\n\n\n######## LOLA\natac <- fread(here(refDir, \\GSM3106257_ATAC_ESC_1.bed\\)) %>% dplyr::select(V1, V2, V3)\ncolnames(atac) <- c(\\chr\\, \\start\\, \\end\\)\natac.gr <- makeGRangesFromDataFrame(atac)\n\n# LOADING LOOPS\nloop.all <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\)) %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\))\nanchor.all <- (extractAnchor(loop.all))\noverlaps <- findOverlaps(anchor.all, atac.gr)\nanchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\noverlaps <- findOverlaps(anchor.noBoundary, atac.gr)\nanchor.noBoundary <- pintersect(anchor.noBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\noverlaps <- findOverlaps(anchor.withinBoundary, atac.gr)\nanchor.withinBoundary <- pintersect(anchor.withinBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\noverlaps <- findOverlaps(anchor.outsideBoundary, atac.gr)\nanchor.outsideBoundary <- pintersect(anchor.outsideBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\n\n\nanchors <- list(anchor.noBoundary, anchor.withBoundary, anchor.outsideBoundary)\ntbs <- list()\ntemps <- list()\n\nalpha <- 0.05\n\n# Process clusters c1 to c8\nfor (i in 1:3) {\n  \n  anchor <- anchors[[i]]\n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ncolnames(temp) <- c(\\target\\, \\noBoundary\\, \\withinBoundary\\, \\outsideBoundary\\)\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```\n```"} -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>%\n  dplyr::select(c(1, 2, 3, 4, 5, 6, 7, 11, 12, 24, 29, 31)) %>% unnest(gene)\n\n\ngene.TSS.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V6, TSS)\ncolnames(gene.TSS.tb) <- c(\\ensembl\\, \\TSS\\)\n\n\ngeneAnnoData <- geneAnnoData %>% dplyr::left_join(gene.TSS.tb, by = c(\\gene\\ = \\ensembl\\))\n\ngeneAnnoData <- geneAnnoData %>% \n  dplyr::mutate(distance1 = (start1 + end1)/2 - TSS,\n                distance2 = (start2 + end2)/2 - TSS,\n                distance = if_else(abs(distance1) > abs(distance2), distance1, distance2))\n\nresult <- geneAnnoData %>%\n  filter(Anno2 == \\P-S\\) %>%\n  group_by(gene) %>%\n  summarise(\n    farRight = if (any(distance > 0)) max(distance[distance > 0]) else 0,  # Return 0 if no positive distance\n    farLeft = if (any(distance < 0)) min(distance[distance < 0]) else 0  # Return 0 if no negative distance\n  ) %>%\n  ungroup()\n\ngeneAnnoData <- geneAnnoData %>% left_join(result, by = c(\\gene\\))\n\ngeneAnnoData <- geneAnnoData %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\)) %>%\n  dplyr::mutate(group = case_when(is.na(farRight) ~ \\No\\,\n                                  (distance > farLeft) & (distance < farRight) ~ \\Within\\,\n                                  TRUE ~ \\Outside\\),\n                size = start2 - start1)\n\ndata <- geneAnnoData %>% dplyr::select(group, id, size) %>% distinct()\nanchor.data <- geneAnnoData %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()\n\ntemp1 <- anchor.data %>% dplyr::filter(group == \\No\\) %>% dplyr::select(-group)\nfwrite(temp1, here(consensusDir, \\insulated_domain_ps_no.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp2 <- anchor.data %>% dplyr::filter(group == \\Within\\) %>% dplyr::select(-group)\nfwrite(temp2, here(consensusDir, \\insulated_domain_ps_within.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp3 <- anchor.data %>% dplyr::filter(group == \\Outside\\) %>% dplyr::select(-group)\nfwrite(temp3, here(consensusDir, \\insulated_domain_ps_outside.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$size\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$size\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\withinBoundary\\))\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\))\n# convPvalue(getPvalWilcox(data, \\outsideBoundary\\, \\withinBoundary\\))\n\n\np <- ggplot(data, aes(x = group, y = size, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n  stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n  scale_fill_manual(values = c(\\grey50\\, \\#5EC962\\, \\#5EC962\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Loop size\\)\n\nfileName <- paste0(\\insulationBoundary_size\\)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n  \n########################\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ndata <- geneAnnoData %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()\n\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\withinBoundary\\))\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\))\n# convPvalue(getPvalWilcox(data, \\outsideBoundary\\, \\withinBoundary\\))\n\np <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\#5EC962\\, \\#5EC962\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.8, 0.5))\n    \nfileName <- paste0(\\insulationBoundary_delta\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n  \n  \n ###################### \n    \n    minValue <- -4\n  obsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\ndata <- geneAnnoData %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\withinBoundary\\))\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\))\n# convPvalue(getPvalWilcox(data, \\outsideBoundary\\, \\withinBoundary\\))\n# \n\np <- ggplot(data, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\#5EC962\\, \\#5EC962\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n    \nfileName <- paste0(\\insulationBoundary_obsexp\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n\n\n\n#####################\n\n\ngene.withinBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \\withinBoundary\\))$gene)\ngene.outsideBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \\outsideBoundary\\))$gene)\ngene.noBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \\noBoundary\\))$gene)\n\ngene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nprint(\\perc of gene with loop within Boundary\\)\nsum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop outside Boundary\\)\nsum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop with no Boundary\\)\nsum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100\n\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%\n  dplyr::mutate(group = case_when(\n    ensembl_gene_id %in% gene.wBoundary ~ \\withinBoundary\\,\n    ensembl_gene_id %in% gene.noBoundary ~ \\noBoundary\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group)) %>%\n  dplyr::mutate(absLog2FC = abs(log2FoldChange))\n\n\nggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\nconvPvalue(getPvalWilcox(diff.RNA, \\withinBoundary\\, \\noBoundary\\))\n\n\n# Create the CDF plot\np <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +\nstat_ecdf(size = 0.4 ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Absolute log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 0.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\nfileName <- paste0(\\log2FC_cdf_insulationBoundary\\)\nwidth <- panelSize(2.5)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Checking characterstics of anchors\ntemp1 <- anchor.data %>% dplyr::filter(group == \\noBoundary\\) %>% dplyr::select(-group)\nanchor.noBoundary <- extractAnchor(temp1)\n\ntemp2 <- anchor.data %>% dplyr::filter(group == \\withinBoundary\\) %>% dplyr::select(-group)\nanchor.withinBoundary <- extractAnchor(temp2)\n\ntemp3 <- anchor.data %>% dplyr::filter(group == \\outsideBoundary\\) %>% dplyr::select(-group)\nanchor.outsideBoundary <- extractAnchor(temp3)\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore\n  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ngetSumScores <- function(track, anchor) {\n  # Find overlaps between all anchors and track regions at once\n  overlaps <- findOverlaps(anchor, track)\n  \n  # Extract the scores and corresponding anchor indices\n  anchor_indices <- queryHits(overlaps)\n  track_scores <- score(track)[subjectHits(overlaps)]\n  \n  # Use tapply to calculate the median scores for each anchor\n  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)\n  \n  # Initialize a numeric vector to store the median scores for each anchor\n  all_median_scores <- rep(NA, length(anchor))\n  \n  # Populate the median scores for the anchors that have overlaps\n  all_median_scores[as.numeric(names(median_scores))] <- median_scores\n  \n  return(all_median_scores)\n}\n\nplotSumScoresBinary <- function(track, peak, name, anchor1, anchor2, anchor3){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor1)\n  b <- getSumScores(peakTrack, anchor2)\n  c <- getSumScores(peakTrack, anchor3)\n  a.tb <- tibble(loop = \\noBoundary\\,\n                 sumScore = a)\n  b.tb <- tibble(loop = \\withBoundary\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\outsideBoundary\\,\n                 sumScore = c)\n  \n  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\n  data$loop <- factor(data$loop, levels = c(\\noBoundary\\, \\withBoundary\\, \\outsideBoundary\\))\n  \n  p12 <- getPvalWilcox(data, \\noBoundary\\, \\withBoundary\\)\n  p13 <- getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\)\n  p23 <- getPvalWilcox(data, \\withBoundary\\, \\outsideBoundary\\)\n  p <-  ggplot(data, aes(x = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(name, \\\\nlog(avg peak score per anchor)\\)) +\n    geom_violin(aes(fill = loop), color = \\black\\,\n                linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                show.legend = FALSE) +\n    geom_boxplot(width = 0.1, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 1,\n      fill = \\red\\, color = \\black\\\n    ) + theme(\n      axis.title = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + \n    #coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.99))) + \n    annotate(\n      \\text\\, x = 1, y = quantile(data$sumScore, 0.5),\n      label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                     \\p13: \\, convPvalue(p13), \\\\n\\,\n                     \\p23: \\, convPvalue(p23)),\n      color = \\black\\, hjust = 0, size = 3\n    ) \n  #+ scale_y_continuous(trans = \\log10\\)\n  \n  fileName <- paste0(\\ChIP_peak_avgPeakScore_boundaryAnchor_\\, name)\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\\))\nplotSumScoresBinary(track, peak, \\H3K4me3\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\n#plotSumScores(track, peak, \\H3K27ac\\)\nplotSumScoresBinary(track, peak, \\H3K27ac\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.bed\\))\n#plotSumScores(track, peak, \\H3K14ac\\)\nplotSumScoresBinary(track, peak, \\H3K14ac\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\CTCF\\)\nplotSumScoresBinary(track, peak, \\CTCF\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\RAD21\\)\nplotSumScoresBinary(track, peak, \\RAD21\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\n\n\n######## LOLA\natac <- fread(here(refDir, \\GSM3106257_ATAC_ESC_1.bed\\)) %>% dplyr::select(V1, V2, V3)\ncolnames(atac) <- c(\\chr\\, \\start\\, \\end\\)\natac.gr <- makeGRangesFromDataFrame(atac)\n\n# LOADING LOOPS\nloop.all <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\)) %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\))\nanchor.all <- (extractAnchor(loop.all))\noverlaps <- findOverlaps(anchor.all, atac.gr)\nanchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\noverlaps <- findOverlaps(anchor.noBoundary, atac.gr)\nanchor.noBoundary <- pintersect(anchor.noBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\noverlaps <- findOverlaps(anchor.withinBoundary, atac.gr)\nanchor.withinBoundary <- pintersect(anchor.withinBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\noverlaps <- findOverlaps(anchor.outsideBoundary, atac.gr)\nanchor.outsideBoundary <- pintersect(anchor.outsideBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\n\n\nanchors <- list(anchor.noBoundary, anchor.withBoundary, anchor.outsideBoundary)\ntbs <- list()\ntemps <- list()\n\nalpha <- 0.05\n\n# Process clusters c1 to c8\nfor (i in 1:3) {\n  \n  anchor <- anchors[[i]]\n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ncolnames(temp) <- c(\\target\\, \\noBoundary\\, \\withinBoundary\\, \\outsideBoundary\\)\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>%\n  dplyr::select(c(1, 2, 3, 4, 5, 6, 7, 11, 12, 24, 29, 31)) %>% unnest(gene)\n\n\ngene.TSS.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3)) %>%\n  dplyr::select(V6, TSS)\ncolnames(gene.TSS.tb) <- c(\\ensembl\\, \\TSS\\)\n\n\ngeneAnnoData <- geneAnnoData %>% dplyr::left_join(gene.TSS.tb, by = c(\\gene\\ = \\ensembl\\))\n\ngeneAnnoData <- geneAnnoData %>% \n  dplyr::mutate(distance1 = (start1 + end1)/2 - TSS,\n                distance2 = (start2 + end2)/2 - TSS,\n                distance = if_else(abs(distance1) > abs(distance2), distance1, distance2))\n\nresult <- geneAnnoData %>%\n  filter(Anno2 == \\P-S\\) %>%\n  group_by(gene) %>%\n  summarise(\n    farRight = if (any(distance > 0)) max(distance[distance > 0]) else 0,  # Return 0 if no positive distance\n    farLeft = if (any(distance < 0)) min(distance[distance < 0]) else 0  # Return 0 if no negative distance\n  ) %>%\n  ungroup()\n\ngeneAnnoData <- geneAnnoData %>% left_join(result, by = c(\\gene\\))\n\ngeneAnnoData <- geneAnnoData %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\)) %>%\n  dplyr::mutate(group = case_when(is.na(farRight) ~ \\No\\,\n                                  (distance > farLeft) & (distance < farRight) ~ \\Within\\,\n                                  TRUE ~ \\Outside\\),\n                size = start2 - start1)\n\ndata <- geneAnnoData %>% dplyr::select(group, id, size) %>% distinct()\nanchor.data <- geneAnnoData %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()\n\ntemp1 <- anchor.data %>% dplyr::filter(group == \\No\\) %>% dplyr::select(-group)\nfwrite(temp1, here(consensusDir, \\insulated_domain_ps_no.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp2 <- anchor.data %>% dplyr::filter(group == \\Within\\) %>% dplyr::select(-group)\nfwrite(temp2, here(consensusDir, \\insulated_domain_ps_within.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp3 <- anchor.data %>% dplyr::filter(group == \\Outside\\) %>% dplyr::select(-group)\nfwrite(temp3, here(consensusDir, \\insulated_domain_ps_outside.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$size\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$size\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\withinBoundary\\))\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\))\n# convPvalue(getPvalWilcox(data, \\outsideBoundary\\, \\withinBoundary\\))\n\n\np <- ggplot(data, aes(x = group, y = size, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n  stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n    ) +\n  scale_fill_manual(values = c(\\grey50\\, \\#5EC962\\, \\#5EC962\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Loop size\\)\n\nfileName <- paste0(\\insulationBoundary_size\\)\nwidth <- panelSize(1.5)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n  \n########################\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ndata <- geneAnnoData %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()\n\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\withinBoundary\\))\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\))\n# convPvalue(getPvalWilcox(data, \\outsideBoundary\\, \\withinBoundary\\))\n\np <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\#5EC962\\, \\#5EC962\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.8, 0.5))\n    \nfileName <- paste0(\\insulationBoundary_delta\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n  \n  \n ###################### \n    \n    minValue <- -4\n  obsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ngeneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\\id\\))\n\ndata <- geneAnnoData %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\withinBoundary\\))\n# convPvalue(getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\))\n# convPvalue(getPvalWilcox(data, \\outsideBoundary\\, \\withinBoundary\\))\n# \n\np <- ggplot(data, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\#5EC962\\, \\#5EC962\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n    \nfileName <- paste0(\\insulationBoundary_obsexp\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n\n\n\n#####################\n\n\ngene.withinBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \\withinBoundary\\))$gene)\ngene.outsideBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \\outsideBoundary\\))$gene)\ngene.noBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \\noBoundary\\))$gene)\n\ngene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nprint(\\perc of gene with loop within Boundary\\)\nsum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop outside Boundary\\)\nsum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop with no Boundary\\)\nsum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100\n\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%\n  dplyr::mutate(group = case_when(\n    ensembl_gene_id %in% gene.wBoundary ~ \\withinBoundary\\,\n    ensembl_gene_id %in% gene.noBoundary ~ \\noBoundary\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group)) %>%\n  dplyr::mutate(absLog2FC = abs(log2FoldChange))\n\n\nggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\nconvPvalue(getPvalWilcox(diff.RNA, \\withinBoundary\\, \\noBoundary\\))\n\n\n# Create the CDF plot\np <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +\nstat_ecdf(size = 0.4 ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Absolute log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 0.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\nfileName <- paste0(\\log2FC_cdf_insulationBoundary\\)\nwidth <- panelSize(2.5)*mmToInch\nheight <- panelSize(1.5)*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\n\n\n### Checking characterstics of anchors\ntemp1 <- anchor.data %>% dplyr::filter(group == \\noBoundary\\) %>% dplyr::select(-group)\nanchor.noBoundary <- extractAnchor(temp1)\n\ntemp2 <- anchor.data %>% dplyr::filter(group == \\withinBoundary\\) %>% dplyr::select(-group)\nanchor.withinBoundary <- extractAnchor(temp2)\n\ntemp3 <- anchor.data %>% dplyr::filter(group == \\outsideBoundary\\) %>% dplyr::select(-group)\nanchor.outsideBoundary <- extractAnchor(temp3)\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore\n  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ngetSumScores <- function(track, anchor) {\n  # Find overlaps between all anchors and track regions at once\n  overlaps <- findOverlaps(anchor, track)\n  \n  # Extract the scores and corresponding anchor indices\n  anchor_indices <- queryHits(overlaps)\n  track_scores <- score(track)[subjectHits(overlaps)]\n  \n  # Use tapply to calculate the median scores for each anchor\n  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)\n  \n  # Initialize a numeric vector to store the median scores for each anchor\n  all_median_scores <- rep(NA, length(anchor))\n  \n  # Populate the median scores for the anchors that have overlaps\n  all_median_scores[as.numeric(names(median_scores))] <- median_scores\n  \n  return(all_median_scores)\n}\n\nplotSumScoresBinary <- function(track, peak, name, anchor1, anchor2, anchor3){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor1)\n  b <- getSumScores(peakTrack, anchor2)\n  c <- getSumScores(peakTrack, anchor3)\n  a.tb <- tibble(loop = \\noBoundary\\,\n                 sumScore = a)\n  b.tb <- tibble(loop = \\withBoundary\\,\n                 sumScore = b)\n  c.tb <- tibble(loop = \\outsideBoundary\\,\n                 sumScore = c)\n  \n  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()\n  data$loop <- factor(data$loop, levels = c(\\noBoundary\\, \\withBoundary\\, \\outsideBoundary\\))\n  \n  p12 <- getPvalWilcox(data, \\noBoundary\\, \\withBoundary\\)\n  p13 <- getPvalWilcox(data, \\noBoundary\\, \\outsideBoundary\\)\n  p23 <- getPvalWilcox(data, \\withBoundary\\, \\outsideBoundary\\)\n  p <-  ggplot(data, aes(x = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(name, \\\\nlog(avg peak score per anchor)\\)) +\n    geom_violin(aes(fill = loop), color = \\black\\,\n                linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                show.legend = FALSE) +\n    geom_boxplot(width = 0.1, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 1,\n      fill = \\red\\, color = \\black\\\n    ) + theme(\n      axis.title = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + \n    #coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.99))) + \n    annotate(\n      \\text\\, x = 1, y = quantile(data$sumScore, 0.5),\n      label = paste0(\\p12: \\, convPvalue(p12), \\\\n\\,\n                     \\p13: \\, convPvalue(p13), \\\\n\\,\n                     \\p23: \\, convPvalue(p23)),\n      color = \\black\\, hjust = 0, size = 3\n    ) \n  #+ scale_y_continuous(trans = \\log10\\)\n  \n  fileName <- paste0(\\ChIP_peak_avgPeakScore_boundaryAnchor_\\, name)\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\\))\nplotSumScoresBinary(track, peak, \\H3K4me3\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\\))\n#plotSumScores(track, peak, \\H3K27ac\\)\nplotSumScoresBinary(track, peak, \\H3K27ac\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\GSM2683440_J1_H3K14ac_mm10Lifted.bed\\))\n#plotSumScores(track, peak, \\H3K14ac\\)\nplotSumScoresBinary(track, peak, \\H3K14ac\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\CTCF\\)\nplotSumScoresBinary(track, peak, \\CTCF\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\ntrack <- import(here(refDir, \\33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n#plotSumScores(track, peak, \\RAD21\\)\nplotSumScoresBinary(track, peak, \\RAD21\\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)\n\n\n\n######## LOLA\natac <- fread(here(refDir, \\GSM3106257_ATAC_ESC_1.bed\\)) %>% dplyr::select(V1, V2, V3)\ncolnames(atac) <- c(\\chr\\, \\start\\, \\end\\)\natac.gr <- makeGRangesFromDataFrame(atac)\n\n# LOADING LOOPS\nloop.all <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\)) %>% dplyr::filter(Anno2 %in% c(\\P-P\\, \\P-E\\, \\E-E\\))\nanchor.all <- (extractAnchor(loop.all))\noverlaps <- findOverlaps(anchor.all, atac.gr)\nanchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\noverlaps <- findOverlaps(anchor.noBoundary, atac.gr)\nanchor.noBoundary <- pintersect(anchor.noBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\noverlaps <- findOverlaps(anchor.withinBoundary, atac.gr)\nanchor.withinBoundary <- pintersect(anchor.withinBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\noverlaps <- findOverlaps(anchor.outsideBoundary, atac.gr)\nanchor.outsideBoundary <- pintersect(anchor.outsideBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])\n\n\n\nanchors <- list(anchor.noBoundary, anchor.withBoundary, anchor.outsideBoundary)\ntbs <- list()\ntemps <- list()\n\nalpha <- 0.05\n\n# Process clusters c1 to c8\nfor (i in 1:3) {\n  \n  anchor <- anchors[[i]]\n  # Run LOLA\n  result <- runLOLA(anchor, anchor.all, lolaDB)\n  tb <- as_tibble(result)\n  \n  # Filter and summarize\n  tb <- tb %>%\n    dplyr::mutate(target = toupper(antibody)) %>%\n    filter(str_to_lower(cellType) == \\embryonic stem cell\\) %>%\n    dplyr::filter(qValue < alpha) %>%\n    dplyr::group_by(target) %>%\n    slice_min(meanRnk, with_ties = FALSE)\n  \n  # Store tb\n  tbs[[i]] <- tb\n  \n  # Select and rename oddsRatio\n  temp <- tb %>% dplyr::select(target, oddsRatio)\n  colnames(temp) <- c(\\target\\, paste0(\\OR_c\\, i))\n  \n  # Store temp\n  temps[[i]] <- temp\n}\n\n# Merge all temp tables into one\ntemp <- Reduce(function(x, y) full_join(x, y, by = \\target\\), temps) %>%\n  mutate_all(~replace_na(., 1))\ncolnames(temp) <- c(\\target\\, \\noBoundary\\, \\withinBoundary\\, \\outsideBoundary\\)\ndata <- temp %>% column_to_rownames(\\target\\) %>% as.matrix()\n\nlibrary(circlize)\ncol_fun <- colorRamp2(c(1, max(data)), c(\\white\\, \\red\\))\n\n\n#fviz_nbclust(data, kmeans, method = \\wss\\)\n\np <- Heatmap(\n  data,\n  name = \\Odds Ratio\\,                   # Name of the heatmap legend\n  cluster_columns = FALSE,            # Remove column dendrogram\n  show_row_dend = FALSE,\n  col = col_fun,\n  border = TRUE\n)\n```\n```"} -->

```r
```r
name <- \chromo_cons_annoHierarchy\
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\)) %>%
  dplyr::select(c(1, 2, 3, 4, 5, 6, 7, 11, 12, 24, 29, 31)) %>% unnest(gene)


gene.TSS.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3)) %>%
  dplyr::select(V6, TSS)
colnames(gene.TSS.tb) <- c(\ensembl\, \TSS\)


geneAnnoData <- geneAnnoData %>% dplyr::left_join(gene.TSS.tb, by = c(\gene\ = \ensembl\))

geneAnnoData <- geneAnnoData %>% 
  dplyr::mutate(distance1 = (start1 + end1)/2 - TSS,
                distance2 = (start2 + end2)/2 - TSS,
                distance = if_else(abs(distance1) > abs(distance2), distance1, distance2))

result <- geneAnnoData %>%
  filter(Anno2 == \P-S\) %>%
  group_by(gene) %>%
  summarise(
    farRight = if (any(distance > 0)) max(distance[distance > 0]) else 0,  # Return 0 if no positive distance
    farLeft = if (any(distance < 0)) min(distance[distance < 0]) else 0  # Return 0 if no negative distance
  ) %>%
  ungroup()

geneAnnoData <- geneAnnoData %>% left_join(result, by = c(\gene\))

geneAnnoData <- geneAnnoData %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\)) %>%
  dplyr::mutate(group = case_when(is.na(farRight) ~ \No\,
                                  (distance > farLeft) & (distance < farRight) ~ \Within\,
                                  TRUE ~ \Outside\),
                size = start2 - start1)

data <- geneAnnoData %>% dplyr::select(group, id, size) %>% distinct()
anchor.data <- geneAnnoData %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()

temp1 <- anchor.data %>% dplyr::filter(group == \No\) %>% dplyr::select(-group)
fwrite(temp1, here(consensusDir, \insulated_domain_ps_no.bedpe\), sep = \\t\, col.names = FALSE)
temp2 <- anchor.data %>% dplyr::filter(group == \Within\) %>% dplyr::select(-group)
fwrite(temp2, here(consensusDir, \insulated_domain_ps_within.bedpe\), sep = \\t\, col.names = FALSE)
temp3 <- anchor.data %>% dplyr::filter(group == \Outside\) %>% dplyr::select(-group)
fwrite(temp3, here(consensusDir, \insulated_domain_ps_outside.bedpe\), sep = \\t\, col.names = FALSE)


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$size
  distance2 <- (data %>% dplyr::filter(group ==group2) )$size
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

# convPvalue(getPvalWilcox(data, \noBoundary\, \withinBoundary\))
# convPvalue(getPvalWilcox(data, \noBoundary\, \outsideBoundary\))
# convPvalue(getPvalWilcox(data, \outsideBoundary\, \withinBoundary\))


p <- ggplot(data, aes(x = group, y = size, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\,
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  stat_summary(
      aes(group = group), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
    ) +
  scale_fill_manual(values = c(\grey50\, \#5EC962\, \#5EC962\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \Loop size\)

fileName <- paste0(\insulationBoundary_size\)
width <- panelSize(1.5)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
  
########################
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

data <- geneAnnoData %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()

# convPvalue(getPvalWilcox(data, \noBoundary\, \withinBoundary\))
# convPvalue(getPvalWilcox(data, \noBoundary\, \outsideBoundary\))
# convPvalue(getPvalWilcox(data, \outsideBoundary\, \withinBoundary\))

p <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c(\grey50\, \#5EC962\, \#5EC962\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \Δ loop score\)  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  geom_hline(yintercept = -0.2,
             alpha = 0.5, 
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\, linetype = \dashed\) +
  coord_cartesian(ylim = c(-0.8, 0.5))
    
fileName <- paste0(\insulationBoundary_delta\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()  
  
  
 ###################### 
    
    minValue <- -4
  obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c(\id\))

data <- geneAnnoData %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

# convPvalue(getPvalWilcox(data, \noBoundary\, \withinBoundary\))
# convPvalue(getPvalWilcox(data, \noBoundary\, \outsideBoundary\))
# convPvalue(getPvalWilcox(data, \outsideBoundary\, \withinBoundary\))
# 

p <- ggplot(data, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c(\grey50\, \#5EC962\, \#5EC962\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \log2(fc of obs/exp)\)  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  coord_cartesian(ylim = c(-2, 2))
    
fileName <- paste0(\insulationBoundary_obsexp\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()  





#####################


gene.withinBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \withinBoundary\))$gene)
gene.outsideBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \outsideBoundary\))$gene)
gene.noBoundary <- unique((geneAnnoData %>% dplyr::filter(group == \noBoundary\))$gene)

gene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

print(\perc of gene with loop within Boundary\)
sum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100

print(\perc of gene with loop outside Boundary\)
sum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100

print(\perc of gene with loop with no Boundary\)
sum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100


diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%
  dplyr::mutate(group = case_when(
    ensembl_gene_id %in% gene.wBoundary ~ \withinBoundary\,
    ensembl_gene_id %in% gene.noBoundary ~ \noBoundary\,
    TRUE ~ NA
  )) %>%
  dplyr::filter(!is.na(group)) %>%
  dplyr::mutate(absLog2FC = abs(log2FoldChange))


ggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC
  distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
convPvalue(getPvalWilcox(diff.RNA, \withinBoundary\, \noBoundary\))


# Create the CDF plot
p <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +
stat_ecdf(size = 0.4 ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Absolute log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 0.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )

fileName <- paste0(\log2FC_cdf_insulationBoundary\)
width <- panelSize(2.5)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



### Checking characterstics of anchors
temp1 <- anchor.data %>% dplyr::filter(group == \noBoundary\) %>% dplyr::select(-group)
anchor.noBoundary <- extractAnchor(temp1)

temp2 <- anchor.data %>% dplyr::filter(group == \withinBoundary\) %>% dplyr::select(-group)
anchor.withinBoundary <- extractAnchor(temp2)

temp3 <- anchor.data %>% dplyr::filter(group == \outsideBoundary\) %>% dplyr::select(-group)
anchor.outsideBoundary <- extractAnchor(temp3)


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore
  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

getSumScores <- function(track, anchor) {
  # Find overlaps between all anchors and track regions at once
  overlaps <- findOverlaps(anchor, track)
  
  # Extract the scores and corresponding anchor indices
  anchor_indices <- queryHits(overlaps)
  track_scores <- score(track)[subjectHits(overlaps)]
  
  # Use tapply to calculate the median scores for each anchor
  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)
  
  # Initialize a numeric vector to store the median scores for each anchor
  all_median_scores <- rep(NA, length(anchor))
  
  # Populate the median scores for the anchors that have overlaps
  all_median_scores[as.numeric(names(median_scores))] <- median_scores
  
  return(all_median_scores)
}

plotSumScoresBinary <- function(track, peak, name, anchor1, anchor2, anchor3){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  a <- getSumScores(peakTrack, anchor1)
  b <- getSumScores(peakTrack, anchor2)
  c <- getSumScores(peakTrack, anchor3)
  a.tb <- tibble(loop = \noBoundary\,
                 sumScore = a)
  b.tb <- tibble(loop = \withBoundary\,
                 sumScore = b)
  c.tb <- tibble(loop = \outsideBoundary\,
                 sumScore = c)
  
  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()
  data$loop <- factor(data$loop, levels = c(\noBoundary\, \withBoundary\, \outsideBoundary\))
  
  p12 <- getPvalWilcox(data, \noBoundary\, \withBoundary\)
  p13 <- getPvalWilcox(data, \noBoundary\, \outsideBoundary\)
  p23 <- getPvalWilcox(data, \withBoundary\, \outsideBoundary\)
  p <-  ggplot(data, aes(x = loop, y = sumScore)) + 
    labs(x = NULL, y = paste0(name, \\nlog(avg peak score per anchor)\)) +
    geom_violin(aes(fill = loop), color = \black\,
                linewidth = lineThick * mmToLineUnit, lineend = \square\,
                show.legend = FALSE) +
    geom_boxplot(width = 0.1, color = \black\,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\,
                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +
    stat_summary(
      aes(group = loop), fun = mean,
      geom = \point\, shape = 21, size = 1,
      fill = \red\, color = \black\
    ) + theme(
      axis.title = element_text(
        size = fontSizeS, family = fontType, color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS, family = fontType, color = \#000000\
      ),
      axis.text.x = element_text(
        angle = 45, hjust = 1, vjust = 1
      ),
      axis.line = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    ) + 
    #coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.99))) + 
    annotate(
      \text\, x = 1, y = quantile(data$sumScore, 0.5),
      label = paste0(\p12: \, convPvalue(p12), \\n\,
                     \p13: \, convPvalue(p13), \\n\,
                     \p23: \, convPvalue(p23)),
      color = \black\, hjust = 0, size = 3
    ) 
  #+ scale_y_continuous(trans = \log10\)
  
  fileName <- paste0(\ChIP_peak_avgPeakScore_boundaryAnchor_\, name)
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# Sum peak score
####
track <- import(here(refDir, \33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed\))
plotSumScoresBinary(track, peak, \H3K4me3\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)

track <- import(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed\))
#plotSumScores(track, peak, \H3K27ac\)
plotSumScoresBinary(track, peak, \H3K27ac\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)

track <- import(here(refDir, \GSM2683440_J1_H3K14ac_mm10Lifted.black.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \GSM2683440_J1_H3K14ac_mm10Lifted.bed\))
#plotSumScores(track, peak, \H3K14ac\)
plotSumScoresBinary(track, peak, \H3K14ac\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)

track <- import(here(refDir, \33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))
#plotSumScores(track, peak, \CTCF\)
plotSumScoresBinary(track, peak, \CTCF\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)

track <- import(here(refDir, \33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))
#plotSumScores(track, peak, \RAD21\)
plotSumScoresBinary(track, peak, \RAD21\, anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)



######## LOLA
atac <- fread(here(refDir, \GSM3106257_ATAC_ESC_1.bed\)) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c(\chr\, \start\, \end\)
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
loop.all <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\)) %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\, \E-E\))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

overlaps <- findOverlaps(anchor.noBoundary, atac.gr)
anchor.noBoundary <- pintersect(anchor.noBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
overlaps <- findOverlaps(anchor.withinBoundary, atac.gr)
anchor.withinBoundary <- pintersect(anchor.withinBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
overlaps <- findOverlaps(anchor.outsideBoundary, atac.gr)
anchor.outsideBoundary <- pintersect(anchor.outsideBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



anchors <- list(anchor.noBoundary, anchor.withBoundary, anchor.outsideBoundary)
tbs <- list()
temps <- list()

alpha <- 0.05

# Process clusters c1 to c8
for (i in 1:3) {
  
  anchor <- anchors[[i]]
  # Run LOLA
  result <- runLOLA(anchor, anchor.all, lolaDB)
  tb <- as_tibble(result)
  
  # Filter and summarize
  tb <- tb %>%
    dplyr::mutate(target = toupper(antibody)) %>%
    filter(str_to_lower(cellType) == \embryonic stem cell\) %>%
    dplyr::filter(qValue < alpha) %>%
    dplyr::group_by(target) %>%
    slice_min(meanRnk, with_ties = FALSE)
  
  # Store tb
  tbs[[i]] <- tb
  
  # Select and rename oddsRatio
  temp <- tb %>% dplyr::select(target, oddsRatio)
  colnames(temp) <- c(\target\, paste0(\OR_c\, i))
  
  # Store temp
  temps[[i]] <- temp
}

# Merge all temp tables into one
temp <- Reduce(function(x, y) full_join(x, y, by = \target\), temps) %>%
  mutate_all(~replace_na(., 1))
colnames(temp) <- c(\target\, \noBoundary\, \withinBoundary\, \outsideBoundary\)
data <- temp %>% column_to_rownames(\target\) %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->



### [2.35] Checking CTCF motif presence at gene TSS

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxudHNzLjVrYi5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiVFNTX2JpbmFyeUdyb3VwMS5iZWRcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gKFYyICsgVjMpLzIgLSAyNTAwLFxuICAgICAgICAgICAgICAgIGVuZCA9IChWMiArIFYzKS8yICsgMjUwMCxcbiAgICAgICAgICAgICAgICBjaHIgPSBWMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoY2hyLCBzdGFydCwgZW5kKVxudHNzLjVrYi5ncm91cDEgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRzcy41a2IuZ3JvdXAxKVxuXG50c3MuNWtiLmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJUU1NfYmluYXJ5R3JvdXAyLmJlZFwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoc3RhcnQgPSAoVjIgKyBWMykvMiAtIDI1MDAsXG4gICAgICAgICAgICAgICAgZW5kID0gKFYyICsgVjMpLzIgKyAyNTAwLFxuICAgICAgICAgICAgICAgIGNociA9IFYxKSAlPiVcbiAgZHBseXI6OnNlbGVjdChjaHIsIHN0YXJ0LCBlbmQpXG50c3MuNWtiLmdyb3VwMiA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodHNzLjVrYi5ncm91cDIpXG5cblxucGxvdFN1bVNjb3Jlc0JpbmFyeSA8LSBmdW5jdGlvbih0cmFjaywgcGVhaywgbmFtZSwgYW5jaG9yMSwgYW5jaG9yMil7XG4gIHBlYWtUcmFjayA8LSB0cmFja1t1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyh0cmFjaywgcGVhaykpKV1cbiAgYSA8LSBnZXRTdW1TY29yZXMocGVha1RyYWNrLCBhbmNob3IxKVxuICBiIDwtIGdldFN1bVNjb3JlcyhwZWFrVHJhY2ssIGFuY2hvcjIpXG4gIGEudGIgPC0gdGliYmxlKGxvb3AgPSBcImdyb3VwMVwiLFxuICAgICAgICAgICAgICAgICBzdW1TY29yZSA9IGEpXG4gIGIudGIgPC0gdGliYmxlKGxvb3AgPSBcImdyb3VwMlwiLFxuICAgICAgICAgICAgICAgICBzdW1TY29yZSA9IGIpXG4gIFxuICBkYXRhIDwtIGJpbmRfcm93cyhhLnRiLCBiLnRiKSAlPiUgZHJvcF9uYSgpXG4gIGRhdGEkbG9vcCA8LSBmYWN0b3IoZGF0YSRsb29wLCBsZXZlbHMgPSBjKFwiZ3JvdXAxXCIsIFwiZ3JvdXAyXCIpKVxuICBcbiAgcDEyIDwtIGdldFB2YWxXaWxjb3goZGF0YSwgXCJncm91cDFcIiwgXCJncm91cDJcIilcbiAgcCA8LSAgZ2dwbG90KGRhdGEsIGFlcyh4ID0gbG9vcCwgeSA9IHN1bVNjb3JlKSkgKyBcbiAgICBsYWJzKHggPSBOVUxMLCB5ID0gcGFzdGUwKG5hbWUsIFwiXFxubG9nKGF2ZyBwZWFrIHNjb3JlIHBlciBhbmNob3IpXCIpKSArXG4gICAgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBsb29wKSwgY29sb3IgPSBcImJsYWNrXCIsXG4gICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIixcbiAgICAgICAgICAgICAgICBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBjb2xvciA9IFwiYmxhY2tcIixcbiAgICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIixcbiAgICAgICAgICAgICAgICAgb3V0bGllci5zaXplID0gMSwgb3V0bGllci5zdHJva2UgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICAgIHN0YXRfc3VtbWFyeShcbiAgICAgIGFlcyhncm91cCA9IGxvb3ApLCBmdW4gPSBtZWFuLFxuICAgICAgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDEsXG4gICAgICBmaWxsID0gXCJyZWRcIiwgY29sb3IgPSBcImJsYWNrXCJcbiAgICApICsgdGhlbWUoXG4gICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICAgKSxcbiAgICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgICAgc2l6ZSA9IGZvbnRTaXplUywgZmFtaWx5ID0gZm9udFR5cGUsIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICAgICksXG4gICAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgICAgYW5nbGUgPSA0NSwgaGp1c3QgPSAxLCB2anVzdCA9IDFcbiAgICAgICksXG4gICAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCIsIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcInNxdWFyZVwiXG4gICAgICApLFxuICAgICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIiwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICAgICksXG4gICAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcInRyYW5zcGFyZW50XCIpLFxuICAgICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICAgICkgKyBcbiAgICAjY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuMCksIHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuOTkpKSkgKyBcbiAgICBhbm5vdGF0ZShcbiAgICAgIFwidGV4dFwiLCB4ID0gMSwgeSA9IHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuNSksXG4gICAgICBsYWJlbCA9IHBhc3RlMChcInAxMjogXCIsIGNvbnZQdmFsdWUocDEyKSksXG4gICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gM1xuICAgICkgXG4gICMrIHNjYWxlX3lfY29udGludW91cyh0cmFucyA9IFwibG9nMTBcIilcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcIkNoSVBfcGVha19hdmdQZWFrU2NvcmVfYmluYXJ5R3JvdXBfXCIsIG5hbWUpXG4gIHdpZHRoIDwtIHBhbmVsU2l6ZSgyKSptbVRvSW5jaFxuICBoZWlnaHQgPC0gcGFuZWxTaXplKDIpKm1tVG9JbmNoXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5cbiMgU3VtIHBlYWsgc2NvcmVcbiMjIyNcbnRyYWNrIDwtIGltcG9ydChoZXJlKHJlZkRpciwgXCIzMzI0OF9DVENGXzA3LTcyOV9CcnVjZS00X3RyaW1fcTIwX2RlZHVwX2JsYWNrX2RlcHRoTm9ybS5id1wiKSwgZm9ybWF0ID0gXCJCaWdXaWdcIilcbnBlYWsgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXCIzMzI0OF9DVENGXzA3LTcyOV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcIikpXG5wbG90U3VtU2NvcmVzQmluYXJ5KHRyYWNrLCBwZWFrLCBcIkNUQ0ZcIiwgdHNzLjVrYi5ncm91cDEsIHRzcy41a2IuZ3JvdXAyKVxuXG50cmFjayA8LSBpbXBvcnQoaGVyZShyZWZEaXIsIFwiMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF90cmltX3EyMF9kZWR1cF9ibGFja19kZXB0aE5vcm0uYndcIiksIGZvcm1hdCA9IFwiQmlnV2lnXCIpXG5wZWFrIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFwiMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXCIpKVxucGxvdFN1bVNjb3Jlc0JpbmFyeSh0cmFjaywgcGVhaywgXCJSQUQyMVwiLCB0c3MuNWtiLmdyb3VwMSwgdHNzLjVrYi5ncm91cDIpXG5cblxuXG5gYGAifQ== -->\n\n```r\ntss.5kb.group1 <- fread(here(refDir, \\TSS_binaryGroup1.bed\\)) %>%\n  dplyr::mutate(start = (V2 + V3)/2 - 2500,\n                end = (V2 + V3)/2 + 2500,\n                chr = V1) %>%\n  dplyr::select(chr, start, end)\ntss.5kb.group1 <- makeGRangesFromDataFrame(tss.5kb.group1)\n\ntss.5kb.group2 <- fread(here(refDir, \\TSS_binaryGroup2.bed\\)) %>%\n  dplyr::mutate(start = (V2 + V3)/2 - 2500,\n                end = (V2 + V3)/2 + 2500,\n                chr = V1) %>%\n  dplyr::select(chr, start, end)\ntss.5kb.group2 <- makeGRangesFromDataFrame(tss.5kb.group2)\n\n\nplotSumScoresBinary <- function(track, peak, name, anchor1, anchor2){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor1)\n  b <- getSumScores(peakTrack, anchor2)\n  a.tb <- tibble(loop = \\group1\\,\n                 sumScore = a)\n  b.tb <- tibble(loop = \\group2\\,\n                 sumScore = b)\n  \n  data <- bind_rows(a.tb, b.tb) %>% drop_na()\n  data$loop <- factor(data$loop, levels = c(\\group1\\, \\group2\\))\n  \n  p12 <- getPvalWilcox(data, \\group1\\, \\group2\\)\n  p <-  ggplot(data, aes(x = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(name, \\\\nlog(avg peak score per anchor)\\)) +\n    geom_violin(aes(fill = loop), color = \\black\\,\n                linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                show.legend = FALSE) +\n    geom_boxplot(width = 0.1, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 1,\n      fill = \\red\\, color = \\black\\\n    ) + theme(\n      axis.title = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + \n    #coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.99))) + \n    annotate(\n      \\text\\, x = 1, y = quantile(data$sumScore, 0.5),\n      label = paste0(\\p12: \\, convPvalue(p12)),\n      color = \\black\\, hjust = 0, size = 3\n    ) \n  #+ scale_y_continuous(trans = \\log10\\)\n  \n  fileName <- paste0(\\ChIP_peak_avgPeakScore_binaryGroup_\\, name)\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \\33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\\))\nplotSumScoresBinary(track, peak, \\CTCF\\, tss.5kb.group1, tss.5kb.group2)\n\ntrack <- import(here(refDir, \\33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\nplotSumScoresBinary(track, peak, \\RAD21\\, tss.5kb.group1, tss.5kb.group2)\n\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
tss.5kb.group1 <- fread(here(refDir, \TSS_binaryGroup1.bed\)) %>%
  dplyr::mutate(start = (V2 + V3)/2 - 2500,
                end = (V2 + V3)/2 + 2500,
                chr = V1) %>%
  dplyr::select(chr, start, end)
tss.5kb.group1 <- makeGRangesFromDataFrame(tss.5kb.group1)

tss.5kb.group2 <- fread(here(refDir, \TSS_binaryGroup2.bed\)) %>%
  dplyr::mutate(start = (V2 + V3)/2 - 2500,
                end = (V2 + V3)/2 + 2500,
                chr = V1) %>%
  dplyr::select(chr, start, end)
tss.5kb.group2 <- makeGRangesFromDataFrame(tss.5kb.group2)


plotSumScoresBinary <- function(track, peak, name, anchor1, anchor2){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  a <- getSumScores(peakTrack, anchor1)
  b <- getSumScores(peakTrack, anchor2)
  a.tb <- tibble(loop = \group1\,
                 sumScore = a)
  b.tb <- tibble(loop = \group2\,
                 sumScore = b)
  
  data <- bind_rows(a.tb, b.tb) %>% drop_na()
  data$loop <- factor(data$loop, levels = c(\group1\, \group2\))
  
  p12 <- getPvalWilcox(data, \group1\, \group2\)
  p <-  ggplot(data, aes(x = loop, y = sumScore)) + 
    labs(x = NULL, y = paste0(name, \\nlog(avg peak score per anchor)\)) +
    geom_violin(aes(fill = loop), color = \black\,
                linewidth = lineThick * mmToLineUnit, lineend = \square\,
                show.legend = FALSE) +
    geom_boxplot(width = 0.1, color = \black\,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\,
                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +
    stat_summary(
      aes(group = loop), fun = mean,
      geom = \point\, shape = 21, size = 1,
      fill = \red\, color = \black\
    ) + theme(
      axis.title = element_text(
        size = fontSizeS, family = fontType, color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS, family = fontType, color = \#000000\
      ),
      axis.text.x = element_text(
        angle = 45, hjust = 1, vjust = 1
      ),
      axis.line = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    ) + 
    #coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.99))) + 
    annotate(
      \text\, x = 1, y = quantile(data$sumScore, 0.5),
      label = paste0(\p12: \, convPvalue(p12)),
      color = \black\, hjust = 0, size = 3
    ) 
  #+ scale_y_continuous(trans = \log10\)
  
  fileName <- paste0(\ChIP_peak_avgPeakScore_binaryGroup_\, name)
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# Sum peak score
####
track <- import(here(refDir, \33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))
plotSumScoresBinary(track, peak, \CTCF\, tss.5kb.group1, tss.5kb.group2)

track <- import(here(refDir, \33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))
plotSumScoresBinary(track, peak, \RAD21\, tss.5kb.group1, tss.5kb.group2)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudHNzLjVrYi5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcVFNTX2JpbmFyeUdyb3VwMS5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gKFYyICsgVjMpLzIgLSAyNTAwLFxuICAgICAgICAgICAgICAgIGVuZCA9IChWMiArIFYzKS8yICsgMjUwMCxcbiAgICAgICAgICAgICAgICBjaHIgPSBWMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoY2hyLCBzdGFydCwgZW5kKVxudHNzLjVrYi5ncm91cDEgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRzcy41a2IuZ3JvdXAxKVxuXG50c3MuNWtiLmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxUU1NfYmluYXJ5R3JvdXAyLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoc3RhcnQgPSAoVjIgKyBWMykvMiAtIDI1MDAsXG4gICAgICAgICAgICAgICAgZW5kID0gKFYyICsgVjMpLzIgKyAyNTAwLFxuICAgICAgICAgICAgICAgIGNociA9IFYxKSAlPiVcbiAgZHBseXI6OnNlbGVjdChjaHIsIHN0YXJ0LCBlbmQpXG50c3MuNWtiLmdyb3VwMiA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodHNzLjVrYi5ncm91cDIpXG5cblxucGxvdFN1bVNjb3Jlc0JpbmFyeSA8LSBmdW5jdGlvbih0cmFjaywgcGVhaywgbmFtZSwgYW5jaG9yMSwgYW5jaG9yMil7XG4gIHBlYWtUcmFjayA8LSB0cmFja1t1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyh0cmFjaywgcGVhaykpKV1cbiAgYSA8LSBnZXRTdW1TY29yZXMocGVha1RyYWNrLCBhbmNob3IxKVxuICBiIDwtIGdldFN1bVNjb3JlcyhwZWFrVHJhY2ssIGFuY2hvcjIpXG4gIGEudGIgPC0gdGliYmxlKGxvb3AgPSBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBzdW1TY29yZSA9IGEpXG4gIGIudGIgPC0gdGliYmxlKGxvb3AgPSBcXGdyb3VwMlxcLFxuICAgICAgICAgICAgICAgICBzdW1TY29yZSA9IGIpXG4gIFxuICBkYXRhIDwtIGJpbmRfcm93cyhhLnRiLCBiLnRiKSAlPiUgZHJvcF9uYSgpXG4gIGRhdGEkbG9vcCA8LSBmYWN0b3IoZGF0YSRsb29wLCBsZXZlbHMgPSBjKFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpKVxuICBcbiAgcDEyIDwtIGdldFB2YWxXaWxjb3goZGF0YSwgXFxncm91cDFcXCwgXFxncm91cDJcXClcbiAgcCA8LSAgZ2dwbG90KGRhdGEsIGFlcyh4ID0gbG9vcCwgeSA9IHN1bVNjb3JlKSkgKyBcbiAgICBsYWJzKHggPSBOVUxMLCB5ID0gcGFzdGUwKG5hbWUsIFxcXFxubG9nKGF2ZyBwZWFrIHNjb3JlIHBlciBhbmNob3IpXFwpKSArXG4gICAgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBsb29wKSwgY29sb3IgPSBcXGJsYWNrXFwsXG4gICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgICBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBjb2xvciA9IFxcYmxhY2tcXCxcbiAgICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgICAgb3V0bGllci5zaXplID0gMSwgb3V0bGllci5zdHJva2UgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICAgIHN0YXRfc3VtbWFyeShcbiAgICAgIGFlcyhncm91cCA9IGxvb3ApLCBmdW4gPSBtZWFuLFxuICAgICAgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDEsXG4gICAgICBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFxcbiAgICApICsgdGhlbWUoXG4gICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICAgKSxcbiAgICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgICAgc2l6ZSA9IGZvbnRTaXplUywgZmFtaWx5ID0gZm9udFR5cGUsIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICAgICksXG4gICAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgICAgYW5nbGUgPSA0NSwgaGp1c3QgPSAxLCB2anVzdCA9IDFcbiAgICAgICksXG4gICAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgICApLFxuICAgICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICAgICksXG4gICAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcXHRyYW5zcGFyZW50XFwpLFxuICAgICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICAgICkgKyBcbiAgICAjY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuMCksIHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuOTkpKSkgKyBcbiAgICBhbm5vdGF0ZShcbiAgICAgIFxcdGV4dFxcLCB4ID0gMSwgeSA9IHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuNSksXG4gICAgICBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSksXG4gICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gM1xuICAgICkgXG4gICMrIHNjYWxlX3lfY29udGludW91cyh0cmFucyA9IFxcbG9nMTBcXClcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXENoSVBfcGVha19hdmdQZWFrU2NvcmVfYmluYXJ5R3JvdXBfXFwsIG5hbWUpXG4gIHdpZHRoIDwtIHBhbmVsU2l6ZSgyKSptbVRvSW5jaFxuICBoZWlnaHQgPC0gcGFuZWxTaXplKDIpKm1tVG9JbmNoXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5cbiMgU3VtIHBlYWsgc2NvcmVcbiMjIyNcbnRyYWNrIDwtIGltcG9ydChoZXJlKHJlZkRpciwgXFwzMzI0OF9DVENGXzA3LTcyOV9CcnVjZS00X3RyaW1fcTIwX2RlZHVwX2JsYWNrX2RlcHRoTm9ybS5id1xcKSwgZm9ybWF0ID0gXFxCaWdXaWdcXClcbnBlYWsgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFwzMzI0OF9DVENGXzA3LTcyOV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcXCkpXG5wbG90U3VtU2NvcmVzQmluYXJ5KHRyYWNrLCBwZWFrLCBcXENUQ0ZcXCwgdHNzLjVrYi5ncm91cDEsIHRzcy41a2IuZ3JvdXAyKVxuXG50cmFjayA8LSBpbXBvcnQoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF90cmltX3EyMF9kZWR1cF9ibGFja19kZXB0aE5vcm0uYndcXCksIGZvcm1hdCA9IFxcQmlnV2lnXFwpXG5wZWFrIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKVxucGxvdFN1bVNjb3Jlc0JpbmFyeSh0cmFjaywgcGVhaywgXFxSQUQyMVxcLCB0c3MuNWtiLmdyb3VwMSwgdHNzLjVrYi5ncm91cDIpXG5cblxuXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\ntss.5kb.group1 <- fread(here(refDir, \\TSS_binaryGroup1.bed\\)) %>%\n  dplyr::mutate(start = (V2 + V3)/2 - 2500,\n                end = (V2 + V3)/2 + 2500,\n                chr = V1) %>%\n  dplyr::select(chr, start, end)\ntss.5kb.group1 <- makeGRangesFromDataFrame(tss.5kb.group1)\n\ntss.5kb.group2 <- fread(here(refDir, \\TSS_binaryGroup2.bed\\)) %>%\n  dplyr::mutate(start = (V2 + V3)/2 - 2500,\n                end = (V2 + V3)/2 + 2500,\n                chr = V1) %>%\n  dplyr::select(chr, start, end)\ntss.5kb.group2 <- makeGRangesFromDataFrame(tss.5kb.group2)\n\n\nplotSumScoresBinary <- function(track, peak, name, anchor1, anchor2){\n  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]\n  a <- getSumScores(peakTrack, anchor1)\n  b <- getSumScores(peakTrack, anchor2)\n  a.tb <- tibble(loop = \\group1\\,\n                 sumScore = a)\n  b.tb <- tibble(loop = \\group2\\,\n                 sumScore = b)\n  \n  data <- bind_rows(a.tb, b.tb) %>% drop_na()\n  data$loop <- factor(data$loop, levels = c(\\group1\\, \\group2\\))\n  \n  p12 <- getPvalWilcox(data, \\group1\\, \\group2\\)\n  p <-  ggplot(data, aes(x = loop, y = sumScore)) + \n    labs(x = NULL, y = paste0(name, \\\\nlog(avg peak score per anchor)\\)) +\n    geom_violin(aes(fill = loop), color = \\black\\,\n                linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                show.legend = FALSE) +\n    geom_boxplot(width = 0.1, color = \\black\\,\n                 linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +\n    stat_summary(\n      aes(group = loop), fun = mean,\n      geom = \\point\\, shape = 21, size = 1,\n      fill = \\red\\, color = \\black\\\n    ) + theme(\n      axis.title = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text = element_text(\n        size = fontSizeS, family = fontType, color = \\#000000\\\n      ),\n      axis.text.x = element_text(\n        angle = 45, hjust = 1, vjust = 1\n      ),\n      axis.line = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      axis.ticks = element_line(\n        color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n      ),\n      panel.background = element_rect(fill = \\transparent\\),\n      legend.text = element_text(family = fontType, size = fontSizeS),\n      legend.title = element_text(family = fontType, size = fontSizeS)\n    ) + \n    #coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.99))) + \n    annotate(\n      \\text\\, x = 1, y = quantile(data$sumScore, 0.5),\n      label = paste0(\\p12: \\, convPvalue(p12)),\n      color = \\black\\, hjust = 0, size = 3\n    ) \n  #+ scale_y_continuous(trans = \\log10\\)\n  \n  fileName <- paste0(\\ChIP_peak_avgPeakScore_binaryGroup_\\, name)\n  width <- panelSize(2)*mmToInch\n  height <- panelSize(2)*mmToInch\n  png(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\n  print(p)\n  dev.off()\n  svglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\n  print(p)\n  dev.off()\n}\n\n# Sum peak score\n####\ntrack <- import(here(refDir, \\33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\\))\nplotSumScoresBinary(track, peak, \\CTCF\\, tss.5kb.group1, tss.5kb.group2)\n\ntrack <- import(here(refDir, \\33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\\), format = \\BigWig\\)\npeak <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\nplotSumScoresBinary(track, peak, \\RAD21\\, tss.5kb.group1, tss.5kb.group2)\n\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudHNzLjVrYi5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcVFNTX2JpbmFyeUdyb3VwMS5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKHN0YXJ0ID0gKFYyICsgVjMpLzIgLSAyNTAwLFxuICAgICAgICAgICAgICAgIGVuZCA9IChWMiArIFYzKS8yICsgMjUwMCxcbiAgICAgICAgICAgICAgICBjaHIgPSBWMSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoY2hyLCBzdGFydCwgZW5kKVxudHNzLjVrYi5ncm91cDEgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRzcy41a2IuZ3JvdXAxKVxuXG50c3MuNWtiLmdyb3VwMiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxUU1NfYmluYXJ5R3JvdXAyLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoc3RhcnQgPSAoVjIgKyBWMykvMiAtIDI1MDAsXG4gICAgICAgICAgICAgICAgZW5kID0gKFYyICsgVjMpLzIgKyAyNTAwLFxuICAgICAgICAgICAgICAgIGNociA9IFYxKSAlPiVcbiAgZHBseXI6OnNlbGVjdChjaHIsIHN0YXJ0LCBlbmQpXG50c3MuNWtiLmdyb3VwMiA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUodHNzLjVrYi5ncm91cDIpXG5cblxucGxvdFN1bVNjb3Jlc0JpbmFyeSA8LSBmdW5jdGlvbih0cmFjaywgcGVhaywgbmFtZSwgYW5jaG9yMSwgYW5jaG9yMil7XG4gIHBlYWtUcmFjayA8LSB0cmFja1t1bmlxdWUocXVlcnlIaXRzKGZpbmRPdmVybGFwcyh0cmFjaywgcGVhaykpKV1cbiAgYSA8LSBnZXRTdW1TY29yZXMocGVha1RyYWNrLCBhbmNob3IxKVxuICBiIDwtIGdldFN1bVNjb3JlcyhwZWFrVHJhY2ssIGFuY2hvcjIpXG4gIGEudGIgPC0gdGliYmxlKGxvb3AgPSBcXGdyb3VwMVxcLFxuICAgICAgICAgICAgICAgICBzdW1TY29yZSA9IGEpXG4gIGIudGIgPC0gdGliYmxlKGxvb3AgPSBcXGdyb3VwMlxcLFxuICAgICAgICAgICAgICAgICBzdW1TY29yZSA9IGIpXG4gIFxuICBkYXRhIDwtIGJpbmRfcm93cyhhLnRiLCBiLnRiKSAlPiUgZHJvcF9uYSgpXG4gIGRhdGEkbG9vcCA8LSBmYWN0b3IoZGF0YSRsb29wLCBsZXZlbHMgPSBjKFxcZ3JvdXAxXFwsIFxcZ3JvdXAyXFwpKVxuICBcbiAgcDEyIDwtIGdldFB2YWxXaWxjb3goZGF0YSwgXFxncm91cDFcXCwgXFxncm91cDJcXClcbiAgcCA8LSAgZ2dwbG90KGRhdGEsIGFlcyh4ID0gbG9vcCwgeSA9IHN1bVNjb3JlKSkgKyBcbiAgICBsYWJzKHggPSBOVUxMLCB5ID0gcGFzdGUwKG5hbWUsIFxcXFxubG9nKGF2ZyBwZWFrIHNjb3JlIHBlciBhbmNob3IpXFwpKSArXG4gICAgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBsb29wKSwgY29sb3IgPSBcXGJsYWNrXFwsXG4gICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgICBzaG93LmxlZ2VuZCA9IEZBTFNFKSArXG4gICAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBjb2xvciA9IFxcYmxhY2tcXCxcbiAgICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgICAgb3V0bGllci5zaXplID0gMSwgb3V0bGllci5zdHJva2UgPSBOQSkgKyB0aGVtZV9jbGFzc2ljKCkgK1xuICAgIHN0YXRfc3VtbWFyeShcbiAgICAgIGFlcyhncm91cCA9IGxvb3ApLCBmdW4gPSBtZWFuLFxuICAgICAgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDEsXG4gICAgICBmaWxsID0gXFxyZWRcXCwgY29sb3IgPSBcXGJsYWNrXFxcbiAgICApICsgdGhlbWUoXG4gICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICAgKSxcbiAgICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgICAgc2l6ZSA9IGZvbnRTaXplUywgZmFtaWx5ID0gZm9udFR5cGUsIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICAgICksXG4gICAgICBheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChcbiAgICAgICAgYW5nbGUgPSA0NSwgaGp1c3QgPSAxLCB2anVzdCA9IDFcbiAgICAgICksXG4gICAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgICApLFxuICAgICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICAgICksXG4gICAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcXHRyYW5zcGFyZW50XFwpLFxuICAgICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICAgICkgKyBcbiAgICAjY29vcmRfY2FydGVzaWFuKHlsaW0gPSBjKHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuMCksIHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuOTkpKSkgKyBcbiAgICBhbm5vdGF0ZShcbiAgICAgIFxcdGV4dFxcLCB4ID0gMSwgeSA9IHF1YW50aWxlKGRhdGEkc3VtU2NvcmUsIDAuNSksXG4gICAgICBsYWJlbCA9IHBhc3RlMChcXHAxMjogXFwsIGNvbnZQdmFsdWUocDEyKSksXG4gICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gM1xuICAgICkgXG4gICMrIHNjYWxlX3lfY29udGludW91cyh0cmFucyA9IFxcbG9nMTBcXClcbiAgXG4gIGZpbGVOYW1lIDwtIHBhc3RlMChcXENoSVBfcGVha19hdmdQZWFrU2NvcmVfYmluYXJ5R3JvdXBfXFwsIG5hbWUpXG4gIHdpZHRoIDwtIHBhbmVsU2l6ZSgyKSptbVRvSW5jaFxuICBoZWlnaHQgPC0gcGFuZWxTaXplKDIpKm1tVG9JbmNoXG4gIHBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG4gIHN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbiAgcHJpbnQocClcbiAgZGV2Lm9mZigpXG59XG5cbiMgU3VtIHBlYWsgc2NvcmVcbiMjIyNcbnRyYWNrIDwtIGltcG9ydChoZXJlKHJlZkRpciwgXFwzMzI0OF9DVENGXzA3LTcyOV9CcnVjZS00X3RyaW1fcTIwX2RlZHVwX2JsYWNrX2RlcHRoTm9ybS5id1xcKSwgZm9ybWF0ID0gXFxCaWdXaWdcXClcbnBlYWsgPC0gaW1wb3J0UGVhayhoZXJlKHJlZkRpciwgXFwzMzI0OF9DVENGXzA3LTcyOV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5iZWRcXCkpXG5wbG90U3VtU2NvcmVzQmluYXJ5KHRyYWNrLCBwZWFrLCBcXENUQ0ZcXCwgdHNzLjVrYi5ncm91cDEsIHRzcy41a2IuZ3JvdXAyKVxuXG50cmFjayA8LSBpbXBvcnQoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF90cmltX3EyMF9kZWR1cF9ibGFja19kZXB0aE5vcm0uYndcXCksIGZvcm1hdCA9IFxcQmlnV2lnXFwpXG5wZWFrIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKVxucGxvdFN1bVNjb3Jlc0JpbmFyeSh0cmFjaywgcGVhaywgXFxSQUQyMVxcLCB0c3MuNWtiLmdyb3VwMSwgdHNzLjVrYi5ncm91cDIpXG5cblxuXG5gYGBcbmBgYCJ9 -->

```r
```r
tss.5kb.group1 <- fread(here(refDir, \TSS_binaryGroup1.bed\)) %>%
  dplyr::mutate(start = (V2 + V3)/2 - 2500,
                end = (V2 + V3)/2 + 2500,
                chr = V1) %>%
  dplyr::select(chr, start, end)
tss.5kb.group1 <- makeGRangesFromDataFrame(tss.5kb.group1)

tss.5kb.group2 <- fread(here(refDir, \TSS_binaryGroup2.bed\)) %>%
  dplyr::mutate(start = (V2 + V3)/2 - 2500,
                end = (V2 + V3)/2 + 2500,
                chr = V1) %>%
  dplyr::select(chr, start, end)
tss.5kb.group2 <- makeGRangesFromDataFrame(tss.5kb.group2)


plotSumScoresBinary <- function(track, peak, name, anchor1, anchor2){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  a <- getSumScores(peakTrack, anchor1)
  b <- getSumScores(peakTrack, anchor2)
  a.tb <- tibble(loop = \group1\,
                 sumScore = a)
  b.tb <- tibble(loop = \group2\,
                 sumScore = b)
  
  data <- bind_rows(a.tb, b.tb) %>% drop_na()
  data$loop <- factor(data$loop, levels = c(\group1\, \group2\))
  
  p12 <- getPvalWilcox(data, \group1\, \group2\)
  p <-  ggplot(data, aes(x = loop, y = sumScore)) + 
    labs(x = NULL, y = paste0(name, \\nlog(avg peak score per anchor)\)) +
    geom_violin(aes(fill = loop), color = \black\,
                linewidth = lineThick * mmToLineUnit, lineend = \square\,
                show.legend = FALSE) +
    geom_boxplot(width = 0.1, color = \black\,
                 linewidth = lineThick * mmToLineUnit, lineend = \square\,
                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +
    stat_summary(
      aes(group = loop), fun = mean,
      geom = \point\, shape = 21, size = 1,
      fill = \red\, color = \black\
    ) + theme(
      axis.title = element_text(
        size = fontSizeS, family = fontType, color = \#000000\
      ),
      axis.text = element_text(
        size = fontSizeS, family = fontType, color = \#000000\
      ),
      axis.text.x = element_text(
        angle = 45, hjust = 1, vjust = 1
      ),
      axis.line = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      axis.ticks = element_line(
        color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
      ),
      panel.background = element_rect(fill = \transparent\),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    ) + 
    #coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.99))) + 
    annotate(
      \text\, x = 1, y = quantile(data$sumScore, 0.5),
      label = paste0(\p12: \, convPvalue(p12)),
      color = \black\, hjust = 0, size = 3
    ) 
  #+ scale_y_continuous(trans = \log10\)
  
  fileName <- paste0(\ChIP_peak_avgPeakScore_binaryGroup_\, name)
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
  print(p)
  dev.off()
}

# Sum peak score
####
track <- import(here(refDir, \33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed\))
plotSumScoresBinary(track, peak, \CTCF\, tss.5kb.group1, tss.5kb.group2)

track <- import(here(refDir, \33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw\), format = \BigWig\)
peak <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))
plotSumScoresBinary(track, peak, \RAD21\, tss.5kb.group1, tss.5kb.group2)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [2.36] Finding farthest P-S

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJEY21WaGRHVWdkR2hsSUdSaGRHRmNibVJoZEdFZ1BDMGdaR0YwWVM1bWNtRnRaU2hjYmlBZ1IzSnZkWEFnUFNCaktGd2lSM0p2ZFhBeFhDSXNJRndpUjNKdmRYQXlYQ0lwTEZ4dUlDQldZV3gxWlNBOUlHTW9NekV1TURNc0lERXdMalkwS1Z4dUtWeHVYRzRqSUVOeVpXRjBaU0IwYUdVZ1ltRnlJSEJzYjNSY2JuQWdQQzBnWjJkd2JHOTBLR1JoZEdFc0lHRmxjeWg0SUQwZ1IzSnZkWEFzSUhrZ1BTQldZV3gxWlN3Z1ptbHNiQ0E5SUVkeWIzVndLU2tnS3lCY2JpQWdaMlZ2YlY5aVlYSW9jM1JoZENBOUlGd2lhV1JsYm5ScGRIbGNJaXdnWTI5c2IzSWdQU0JjSW1Kc1lXTnJYQ0lzSUhkcFpIUm9JRDBnTUM0M0xDQmhiSEJvWVNBOUlEQXVOaXdnYzJodmR5NXNaV2RsYm1RZ1BTQkdRVXhUUlN4Y2JpQWdJQ0FnSUNBZ0lDQWdiR2x1WlhkcFpIUm9JRDBnYkdsdVpWUm9hV05ySUNvZ2JXMVViMHhwYm1WVmJtbDBMQ0JzYVc1bFpXNWtJRDBnWENKemNYVmhjbVZjSWlrZ0t5QWpJRlZ6WlNCcFpHVnVkR2wwZVNCbWIzSWdjbUYzSUhaaGJIVmxjMXh1SUNCc1lXSnpLSGtnUFNCY0lpVWdiMllnVkZOVElHOXVJSE4wY21sd1pWd2lLU0FySUZ4dUlDQjBhR1Z0WlY5amJHRnpjMmxqS0NrZ0sxeHVJQ0IwYUdWdFpTaGNiaUFnSUNCaGVHbHpMblJwZEd4bElEMGdaV3hsYldWdWRGOTBaWGgwS0Z4dUlDQWdJQ0FnYzJsNlpTQTlJR1p2Ym5SVGFYcGxUU3hjYmlBZ0lDQWdJR1poYldsc2VTQTlJR1p2Ym5SVWVYQmxMRnh1SUNBZ0lDQWdZMjlzYjNJZ1BTQmNJaU13TURBd01EQmNJbHh1SUNBZ0lDa3NYRzRnSUNBZ1lYaHBjeTUwWlhoMElEMGdaV3hsYldWdWRGOTBaWGgwS0Z4dUlDQWdJQ0FnYzJsNlpTQTlJR1p2Ym5SVGFYcGxVeXhjYmlBZ0lDQWdJR1poYldsc2VTQTlJR1p2Ym5SVWVYQmxMRnh1SUNBZ0lDQWdZMjlzYjNJZ1BTQmNJaU13TURBd01EQmNJbHh1SUNBZ0lDa3NYRzRnSUNBZ1lYaHBjeTVzYVc1bElEMGdaV3hsYldWdWRGOXNhVzVsS0Z4dUlDQWdJQ0FnWTI5c2IzSWdQU0JjSWlNd01EQXdNREJjSWl4Y2JpQWdJQ0FnSUhOcGVtVWdQU0JzYVc1bFZHaHBZMnNxYlcxVWIweHBibVZWYm1sMExGeHVJQ0FnSUNBZ2JHbHVaV1Z1WkNBOUlGd2ljM0YxWVhKbFhDSmNiaUFnSUNBcExGeHVJQ0FnSUdGNGFYTXVkR2xqYTNNZ1BTQmxiR1Z0Wlc1MFgyeHBibVVvWEc0Z0lDQWdJQ0JqYjJ4dmNpQTlJRndpSXpBd01EQXdNRndpTEZ4dUlDQWdJQ0FnYzJsNlpTQTlJR3hwYm1WVWFHbGpheXB0YlZSdlRHbHVaVlZ1YVhRc1hHNGdJQ0FnSUNCc2FXNWxaVzVrSUQwZ1hDSnpjWFZoY21WY0lseHVJQ0FnSUNrc1hHNGdJQ0FnY0dGdVpXd3VZbUZqYTJkeWIzVnVaQ0E5SUdWc1pXMWxiblJmY21WamRDaG1hV3hzSUQwZ1hDSjBjbUZ1YzNCaGNtVnVkRndpS1N4Y2JpQWdJQ0JzWldkbGJtUXVkR1Y0ZENBOUlHVnNaVzFsYm5SZmRHVjRkQ2htWVcxcGJIa2dQU0JtYjI1MFZIbHdaU3dnYzJsNlpTQTlJR1p2Ym5SVGFYcGxVeWtzWEc0Z0lDQWdiR1ZuWlc1a0xuUnBkR3hsSUQwZ1pXeGxiV1Z1ZEY5MFpYaDBLR1poYldsc2VTQTlJR1p2Ym5SVWVYQmxMQ0J6YVhwbElEMGdabTl1ZEZOcGVtVlRLVnh1SUNBcFhHNWNibVpwYkdWT1lXMWxJRHd0SUhCaGMzUmxNQ2hjSW5CbGNtTmZiMjVmYzNSeWFYQmxYMkpwYm1GeWVVZHliM1Z3WENJcFhHNTNhV1IwYUNBOExTQndZVzVsYkZOcGVtVW9NUzR5TlNrcWJXMVViMGx1WTJoY2JtaGxhV2RvZENBOExTQndZVzVsYkZOcGVtVW9NUzR5S1NwdGJWUnZTVzVqYUZ4dWMzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNJaTV6ZG1kY0lpa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbiMgQ3JlYXRlIHRoZSBkYXRhXG5kYXRhIDwtIGRhdGEuZnJhbWUoXG4gIEdyb3VwID0gYyhcXEdyb3VwMVxcLCBcXEdyb3VwMlxcKSxcbiAgVmFsdWUgPSBjKDMxLjAzLCAxMC42NClcbilcblxuIyBDcmVhdGUgdGhlIGJhciBwbG90XG5wIDwtIGdncGxvdChkYXRhLCBhZXMoeCA9IEdyb3VwLCB5ID0gVmFsdWUsIGZpbGwgPSBHcm91cCkpICsgXG4gIGdlb21fYmFyKHN0YXQgPSBcXGlkZW50aXR5XFwsIGNvbG9yID0gXFxibGFja1xcLCB3aWR0aCA9IDAuNywgYWxwaGEgPSAwLjYsIHNob3cubGVnZW5kID0gRkFMU0UsXG4gICAgICAgICAgIGxpbmV3aWR0aCA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwpICsgIyBVc2UgaWRlbnRpdHkgZm9yIHJhdyB2YWx1ZXNcbiAgbGFicyh5ID0gXFwlIG9mIFRTUyBvbiBzdHJpcGVcXCkgKyBcbiAgdGhlbWVfY2xhc3NpYygpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZVMsXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxwZXJjX29uX3N0cmlwZV9iaW5hcnlHcm91cFxcKVxud2lkdGggPC0gcGFuZWxTaXplKDEuMjUpKm1tVG9JbmNoXG5oZWlnaHQgPC0gcGFuZWxTaXplKDEuMikqbW1Ub0luY2hcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
# Create the data
data <- data.frame(
  Group = c(\Group1\, \Group2\),
  Value = c(31.03, 10.64)
)

# Create the bar plot
p <- ggplot(data, aes(x = Group, y = Value, fill = Group)) + 
  geom_bar(stat = \identity\, color = \black\, width = 0.7, alpha = 0.6, show.legend = FALSE,
           linewidth = lineThick * mmToLineUnit, lineend = \square\) + # Use identity for raw values
  labs(y = \% of TSS on stripe\) + 
  theme_classic() +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- paste0(\perc_on_stripe_binaryGroup\)
width <- panelSize(1.25)*mmToInch
height <- panelSize(1.2)*mmToInch
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dUl5QkRjbVZoZEdVZ2RHaGxJR1JoZEdGY2JtUmhkR0VnUEMwZ1pHRjBZUzVtY21GdFpTaGNiaUFnUjNKdmRYQWdQU0JqS0Z4Y1IzSnZkWEF4WEZ3c0lGeGNSM0p2ZFhBeVhGd3BMRnh1SUNCV1lXeDFaU0E5SUdNb016RXVNRE1zSURFd0xqWTBLVnh1S1Z4dVhHNGpJRU55WldGMFpTQjBhR1VnWW1GeUlIQnNiM1JjYm5BZ1BDMGdaMmR3Ykc5MEtHUmhkR0VzSUdGbGN5aDRJRDBnUjNKdmRYQXNJSGtnUFNCV1lXeDFaU3dnWm1sc2JDQTlJRWR5YjNWd0tTa2dLeUJjYmlBZ1oyVnZiVjlpWVhJb2MzUmhkQ0E5SUZ4Y2FXUmxiblJwZEhsY1hDd2dZMjlzYjNJZ1BTQmNYR0pzWVdOclhGd3NJSGRwWkhSb0lEMGdNQzQzTENCaGJIQm9ZU0E5SURBdU5pd2djMmh2ZHk1c1pXZGxibVFnUFNCR1FVeFRSU3hjYmlBZ0lDQWdJQ0FnSUNBZ2JHbHVaWGRwWkhSb0lEMGdiR2x1WlZSb2FXTnJJQ29nYlcxVWIweHBibVZWYm1sMExDQnNhVzVsWlc1a0lEMGdYRnh6Y1hWaGNtVmNYQ2tnS3lBaklGVnpaU0JwWkdWdWRHbDBlU0JtYjNJZ2NtRjNJSFpoYkhWbGMxeHVJQ0JzWVdKektIa2dQU0JjWENVZ2IyWWdWRk5USUc5dUlITjBjbWx3WlZ4Y0tTQXJJRnh1SUNCMGFHVnRaVjlqYkdGemMybGpLQ2tnSzF4dUlDQjBhR1Z0WlNoY2JpQWdJQ0JoZUdsekxuUnBkR3hsSUQwZ1pXeGxiV1Z1ZEY5MFpYaDBLRnh1SUNBZ0lDQWdjMmw2WlNBOUlHWnZiblJUYVhwbFRTeGNiaUFnSUNBZ0lHWmhiV2xzZVNBOUlHWnZiblJVZVhCbExGeHVJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hDTXdNREF3TURCY1hGeHVJQ0FnSUNrc1hHNGdJQ0FnWVhocGN5NTBaWGgwSUQwZ1pXeGxiV1Z1ZEY5MFpYaDBLRnh1SUNBZ0lDQWdjMmw2WlNBOUlHWnZiblJUYVhwbFV5eGNiaUFnSUNBZ0lHWmhiV2xzZVNBOUlHWnZiblJVZVhCbExGeHVJQ0FnSUNBZ1kyOXNiM0lnUFNCY1hDTXdNREF3TURCY1hGeHVJQ0FnSUNrc1hHNGdJQ0FnWVhocGN5NXNhVzVsSUQwZ1pXeGxiV1Z1ZEY5c2FXNWxLRnh1SUNBZ0lDQWdZMjlzYjNJZ1BTQmNYQ013TURBd01EQmNYQ3hjYmlBZ0lDQWdJSE5wZW1VZ1BTQnNhVzVsVkdocFkyc3FiVzFVYjB4cGJtVlZibWwwTEZ4dUlDQWdJQ0FnYkdsdVpXVnVaQ0E5SUZ4Y2MzRjFZWEpsWEZ4Y2JpQWdJQ0FwTEZ4dUlDQWdJR0Y0YVhNdWRHbGphM01nUFNCbGJHVnRaVzUwWDJ4cGJtVW9YRzRnSUNBZ0lDQmpiMnh2Y2lBOUlGeGNJekF3TURBd01GeGNMRnh1SUNBZ0lDQWdjMmw2WlNBOUlHeHBibVZVYUdsamF5cHRiVlJ2VEdsdVpWVnVhWFFzWEc0Z0lDQWdJQ0JzYVc1bFpXNWtJRDBnWEZ4emNYVmhjbVZjWEZ4dUlDQWdJQ2tzWEc0Z0lDQWdjR0Z1Wld3dVltRmphMmR5YjNWdVpDQTlJR1ZzWlcxbGJuUmZjbVZqZENobWFXeHNJRDBnWEZ4MGNtRnVjM0JoY21WdWRGeGNLU3hjYmlBZ0lDQnNaV2RsYm1RdWRHVjRkQ0E5SUdWc1pXMWxiblJmZEdWNGRDaG1ZVzFwYkhrZ1BTQm1iMjUwVkhsd1pTd2djMmw2WlNBOUlHWnZiblJUYVhwbFV5a3NYRzRnSUNBZ2JHVm5aVzVrTG5ScGRHeGxJRDBnWld4bGJXVnVkRjkwWlhoMEtHWmhiV2xzZVNBOUlHWnZiblJVZVhCbExDQnphWHBsSUQwZ1ptOXVkRk5wZW1WVEtWeHVJQ0FwWEc1Y2JtWnBiR1ZPWVcxbElEd3RJSEJoYzNSbE1DaGNYSEJsY21OZmIyNWZjM1J5YVhCbFgySnBibUZ5ZVVkeWIzVndYRndwWEc1M2FXUjBhQ0E4TFNCd1lXNWxiRk5wZW1Vb01TNHlOU2txYlcxVWIwbHVZMmhjYm1obGFXZG9kQ0E4TFNCd1lXNWxiRk5wZW1Vb01TNHlLU3B0YlZSdlNXNWphRnh1YzNabmJHbDBaU2hvWlhKbEtHWnBaMFJwY2l3Z2NHRnpkR1V3S0dacGJHVk9ZVzFsTENCY1hDNXpkbWRjWENrcExDQWdhR1ZwWjJoMElEMGdhR1ZwWjJoMExDQjNhV1IwYUNBOUlIZHBaSFJvS1Z4dWNISnBiblFvY0NsY2JtUmxkaTV2Wm1Zb0tWeHVZR0JnWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5gYGByXG4jIENyZWF0ZSB0aGUgZGF0YVxuZGF0YSA8LSBkYXRhLmZyYW1lKFxuICBHcm91cCA9IGMoXFxHcm91cDFcXCwgXFxHcm91cDJcXCksXG4gIFZhbHVlID0gYygzMS4wMywgMTAuNjQpXG4pXG5cbiMgQ3JlYXRlIHRoZSBiYXIgcGxvdFxucCA8LSBnZ3Bsb3QoZGF0YSwgYWVzKHggPSBHcm91cCwgeSA9IFZhbHVlLCBmaWxsID0gR3JvdXApKSArIFxuICBnZW9tX2JhcihzdGF0ID0gXFxpZGVudGl0eVxcLCBjb2xvciA9IFxcYmxhY2tcXCwgd2lkdGggPSAwLjcsIGFscGhhID0gMC42LCBzaG93LmxlZ2VuZCA9IEZBTFNFLFxuICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcXHNxdWFyZVxcKSArICMgVXNlIGlkZW50aXR5IGZvciByYXcgdmFsdWVzXG4gIGxhYnMoeSA9IFxcJSBvZiBUU1Mgb24gc3RyaXBlXFwpICsgXG4gIHRoZW1lX2NsYXNzaWMoKSArXG4gIHRoZW1lKFxuICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcXHRyYW5zcGFyZW50XFwpLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gIClcblxuZmlsZU5hbWUgPC0gcGFzdGUwKFxccGVyY19vbl9zdHJpcGVfYmluYXJ5R3JvdXBcXClcbndpZHRoIDwtIHBhbmVsU2l6ZSgxLjI1KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjIpKm1tVG9JbmNoXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBDcmVhdGUgdGhlIGRhdGFcbmRhdGEgPC0gZGF0YS5mcmFtZShcbiAgR3JvdXAgPSBjKFxcR3JvdXAxXFwsIFxcR3JvdXAyXFwpLFxuICBWYWx1ZSA9IGMoMzEuMDMsIDEwLjY0KVxuKVxuXG4jIENyZWF0ZSB0aGUgYmFyIHBsb3RcbnAgPC0gZ2dwbG90KGRhdGEsIGFlcyh4ID0gR3JvdXAsIHkgPSBWYWx1ZSwgZmlsbCA9IEdyb3VwKSkgKyBcbiAgZ2VvbV9iYXIoc3RhdCA9IFxcaWRlbnRpdHlcXCwgY29sb3IgPSBcXGJsYWNrXFwsIHdpZHRoID0gMC43LCBhbHBoYSA9IDAuNiwgc2hvdy5sZWdlbmQgPSBGQUxTRSxcbiAgICAgICAgICAgbGluZXdpZHRoID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCkgKyAjIFVzZSBpZGVudGl0eSBmb3IgcmF3IHZhbHVlc1xuICBsYWJzKHkgPSBcXCUgb2YgVFNTIG9uIHN0cmlwZVxcKSArIFxuICB0aGVtZV9jbGFzc2ljKCkgK1xuICB0aGVtZShcbiAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplTSxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUyxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXHBlcmNfb25fc3RyaXBlX2JpbmFyeUdyb3VwXFwpXG53aWR0aCA8LSBwYW5lbFNpemUoMS4yNSkqbW1Ub0luY2hcbmhlaWdodCA8LSBwYW5lbFNpemUoMS4yKSptbVRvSW5jaFxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuYGBgXG5gYGAifQ== -->

```r
```r
# Create the data
data <- data.frame(
  Group = c(\Group1\, \Group2\),
  Value = c(31.03, 10.64)
)

# Create the bar plot
p <- ggplot(data, aes(x = Group, y = Value, fill = Group)) + 
  geom_bar(stat = \identity\, color = \black\, width = 0.7, alpha = 0.6, show.legend = FALSE,
           linewidth = lineThick * mmToLineUnit, lineend = \square\) + # Use identity for raw values
  labs(y = \% of TSS on stripe\) + 
  theme_classic() +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- paste0(\perc_on_stripe_binaryGroup\)
width <- panelSize(1.25)*mmToInch
height <- panelSize(1.2)*mmToInch
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [3.37] Checking RAD21 level at tss

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVkR1Z0Y0NBOExTQm1jbVZoWkNob1pYSmxLSEpsWmtScGNpd2dYQ0prYVdabVgwY3hMbVJVUVVkZlJ6RXVNbWt1WkZSQlIxOTJjMTlITVM0eWFTNUVUVk5QTG5SemRsd2lLU2tnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWXlneExDQXlLU2xjYm1kbGJtVk1hWE4wSUR3dElDaDBaVzF3SUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0dWNGRHVnlibUZzWDJkbGJtVmZibUZ0WlNBbGFXNGxJR01vWENKTGJHWTBYQ0lzSUZ3aVZHSjRNMXdpTENCY0lrcDFibHdpTENCY0lrWnZjMnd5WENJc0lGd2lUWGxqWENJc0lGd2lVR2hzWkdFeFhDSXBLU2trWlc1elpXMWliRjluWlc1bFgybGtYRzVjYmlNZ1RFOUJSQ0JCVGs1UFZFRlVSVVFnVEU5UFVGeHVibUZ0WlNBOExTQmNJbU5vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGNJbHh1WkdsbVprTjFkRzltWmlBOExTQXdMakpjYm1kbGJtVkJibTV2UkdGMFlTQThMU0JzYjJGa1RHOXZjRUZ1Ym05RVlYUmhLR2hsY21Vb1kyOXVjMlZ1YzNWelJHbHlMQ0J3WVhOMFpUQW9ibUZ0WlN3Z1hDSmZjQzF1WDJWdWMyVnRZbXhNYVhOMExuUnpkbHdpS1Nrc1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJR1JwWm1aRGRYUnZabVlnUFNCa2FXWm1RM1YwYjJabUxGeHVJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0JoYm01dlRHbHpkQ0E5SUdNb1hDSlFMVkJjSWl3Z1hDSlFMVVZjSWl3Z1hDSlFMVk5jSWl3Z1hDSlFMVmhjSWlrcEpUNGxYRzRnSUdSd2JIbHlPanB0ZFhSaGRHVW9aR2x6ZEdGdVkyVWdQU0J6ZEdGeWRESWdMU0J6ZEdGeWRERXBYRzVjYm1acGJIUmxjbVZrVEc5dmNDQThMU0JuWlc1bFFXNXViMFJoZEdFZ0pUNGxJSFZ1Ym1WemRDaG5aVzVsS1NBbFBpVWdaSEJzZVhJNk9tWnBiSFJsY2loblpXNWxJQ1ZwYmlVZ1oyVnVaVXhwYzNRcFhHNW1kM0pwZEdVb1ptbHNkR1Z5WldSTWIyOXdMQ0JvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRndpVUMxT1gzTmxiR1ZqZEdWa1IyVnVaUzVpWldSd1pWd2lLU2tzSUZ4dUlDQWdJQ0FnSUNBZ2MyVndJRDBnWENKY1hIUmNJaXdnWTI5c0xtNWhiV1Z6SUQwZ1JrRk1VMFVwWEc0Z0lGeHVkR1Z0Y0d4dmIzQWdQQzBnWm1sc2RHVnlaV1JNYjI5d0lDVStKU0JrY0d4NWNqbzZabWxzZEdWeUtFRnVibTh5SUNWcGJpVWdZeWhjSWxBdFVGd2lMQ0JjSWxBdFJWd2lLU2xjYm1aM2NtbDBaU2gwWlcxd2JHOXZjQ3dnYUdWeVpTaGpiMjV6Wlc1emRYTkVhWElzSUhCaGMzUmxNQ2hjSWxBdFVFVmZjMlZzWldOMFpXUkhaVzVsTG1KbFpIQmxYQ0lwS1N3Z1hHNGdJQ0FnSUNBZ0lDQnpaWEFnUFNCY0lseGNkRndpTENCamIyd3VibUZ0WlhNZ1BTQkdRVXhUUlNsY2JpQWdYRzUwWlcxd2JHOXZjQ0E4TFNCbWFXeDBaWEpsWkV4dmIzQWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9RVzV1YnpJZ0pXbHVKU0JqS0Z3aVVDMVRYQ0lwS1Z4dVpuZHlhWFJsS0hSbGJYQnNiMjl3TENCb1pYSmxLR052Ym5ObGJuTjFjMFJwY2l3Z2NHRnpkR1V3S0Z3aVVDMVRYM05sYkdWamRHVmtSMlZ1WlM1aVpXUndaVndpS1Nrc0lGeHVJQ0FnSUNBZ0lDQWdjMlZ3SUQwZ1hDSmNYSFJjSWl3Z1kyOXNMbTVoYldWeklEMGdSa0ZNVTBVcFhHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxudGVtcCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyKSlcbmdlbmVMaXN0IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGV4dGVybmFsX2dlbmVfbmFtZSAlaW4lIGMoXFxLbGY0XFwsIFxcVGJ4M1xcLCBcXEp1blxcLCBcXEZvc2wyXFwsIFxcTXljXFwsIFxcUGhsZGExXFwpKSkkZW5zZW1ibF9nZW5lX2lkXG5cbiMgTE9BRCBBTk5PVEFURUQgTE9PUFxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGlmZkN1dG9mZiA8LSAwLjJcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1uX2Vuc2VtYmxMaXN0LnRzdlxcKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSBkaWZmQ3V0b2ZmLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lXG4gIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpXG5cbmZpbHRlcmVkTG9vcCA8LSBnZW5lQW5ub0RhdGEgJT4lIHVubmVzdChnZW5lKSAlPiUgZHBseXI6OmZpbHRlcihnZW5lICVpbiUgZ2VuZUxpc3QpXG5md3JpdGUoZmlsdGVyZWRMb29wLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcUC1OX3NlbGVjdGVkR2VuZS5iZWRwZVxcKSksIFxuICAgICAgICAgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gRkFMU0UpXG4gIFxudGVtcGxvb3AgPC0gZmlsdGVyZWRMb29wICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcKSlcbmZ3cml0ZSh0ZW1wbG9vcCwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXFAtUEVfc2VsZWN0ZWRHZW5lLmJlZHBlXFwpKSwgXG4gICAgICAgICBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBGQUxTRSlcbiAgXG50ZW1wbG9vcCA8LSBmaWx0ZXJlZExvb3AgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUC1TXFwpKVxuZndyaXRlKHRlbXBsb29wLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcUC1TX3NlbGVjdGVkR2VuZS5iZWRwZVxcKSksIFxuICAgICAgICAgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gRkFMU0UpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
temp <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>% dplyr::select(c(1, 2))
geneList <- (temp %>% dplyr::filter(external_gene_name %in% c(\Klf4\, \Tbx3\, \Jun\, \Fosl2\, \Myc\, \Phlda1\)))$ensembl_gene_id

# LOAD ANNOTATED LOOP
name <- \chromo_cons_annoHierarchy\
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>%
  dplyr::mutate(distance = start2 - start1)

filteredLoop <- geneAnnoData %>% unnest(gene) %>% dplyr::filter(gene %in% geneList)
fwrite(filteredLoop, here(consensusDir, paste0(\P-N_selectedGene.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  
temploop <- filteredLoop %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\))
fwrite(temploop, here(consensusDir, paste0(\P-PE_selectedGene.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  
temploop <- filteredLoop %>% dplyr::filter(Anno2 %in% c(\P-S\))
fwrite(temploop, here(consensusDir, paste0(\P-S_selectedGene.bedpe\)), 
         sep = \\t\, col.names = FALSE)



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWRHVnRjQ0E4TFNCbWNtVmhaQ2hvWlhKbEtISmxaa1JwY2l3Z1hGeGthV1ptWDBjeExtUlVRVWRmUnpFdU1ta3VaRlJCUjE5MmMxOUhNUzR5YVM1RVRWTlBMblJ6ZGx4Y0tTa2dKVDRsSUdSd2JIbHlPanB6Wld4bFkzUW9ZeWd4TENBeUtTbGNibWRsYm1WTWFYTjBJRHd0SUNoMFpXMXdJQ1UrSlNCa2NHeDVjam82Wm1sc2RHVnlLR1Y0ZEdWeWJtRnNYMmRsYm1WZmJtRnRaU0FsYVc0bElHTW9YRnhMYkdZMFhGd3NJRnhjVkdKNE0xeGNMQ0JjWEVwMWJseGNMQ0JjWEVadmMyd3lYRndzSUZ4Y1RYbGpYRndzSUZ4Y1VHaHNaR0V4WEZ3cEtTa2taVzV6WlcxaWJGOW5aVzVsWDJsa1hHNWNiaU1nVEU5QlJDQkJUazVQVkVGVVJVUWdURTlQVUZ4dWJtRnRaU0E4TFNCY1hHTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsY1hGeHVaR2xtWmtOMWRHOW1aaUE4TFNBd0xqSmNibWRsYm1WQmJtNXZSR0YwWVNBOExTQnNiMkZrVEc5dmNFRnVibTlFWVhSaEtHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQndZWE4wWlRBb2JtRnRaU3dnWEZ4ZmNDMXVYMlZ1YzJWdFlteE1hWE4wTG5SemRseGNLU2tzWEc0Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lHUnBabVpEZFhSdlptWWdQU0JrYVdabVEzVjBiMlptTEZ4dUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQmhibTV2VEdsemRDQTlJR01vWEZ4UUxWQmNYQ3dnWEZ4UUxVVmNYQ3dnWEZ4UUxWTmNYQ3dnWEZ4UUxWaGNYQ2twSlQ0bFhHNGdJR1J3YkhseU9qcHRkWFJoZEdVb1pHbHpkR0Z1WTJVZ1BTQnpkR0Z5ZERJZ0xTQnpkR0Z5ZERFcFhHNWNibVpwYkhSbGNtVmtURzl2Y0NBOExTQm5aVzVsUVc1dWIwUmhkR0VnSlQ0bElIVnVibVZ6ZENoblpXNWxLU0FsUGlVZ1pIQnNlWEk2T21acGJIUmxjaWhuWlc1bElDVnBiaVVnWjJWdVpVeHBjM1FwWEc1bWQzSnBkR1VvWm1sc2RHVnlaV1JNYjI5d0xDQm9aWEpsS0dOdmJuTmxibk4xYzBScGNpd2djR0Z6ZEdVd0tGeGNVQzFPWDNObGJHVmpkR1ZrUjJWdVpTNWlaV1J3WlZ4Y0tTa3NJRnh1SUNBZ0lDQWdJQ0FnYzJWd0lEMGdYRnhjWEhSY1hDd2dZMjlzTG01aGJXVnpJRDBnUmtGTVUwVXBYRzRnSUZ4dWRHVnRjR3h2YjNBZ1BDMGdabWxzZEdWeVpXUk1iMjl3SUNVK0pTQmtjR3g1Y2pvNlptbHNkR1Z5S0VGdWJtOHlJQ1ZwYmlVZ1l5aGNYRkF0VUZ4Y0xDQmNYRkF0UlZ4Y0tTbGNibVozY21sMFpTaDBaVzF3Ykc5dmNDd2dhR1Z5WlNoamIyNXpaVzV6ZFhORWFYSXNJSEJoYzNSbE1DaGNYRkF0VUVWZmMyVnNaV04wWldSSFpXNWxMbUpsWkhCbFhGd3BLU3dnWEc0Z0lDQWdJQ0FnSUNCelpYQWdQU0JjWEZ4Y2RGeGNMQ0JqYjJ3dWJtRnRaWE1nUFNCR1FVeFRSU2xjYmlBZ1hHNTBaVzF3Ykc5dmNDQThMU0JtYVd4MFpYSmxaRXh2YjNBZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1FXNXVieklnSldsdUpTQmpLRnhjVUMxVFhGd3BLVnh1Wm5keWFYUmxLSFJsYlhCc2IyOXdMQ0JvWlhKbEtHTnZibk5sYm5OMWMwUnBjaXdnY0dGemRHVXdLRnhjVUMxVFgzTmxiR1ZqZEdWa1IyVnVaUzVpWldSd1pWeGNLU2tzSUZ4dUlDQWdJQ0FnSUNBZ2MyVndJRDBnWEZ4Y1hIUmNYQ3dnWTI5c0xtNWhiV1Z6SUQwZ1JrRk1VMFVwWEc1Z1lHQmNibUJnWUNKOSAtLT5cblxuYGBgclxuYGBgclxudGVtcCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyKSlcbmdlbmVMaXN0IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGV4dGVybmFsX2dlbmVfbmFtZSAlaW4lIGMoXFxLbGY0XFwsIFxcVGJ4M1xcLCBcXEp1blxcLCBcXEZvc2wyXFwsIFxcTXljXFwsIFxcUGhsZGExXFwpKSkkZW5zZW1ibF9nZW5lX2lkXG5cbiMgTE9BRCBBTk5PVEFURUQgTE9PUFxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGlmZkN1dG9mZiA8LSAwLjJcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1uX2Vuc2VtYmxMaXN0LnRzdlxcKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSBkaWZmQ3V0b2ZmLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lXG4gIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpXG5cbmZpbHRlcmVkTG9vcCA8LSBnZW5lQW5ub0RhdGEgJT4lIHVubmVzdChnZW5lKSAlPiUgZHBseXI6OmZpbHRlcihnZW5lICVpbiUgZ2VuZUxpc3QpXG5md3JpdGUoZmlsdGVyZWRMb29wLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcUC1OX3NlbGVjdGVkR2VuZS5iZWRwZVxcKSksIFxuICAgICAgICAgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gRkFMU0UpXG4gIFxudGVtcGxvb3AgPC0gZmlsdGVyZWRMb29wICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcKSlcbmZ3cml0ZSh0ZW1wbG9vcCwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXFAtUEVfc2VsZWN0ZWRHZW5lLmJlZHBlXFwpKSwgXG4gICAgICAgICBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBGQUxTRSlcbiAgXG50ZW1wbG9vcCA8LSBmaWx0ZXJlZExvb3AgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUC1TXFwpKVxuZndyaXRlKHRlbXBsb29wLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcUC1TX3NlbGVjdGVkR2VuZS5iZWRwZVxcKSksIFxuICAgICAgICAgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gRkFMU0UpXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudGVtcCA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyKSlcbmdlbmVMaXN0IDwtICh0ZW1wICU+JSBkcGx5cjo6ZmlsdGVyKGV4dGVybmFsX2dlbmVfbmFtZSAlaW4lIGMoXFxLbGY0XFwsIFxcVGJ4M1xcLCBcXEp1blxcLCBcXEZvc2wyXFwsIFxcTXljXFwsIFxcUGhsZGExXFwpKSkkZW5zZW1ibF9nZW5lX2lkXG5cbiMgTE9BRCBBTk5PVEFURUQgTE9PUFxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuZGlmZkN1dG9mZiA8LSAwLjJcbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1uX2Vuc2VtYmxMaXN0LnRzdlxcKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSBkaWZmQ3V0b2ZmLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbm5vTGlzdCA9IGMoXFxQLVBcXCwgXFxQLUVcXCwgXFxQLVNcXCwgXFxQLVhcXCkpJT4lXG4gIGRwbHlyOjptdXRhdGUoZGlzdGFuY2UgPSBzdGFydDIgLSBzdGFydDEpXG5cbmZpbHRlcmVkTG9vcCA8LSBnZW5lQW5ub0RhdGEgJT4lIHVubmVzdChnZW5lKSAlPiUgZHBseXI6OmZpbHRlcihnZW5lICVpbiUgZ2VuZUxpc3QpXG5md3JpdGUoZmlsdGVyZWRMb29wLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcUC1OX3NlbGVjdGVkR2VuZS5iZWRwZVxcKSksIFxuICAgICAgICAgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gRkFMU0UpXG4gIFxudGVtcGxvb3AgPC0gZmlsdGVyZWRMb29wICU+JSBkcGx5cjo6ZmlsdGVyKEFubm8yICVpbiUgYyhcXFAtUFxcLCBcXFAtRVxcKSlcbmZ3cml0ZSh0ZW1wbG9vcCwgaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChcXFAtUEVfc2VsZWN0ZWRHZW5lLmJlZHBlXFwpKSwgXG4gICAgICAgICBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBGQUxTRSlcbiAgXG50ZW1wbG9vcCA8LSBmaWx0ZXJlZExvb3AgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUC1TXFwpKVxuZndyaXRlKHRlbXBsb29wLCBoZXJlKGNvbnNlbnN1c0RpciwgcGFzdGUwKFxcUC1TX3NlbGVjdGVkR2VuZS5iZWRwZVxcKSksIFxuICAgICAgICAgc2VwID0gXFxcXHRcXCwgY29sLm5hbWVzID0gRkFMU0UpXG5gYGBcbmBgYCJ9 -->

```r
```r
temp <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>% dplyr::select(c(1, 2))
geneList <- (temp %>% dplyr::filter(external_gene_name %in% c(\Klf4\, \Tbx3\, \Jun\, \Fosl2\, \Myc\, \Phlda1\)))$ensembl_gene_id

# LOAD ANNOTATED LOOP
name <- \chromo_cons_annoHierarchy\
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>%
  dplyr::mutate(distance = start2 - start1)

filteredLoop <- geneAnnoData %>% unnest(gene) %>% dplyr::filter(gene %in% geneList)
fwrite(filteredLoop, here(consensusDir, paste0(\P-N_selectedGene.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  
temploop <- filteredLoop %>% dplyr::filter(Anno2 %in% c(\P-P\, \P-E\))
fwrite(temploop, here(consensusDir, paste0(\P-PE_selectedGene.bedpe\)), 
         sep = \\t\, col.names = FALSE)
  
temploop <- filteredLoop %>% dplyr::filter(Anno2 %in% c(\P-S\))
fwrite(temploop, here(consensusDir, paste0(\P-S_selectedGene.bedpe\)), 
         sep = \\t\, col.names = FALSE)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [3.38] Stripe percentage

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxubmFtZSA8LSBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcIlxuXG4jIElNUE9SVCBTLVMgbG9vcHNcbmFsbExvb3BzIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcImNocm9tb19jb25zX2Fubm9IaWVyYXJjaHkudHN2XCIpKVxuc3RyTG9vcHMgPC0gYWxsTG9vcHMgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFwiUy1TXCIpKVxudGVtcCA8LSBzdHJMb29wcyAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDYpKVxuY29sbmFtZXModGVtcCkgPC0gYyhcImNocm9tXCIsIFwic3RhcnRcIiwgXCJlbmRcIilcbnN0ckxvb3BzR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRlbXApXG5cbiMgSU1QT1JUIFRTU1xuZmxhbmtTaXplIDwtIDEwXG5nZW5lLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcIm1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFwiKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFwiK1wiLCBWMiwgVjMpLFxuICAgICAgICAgICAgICAgIFRTU3N0YXJ0ID0gVFNTIC0gZmxhbmtTaXplLFxuICAgICAgICAgICAgICAgIFRTU2VuZCA9IFRTUyArIGZsYW5rU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTU3N0YXJ0LCBUU1NlbmQsIFY2LCBWNSlcbmNvbG5hbWVzKGdlbmUudGIpIDwtIGMoXCJjaHJvbVwiLCBcInN0YXJ0XCIsIFwiZW5kXCIsIFwiZW5zZW1ibFwiLCBcImdlbmVcIilcbmdlbmVHciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZS50Yiwga2VlcC5leHRyYS5jb2x1bW5zID0gVFJVRSlcblxuXG4jIEZpbmQgb3ZlcmxhcHMgYmV0d2VlbiBsb29wcyBhbmQgVFNTXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoZ2VuZUdyLCBzdHJMb29wc0dyKVxuXG4jIEFubm90YXRlIG92ZXJsYXBzXG50c3Nfd2l0aF9sb29wcyA8LSBnZW5lR3JbcXVlcnlIaXRzKG92ZXJsYXBzKV1cbmxvb3BzX3dpdGhfdHNzIDwtIHN0ckxvb3BzR3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXVxuXG4jIENvbWJpbmUgaW50byBhIGRhdGEgZnJhbWUgZm9yIHByb2Nlc3Npbmdcbmxvb3BfZGF0YSA8LSBkYXRhLmZyYW1lKGdlbmUgPSB0c3Nfd2l0aF9sb29wcyRlbnNlbWJsLFxuICAgICAgICAgICAgICAgICAgICAgICAgbG9vcF9jaHIgPSBzZXFuYW1lcyhsb29wc193aXRoX3RzcyksXG4gICAgICAgICAgICAgICAgICAgICAgICBsb29wX3N0YXJ0ID0gc3RhcnQobG9vcHNfd2l0aF90c3MpLFxuICAgICAgICAgICAgICAgICAgICAgICAgbG9vcF9lbmQgPSBlbmQobG9vcHNfd2l0aF90c3MpLFxuICAgICAgICAgICAgICAgICAgICAgICAgbG9vcF93aWR0aCA9IHdpZHRoKGxvb3BzX3dpdGhfdHNzKSlcblxuIyBJZGVudGlmeSB0aGUgbGFyZ2VzdCBsb29wIGZvciBlYWNoIGdlbmVcbmxhcmdlc3RfbG9vcHMgPC0gbG9vcF9kYXRhW29yZGVyKGxvb3BfZGF0YSRnZW5lLCAtbG9vcF9kYXRhJGxvb3Bfd2lkdGgpLCBdXG5sYXJnZXN0X2xvb3BzIDwtIGxhcmdlc3RfbG9vcHNbIWR1cGxpY2F0ZWQobGFyZ2VzdF9sb29wcyRnZW5lKSwgXVxubGFyZ2VzdF9sb29wcyA8LSBsYXJnZXN0X2xvb3BzICU+JSBkcGx5cjo6bXV0YXRlKGxvb3BJRCA9IHBhc3RlKGxvb3BfY2hyLCBsb29wX3N0YXJ0LCBsb29wX2VuZCwgc2VwID0gXCJfXCIpKVxubGFyZ2VzdF9sb29wcyA8LSBsYXJnZXN0X2xvb3BzW29yZGVyKGxhcmdlc3RfbG9vcHMkbG9vcF9jaHIsIGxhcmdlc3RfbG9vcHMkbG9vcF9zdGFydCksXVxucm93bmFtZXMobGFyZ2VzdF9sb29wcykgPC0gTlVMTFxuXG4jIENoZWNraW5nIHNtYWxsZXIgbG9vcHNcbmFsbExvb3BzR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGFsbExvb3BzLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNlcW5hbWVzLmZpZWxkID0gXCJjaHJvbTFcIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdGFydC5maWVsZCA9IFwic3RhcnQxXCIsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZW5kLmZpZWxkID0gXCJlbmQyXCIpXG5sYXJnZXN0TG9vcHNHciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUobGFyZ2VzdF9sb29wcywgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc2VxbmFtZXMuZmllbGQgPSBcImxvb3BfY2hyXCIsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHN0YXJ0LmZpZWxkID0gXCJsb29wX3N0YXJ0XCIsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZC5maWVsZCA9IFwibG9vcF9lbmRcIilcbmxhcmdlc3RMb29wc0dyIDwtIHNvcnQodW5pcXVlKGxhcmdlc3RMb29wc0dyKSlcbmNvbXBsZXRlX292ZXJsYXBzIDwtIHN1YnNldEJ5T3ZlcmxhcHMoYWxsTG9vcHNHciwgbGFyZ2VzdExvb3BzR3IsIHR5cGUgPSBcIndpdGhpblwiKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGNvbXBsZXRlX292ZXJsYXBzLCBsYXJnZXN0TG9vcHNHcilcblxuXG5jb21wbGV0ZU92ZXJsYXBEZiA8LSBhcy5kYXRhLmZyYW1lKGNvbXBsZXRlX292ZXJsYXBzKSAlPiUgZHBseXI6Om11dGF0ZShsb29wSURBbGwgPSBwYXN0ZShzZXFuYW1lcywgc3RhcnQsIGVuZCwgc2VwID0gXCJfXCIpKVxubGFyZ2VzdExvb3BzRGYgPC0gYXMuZGF0YS5mcmFtZShsYXJnZXN0TG9vcHNHcikgJT4lIGRwbHlyOjptdXRhdGUobG9vcElEID0gcGFzdGUoc2VxbmFtZXMsIHN0YXJ0LCBlbmQsIHNlcCA9IFwiX1wiKSlcblxubG9vcElEcGFpcnMgPC0gZGF0YS5mcmFtZShsb29wSUQgPSBjb21wbGV0ZU92ZXJsYXBEZiRsb29wSURBbGxbcXVlcnlIaXRzKG92ZXJsYXBzKV0sXG4gICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BJRDIgPSBsYXJnZXN0TG9vcHNEZiRsb29wSURbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxuYWxsTG9vcHNBbm5vdGF0ZWQgPC0gYWxsTG9vcHMgJT4lIGRwbHlyOjptdXRhdGUobG9vcElEID0gcGFzdGUoY2hyb20xLCBzdGFydDEsIGVuZDIsIHNlcCA9IFwiX1wiKSkgJT4lIGRwbHlyOjpsZWZ0X2pvaW4obG9vcElEcGFpcnMsIGJ5ID0gYyhcImxvb3BJRFwiKSlcblxudGVtcCA8LSBhbGxMb29wc0Fubm90YXRlZCAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXCJQLUVcIiwgXCJQLVBcIiwgXCJFLUVcIikpICU+JSBkcGx5cjo6bXV0YXRlKGhhc1NTID0gIWlzLm5hKGxvb3BJRDIpKVxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihoYXNTUyA9PWdyb3VwMSkgKSRkaWZmX2RUQUdfRE1TT1xuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoaGFzU1MgPT1ncm91cDIpICkkZGlmZl9kVEFHX0RNU09cbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5wdiA8LSBjb252UHZhbHVlKGdldFB2YWxXaWxjb3godGVtcCwgVFJVRSwgRkFMU0UpKVxuZ2dwbG90KHRlbXAsIGFlcyh4ID0gaGFzU1MsIHkgPSBkaWZmX2RUQUdfRE1TTykpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBoYXNTUyksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBoYXNTUyksIGZ1biA9IG1lYW4sIFxuICAgICAgICAgICAgICAgZ2VvbSA9IFwicG9pbnRcIiwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcInJlZFwiLCBjb2xvciA9IFwiYmxhY2tcIikgK1xuICB0aGVtZV9jbGFzc2ljKCkgK1xuICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHB2LCBzaXplID0gNSwgY29sb3IgPSBcImJsYWNrXCIpICtcbiAgZ2d0aXRsZShcIlBFLVBFXCIpICsgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcblxuXG4jIENvdW50aW5nIGxvb3AgdHlwZXNcbmFsbExvb3BzQW5ub3RhdGVkRmlsdGVyZWQgPC0gYWxsTG9vcHNBbm5vdGF0ZWQgJT4lIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGxvb3BJRDIpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighKGxvb3BJRCA9PSBsb29wSUQyKSlcbnRlbXAgPC0gYWxsTG9vcHNBbm5vdGF0ZWRGaWx0ZXJlZCAlPiUgZHBseXI6OnNlbGVjdChsb29wSUQyLCBBbm5vMilcbnJlc3VsdCA8LSB0ZW1wICU+JVxuICBncm91cF9ieShsb29wSUQyLCBBbm5vMikgJT4lXG4gIHN1bW1hcmlzZShjb3VudCA9IG4oKSwgLmdyb3VwcyA9ICdkcm9wJykgJT4lXG4gIGdyb3VwX2J5KGxvb3BJRDIpICU+JVxuICBtdXRhdGUoZnJlcXVlbmN5ID0gY291bnQgLyBzdW0oY291bnQpKSAlPiVcbiAgYXJyYW5nZShsb29wSUQyLCBBbm5vMilcblxucmVzdWx0IDwtIGxhcmdlc3RfbG9vcHMgJT4lIGRwbHlyOjpsZWZ0X2pvaW4ocmVzdWx0LCBieSA9IGMoXCJsb29wSURcIiA9IFwibG9vcElEMlwiKSlcblxuZ2VuZS5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcIikpJGdlbmVcbmdlbmUuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XCIpKSRnZW5lXG5cbmRhdGEgPC0gdGliYmxlKFxuICBnZW5lID0gYyhnZW5lLmdyb3VwMSwgZ2VuZS5ncm91cDIpLFxuICBncm91cCA9IGMocmVwKFwiZ3JvdXAxXCIsIGxlbmd0aChnZW5lLmdyb3VwMSkpLFxuICAgICAgICAgICAgcmVwKFwiZ3JvdXAyXCIsIGxlbmd0aChnZW5lLmdyb3VwMikpKVxuKVxuXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4ocmVzdWx0LCBieSA9IGMoXCJnZW5lXCIpKVxuZGF0YSA8LSBkYXRhICU+JSBmaWx0ZXIoY29tcGxldGUuY2FzZXMoLikpXG5cbmFsbF9hbm5vMiA8LSB1bmlxdWUoZGF0YSRBbm5vMilcblxuIyBDYWxjdWxhdGUgYXZlcmFnZSBmcmVxdWVuY3kgb2YgQW5ubzIgZm9yIGVhY2ggZ2VuZSBpbiBlYWNoIGdyb3VwXG5yZXN1bHQgPC0gZGF0YSAlPiVcbiAgIyBFbnN1cmUgYWxsIHBvc3NpYmxlIEFubm8yIHZhbHVlcyBhcmUgcHJlc2VudCBmb3IgZWFjaCBnZW5lIGFuZCBncm91cFxuICBjb21wbGV0ZShnZW5lLCBBbm5vMiA9IGFsbF9hbm5vMiwgZmlsbCA9IGxpc3QoZnJlcXVlbmN5ID0gMCkpICU+JSBcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihcbiAgICBnZW5lICVpbiUgZ2VuZS5ncm91cDEgfiBcImdyb3VwMVwiLFxuICAgIGdlbmUgJWluJSBnZW5lLmdyb3VwMiB+IFwiZ3JvdXAyXCIsXG4gICAgVFJVRSB+IE5BXG4gICkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGdyb3VwLCBBbm5vMiwgZnJlcXVlbmN5KVxuICBcblxuZ2dwbG90KHJlc3VsdCwgYWVzKHggPSBBbm5vMiwgZmlsbCA9IGdyb3VwLCB5ID0gZnJlcXVlbmN5KSkgKyBnZW9tX2JveHBsb3QoKVxuXG5gYGAifQ== -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\n# IMPORT S-S loops\nallLoops <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\))\nstrLoops <- allLoops %>% dplyr::filter(Anno2 %in% c(\\S-S\\))\ntemp <- strLoops %>% dplyr::select(c(1, 2, 6))\ncolnames(temp) <- c(\\chrom\\, \\start\\, \\end\\)\nstrLoopsGr <- makeGRangesFromDataFrame(temp)\n\n# IMPORT TSS\nflankSize <- 10\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6, V5)\ncolnames(gene.tb) <- c(\\chrom\\, \\start\\, \\end\\, \\ensembl\\, \\gene\\)\ngeneGr <- makeGRangesFromDataFrame(gene.tb, keep.extra.columns = TRUE)\n\n\n# Find overlaps between loops and TSS\noverlaps <- findOverlaps(geneGr, strLoopsGr)\n\n# Annotate overlaps\ntss_with_loops <- geneGr[queryHits(overlaps)]\nloops_with_tss <- strLoopsGr[subjectHits(overlaps)]\n\n# Combine into a data frame for processing\nloop_data <- data.frame(gene = tss_with_loops$ensembl,\n                        loop_chr = seqnames(loops_with_tss),\n                        loop_start = start(loops_with_tss),\n                        loop_end = end(loops_with_tss),\n                        loop_width = width(loops_with_tss))\n\n# Identify the largest loop for each gene\nlargest_loops <- loop_data[order(loop_data$gene, -loop_data$loop_width), ]\nlargest_loops <- largest_loops[!duplicated(largest_loops$gene), ]\nlargest_loops <- largest_loops %>% dplyr::mutate(loopID = paste(loop_chr, loop_start, loop_end, sep = \\_\\))\nlargest_loops <- largest_loops[order(largest_loops$loop_chr, largest_loops$loop_start),]\nrownames(largest_loops) <- NULL\n\n# Checking smaller loops\nallLoopsGr <- makeGRangesFromDataFrame(allLoops, \n                                       seqnames.field = \\chrom1\\, \n                                       start.field = \\start1\\, \n                                       end.field = \\end2\\)\nlargestLoopsGr <- makeGRangesFromDataFrame(largest_loops, \n                                           seqnames.field = \\loop_chr\\, \n                                           start.field = \\loop_start\\, \n                                           end.field = \\loop_end\\)\nlargestLoopsGr <- sort(unique(largestLoopsGr))\ncomplete_overlaps <- subsetByOverlaps(allLoopsGr, largestLoopsGr, type = \\within\\)\noverlaps <- findOverlaps(complete_overlaps, largestLoopsGr)\n\n\ncompleteOverlapDf <- as.data.frame(complete_overlaps) %>% dplyr::mutate(loopIDAll = paste(seqnames, start, end, sep = \\_\\))\nlargestLoopsDf <- as.data.frame(largestLoopsGr) %>% dplyr::mutate(loopID = paste(seqnames, start, end, sep = \\_\\))\n\nloopIDpairs <- data.frame(loopID = completeOverlapDf$loopIDAll[queryHits(overlaps)],\n                          loopID2 = largestLoopsDf$loopID[subjectHits(overlaps)])\n\nallLoopsAnnotated <- allLoops %>% dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \\_\\)) %>% dplyr::left_join(loopIDpairs, by = c(\\loopID\\))\n\ntemp <- allLoopsAnnotated %>% dplyr::filter(Anno2 %in% c(\\P-E\\, \\P-P\\, \\E-E\\)) %>% dplyr::mutate(hasSS = !is.na(loopID2))\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(hasSS ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(hasSS ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, TRUE, FALSE))\nggplot(temp, aes(x = hasSS, y = diff_dTAG_DMSO)) + geom_violin(aes(fill = hasSS), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = hasSS), fun = mean, \n               geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme_classic() +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\) +\n  ggtitle(\\PE-PE\\) + geom_hline(yintercept = 0)\n\n\n# Counting loop types\nallLoopsAnnotatedFiltered <- allLoopsAnnotated %>% dplyr::filter(!is.na(loopID2)) %>%\n  dplyr::filter(!(loopID == loopID2))\ntemp <- allLoopsAnnotatedFiltered %>% dplyr::select(loopID2, Anno2)\nresult <- temp %>%\n  group_by(loopID2, Anno2) %>%\n  summarise(count = n(), .groups = 'drop') %>%\n  group_by(loopID2) %>%\n  mutate(frequency = count / sum(count)) %>%\n  arrange(loopID2, Anno2)\n\nresult <- largest_loops %>% dplyr::left_join(result, by = c(\\loopID\\ = \\loopID2\\))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(result, by = c(\\gene\\))\ndata <- data %>% filter(complete.cases(.))\n\nall_anno2 <- unique(data$Anno2)\n\n# Calculate average frequency of Anno2 for each gene in each group\nresult <- data %>%\n  # Ensure all possible Anno2 values are present for each gene and group\n  complete(gene, Anno2 = all_anno2, fill = list(frequency = 0)) %>% \n  dplyr::mutate(group = case_when(\n    gene %in% gene.group1 ~ \\group1\\,\n    gene %in% gene.group2 ~ \\group2\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::select(group, Anno2, frequency)\n  \n\nggplot(result, aes(x = Anno2, fill = group, y = frequency)) + geom_boxplot()\n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\

# IMPORT S-S loops
allLoops <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\))
strLoops <- allLoops %>% dplyr::filter(Anno2 %in% c(\S-S\))
temp <- strLoops %>% dplyr::select(c(1, 2, 6))
colnames(temp) <- c(\chrom\, \start\, \end\)
strLoopsGr <- makeGRangesFromDataFrame(temp)

# IMPORT TSS
flankSize <- 10
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c(\chrom\, \start\, \end\, \ensembl\, \gene\)
geneGr <- makeGRangesFromDataFrame(gene.tb, keep.extra.columns = TRUE)


# Find overlaps between loops and TSS
overlaps <- findOverlaps(geneGr, strLoopsGr)

# Annotate overlaps
tss_with_loops <- geneGr[queryHits(overlaps)]
loops_with_tss <- strLoopsGr[subjectHits(overlaps)]

# Combine into a data frame for processing
loop_data <- data.frame(gene = tss_with_loops$ensembl,
                        loop_chr = seqnames(loops_with_tss),
                        loop_start = start(loops_with_tss),
                        loop_end = end(loops_with_tss),
                        loop_width = width(loops_with_tss))

# Identify the largest loop for each gene
largest_loops <- loop_data[order(loop_data$gene, -loop_data$loop_width), ]
largest_loops <- largest_loops[!duplicated(largest_loops$gene), ]
largest_loops <- largest_loops %>% dplyr::mutate(loopID = paste(loop_chr, loop_start, loop_end, sep = \_\))
largest_loops <- largest_loops[order(largest_loops$loop_chr, largest_loops$loop_start),]
rownames(largest_loops) <- NULL

# Checking smaller loops
allLoopsGr <- makeGRangesFromDataFrame(allLoops, 
                                       seqnames.field = \chrom1\, 
                                       start.field = \start1\, 
                                       end.field = \end2\)
largestLoopsGr <- makeGRangesFromDataFrame(largest_loops, 
                                           seqnames.field = \loop_chr\, 
                                           start.field = \loop_start\, 
                                           end.field = \loop_end\)
largestLoopsGr <- sort(unique(largestLoopsGr))
complete_overlaps <- subsetByOverlaps(allLoopsGr, largestLoopsGr, type = \within\)
overlaps <- findOverlaps(complete_overlaps, largestLoopsGr)


completeOverlapDf <- as.data.frame(complete_overlaps) %>% dplyr::mutate(loopIDAll = paste(seqnames, start, end, sep = \_\))
largestLoopsDf <- as.data.frame(largestLoopsGr) %>% dplyr::mutate(loopID = paste(seqnames, start, end, sep = \_\))

loopIDpairs <- data.frame(loopID = completeOverlapDf$loopIDAll[queryHits(overlaps)],
                          loopID2 = largestLoopsDf$loopID[subjectHits(overlaps)])

allLoopsAnnotated <- allLoops %>% dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \_\)) %>% dplyr::left_join(loopIDpairs, by = c(\loopID\))

temp <- allLoopsAnnotated %>% dplyr::filter(Anno2 %in% c(\P-E\, \P-P\, \E-E\)) %>% dplyr::mutate(hasSS = !is.na(loopID2))
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(hasSS ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(hasSS ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
pv <- convPvalue(getPvalWilcox(temp, TRUE, FALSE))
ggplot(temp, aes(x = hasSS, y = diff_dTAG_DMSO)) + geom_violin(aes(fill = hasSS), show.legend = FALSE) + 
  geom_boxplot(width = 0.1, outlier.shape = NA) +
  stat_summary(aes(group = hasSS), fun = mean, 
               geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  theme_classic() +
  annotate(\text\, x = 1, y = 0, label = pv, size = 5, color = \black\) +
  ggtitle(\PE-PE\) + geom_hline(yintercept = 0)


# Counting loop types
allLoopsAnnotatedFiltered <- allLoopsAnnotated %>% dplyr::filter(!is.na(loopID2)) %>%
  dplyr::filter(!(loopID == loopID2))
temp <- allLoopsAnnotatedFiltered %>% dplyr::select(loopID2, Anno2)
result <- temp %>%
  group_by(loopID2, Anno2) %>%
  summarise(count = n(), .groups = 'drop') %>%
  group_by(loopID2) %>%
  mutate(frequency = count / sum(count)) %>%
  arrange(loopID2, Anno2)

result <- largest_loops %>% dplyr::left_join(result, by = c(\loopID\ = \loopID2\))

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep(\group1\, length(gene.group1)),
            rep(\group2\, length(gene.group2)))
)

data <- data %>% dplyr::left_join(result, by = c(\gene\))
data <- data %>% filter(complete.cases(.))

all_anno2 <- unique(data$Anno2)

# Calculate average frequency of Anno2 for each gene in each group
result <- data %>%
  # Ensure all possible Anno2 values are present for each gene and group
  complete(gene, Anno2 = all_anno2, fill = list(frequency = 0)) %>% 
  dplyr::mutate(group = case_when(
    gene %in% gene.group1 ~ \group1\,
    gene %in% gene.group2 ~ \group2\,
    TRUE ~ NA
  )) %>%
  dplyr::select(group, Anno2, frequency)
  

ggplot(result, aes(x = Anno2, fill = group, y = frequency)) + geom_boxplot()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG4jIElNUE9SVCBTLVMgbG9vcHNcbmFsbExvb3BzIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHkudHN2XFwpKVxuc3RyTG9vcHMgPC0gYWxsTG9vcHMgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUy1TXFwpKVxudGVtcCA8LSBzdHJMb29wcyAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDYpKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGNocm9tXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnN0ckxvb3BzR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRlbXApXG5cbiMgSU1QT1JUIFRTU1xuZmxhbmtTaXplIDwtIDEwXG5nZW5lLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpLFxuICAgICAgICAgICAgICAgIFRTU3N0YXJ0ID0gVFNTIC0gZmxhbmtTaXplLFxuICAgICAgICAgICAgICAgIFRTU2VuZCA9IFRTUyArIGZsYW5rU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTU3N0YXJ0LCBUU1NlbmQsIFY2LCBWNSlcbmNvbG5hbWVzKGdlbmUudGIpIDwtIGMoXFxjaHJvbVxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcZW5zZW1ibFxcLCBcXGdlbmVcXClcbmdlbmVHciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZS50Yiwga2VlcC5leHRyYS5jb2x1bW5zID0gVFJVRSlcblxuXG4jIEZpbmQgb3ZlcmxhcHMgYmV0d2VlbiBsb29wcyBhbmQgVFNTXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoZ2VuZUdyLCBzdHJMb29wc0dyKVxuXG4jIEFubm90YXRlIG92ZXJsYXBzXG50c3Nfd2l0aF9sb29wcyA8LSBnZW5lR3JbcXVlcnlIaXRzKG92ZXJsYXBzKV1cbmxvb3BzX3dpdGhfdHNzIDwtIHN0ckxvb3BzR3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXVxuXG4jIENvbWJpbmUgaW50byBhIGRhdGEgZnJhbWUgZm9yIHByb2Nlc3Npbmdcbmxvb3BfZGF0YSA8LSBkYXRhLmZyYW1lKGdlbmUgPSB0c3Nfd2l0aF9sb29wcyRlbnNlbWJsLFxuICAgICAgICAgICAgICAgICAgICAgICAgbG9vcF9jaHIgPSBzZXFuYW1lcyhsb29wc193aXRoX3RzcyksXG4gICAgICAgICAgICAgICAgICAgICAgICBsb29wX3N0YXJ0ID0gc3RhcnQobG9vcHNfd2l0aF90c3MpLFxuICAgICAgICAgICAgICAgICAgICAgICAgbG9vcF9lbmQgPSBlbmQobG9vcHNfd2l0aF90c3MpLFxuICAgICAgICAgICAgICAgICAgICAgICAgbG9vcF93aWR0aCA9IHdpZHRoKGxvb3BzX3dpdGhfdHNzKSlcblxuIyBJZGVudGlmeSB0aGUgbGFyZ2VzdCBsb29wIGZvciBlYWNoIGdlbmVcbmxhcmdlc3RfbG9vcHMgPC0gbG9vcF9kYXRhW29yZGVyKGxvb3BfZGF0YSRnZW5lLCAtbG9vcF9kYXRhJGxvb3Bfd2lkdGgpLCBdXG5sYXJnZXN0X2xvb3BzIDwtIGxhcmdlc3RfbG9vcHNbIWR1cGxpY2F0ZWQobGFyZ2VzdF9sb29wcyRnZW5lKSwgXVxubGFyZ2VzdF9sb29wcyA8LSBsYXJnZXN0X2xvb3BzICU+JSBkcGx5cjo6bXV0YXRlKGxvb3BJRCA9IHBhc3RlKGxvb3BfY2hyLCBsb29wX3N0YXJ0LCBsb29wX2VuZCwgc2VwID0gXFxfXFwpKVxubGFyZ2VzdF9sb29wcyA8LSBsYXJnZXN0X2xvb3BzW29yZGVyKGxhcmdlc3RfbG9vcHMkbG9vcF9jaHIsIGxhcmdlc3RfbG9vcHMkbG9vcF9zdGFydCksXVxucm93bmFtZXMobGFyZ2VzdF9sb29wcykgPC0gTlVMTFxuXG4jIENoZWNraW5nIHNtYWxsZXIgbG9vcHNcbmFsbExvb3BzR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGFsbExvb3BzLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNlcW5hbWVzLmZpZWxkID0gXFxjaHJvbTFcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdGFydC5maWVsZCA9IFxcc3RhcnQxXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZW5kLmZpZWxkID0gXFxlbmQyXFwpXG5sYXJnZXN0TG9vcHNHciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUobGFyZ2VzdF9sb29wcywgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc2VxbmFtZXMuZmllbGQgPSBcXGxvb3BfY2hyXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHN0YXJ0LmZpZWxkID0gXFxsb29wX3N0YXJ0XFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZC5maWVsZCA9IFxcbG9vcF9lbmRcXClcbmxhcmdlc3RMb29wc0dyIDwtIHNvcnQodW5pcXVlKGxhcmdlc3RMb29wc0dyKSlcbmNvbXBsZXRlX292ZXJsYXBzIDwtIHN1YnNldEJ5T3ZlcmxhcHMoYWxsTG9vcHNHciwgbGFyZ2VzdExvb3BzR3IsIHR5cGUgPSBcXHdpdGhpblxcKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGNvbXBsZXRlX292ZXJsYXBzLCBsYXJnZXN0TG9vcHNHcilcblxuXG5jb21wbGV0ZU92ZXJsYXBEZiA8LSBhcy5kYXRhLmZyYW1lKGNvbXBsZXRlX292ZXJsYXBzKSAlPiUgZHBseXI6Om11dGF0ZShsb29wSURBbGwgPSBwYXN0ZShzZXFuYW1lcywgc3RhcnQsIGVuZCwgc2VwID0gXFxfXFwpKVxubGFyZ2VzdExvb3BzRGYgPC0gYXMuZGF0YS5mcmFtZShsYXJnZXN0TG9vcHNHcikgJT4lIGRwbHlyOjptdXRhdGUobG9vcElEID0gcGFzdGUoc2VxbmFtZXMsIHN0YXJ0LCBlbmQsIHNlcCA9IFxcX1xcKSlcblxubG9vcElEcGFpcnMgPC0gZGF0YS5mcmFtZShsb29wSUQgPSBjb21wbGV0ZU92ZXJsYXBEZiRsb29wSURBbGxbcXVlcnlIaXRzKG92ZXJsYXBzKV0sXG4gICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BJRDIgPSBsYXJnZXN0TG9vcHNEZiRsb29wSURbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxuYWxsTG9vcHNBbm5vdGF0ZWQgPC0gYWxsTG9vcHMgJT4lIGRwbHlyOjptdXRhdGUobG9vcElEID0gcGFzdGUoY2hyb20xLCBzdGFydDEsIGVuZDIsIHNlcCA9IFxcX1xcKSkgJT4lIGRwbHlyOjpsZWZ0X2pvaW4obG9vcElEcGFpcnMsIGJ5ID0gYyhcXGxvb3BJRFxcKSlcblxudGVtcCA8LSBhbGxMb29wc0Fubm90YXRlZCAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxQLUVcXCwgXFxQLVBcXCwgXFxFLUVcXCkpICU+JSBkcGx5cjo6bXV0YXRlKGhhc1NTID0gIWlzLm5hKGxvb3BJRDIpKVxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihoYXNTUyA9PWdyb3VwMSkgKSRkaWZmX2RUQUdfRE1TT1xuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoaGFzU1MgPT1ncm91cDIpICkkZGlmZl9kVEFHX0RNU09cbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5wdiA8LSBjb252UHZhbHVlKGdldFB2YWxXaWxjb3godGVtcCwgVFJVRSwgRkFMU0UpKVxuZ2dwbG90KHRlbXAsIGFlcyh4ID0gaGFzU1MsIHkgPSBkaWZmX2RUQUdfRE1TTykpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBoYXNTUyksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBoYXNTUyksIGZ1biA9IG1lYW4sIFxuICAgICAgICAgICAgICAgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICB0aGVtZV9jbGFzc2ljKCkgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHB2LCBzaXplID0gNSwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2d0aXRsZShcXFBFLVBFXFwpICsgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcblxuXG4jIENvdW50aW5nIGxvb3AgdHlwZXNcbmFsbExvb3BzQW5ub3RhdGVkRmlsdGVyZWQgPC0gYWxsTG9vcHNBbm5vdGF0ZWQgJT4lIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGxvb3BJRDIpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighKGxvb3BJRCA9PSBsb29wSUQyKSlcbnRlbXAgPC0gYWxsTG9vcHNBbm5vdGF0ZWRGaWx0ZXJlZCAlPiUgZHBseXI6OnNlbGVjdChsb29wSUQyLCBBbm5vMilcbnJlc3VsdCA8LSB0ZW1wICU+JVxuICBncm91cF9ieShsb29wSUQyLCBBbm5vMikgJT4lXG4gIHN1bW1hcmlzZShjb3VudCA9IG4oKSwgLmdyb3VwcyA9ICdkcm9wJykgJT4lXG4gIGdyb3VwX2J5KGxvb3BJRDIpICU+JVxuICBtdXRhdGUoZnJlcXVlbmN5ID0gY291bnQgLyBzdW0oY291bnQpKSAlPiVcbiAgYXJyYW5nZShsb29wSUQyLCBBbm5vMilcblxucmVzdWx0IDwtIGxhcmdlc3RfbG9vcHMgJT4lIGRwbHlyOjpsZWZ0X2pvaW4ocmVzdWx0LCBieSA9IGMoXFxsb29wSURcXCA9IFxcbG9vcElEMlxcKSlcblxuZ2VuZS5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdlbmUuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XFwpKSRnZW5lXG5cbmRhdGEgPC0gdGliYmxlKFxuICBnZW5lID0gYyhnZW5lLmdyb3VwMSwgZ2VuZS5ncm91cDIpLFxuICBncm91cCA9IGMocmVwKFxcZ3JvdXAxXFwsIGxlbmd0aChnZW5lLmdyb3VwMSkpLFxuICAgICAgICAgICAgcmVwKFxcZ3JvdXAyXFwsIGxlbmd0aChnZW5lLmdyb3VwMikpKVxuKVxuXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4ocmVzdWx0LCBieSA9IGMoXFxnZW5lXFwpKVxuZGF0YSA8LSBkYXRhICU+JSBmaWx0ZXIoY29tcGxldGUuY2FzZXMoLikpXG5cbmFsbF9hbm5vMiA8LSB1bmlxdWUoZGF0YSRBbm5vMilcblxuIyBDYWxjdWxhdGUgYXZlcmFnZSBmcmVxdWVuY3kgb2YgQW5ubzIgZm9yIGVhY2ggZ2VuZSBpbiBlYWNoIGdyb3VwXG5yZXN1bHQgPC0gZGF0YSAlPiVcbiAgIyBFbnN1cmUgYWxsIHBvc3NpYmxlIEFubm8yIHZhbHVlcyBhcmUgcHJlc2VudCBmb3IgZWFjaCBnZW5lIGFuZCBncm91cFxuICBjb21wbGV0ZShnZW5lLCBBbm5vMiA9IGFsbF9hbm5vMiwgZmlsbCA9IGxpc3QoZnJlcXVlbmN5ID0gMCkpICU+JSBcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihcbiAgICBnZW5lICVpbiUgZ2VuZS5ncm91cDEgfiBcXGdyb3VwMVxcLFxuICAgIGdlbmUgJWluJSBnZW5lLmdyb3VwMiB+IFxcZ3JvdXAyXFwsXG4gICAgVFJVRSB+IE5BXG4gICkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGdyb3VwLCBBbm5vMiwgZnJlcXVlbmN5KVxuICBcblxuZ2dwbG90KHJlc3VsdCwgYWVzKHggPSBBbm5vMiwgZmlsbCA9IGdyb3VwLCB5ID0gZnJlcXVlbmN5KSkgKyBnZW9tX2JveHBsb3QoKVxuXG5gYGBcbmBgYCJ9 -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n\n# IMPORT S-S loops\nallLoops <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\))\nstrLoops <- allLoops %>% dplyr::filter(Anno2 %in% c(\\S-S\\))\ntemp <- strLoops %>% dplyr::select(c(1, 2, 6))\ncolnames(temp) <- c(\\chrom\\, \\start\\, \\end\\)\nstrLoopsGr <- makeGRangesFromDataFrame(temp)\n\n# IMPORT TSS\nflankSize <- 10\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6, V5)\ncolnames(gene.tb) <- c(\\chrom\\, \\start\\, \\end\\, \\ensembl\\, \\gene\\)\ngeneGr <- makeGRangesFromDataFrame(gene.tb, keep.extra.columns = TRUE)\n\n\n# Find overlaps between loops and TSS\noverlaps <- findOverlaps(geneGr, strLoopsGr)\n\n# Annotate overlaps\ntss_with_loops <- geneGr[queryHits(overlaps)]\nloops_with_tss <- strLoopsGr[subjectHits(overlaps)]\n\n# Combine into a data frame for processing\nloop_data <- data.frame(gene = tss_with_loops$ensembl,\n                        loop_chr = seqnames(loops_with_tss),\n                        loop_start = start(loops_with_tss),\n                        loop_end = end(loops_with_tss),\n                        loop_width = width(loops_with_tss))\n\n# Identify the largest loop for each gene\nlargest_loops <- loop_data[order(loop_data$gene, -loop_data$loop_width), ]\nlargest_loops <- largest_loops[!duplicated(largest_loops$gene), ]\nlargest_loops <- largest_loops %>% dplyr::mutate(loopID = paste(loop_chr, loop_start, loop_end, sep = \\_\\))\nlargest_loops <- largest_loops[order(largest_loops$loop_chr, largest_loops$loop_start),]\nrownames(largest_loops) <- NULL\n\n# Checking smaller loops\nallLoopsGr <- makeGRangesFromDataFrame(allLoops, \n                                       seqnames.field = \\chrom1\\, \n                                       start.field = \\start1\\, \n                                       end.field = \\end2\\)\nlargestLoopsGr <- makeGRangesFromDataFrame(largest_loops, \n                                           seqnames.field = \\loop_chr\\, \n                                           start.field = \\loop_start\\, \n                                           end.field = \\loop_end\\)\nlargestLoopsGr <- sort(unique(largestLoopsGr))\ncomplete_overlaps <- subsetByOverlaps(allLoopsGr, largestLoopsGr, type = \\within\\)\noverlaps <- findOverlaps(complete_overlaps, largestLoopsGr)\n\n\ncompleteOverlapDf <- as.data.frame(complete_overlaps) %>% dplyr::mutate(loopIDAll = paste(seqnames, start, end, sep = \\_\\))\nlargestLoopsDf <- as.data.frame(largestLoopsGr) %>% dplyr::mutate(loopID = paste(seqnames, start, end, sep = \\_\\))\n\nloopIDpairs <- data.frame(loopID = completeOverlapDf$loopIDAll[queryHits(overlaps)],\n                          loopID2 = largestLoopsDf$loopID[subjectHits(overlaps)])\n\nallLoopsAnnotated <- allLoops %>% dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \\_\\)) %>% dplyr::left_join(loopIDpairs, by = c(\\loopID\\))\n\ntemp <- allLoopsAnnotated %>% dplyr::filter(Anno2 %in% c(\\P-E\\, \\P-P\\, \\E-E\\)) %>% dplyr::mutate(hasSS = !is.na(loopID2))\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(hasSS ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(hasSS ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, TRUE, FALSE))\nggplot(temp, aes(x = hasSS, y = diff_dTAG_DMSO)) + geom_violin(aes(fill = hasSS), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = hasSS), fun = mean, \n               geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme_classic() +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\) +\n  ggtitle(\\PE-PE\\) + geom_hline(yintercept = 0)\n\n\n# Counting loop types\nallLoopsAnnotatedFiltered <- allLoopsAnnotated %>% dplyr::filter(!is.na(loopID2)) %>%\n  dplyr::filter(!(loopID == loopID2))\ntemp <- allLoopsAnnotatedFiltered %>% dplyr::select(loopID2, Anno2)\nresult <- temp %>%\n  group_by(loopID2, Anno2) %>%\n  summarise(count = n(), .groups = 'drop') %>%\n  group_by(loopID2) %>%\n  mutate(frequency = count / sum(count)) %>%\n  arrange(loopID2, Anno2)\n\nresult <- largest_loops %>% dplyr::left_join(result, by = c(\\loopID\\ = \\loopID2\\))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(result, by = c(\\gene\\))\ndata <- data %>% filter(complete.cases(.))\n\nall_anno2 <- unique(data$Anno2)\n\n# Calculate average frequency of Anno2 for each gene in each group\nresult <- data %>%\n  # Ensure all possible Anno2 values are present for each gene and group\n  complete(gene, Anno2 = all_anno2, fill = list(frequency = 0)) %>% \n  dplyr::mutate(group = case_when(\n    gene %in% gene.group1 ~ \\group1\\,\n    gene %in% gene.group2 ~ \\group2\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::select(group, Anno2, frequency)\n  \n\nggplot(result, aes(x = Anno2, fill = group, y = frequency)) + geom_boxplot()\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG4jIElNUE9SVCBTLVMgbG9vcHNcbmFsbExvb3BzIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHkudHN2XFwpKVxuc3RyTG9vcHMgPC0gYWxsTG9vcHMgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUy1TXFwpKVxudGVtcCA8LSBzdHJMb29wcyAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDYpKVxuY29sbmFtZXModGVtcCkgPC0gYyhcXGNocm9tXFwsIFxcc3RhcnRcXCwgXFxlbmRcXClcbnN0ckxvb3BzR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKHRlbXApXG5cbiMgSU1QT1JUIFRTU1xuZmxhbmtTaXplIDwtIDEwXG5nZW5lLnRiIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXG1tMTBfR1JDbTM4LnA2X2dlbmVfc29ydGVkLmJlZFxcKSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoVFNTID0gaWZlbHNlKFY0ID09IFxcK1xcLCBWMiwgVjMpLFxuICAgICAgICAgICAgICAgIFRTU3N0YXJ0ID0gVFNTIC0gZmxhbmtTaXplLFxuICAgICAgICAgICAgICAgIFRTU2VuZCA9IFRTUyArIGZsYW5rU2l6ZSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoVjEsIFRTU3N0YXJ0LCBUU1NlbmQsIFY2LCBWNSlcbmNvbG5hbWVzKGdlbmUudGIpIDwtIGMoXFxjaHJvbVxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwsIFxcZW5zZW1ibFxcLCBcXGdlbmVcXClcbmdlbmVHciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZ2VuZS50Yiwga2VlcC5leHRyYS5jb2x1bW5zID0gVFJVRSlcblxuXG4jIEZpbmQgb3ZlcmxhcHMgYmV0d2VlbiBsb29wcyBhbmQgVFNTXG5vdmVybGFwcyA8LSBmaW5kT3ZlcmxhcHMoZ2VuZUdyLCBzdHJMb29wc0dyKVxuXG4jIEFubm90YXRlIG92ZXJsYXBzXG50c3Nfd2l0aF9sb29wcyA8LSBnZW5lR3JbcXVlcnlIaXRzKG92ZXJsYXBzKV1cbmxvb3BzX3dpdGhfdHNzIDwtIHN0ckxvb3BzR3Jbc3ViamVjdEhpdHMob3ZlcmxhcHMpXVxuXG4jIENvbWJpbmUgaW50byBhIGRhdGEgZnJhbWUgZm9yIHByb2Nlc3Npbmdcbmxvb3BfZGF0YSA8LSBkYXRhLmZyYW1lKGdlbmUgPSB0c3Nfd2l0aF9sb29wcyRlbnNlbWJsLFxuICAgICAgICAgICAgICAgICAgICAgICAgbG9vcF9jaHIgPSBzZXFuYW1lcyhsb29wc193aXRoX3RzcyksXG4gICAgICAgICAgICAgICAgICAgICAgICBsb29wX3N0YXJ0ID0gc3RhcnQobG9vcHNfd2l0aF90c3MpLFxuICAgICAgICAgICAgICAgICAgICAgICAgbG9vcF9lbmQgPSBlbmQobG9vcHNfd2l0aF90c3MpLFxuICAgICAgICAgICAgICAgICAgICAgICAgbG9vcF93aWR0aCA9IHdpZHRoKGxvb3BzX3dpdGhfdHNzKSlcblxuIyBJZGVudGlmeSB0aGUgbGFyZ2VzdCBsb29wIGZvciBlYWNoIGdlbmVcbmxhcmdlc3RfbG9vcHMgPC0gbG9vcF9kYXRhW29yZGVyKGxvb3BfZGF0YSRnZW5lLCAtbG9vcF9kYXRhJGxvb3Bfd2lkdGgpLCBdXG5sYXJnZXN0X2xvb3BzIDwtIGxhcmdlc3RfbG9vcHNbIWR1cGxpY2F0ZWQobGFyZ2VzdF9sb29wcyRnZW5lKSwgXVxubGFyZ2VzdF9sb29wcyA8LSBsYXJnZXN0X2xvb3BzICU+JSBkcGx5cjo6bXV0YXRlKGxvb3BJRCA9IHBhc3RlKGxvb3BfY2hyLCBsb29wX3N0YXJ0LCBsb29wX2VuZCwgc2VwID0gXFxfXFwpKVxubGFyZ2VzdF9sb29wcyA8LSBsYXJnZXN0X2xvb3BzW29yZGVyKGxhcmdlc3RfbG9vcHMkbG9vcF9jaHIsIGxhcmdlc3RfbG9vcHMkbG9vcF9zdGFydCksXVxucm93bmFtZXMobGFyZ2VzdF9sb29wcykgPC0gTlVMTFxuXG4jIENoZWNraW5nIHNtYWxsZXIgbG9vcHNcbmFsbExvb3BzR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGFsbExvb3BzLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNlcW5hbWVzLmZpZWxkID0gXFxjaHJvbTFcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdGFydC5maWVsZCA9IFxcc3RhcnQxXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZW5kLmZpZWxkID0gXFxlbmQyXFwpXG5sYXJnZXN0TG9vcHNHciA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUobGFyZ2VzdF9sb29wcywgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc2VxbmFtZXMuZmllbGQgPSBcXGxvb3BfY2hyXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHN0YXJ0LmZpZWxkID0gXFxsb29wX3N0YXJ0XFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZC5maWVsZCA9IFxcbG9vcF9lbmRcXClcbmxhcmdlc3RMb29wc0dyIDwtIHNvcnQodW5pcXVlKGxhcmdlc3RMb29wc0dyKSlcbmNvbXBsZXRlX292ZXJsYXBzIDwtIHN1YnNldEJ5T3ZlcmxhcHMoYWxsTG9vcHNHciwgbGFyZ2VzdExvb3BzR3IsIHR5cGUgPSBcXHdpdGhpblxcKVxub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGNvbXBsZXRlX292ZXJsYXBzLCBsYXJnZXN0TG9vcHNHcilcblxuXG5jb21wbGV0ZU92ZXJsYXBEZiA8LSBhcy5kYXRhLmZyYW1lKGNvbXBsZXRlX292ZXJsYXBzKSAlPiUgZHBseXI6Om11dGF0ZShsb29wSURBbGwgPSBwYXN0ZShzZXFuYW1lcywgc3RhcnQsIGVuZCwgc2VwID0gXFxfXFwpKVxubGFyZ2VzdExvb3BzRGYgPC0gYXMuZGF0YS5mcmFtZShsYXJnZXN0TG9vcHNHcikgJT4lIGRwbHlyOjptdXRhdGUobG9vcElEID0gcGFzdGUoc2VxbmFtZXMsIHN0YXJ0LCBlbmQsIHNlcCA9IFxcX1xcKSlcblxubG9vcElEcGFpcnMgPC0gZGF0YS5mcmFtZShsb29wSUQgPSBjb21wbGV0ZU92ZXJsYXBEZiRsb29wSURBbGxbcXVlcnlIaXRzKG92ZXJsYXBzKV0sXG4gICAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BJRDIgPSBsYXJnZXN0TG9vcHNEZiRsb29wSURbc3ViamVjdEhpdHMob3ZlcmxhcHMpXSlcblxuYWxsTG9vcHNBbm5vdGF0ZWQgPC0gYWxsTG9vcHMgJT4lIGRwbHlyOjptdXRhdGUobG9vcElEID0gcGFzdGUoY2hyb20xLCBzdGFydDEsIGVuZDIsIHNlcCA9IFxcX1xcKSkgJT4lIGRwbHlyOjpsZWZ0X2pvaW4obG9vcElEcGFpcnMsIGJ5ID0gYyhcXGxvb3BJRFxcKSlcblxudGVtcCA8LSBhbGxMb29wc0Fubm90YXRlZCAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxQLUVcXCwgXFxQLVBcXCwgXFxFLUVcXCkpICU+JSBkcGx5cjo6bXV0YXRlKGhhc1NTID0gIWlzLm5hKGxvb3BJRDIpKVxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihoYXNTUyA9PWdyb3VwMSkgKSRkaWZmX2RUQUdfRE1TT1xuICBkaXN0YW5jZTIgPC0gKGRhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoaGFzU1MgPT1ncm91cDIpICkkZGlmZl9kVEFHX0RNU09cbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5wdiA8LSBjb252UHZhbHVlKGdldFB2YWxXaWxjb3godGVtcCwgVFJVRSwgRkFMU0UpKVxuZ2dwbG90KHRlbXAsIGFlcyh4ID0gaGFzU1MsIHkgPSBkaWZmX2RUQUdfRE1TTykpICsgZ2VvbV92aW9saW4oYWVzKGZpbGwgPSBoYXNTUyksIHNob3cubGVnZW5kID0gRkFMU0UpICsgXG4gIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuMSwgb3V0bGllci5zaGFwZSA9IE5BKSArXG4gIHN0YXRfc3VtbWFyeShhZXMoZ3JvdXAgPSBoYXNTUyksIGZ1biA9IG1lYW4sIFxuICAgICAgICAgICAgICAgZ2VvbSA9IFxccG9pbnRcXCwgc2hhcGUgPSAyMSwgc2l6ZSA9IDIsIGZpbGwgPSBcXHJlZFxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICB0aGVtZV9jbGFzc2ljKCkgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHB2LCBzaXplID0gNSwgY29sb3IgPSBcXGJsYWNrXFwpICtcbiAgZ2d0aXRsZShcXFBFLVBFXFwpICsgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMClcblxuXG4jIENvdW50aW5nIGxvb3AgdHlwZXNcbmFsbExvb3BzQW5ub3RhdGVkRmlsdGVyZWQgPC0gYWxsTG9vcHNBbm5vdGF0ZWQgJT4lIGRwbHlyOjpmaWx0ZXIoIWlzLm5hKGxvb3BJRDIpKSAlPiVcbiAgZHBseXI6OmZpbHRlcighKGxvb3BJRCA9PSBsb29wSUQyKSlcbnRlbXAgPC0gYWxsTG9vcHNBbm5vdGF0ZWRGaWx0ZXJlZCAlPiUgZHBseXI6OnNlbGVjdChsb29wSUQyLCBBbm5vMilcbnJlc3VsdCA8LSB0ZW1wICU+JVxuICBncm91cF9ieShsb29wSUQyLCBBbm5vMikgJT4lXG4gIHN1bW1hcmlzZShjb3VudCA9IG4oKSwgLmdyb3VwcyA9ICdkcm9wJykgJT4lXG4gIGdyb3VwX2J5KGxvb3BJRDIpICU+JVxuICBtdXRhdGUoZnJlcXVlbmN5ID0gY291bnQgLyBzdW0oY291bnQpKSAlPiVcbiAgYXJyYW5nZShsb29wSUQyLCBBbm5vMilcblxucmVzdWx0IDwtIGxhcmdlc3RfbG9vcHMgJT4lIGRwbHlyOjpsZWZ0X2pvaW4ocmVzdWx0LCBieSA9IGMoXFxsb29wSURcXCA9IFxcbG9vcElEMlxcKSlcblxuZ2VuZS5ncm91cDEgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMS50c3ZcXCkpJGdlbmVcbmdlbmUuZ3JvdXAyIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDIudHN2XFwpKSRnZW5lXG5cbmRhdGEgPC0gdGliYmxlKFxuICBnZW5lID0gYyhnZW5lLmdyb3VwMSwgZ2VuZS5ncm91cDIpLFxuICBncm91cCA9IGMocmVwKFxcZ3JvdXAxXFwsIGxlbmd0aChnZW5lLmdyb3VwMSkpLFxuICAgICAgICAgICAgcmVwKFxcZ3JvdXAyXFwsIGxlbmd0aChnZW5lLmdyb3VwMikpKVxuKVxuXG5kYXRhIDwtIGRhdGEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4ocmVzdWx0LCBieSA9IGMoXFxnZW5lXFwpKVxuZGF0YSA8LSBkYXRhICU+JSBmaWx0ZXIoY29tcGxldGUuY2FzZXMoLikpXG5cbmFsbF9hbm5vMiA8LSB1bmlxdWUoZGF0YSRBbm5vMilcblxuIyBDYWxjdWxhdGUgYXZlcmFnZSBmcmVxdWVuY3kgb2YgQW5ubzIgZm9yIGVhY2ggZ2VuZSBpbiBlYWNoIGdyb3VwXG5yZXN1bHQgPC0gZGF0YSAlPiVcbiAgIyBFbnN1cmUgYWxsIHBvc3NpYmxlIEFubm8yIHZhbHVlcyBhcmUgcHJlc2VudCBmb3IgZWFjaCBnZW5lIGFuZCBncm91cFxuICBjb21wbGV0ZShnZW5lLCBBbm5vMiA9IGFsbF9hbm5vMiwgZmlsbCA9IGxpc3QoZnJlcXVlbmN5ID0gMCkpICU+JSBcbiAgZHBseXI6Om11dGF0ZShncm91cCA9IGNhc2Vfd2hlbihcbiAgICBnZW5lICVpbiUgZ2VuZS5ncm91cDEgfiBcXGdyb3VwMVxcLFxuICAgIGdlbmUgJWluJSBnZW5lLmdyb3VwMiB+IFxcZ3JvdXAyXFwsXG4gICAgVFJVRSB+IE5BXG4gICkpICU+JVxuICBkcGx5cjo6c2VsZWN0KGdyb3VwLCBBbm5vMiwgZnJlcXVlbmN5KVxuICBcblxuZ2dwbG90KHJlc3VsdCwgYWVzKHggPSBBbm5vMiwgZmlsbCA9IGdyb3VwLCB5ID0gZnJlcXVlbmN5KSkgKyBnZW9tX2JveHBsb3QoKVxuXG5gYGBcbmBgYCJ9 -->

```r
```r
name <- \chromo_cons_annoHierarchy\

# IMPORT S-S loops
allLoops <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\))
strLoops <- allLoops %>% dplyr::filter(Anno2 %in% c(\S-S\))
temp <- strLoops %>% dplyr::select(c(1, 2, 6))
colnames(temp) <- c(\chrom\, \start\, \end\)
strLoopsGr <- makeGRangesFromDataFrame(temp)

# IMPORT TSS
flankSize <- 10
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c(\chrom\, \start\, \end\, \ensembl\, \gene\)
geneGr <- makeGRangesFromDataFrame(gene.tb, keep.extra.columns = TRUE)


# Find overlaps between loops and TSS
overlaps <- findOverlaps(geneGr, strLoopsGr)

# Annotate overlaps
tss_with_loops <- geneGr[queryHits(overlaps)]
loops_with_tss <- strLoopsGr[subjectHits(overlaps)]

# Combine into a data frame for processing
loop_data <- data.frame(gene = tss_with_loops$ensembl,
                        loop_chr = seqnames(loops_with_tss),
                        loop_start = start(loops_with_tss),
                        loop_end = end(loops_with_tss),
                        loop_width = width(loops_with_tss))

# Identify the largest loop for each gene
largest_loops <- loop_data[order(loop_data$gene, -loop_data$loop_width), ]
largest_loops <- largest_loops[!duplicated(largest_loops$gene), ]
largest_loops <- largest_loops %>% dplyr::mutate(loopID = paste(loop_chr, loop_start, loop_end, sep = \_\))
largest_loops <- largest_loops[order(largest_loops$loop_chr, largest_loops$loop_start),]
rownames(largest_loops) <- NULL

# Checking smaller loops
allLoopsGr <- makeGRangesFromDataFrame(allLoops, 
                                       seqnames.field = \chrom1\, 
                                       start.field = \start1\, 
                                       end.field = \end2\)
largestLoopsGr <- makeGRangesFromDataFrame(largest_loops, 
                                           seqnames.field = \loop_chr\, 
                                           start.field = \loop_start\, 
                                           end.field = \loop_end\)
largestLoopsGr <- sort(unique(largestLoopsGr))
complete_overlaps <- subsetByOverlaps(allLoopsGr, largestLoopsGr, type = \within\)
overlaps <- findOverlaps(complete_overlaps, largestLoopsGr)


completeOverlapDf <- as.data.frame(complete_overlaps) %>% dplyr::mutate(loopIDAll = paste(seqnames, start, end, sep = \_\))
largestLoopsDf <- as.data.frame(largestLoopsGr) %>% dplyr::mutate(loopID = paste(seqnames, start, end, sep = \_\))

loopIDpairs <- data.frame(loopID = completeOverlapDf$loopIDAll[queryHits(overlaps)],
                          loopID2 = largestLoopsDf$loopID[subjectHits(overlaps)])

allLoopsAnnotated <- allLoops %>% dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \_\)) %>% dplyr::left_join(loopIDpairs, by = c(\loopID\))

temp <- allLoopsAnnotated %>% dplyr::filter(Anno2 %in% c(\P-E\, \P-P\, \E-E\)) %>% dplyr::mutate(hasSS = !is.na(loopID2))
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(hasSS ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(hasSS ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
pv <- convPvalue(getPvalWilcox(temp, TRUE, FALSE))
ggplot(temp, aes(x = hasSS, y = diff_dTAG_DMSO)) + geom_violin(aes(fill = hasSS), show.legend = FALSE) + 
  geom_boxplot(width = 0.1, outlier.shape = NA) +
  stat_summary(aes(group = hasSS), fun = mean, 
               geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  theme_classic() +
  annotate(\text\, x = 1, y = 0, label = pv, size = 5, color = \black\) +
  ggtitle(\PE-PE\) + geom_hline(yintercept = 0)


# Counting loop types
allLoopsAnnotatedFiltered <- allLoopsAnnotated %>% dplyr::filter(!is.na(loopID2)) %>%
  dplyr::filter(!(loopID == loopID2))
temp <- allLoopsAnnotatedFiltered %>% dplyr::select(loopID2, Anno2)
result <- temp %>%
  group_by(loopID2, Anno2) %>%
  summarise(count = n(), .groups = 'drop') %>%
  group_by(loopID2) %>%
  mutate(frequency = count / sum(count)) %>%
  arrange(loopID2, Anno2)

result <- largest_loops %>% dplyr::left_join(result, by = c(\loopID\ = \loopID2\))

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep(\group1\, length(gene.group1)),
            rep(\group2\, length(gene.group2)))
)

data <- data %>% dplyr::left_join(result, by = c(\gene\))
data <- data %>% filter(complete.cases(.))

all_anno2 <- unique(data$Anno2)

# Calculate average frequency of Anno2 for each gene in each group
result <- data %>%
  # Ensure all possible Anno2 values are present for each gene and group
  complete(gene, Anno2 = all_anno2, fill = list(frequency = 0)) %>% 
  dplyr::mutate(group = case_when(
    gene %in% gene.group1 ~ \group1\,
    gene %in% gene.group2 ~ \group2\,
    TRUE ~ NA
  )) %>%
  dplyr::select(group, Anno2, frequency)
  

ggplot(result, aes(x = Anno2, fill = group, y = frequency)) + geom_boxplot()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


###[3.39] Splitting bedpe

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBWaWV3IHJlc3VsdHNcbmdncGxvdChsYXJnZXN0X2xvb3BzLCBhZXMoeCA9IGxvb3Bfd2lkdGgpKSArIGdlb21faGlzdG9ncmFtKClcblxuXG4jIyMgQ2hlY2tpbmcgaG93IG1hbnkgZ2VuZXMgZnJvbSBlYWNoIGdyb3VwIGhhcyBlbmNvbXBhc3NpbmcgUy1TXG5nZW5lLmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlwiKSkkZ2VuZVxuZ2VuZS5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcIikpJGdlbmVcblxuZGF0YSA8LSB0aWJibGUoXG4gIGdlbmUgPSBjKGdlbmUuZ3JvdXAxLCBnZW5lLmdyb3VwMiksXG4gIGdyb3VwID0gYyhyZXAoXCJncm91cDFcIiwgbGVuZ3RoKGdlbmUuZ3JvdXAxKSksXG4gICAgICAgICAgICByZXAoXCJncm91cDJcIiwgbGVuZ3RoKGdlbmUuZ3JvdXAyKSkpXG4pXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihsYXJnZXN0X2xvb3BzLCBieSA9IGMoXCJnZW5lXCIpKVxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKFxuICBoYXNTUyA9IGlmZWxzZShpcy5uYShsb29wX3dpZHRoKSwgXCJOT1wiLCBcIllFU1wiKVxuKVxuXG5kYXRhX3N1bW1hcnkgPC0gZGF0YSAlPiVcbiAgZ3JvdXBfYnkoZ3JvdXApICU+JVxuICBzdW1tYXJpemUoXG4gICAgdG90YWwgPSBuKCksXG4gICAgaGFzU1NfeWVzID0gc3VtKGhhc1NTID09IFwiWUVTXCIpLFxuICAgIHBlcmNlbnRhZ2VfeWVzID0gKGhhc1NTX3llcyAvIHRvdGFsKSAqIDEwMFxuICApXG5cbmdncGxvdChkYXRhX3N1bW1hcnksIGFlcyh4ID0gZ3JvdXAsIHkgPSBwZXJjZW50YWdlX3llcywgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JhcihzdGF0ID0gXCJpZGVudGl0eVwiLCBjb2xvciA9IFwiYmxhY2tcIikgK1xuICBsYWJzKFxuICAgIHRpdGxlID0gXCJQZXJjZW50YWdlIG9mIEVhY2ggR3JvdXAgd2l0aCBoYXNTUyA9IFlFU1wiLFxuICAgIHggPSBcIkdyb3VwXCIsXG4gICAgeSA9IFwiUGVyY2VudGFnZSAoJSlcIlxuICApICsgeWxpbSgwLCAxMDApICtcbiAgdGhlbWVfbWluaW1hbCgpXG5cblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGhhc1NTID09IFwiWUVTXCIpXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJGxvb3Bfd2lkdGhcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJGxvb3Bfd2lkdGhcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5wdiA8LSBjb252UHZhbHVlKGdldFB2YWxXaWxjb3godGVtcCwgXCJncm91cDFcIiwgXCJncm91cDJcIikpXG5cbmdncGxvdCh0ZW1wLCBhZXMoeCA9IGdyb3VwLCB5ID0gbG9vcF93aWR0aCkpICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSkgK1xuICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHB2LCBzaXplID0gNSwgY29sb3IgPSBcImJsYWNrXCIpXG5cbiMjIyBDb21wYXJpbmcgUk5BIHBlcnR1cmJhdGlvblxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlwiKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoYygxLCA0LCA1KSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoaGFzU1MgPSBpZmVsc2UoZW5zZW1ibF9nZW5lX2lkICVpbiUgbGFyZ2VzdF9sb29wcyRnZW5lLCBcImhhc1NTXCIsIFwibm9TU1wiKSlcblxuXG5nZ3Bsb3QoZGlmZi5STkEsIGFlcyh4ID0gYWJzKGxvZzJGb2xkQ2hhbmdlKSwgY29sb3IgPSBoYXNTUykpICtcbiAgc3RhdF9lY2RmKHNpemUgPSAwLjQpICtcbiAgbGFicyhcbiAgICB4ID0gXCJBYnNvbHV0ZSBsb2cyKGZvbGQgY2hhbmdlKVwiLFxuICAgIHkgPSBcIkN1bXVsYXRpdmUgUHJvYmFiaWxpdHlcIlxuICApICsgY29vcmRfY2FydGVzaWFuKHhsaW0gPSBjKDAsIDEuNSkpICtcbiAgdGhlbWVfY2xhc3NpYygpICsgIyBDbGVhbiB0aGVtZVxuICB0aGVtZShcbiAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCIsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcInNxdWFyZVwiXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIixcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFwidHJhbnNwYXJlbnRcIiksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgICApXG5cblxuIyMjIENoZWNraW5nIENoSVAgcGVhayBkZW5zaXR5XG5sYXJnZXN0X2xvb3BzR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGxhcmdlc3RfbG9vcHMsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzZXFuYW1lcy5maWVsZCA9IFwibG9vcF9jaHJcIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHN0YXJ0LmZpZWxkID0gXCJsb29wX3N0YXJ0XCIsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmQuZmllbGQgPSBcImxvb3BfZW5kXCIsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFKVxuXG4jIEZpbmQgb3ZlcmxhcHMgYmV0d2VlbiBDaElQLXNlcSBwZWFrcyBhbmQgdGhlIGxhcmdlc3QgbG9vcHNcbmNoaXBfb3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGxhcmdlc3RfbG9vcHNHciwgcGVhay5DVENGKVxuXG4jIENvdW50IHRoZSBudW1iZXIgb2YgQ2hJUC1zZXEgcGVha3MgcGVyIGxvb3Bcbmxvb3BfcGVha19jb3VudHMgPC0gdGFibGUocXVlcnlIaXRzKGNoaXBfb3ZlcmxhcHMpKVxuXG4jIENyZWF0ZSBhIGRhdGEgZnJhbWUgd2l0aCB0aGUgY291bnRzIGFuZCBsb29wIGRldGFpbHNcbmxhcmdlc3RfbG9vcHMkZGVuc2l0eSA8LSAwICAjIEluaXRpYWxpemUgZGVuc2l0eSBjb2x1bW5cbmxhcmdlc3RfbG9vcHMkY291bnQgPC0gMCAgICAjIEluaXRpYWxpemUgcGVhayBjb3VudCBjb2x1bW5cblxuIyBBZGQgcGVhayBjb3VudHMgdG8gdGhlIGNvcnJlc3BvbmRpbmcgbG9vcHNcbmxhcmdlc3RfbG9vcHNbYXMubnVtZXJpYyhuYW1lcyhsb29wX3BlYWtfY291bnRzKSksIFwiY291bnRcIl0gPC0gYXMuaW50ZWdlcihsb29wX3BlYWtfY291bnRzKVxuXG4jIENhbGN1bGF0ZSB0aGUgZGVuc2l0eSAocGVha3MgcGVyIGtpbG9iYXNlKVxubGFyZ2VzdF9sb29wcyRkZW5zaXR5IDwtIGxhcmdlc3RfbG9vcHMkY291bnQgLyAoKGxhcmdlc3RfbG9vcHMkbG9vcF93aWR0aC0xKSAvIDEwMDApXG5cblxuZGF0YSA8LSB0aWJibGUoXG4gIGdlbmUgPSBjKGdlbmUuZ3JvdXAxLCBnZW5lLmdyb3VwMiksXG4gIGdyb3VwID0gYyhyZXAoXCJncm91cDFcIiwgbGVuZ3RoKGdlbmUuZ3JvdXAxKSksXG4gICAgICAgICAgICByZXAoXCJncm91cDJcIiwgbGVuZ3RoKGdlbmUuZ3JvdXAyKSkpXG4pXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihsYXJnZXN0X2xvb3BzLCBieSA9IGMoXCJnZW5lXCIpKVxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKFxuICBoYXNTUyA9IGlmZWxzZShpcy5uYShsb29wX3dpZHRoKSwgXCJOT1wiLCBcIllFU1wiKVxuKSAlPiUgZHBseXI6OmZpbHRlcihoYXNTUyA9PSBcIllFU1wiKVxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJGRlbnNpdHlcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJGRlbnNpdHlcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnB2IDwtIGNvbnZQdmFsdWUoZ2V0UHZhbFdpbGNveChkYXRhLCBcImdyb3VwMVwiLCBcImdyb3VwMlwiKSlcblxuZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBkZW5zaXR5KSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgXG4gICAgICAgICAgICAgICBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFwicmVkXCIsIGNvbG9yID0gXCJibGFja1wiKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArXG4gIGFubm90YXRlKFwidGV4dFwiLCB4ID0gMSwgeSA9IDAsIGxhYmVsID0gcHYsIHNpemUgPSA1LCBjb2xvciA9IFwiYmxhY2tcIikgK1xuICBnZ3RpdGxlKFwiQ1RDRlwiKVxuXG5cbmBgYCJ9 -->\n\n```r\n# View results\nggplot(largest_loops, aes(x = loop_width)) + geom_histogram()\n\n\n### Checking how many genes from each group has encompassing S-S\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\\gene\\))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \\NO\\, \\YES\\)\n)\n\ndata_summary <- data %>%\n  group_by(group) %>%\n  summarize(\n    total = n(),\n    hasSS_yes = sum(hasSS == \\YES\\),\n    percentage_yes = (hasSS_yes / total) * 100\n  )\n\nggplot(data_summary, aes(x = group, y = percentage_yes, fill = group)) +\n  geom_bar(stat = \\identity\\, color = \\black\\) +\n  labs(\n    title = \\Percentage of Each Group with hasSS = YES\\,\n    x = \\Group\\,\n    y = \\Percentage (%)\\\n  ) + ylim(0, 100) +\n  theme_minimal()\n\n\ntemp <- data %>% dplyr::filter(hasSS == \\YES\\)\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$loop_width\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$loop_width\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, \\group1\\, \\group2\\))\n\nggplot(temp, aes(x = group, y = loop_width)) + geom_violin() + geom_boxplot(width = 0.5) +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\)\n\n### Comparing RNA perturbation\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(c(1, 4, 5)) %>%\n  dplyr::mutate(hasSS = ifelse(ensembl_gene_id %in% largest_loops$gene, \\hasSS\\, \\noSS\\))\n\n\nggplot(diff.RNA, aes(x = abs(log2FoldChange), color = hasSS)) +\n  stat_ecdf(size = 0.4) +\n  labs(\n    x = \\Absolute log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\n\n### Checking ChIP peak density\nlargest_loopsGr <- makeGRangesFromDataFrame(largest_loops, \n                                            seqnames.field = \\loop_chr\\, \n                                            start.field = \\loop_start\\, \n                                            end.field = \\loop_end\\, \n                                            keep.extra.columns = TRUE)\n\n# Find overlaps between ChIP-seq peaks and the largest loops\nchip_overlaps <- findOverlaps(largest_loopsGr, peak.CTCF)\n\n# Count the number of ChIP-seq peaks per loop\nloop_peak_counts <- table(queryHits(chip_overlaps))\n\n# Create a data frame with the counts and loop details\nlargest_loops$density <- 0  # Initialize density column\nlargest_loops$count <- 0    # Initialize peak count column\n\n# Add peak counts to the corresponding loops\nlargest_loops[as.numeric(names(loop_peak_counts)), \\count\\] <- as.integer(loop_peak_counts)\n\n# Calculate the density (peaks per kilobase)\nlargest_loops$density <- largest_loops$count / ((largest_loops$loop_width-1) / 1000)\n\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\\gene\\))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \\NO\\, \\YES\\)\n) %>% dplyr::filter(hasSS == \\YES\\)\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$density\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$density\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\npv <- convPvalue(getPvalWilcox(data, \\group1\\, \\group2\\))\n\nggplot(data, aes(x = group, y = density)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = group), fun = mean, \n               geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme_classic() +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\) +\n  ggtitle(\\CTCF\\)\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
# View results
ggplot(largest_loops, aes(x = loop_width)) + geom_histogram()


### Checking how many genes from each group has encompassing S-S
gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep(\group1\, length(gene.group1)),
            rep(\group2\, length(gene.group2)))
)

data <- data %>% dplyr::left_join(largest_loops, by = c(\gene\))
data <- data %>% dplyr::mutate(
  hasSS = ifelse(is.na(loop_width), \NO\, \YES\)
)

data_summary <- data %>%
  group_by(group) %>%
  summarize(
    total = n(),
    hasSS_yes = sum(hasSS == \YES\),
    percentage_yes = (hasSS_yes / total) * 100
  )

ggplot(data_summary, aes(x = group, y = percentage_yes, fill = group)) +
  geom_bar(stat = \identity\, color = \black\) +
  labs(
    title = \Percentage of Each Group with hasSS = YES\,
    x = \Group\,
    y = \Percentage (%)\
  ) + ylim(0, 100) +
  theme_minimal()


temp <- data %>% dplyr::filter(hasSS == \YES\)
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$loop_width
  distance2 <- (data %>% dplyr::filter(group ==group2) )$loop_width
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
pv <- convPvalue(getPvalWilcox(temp, \group1\, \group2\))

ggplot(temp, aes(x = group, y = loop_width)) + geom_violin() + geom_boxplot(width = 0.5) +
  annotate(\text\, x = 1, y = 0, label = pv, size = 5, color = \black\)

### Comparing RNA perturbation

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(c(1, 4, 5)) %>%
  dplyr::mutate(hasSS = ifelse(ensembl_gene_id %in% largest_loops$gene, \hasSS\, \noSS\))


ggplot(diff.RNA, aes(x = abs(log2FoldChange), color = hasSS)) +
  stat_ecdf(size = 0.4) +
  labs(
    x = \Absolute log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )


### Checking ChIP peak density
largest_loopsGr <- makeGRangesFromDataFrame(largest_loops, 
                                            seqnames.field = \loop_chr\, 
                                            start.field = \loop_start\, 
                                            end.field = \loop_end\, 
                                            keep.extra.columns = TRUE)

# Find overlaps between ChIP-seq peaks and the largest loops
chip_overlaps <- findOverlaps(largest_loopsGr, peak.CTCF)

# Count the number of ChIP-seq peaks per loop
loop_peak_counts <- table(queryHits(chip_overlaps))

# Create a data frame with the counts and loop details
largest_loops$density <- 0  # Initialize density column
largest_loops$count <- 0    # Initialize peak count column

# Add peak counts to the corresponding loops
largest_loops[as.numeric(names(loop_peak_counts)), \count\] <- as.integer(loop_peak_counts)

# Calculate the density (peaks per kilobase)
largest_loops$density <- largest_loops$count / ((largest_loops$loop_width-1) / 1000)


data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep(\group1\, length(gene.group1)),
            rep(\group2\, length(gene.group2)))
)

data <- data %>% dplyr::left_join(largest_loops, by = c(\gene\))
data <- data %>% dplyr::mutate(
  hasSS = ifelse(is.na(loop_width), \NO\, \YES\)
) %>% dplyr::filter(hasSS == \YES\)

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$density
  distance2 <- (data %>% dplyr::filter(group ==group2) )$density
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv <- convPvalue(getPvalWilcox(data, \group1\, \group2\))

ggplot(data, aes(x = group, y = density)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
  geom_boxplot(width = 0.1, outlier.shape = NA) +
  stat_summary(aes(group = group), fun = mean, 
               geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  theme_classic() +
  annotate(\text\, x = 1, y = 0, label = pv, size = 5, color = \black\) +
  ggtitle(\CTCF\)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBWaWV3IHJlc3VsdHNcbmdncGxvdChsYXJnZXN0X2xvb3BzLCBhZXMoeCA9IGxvb3Bfd2lkdGgpKSArIGdlb21faGlzdG9ncmFtKClcblxuXG4jIyMgQ2hlY2tpbmcgaG93IG1hbnkgZ2VuZXMgZnJvbSBlYWNoIGdyb3VwIGhhcyBlbmNvbXBhc3NpbmcgUy1TXG5nZW5lLmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlxcKSkkZ2VuZVxuZ2VuZS5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuZGF0YSA8LSB0aWJibGUoXG4gIGdlbmUgPSBjKGdlbmUuZ3JvdXAxLCBnZW5lLmdyb3VwMiksXG4gIGdyb3VwID0gYyhyZXAoXFxncm91cDFcXCwgbGVuZ3RoKGdlbmUuZ3JvdXAxKSksXG4gICAgICAgICAgICByZXAoXFxncm91cDJcXCwgbGVuZ3RoKGdlbmUuZ3JvdXAyKSkpXG4pXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihsYXJnZXN0X2xvb3BzLCBieSA9IGMoXFxnZW5lXFwpKVxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKFxuICBoYXNTUyA9IGlmZWxzZShpcy5uYShsb29wX3dpZHRoKSwgXFxOT1xcLCBcXFlFU1xcKVxuKVxuXG5kYXRhX3N1bW1hcnkgPC0gZGF0YSAlPiVcbiAgZ3JvdXBfYnkoZ3JvdXApICU+JVxuICBzdW1tYXJpemUoXG4gICAgdG90YWwgPSBuKCksXG4gICAgaGFzU1NfeWVzID0gc3VtKGhhc1NTID09IFxcWUVTXFwpLFxuICAgIHBlcmNlbnRhZ2VfeWVzID0gKGhhc1NTX3llcyAvIHRvdGFsKSAqIDEwMFxuICApXG5cbmdncGxvdChkYXRhX3N1bW1hcnksIGFlcyh4ID0gZ3JvdXAsIHkgPSBwZXJjZW50YWdlX3llcywgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JhcihzdGF0ID0gXFxpZGVudGl0eVxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBsYWJzKFxuICAgIHRpdGxlID0gXFxQZXJjZW50YWdlIG9mIEVhY2ggR3JvdXAgd2l0aCBoYXNTUyA9IFlFU1xcLFxuICAgIHggPSBcXEdyb3VwXFwsXG4gICAgeSA9IFxcUGVyY2VudGFnZSAoJSlcXFxuICApICsgeWxpbSgwLCAxMDApICtcbiAgdGhlbWVfbWluaW1hbCgpXG5cblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGhhc1NTID09IFxcWUVTXFwpXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJGxvb3Bfd2lkdGhcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJGxvb3Bfd2lkdGhcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5wdiA8LSBjb252UHZhbHVlKGdldFB2YWxXaWxjb3godGVtcCwgXFxncm91cDFcXCwgXFxncm91cDJcXCkpXG5cbmdncGxvdCh0ZW1wLCBhZXMoeCA9IGdyb3VwLCB5ID0gbG9vcF93aWR0aCkpICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSkgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHB2LCBzaXplID0gNSwgY29sb3IgPSBcXGJsYWNrXFwpXG5cbiMjIyBDb21wYXJpbmcgUk5BIHBlcnR1cmJhdGlvblxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoYygxLCA0LCA1KSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoaGFzU1MgPSBpZmVsc2UoZW5zZW1ibF9nZW5lX2lkICVpbiUgbGFyZ2VzdF9sb29wcyRnZW5lLCBcXGhhc1NTXFwsIFxcbm9TU1xcKSlcblxuXG5nZ3Bsb3QoZGlmZi5STkEsIGFlcyh4ID0gYWJzKGxvZzJGb2xkQ2hhbmdlKSwgY29sb3IgPSBoYXNTUykpICtcbiAgc3RhdF9lY2RmKHNpemUgPSAwLjQpICtcbiAgbGFicyhcbiAgICB4ID0gXFxBYnNvbHV0ZSBsb2cyKGZvbGQgY2hhbmdlKVxcLFxuICAgIHkgPSBcXEN1bXVsYXRpdmUgUHJvYmFiaWxpdHlcXFxuICApICsgY29vcmRfY2FydGVzaWFuKHhsaW0gPSBjKDAsIDEuNSkpICtcbiAgdGhlbWVfY2xhc3NpYygpICsgIyBDbGVhbiB0aGVtZVxuICB0aGVtZShcbiAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgICApXG5cblxuIyMjIENoZWNraW5nIENoSVAgcGVhayBkZW5zaXR5XG5sYXJnZXN0X2xvb3BzR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGxhcmdlc3RfbG9vcHMsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzZXFuYW1lcy5maWVsZCA9IFxcbG9vcF9jaHJcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHN0YXJ0LmZpZWxkID0gXFxsb29wX3N0YXJ0XFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmQuZmllbGQgPSBcXGxvb3BfZW5kXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFKVxuXG4jIEZpbmQgb3ZlcmxhcHMgYmV0d2VlbiBDaElQLXNlcSBwZWFrcyBhbmQgdGhlIGxhcmdlc3QgbG9vcHNcbmNoaXBfb3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGxhcmdlc3RfbG9vcHNHciwgcGVhay5DVENGKVxuXG4jIENvdW50IHRoZSBudW1iZXIgb2YgQ2hJUC1zZXEgcGVha3MgcGVyIGxvb3Bcbmxvb3BfcGVha19jb3VudHMgPC0gdGFibGUocXVlcnlIaXRzKGNoaXBfb3ZlcmxhcHMpKVxuXG4jIENyZWF0ZSBhIGRhdGEgZnJhbWUgd2l0aCB0aGUgY291bnRzIGFuZCBsb29wIGRldGFpbHNcbmxhcmdlc3RfbG9vcHMkZGVuc2l0eSA8LSAwICAjIEluaXRpYWxpemUgZGVuc2l0eSBjb2x1bW5cbmxhcmdlc3RfbG9vcHMkY291bnQgPC0gMCAgICAjIEluaXRpYWxpemUgcGVhayBjb3VudCBjb2x1bW5cblxuIyBBZGQgcGVhayBjb3VudHMgdG8gdGhlIGNvcnJlc3BvbmRpbmcgbG9vcHNcbmxhcmdlc3RfbG9vcHNbYXMubnVtZXJpYyhuYW1lcyhsb29wX3BlYWtfY291bnRzKSksIFxcY291bnRcXF0gPC0gYXMuaW50ZWdlcihsb29wX3BlYWtfY291bnRzKVxuXG4jIENhbGN1bGF0ZSB0aGUgZGVuc2l0eSAocGVha3MgcGVyIGtpbG9iYXNlKVxubGFyZ2VzdF9sb29wcyRkZW5zaXR5IDwtIGxhcmdlc3RfbG9vcHMkY291bnQgLyAoKGxhcmdlc3RfbG9vcHMkbG9vcF93aWR0aC0xKSAvIDEwMDApXG5cblxuZGF0YSA8LSB0aWJibGUoXG4gIGdlbmUgPSBjKGdlbmUuZ3JvdXAxLCBnZW5lLmdyb3VwMiksXG4gIGdyb3VwID0gYyhyZXAoXFxncm91cDFcXCwgbGVuZ3RoKGdlbmUuZ3JvdXAxKSksXG4gICAgICAgICAgICByZXAoXFxncm91cDJcXCwgbGVuZ3RoKGdlbmUuZ3JvdXAyKSkpXG4pXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihsYXJnZXN0X2xvb3BzLCBieSA9IGMoXFxnZW5lXFwpKVxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKFxuICBoYXNTUyA9IGlmZWxzZShpcy5uYShsb29wX3dpZHRoKSwgXFxOT1xcLCBcXFlFU1xcKVxuKSAlPiUgZHBseXI6OmZpbHRlcihoYXNTUyA9PSBcXFlFU1xcKVxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJGRlbnNpdHlcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJGRlbnNpdHlcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnB2IDwtIGNvbnZQdmFsdWUoZ2V0UHZhbFdpbGNveChkYXRhLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSlcblxuZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBkZW5zaXR5KSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgXG4gICAgICAgICAgICAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDAsIGxhYmVsID0gcHYsIHNpemUgPSA1LCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZ3RpdGxlKFxcQ1RDRlxcKVxuXG5cbmBgYFxuYGBgIn0= -->\n\n```r\n```r\n# View results\nggplot(largest_loops, aes(x = loop_width)) + geom_histogram()\n\n\n### Checking how many genes from each group has encompassing S-S\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\\gene\\))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \\NO\\, \\YES\\)\n)\n\ndata_summary <- data %>%\n  group_by(group) %>%\n  summarize(\n    total = n(),\n    hasSS_yes = sum(hasSS == \\YES\\),\n    percentage_yes = (hasSS_yes / total) * 100\n  )\n\nggplot(data_summary, aes(x = group, y = percentage_yes, fill = group)) +\n  geom_bar(stat = \\identity\\, color = \\black\\) +\n  labs(\n    title = \\Percentage of Each Group with hasSS = YES\\,\n    x = \\Group\\,\n    y = \\Percentage (%)\\\n  ) + ylim(0, 100) +\n  theme_minimal()\n\n\ntemp <- data %>% dplyr::filter(hasSS == \\YES\\)\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$loop_width\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$loop_width\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, \\group1\\, \\group2\\))\n\nggplot(temp, aes(x = group, y = loop_width)) + geom_violin() + geom_boxplot(width = 0.5) +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\)\n\n### Comparing RNA perturbation\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(c(1, 4, 5)) %>%\n  dplyr::mutate(hasSS = ifelse(ensembl_gene_id %in% largest_loops$gene, \\hasSS\\, \\noSS\\))\n\n\nggplot(diff.RNA, aes(x = abs(log2FoldChange), color = hasSS)) +\n  stat_ecdf(size = 0.4) +\n  labs(\n    x = \\Absolute log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\n\n### Checking ChIP peak density\nlargest_loopsGr <- makeGRangesFromDataFrame(largest_loops, \n                                            seqnames.field = \\loop_chr\\, \n                                            start.field = \\loop_start\\, \n                                            end.field = \\loop_end\\, \n                                            keep.extra.columns = TRUE)\n\n# Find overlaps between ChIP-seq peaks and the largest loops\nchip_overlaps <- findOverlaps(largest_loopsGr, peak.CTCF)\n\n# Count the number of ChIP-seq peaks per loop\nloop_peak_counts <- table(queryHits(chip_overlaps))\n\n# Create a data frame with the counts and loop details\nlargest_loops$density <- 0  # Initialize density column\nlargest_loops$count <- 0    # Initialize peak count column\n\n# Add peak counts to the corresponding loops\nlargest_loops[as.numeric(names(loop_peak_counts)), \\count\\] <- as.integer(loop_peak_counts)\n\n# Calculate the density (peaks per kilobase)\nlargest_loops$density <- largest_loops$count / ((largest_loops$loop_width-1) / 1000)\n\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\\gene\\))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \\NO\\, \\YES\\)\n) %>% dplyr::filter(hasSS == \\YES\\)\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$density\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$density\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\npv <- convPvalue(getPvalWilcox(data, \\group1\\, \\group2\\))\n\nggplot(data, aes(x = group, y = density)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = group), fun = mean, \n               geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme_classic() +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\) +\n  ggtitle(\\CTCF\\)\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBWaWV3IHJlc3VsdHNcbmdncGxvdChsYXJnZXN0X2xvb3BzLCBhZXMoeCA9IGxvb3Bfd2lkdGgpKSArIGdlb21faGlzdG9ncmFtKClcblxuXG4jIyMgQ2hlY2tpbmcgaG93IG1hbnkgZ2VuZXMgZnJvbSBlYWNoIGdyb3VwIGhhcyBlbmNvbXBhc3NpbmcgUy1TXG5nZW5lLmdyb3VwMSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxnZW5lTGlzdF9kVEFHX3ZzX0RNU09fUk5BX2xvb3BfYmluYXJ5R3JvdXAxLnRzdlxcKSkkZ2VuZVxuZ2VuZS5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuZGF0YSA8LSB0aWJibGUoXG4gIGdlbmUgPSBjKGdlbmUuZ3JvdXAxLCBnZW5lLmdyb3VwMiksXG4gIGdyb3VwID0gYyhyZXAoXFxncm91cDFcXCwgbGVuZ3RoKGdlbmUuZ3JvdXAxKSksXG4gICAgICAgICAgICByZXAoXFxncm91cDJcXCwgbGVuZ3RoKGdlbmUuZ3JvdXAyKSkpXG4pXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihsYXJnZXN0X2xvb3BzLCBieSA9IGMoXFxnZW5lXFwpKVxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKFxuICBoYXNTUyA9IGlmZWxzZShpcy5uYShsb29wX3dpZHRoKSwgXFxOT1xcLCBcXFlFU1xcKVxuKVxuXG5kYXRhX3N1bW1hcnkgPC0gZGF0YSAlPiVcbiAgZ3JvdXBfYnkoZ3JvdXApICU+JVxuICBzdW1tYXJpemUoXG4gICAgdG90YWwgPSBuKCksXG4gICAgaGFzU1NfeWVzID0gc3VtKGhhc1NTID09IFxcWUVTXFwpLFxuICAgIHBlcmNlbnRhZ2VfeWVzID0gKGhhc1NTX3llcyAvIHRvdGFsKSAqIDEwMFxuICApXG5cbmdncGxvdChkYXRhX3N1bW1hcnksIGFlcyh4ID0gZ3JvdXAsIHkgPSBwZXJjZW50YWdlX3llcywgZmlsbCA9IGdyb3VwKSkgK1xuICBnZW9tX2JhcihzdGF0ID0gXFxpZGVudGl0eVxcLCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBsYWJzKFxuICAgIHRpdGxlID0gXFxQZXJjZW50YWdlIG9mIEVhY2ggR3JvdXAgd2l0aCBoYXNTUyA9IFlFU1xcLFxuICAgIHggPSBcXEdyb3VwXFwsXG4gICAgeSA9IFxcUGVyY2VudGFnZSAoJSlcXFxuICApICsgeWxpbSgwLCAxMDApICtcbiAgdGhlbWVfbWluaW1hbCgpXG5cblxudGVtcCA8LSBkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGhhc1NTID09IFxcWUVTXFwpXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJGxvb3Bfd2lkdGhcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJGxvb3Bfd2lkdGhcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5wdiA8LSBjb252UHZhbHVlKGdldFB2YWxXaWxjb3godGVtcCwgXFxncm91cDFcXCwgXFxncm91cDJcXCkpXG5cbmdncGxvdCh0ZW1wLCBhZXMoeCA9IGdyb3VwLCB5ID0gbG9vcF93aWR0aCkpICsgZ2VvbV92aW9saW4oKSArIGdlb21fYm94cGxvdCh3aWR0aCA9IDAuNSkgK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHB2LCBzaXplID0gNSwgY29sb3IgPSBcXGJsYWNrXFwpXG5cbiMjIyBDb21wYXJpbmcgUk5BIHBlcnR1cmJhdGlvblxuXG5kaWZmLlJOQSA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxkaWZmX0cxLmRUQUdfRzEuMmkuZFRBR192c19HMS4yaS5ETVNPLnRzdlxcKSkgJT4lXG4gIGRwbHlyOjpzZWxlY3QoYygxLCA0LCA1KSkgJT4lXG4gIGRwbHlyOjptdXRhdGUoaGFzU1MgPSBpZmVsc2UoZW5zZW1ibF9nZW5lX2lkICVpbiUgbGFyZ2VzdF9sb29wcyRnZW5lLCBcXGhhc1NTXFwsIFxcbm9TU1xcKSlcblxuXG5nZ3Bsb3QoZGlmZi5STkEsIGFlcyh4ID0gYWJzKGxvZzJGb2xkQ2hhbmdlKSwgY29sb3IgPSBoYXNTUykpICtcbiAgc3RhdF9lY2RmKHNpemUgPSAwLjQpICtcbiAgbGFicyhcbiAgICB4ID0gXFxBYnNvbHV0ZSBsb2cyKGZvbGQgY2hhbmdlKVxcLFxuICAgIHkgPSBcXEN1bXVsYXRpdmUgUHJvYmFiaWxpdHlcXFxuICApICsgY29vcmRfY2FydGVzaWFuKHhsaW0gPSBjKDAsIDEuNSkpICtcbiAgdGhlbWVfY2xhc3NpYygpICsgIyBDbGVhbiB0aGVtZVxuICB0aGVtZShcbiAgICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMudGV4dCA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sXG4gICAgICBmYW1pbHkgPSBmb250VHlwZSxcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgICApXG5cblxuIyMjIENoZWNraW5nIENoSVAgcGVhayBkZW5zaXR5XG5sYXJnZXN0X2xvb3BzR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGxhcmdlc3RfbG9vcHMsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzZXFuYW1lcy5maWVsZCA9IFxcbG9vcF9jaHJcXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHN0YXJ0LmZpZWxkID0gXFxsb29wX3N0YXJ0XFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmQuZmllbGQgPSBcXGxvb3BfZW5kXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFKVxuXG4jIEZpbmQgb3ZlcmxhcHMgYmV0d2VlbiBDaElQLXNlcSBwZWFrcyBhbmQgdGhlIGxhcmdlc3QgbG9vcHNcbmNoaXBfb3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGxhcmdlc3RfbG9vcHNHciwgcGVhay5DVENGKVxuXG4jIENvdW50IHRoZSBudW1iZXIgb2YgQ2hJUC1zZXEgcGVha3MgcGVyIGxvb3Bcbmxvb3BfcGVha19jb3VudHMgPC0gdGFibGUocXVlcnlIaXRzKGNoaXBfb3ZlcmxhcHMpKVxuXG4jIENyZWF0ZSBhIGRhdGEgZnJhbWUgd2l0aCB0aGUgY291bnRzIGFuZCBsb29wIGRldGFpbHNcbmxhcmdlc3RfbG9vcHMkZGVuc2l0eSA8LSAwICAjIEluaXRpYWxpemUgZGVuc2l0eSBjb2x1bW5cbmxhcmdlc3RfbG9vcHMkY291bnQgPC0gMCAgICAjIEluaXRpYWxpemUgcGVhayBjb3VudCBjb2x1bW5cblxuIyBBZGQgcGVhayBjb3VudHMgdG8gdGhlIGNvcnJlc3BvbmRpbmcgbG9vcHNcbmxhcmdlc3RfbG9vcHNbYXMubnVtZXJpYyhuYW1lcyhsb29wX3BlYWtfY291bnRzKSksIFxcY291bnRcXF0gPC0gYXMuaW50ZWdlcihsb29wX3BlYWtfY291bnRzKVxuXG4jIENhbGN1bGF0ZSB0aGUgZGVuc2l0eSAocGVha3MgcGVyIGtpbG9iYXNlKVxubGFyZ2VzdF9sb29wcyRkZW5zaXR5IDwtIGxhcmdlc3RfbG9vcHMkY291bnQgLyAoKGxhcmdlc3RfbG9vcHMkbG9vcF93aWR0aC0xKSAvIDEwMDApXG5cblxuZGF0YSA8LSB0aWJibGUoXG4gIGdlbmUgPSBjKGdlbmUuZ3JvdXAxLCBnZW5lLmdyb3VwMiksXG4gIGdyb3VwID0gYyhyZXAoXFxncm91cDFcXCwgbGVuZ3RoKGdlbmUuZ3JvdXAxKSksXG4gICAgICAgICAgICByZXAoXFxncm91cDJcXCwgbGVuZ3RoKGdlbmUuZ3JvdXAyKSkpXG4pXG5cbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OmxlZnRfam9pbihsYXJnZXN0X2xvb3BzLCBieSA9IGMoXFxnZW5lXFwpKVxuZGF0YSA8LSBkYXRhICU+JSBkcGx5cjo6bXV0YXRlKFxuICBoYXNTUyA9IGlmZWxzZShpcy5uYShsb29wX3dpZHRoKSwgXFxOT1xcLCBcXFlFU1xcKVxuKSAlPiUgZHBseXI6OmZpbHRlcihoYXNTUyA9PSBcXFlFU1xcKVxuXG5nZXRQdmFsV2lsY294IDwtIGZ1bmN0aW9uKGRhdGEsIGdyb3VwMSwgZ3JvdXAyKXtcbiAgZGlzdGFuY2UxIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAxKSApJGRlbnNpdHlcbiAgZGlzdGFuY2UyIDwtIChkYXRhICU+JSBkcGx5cjo6ZmlsdGVyKGdyb3VwID09Z3JvdXAyKSApJGRlbnNpdHlcbiAgd2lsIDwtIHdpbGNveC50ZXN0KGRpc3RhbmNlMSwgZGlzdGFuY2UyKVxuICByZXR1cm4od2lsJHAudmFsdWUpXG59XG5cbnB2IDwtIGNvbnZQdmFsdWUoZ2V0UHZhbFdpbGNveChkYXRhLCBcXGdyb3VwMVxcLCBcXGdyb3VwMlxcKSlcblxuZ2dwbG90KGRhdGEsIGFlcyh4ID0gZ3JvdXAsIHkgPSBkZW5zaXR5KSkgKyBnZW9tX3Zpb2xpbihhZXMoZmlsbCA9IGdyb3VwKSwgc2hvdy5sZWdlbmQgPSBGQUxTRSkgKyBcbiAgZ2VvbV9ib3hwbG90KHdpZHRoID0gMC4xLCBvdXRsaWVyLnNoYXBlID0gTkEpICtcbiAgc3RhdF9zdW1tYXJ5KGFlcyhncm91cCA9IGdyb3VwKSwgZnVuID0gbWVhbiwgXG4gICAgICAgICAgICAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMiwgZmlsbCA9IFxccmVkXFwsIGNvbG9yID0gXFxibGFja1xcKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArXG4gIGFubm90YXRlKFxcdGV4dFxcLCB4ID0gMSwgeSA9IDAsIGxhYmVsID0gcHYsIHNpemUgPSA1LCBjb2xvciA9IFxcYmxhY2tcXCkgK1xuICBnZ3RpdGxlKFxcQ1RDRlxcKVxuXG5cbmBgYFxuYGBgIn0= -->

```r
```r
# View results
ggplot(largest_loops, aes(x = loop_width)) + geom_histogram()


### Checking how many genes from each group has encompassing S-S
gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep(\group1\, length(gene.group1)),
            rep(\group2\, length(gene.group2)))
)

data <- data %>% dplyr::left_join(largest_loops, by = c(\gene\))
data <- data %>% dplyr::mutate(
  hasSS = ifelse(is.na(loop_width), \NO\, \YES\)
)

data_summary <- data %>%
  group_by(group) %>%
  summarize(
    total = n(),
    hasSS_yes = sum(hasSS == \YES\),
    percentage_yes = (hasSS_yes / total) * 100
  )

ggplot(data_summary, aes(x = group, y = percentage_yes, fill = group)) +
  geom_bar(stat = \identity\, color = \black\) +
  labs(
    title = \Percentage of Each Group with hasSS = YES\,
    x = \Group\,
    y = \Percentage (%)\
  ) + ylim(0, 100) +
  theme_minimal()


temp <- data %>% dplyr::filter(hasSS == \YES\)
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$loop_width
  distance2 <- (data %>% dplyr::filter(group ==group2) )$loop_width
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
pv <- convPvalue(getPvalWilcox(temp, \group1\, \group2\))

ggplot(temp, aes(x = group, y = loop_width)) + geom_violin() + geom_boxplot(width = 0.5) +
  annotate(\text\, x = 1, y = 0, label = pv, size = 5, color = \black\)

### Comparing RNA perturbation

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(c(1, 4, 5)) %>%
  dplyr::mutate(hasSS = ifelse(ensembl_gene_id %in% largest_loops$gene, \hasSS\, \noSS\))


ggplot(diff.RNA, aes(x = abs(log2FoldChange), color = hasSS)) +
  stat_ecdf(size = 0.4) +
  labs(
    x = \Absolute log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )


### Checking ChIP peak density
largest_loopsGr <- makeGRangesFromDataFrame(largest_loops, 
                                            seqnames.field = \loop_chr\, 
                                            start.field = \loop_start\, 
                                            end.field = \loop_end\, 
                                            keep.extra.columns = TRUE)

# Find overlaps between ChIP-seq peaks and the largest loops
chip_overlaps <- findOverlaps(largest_loopsGr, peak.CTCF)

# Count the number of ChIP-seq peaks per loop
loop_peak_counts <- table(queryHits(chip_overlaps))

# Create a data frame with the counts and loop details
largest_loops$density <- 0  # Initialize density column
largest_loops$count <- 0    # Initialize peak count column

# Add peak counts to the corresponding loops
largest_loops[as.numeric(names(loop_peak_counts)), \count\] <- as.integer(loop_peak_counts)

# Calculate the density (peaks per kilobase)
largest_loops$density <- largest_loops$count / ((largest_loops$loop_width-1) / 1000)


data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep(\group1\, length(gene.group1)),
            rep(\group2\, length(gene.group2)))
)

data <- data %>% dplyr::left_join(largest_loops, by = c(\gene\))
data <- data %>% dplyr::mutate(
  hasSS = ifelse(is.na(loop_width), \NO\, \YES\)
) %>% dplyr::filter(hasSS == \YES\)

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$density
  distance2 <- (data %>% dplyr::filter(group ==group2) )$density
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv <- convPvalue(getPvalWilcox(data, \group1\, \group2\))

ggplot(data, aes(x = group, y = density)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
  geom_boxplot(width = 0.1, outlier.shape = NA) +
  stat_summary(aes(group = group), fun = mean, 
               geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  theme_classic() +
  annotate(\text\, x = 1, y = 0, label = pv, size = 5, color = \black\) +
  ggtitle(\CTCF\)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [3.40] Finding largest encompassing S-S

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVibUZ0WlNBOExTQmNJbU5vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIbGNJbHh1WEc0aklFbE5VRTlTVkNCVExWTWdURTlQVUZOY2JtRnNiRXh2YjNCeklEd3RJR1p5WldGa0tHaGxjbVVvWTI5dWMyVnVjM1Z6UkdseUxDQmNJbU5vY205dGIxOWpiMjV6WDJGdWJtOUlhV1Z5WVhKamFIa3VkSE4yWENJcEtWeHVjM1J5VEc5dmNITWdQQzBnWVd4c1RHOXZjSE1nSlQ0bElHUndiSGx5T2pwbWFXeDBaWElvUVc1dWJ6SWdKV2x1SlNCaktGd2lVeTFUWENJcEtWeHVkR1Z0Y0NBOExTQnpkSEpNYjI5d2N5QWxQaVVnWkhCc2VYSTZPbk5sYkdWamRDaGpLREVzSURJc0lETXNJRFVzSURZcEtTQWdJeUJCYzNOMWJXbHVaeUJqYjJ4MWJXNXpJR2x1WTJ4MVpHVWdZVzVqYUc5eUlIQnZjMmwwYVc5dWMxeHVZMjlzYm1GdFpYTW9kR1Z0Y0NrZ1BDMGdZeWhjSW1Ob2NtOXRYQ0lzSUZ3aWMzUmhjblF4WENJc0lGd2laVzVrTVZ3aUxDQmNJbk4wWVhKME1sd2lMQ0JjSW1WdVpESmNJaWxjYm5OMGNreHZiM0J6UjNJeElEd3RJRzFoYTJWSFVtRnVaMlZ6Um5KdmJVUmhkR0ZHY21GdFpTaGNiaUFnZEdWdGNDQWxQaVVnWkhCc2VYSTZPbk5sYkdWamRDaGphSEp2YlN3Z2MzUmhjblFnUFNCemRHRnlkREVzSUdWdVpDQTlJR1Z1WkRFcFhHNHBYRzV6ZEhKTWIyOXdjMGR5TWlBOExTQnRZV3RsUjFKaGJtZGxjMFp5YjIxRVlYUmhSbkpoYldVb1hHNGdJSFJsYlhBZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb1kyaHliMjBzSUhOMFlYSjBJRDBnYzNSaGNuUXlMQ0JsYm1RZ1BTQmxibVF5S1Z4dUtWeHVYRzRqSUVsTlVFOVNWQ0JEVkVOR0lFMVBWRWxHSUVGT1RrOVVRVlJKVDA1Y2JtTjBZMlpOYjNScFpuTWdQQzBnWm5KbFlXUW9hR1Z5WlNoeVpXWkVhWElzSUZ3aU16TXlORGhmUTFSRFJsOHdOeTAzTWpsZlFuSjFZMlV0TkY5d1pXRnJjeTV0WlhKblpWQmxZV3N1Ylc5MGFXWkJibTV2ZEdGMFpXUXVZbVZrWENJcEtWeHVZMjlzYm1GdFpYTW9ZM1JqWmsxdmRHbG1jeWtnUEMwZ1l5aGNJbU5vY205dFhDSXNJRndpYzNSaGNuUmNJaXdnWENKbGJtUmNJaXdnWENKdGIzUnBabHdpS1Z4dVkzUmpaa2R5SUR3dElHMWhhMlZIVW1GdVoyVnpSbkp2YlVSaGRHRkdjbUZ0WlNoamRHTm1UVzkwYVdaekxDQnJaV1Z3TG1WNGRISmhMbU52YkhWdGJuTWdQU0JVVWxWRktWeHVYRzRqSUVGdWJtOTBZWFJsSUdWaFkyZ2diRzl2Y0NCaGJtTm9iM0lnZDJsMGFDQkRWRU5HSUcxdmRHbG1jMXh1WVc1amFHOXlNVjkzYVhSb1gyTjBZMllnUEMwZ1ptbHVaRTkyWlhKc1lYQnpLSE4wY2t4dmIzQnpSM0l4TENCamRHTm1SM0lwWEc1aGJtTm9iM0l5WDNkcGRHaGZZM1JqWmlBOExTQm1hVzVrVDNabGNteGhjSE1vYzNSeVRHOXZjSE5IY2pJc0lHTjBZMlpIY2lsY2JseHVJeUJIWlhRZ2JXOTBhV1lnYVc1bWIzSnRZWFJwYjI0Z1ptOXlJR0Z1WTJodmNqRWdiM1psY214aGNITmNibUZ1WTJodmNqRmZZM1JqWmw5dGIzUnBaaUE4TFNCeVpYQW9Ua0VzSUd4bGJtZDBhQ2h6ZEhKTWIyOXdjMGR5TVNrcElDQWpJRWx1YVhScFlXeHBlbVVnYlc5MGFXWWdkbVZqZEc5eVhHNWhibU5vYjNJeFgyTjBZMlpmYlc5MGFXWmJjWFZsY25sSWFYUnpLR0Z1WTJodmNqRmZkMmwwYUY5amRHTm1LVjBnUEMwZ1kzUmpaa2R5VzNOMVltcGxZM1JJYVhSektHRnVZMmh2Y2pGZmQybDBhRjlqZEdObUtWMGtiVzkwYVdaY2JseHVJeUJIWlhRZ2JXOTBhV1lnYVc1bWIzSnRZWFJwYjI0Z1ptOXlJR0Z1WTJodmNqSWdiM1psY214aGNITmNibUZ1WTJodmNqSmZZM1JqWmw5dGIzUnBaaUE4TFNCeVpYQW9Ua0VzSUd4bGJtZDBhQ2h6ZEhKTWIyOXdjMGR5TWlrcElDQWpJRWx1YVhScFlXeHBlbVVnYlc5MGFXWWdkbVZqZEc5eVhHNWhibU5vYjNJeVgyTjBZMlpmYlc5MGFXWmJjWFZsY25sSWFYUnpLR0Z1WTJodmNqSmZkMmwwYUY5amRHTm1LVjBnUEMwZ1kzUmpaa2R5VzNOMVltcGxZM1JJYVhSektHRnVZMmh2Y2pKZmQybDBhRjlqZEdObUtWMGtiVzkwYVdaY2JseHVJeUJCWkdRZ2JXOTBhV1lnYVc1bWIzSnRZWFJwYjI0Z2RHOGdjM1J5VEc5dmNITmNibk4wY2t4dmIzQnpJRHd0SUhOMGNreHZiM0J6SUNVK0pWeHVJQ0J0ZFhSaGRHVW9YRzRnSUNBZ1lXNWphRzl5TVY5dGIzUnBaaUE5SUdGdVkyaHZjakZmWTNSalpsOXRiM1JwWml4Y2JpQWdJQ0JoYm1Ob2IzSXlYMjF2ZEdsbUlEMGdZVzVqYUc5eU1sOWpkR05tWDIxdmRHbG1YRzRnSUNsY2JseHVJeUJHYVd4MFpYSWdabTl5SUdOdmJuWmxjbWRsYm5RZ1ExUkRSaUJwYm5SbGNtRmpkR2x2Ym5NZ0tHWnZjbmRoY21RZ2FXNGdZVzVqYUc5eU1Td2djbVYyWlhKelpTQnBiaUJoYm1Ob2IzSXlLVnh1WTI5dWRtVnlaMlZ1ZEY5c2IyOXdjeUE4TFNCemRISk1iMjl3Y3lBbFBpVmNiaUFnWm1sc2RHVnlLR0Z1WTJodmNqRmZiVzkwYVdZZ1BUMGdYQ0ptZDJSY0lpQW1JR0Z1WTJodmNqSmZiVzkwYVdZZ1BUMGdYQ0p5WlhaY0lpa2dKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9RVzV1YnpJZ0pXbHVKU0JqS0Z3aVV5MVRYQ0lwS1Z4dVlHQmdJbjA9IC0tPlxuXG5gYGByXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5cbiMgSU1QT1JUIFMtUyBMT09QU1xuYWxsTG9vcHMgPC0gZnJlYWQoaGVyZShjb25zZW5zdXNEaXIsIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeS50c3ZcXCkpXG5zdHJMb29wcyA8LSBhbGxMb29wcyAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxTLVNcXCkpXG50ZW1wIDwtIHN0ckxvb3BzICU+JSBkcGx5cjo6c2VsZWN0KGMoMSwgMiwgMywgNSwgNikpICAjIEFzc3VtaW5nIGNvbHVtbnMgaW5jbHVkZSBhbmNob3IgcG9zaXRpb25zXG5jb2xuYW1lcyh0ZW1wKSA8LSBjKFxcY2hyb21cXCwgXFxzdGFydDFcXCwgXFxlbmQxXFwsIFxcc3RhcnQyXFwsIFxcZW5kMlxcKVxuc3RyTG9vcHNHcjEgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKFxuICB0ZW1wICU+JSBkcGx5cjo6c2VsZWN0KGNocm9tLCBzdGFydCA9IHN0YXJ0MSwgZW5kID0gZW5kMSlcbilcbnN0ckxvb3BzR3IyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShcbiAgdGVtcCAlPiUgZHBseXI6OnNlbGVjdChjaHJvbSwgc3RhcnQgPSBzdGFydDIsIGVuZCA9IGVuZDIpXG4pXG5cbiMgSU1QT1JUIENUQ0YgTU9USUYgQU5OT1RBVElPTlxuY3RjZk1vdGlmcyA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFwzMzI0OF9DVENGXzA3LTcyOV9CcnVjZS00X3BlYWtzLm1lcmdlUGVhay5tb3RpZkFubm90YXRlZC5iZWRcXCkpXG5jb2xuYW1lcyhjdGNmTW90aWZzKSA8LSBjKFxcY2hyb21cXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXG1vdGlmXFwpXG5jdGNmR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGN0Y2ZNb3RpZnMsIGtlZXAuZXh0cmEuY29sdW1ucyA9IFRSVUUpXG5cbiMgQW5ub3RhdGUgZWFjaCBsb29wIGFuY2hvciB3aXRoIENUQ0YgbW90aWZzXG5hbmNob3IxX3dpdGhfY3RjZiA8LSBmaW5kT3ZlcmxhcHMoc3RyTG9vcHNHcjEsIGN0Y2ZHcilcbmFuY2hvcjJfd2l0aF9jdGNmIDwtIGZpbmRPdmVybGFwcyhzdHJMb29wc0dyMiwgY3RjZkdyKVxuXG4jIEdldCBtb3RpZiBpbmZvcm1hdGlvbiBmb3IgYW5jaG9yMSBvdmVybGFwc1xuYW5jaG9yMV9jdGNmX21vdGlmIDwtIHJlcChOQSwgbGVuZ3RoKHN0ckxvb3BzR3IxKSkgICMgSW5pdGlhbGl6ZSBtb3RpZiB2ZWN0b3JcbmFuY2hvcjFfY3RjZl9tb3RpZltxdWVyeUhpdHMoYW5jaG9yMV93aXRoX2N0Y2YpXSA8LSBjdGNmR3Jbc3ViamVjdEhpdHMoYW5jaG9yMV93aXRoX2N0Y2YpXSRtb3RpZlxuXG4jIEdldCBtb3RpZiBpbmZvcm1hdGlvbiBmb3IgYW5jaG9yMiBvdmVybGFwc1xuYW5jaG9yMl9jdGNmX21vdGlmIDwtIHJlcChOQSwgbGVuZ3RoKHN0ckxvb3BzR3IyKSkgICMgSW5pdGlhbGl6ZSBtb3RpZiB2ZWN0b3JcbmFuY2hvcjJfY3RjZl9tb3RpZltxdWVyeUhpdHMoYW5jaG9yMl93aXRoX2N0Y2YpXSA8LSBjdGNmR3Jbc3ViamVjdEhpdHMoYW5jaG9yMl93aXRoX2N0Y2YpXSRtb3RpZlxuXG4jIEFkZCBtb3RpZiBpbmZvcm1hdGlvbiB0byBzdHJMb29wc1xuc3RyTG9vcHMgPC0gc3RyTG9vcHMgJT4lXG4gIG11dGF0ZShcbiAgICBhbmNob3IxX21vdGlmID0gYW5jaG9yMV9jdGNmX21vdGlmLFxuICAgIGFuY2hvcjJfbW90aWYgPSBhbmNob3IyX2N0Y2ZfbW90aWZcbiAgKVxuXG4jIEZpbHRlciBmb3IgY29udmVyZ2VudCBDVENGIGludGVyYWN0aW9ucyAoZm9yd2FyZCBpbiBhbmNob3IxLCByZXZlcnNlIGluIGFuY2hvcjIpXG5jb252ZXJnZW50X2xvb3BzIDwtIHN0ckxvb3BzICU+JVxuICBmaWx0ZXIoYW5jaG9yMV9tb3RpZiA9PSBcXGZ3ZFxcICYgYW5jaG9yMl9tb3RpZiA9PSBcXHJldlxcKSAlPiUgZHBseXI6OmZpbHRlcihBbm5vMiAlaW4lIGMoXFxTLVNcXCkpXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->
name <- \chromo_cons_annoHierarchy\

# IMPORT S-S LOOPS
allLoops <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\))
strLoops <- allLoops %>% dplyr::filter(Anno2 %in% c(\S-S\))
temp <- strLoops %>% dplyr::select(c(1, 2, 3, 5, 6))  # Assuming columns include anchor positions
colnames(temp) <- c(\chrom\, \start1\, \end1\, \start2\, \end2\)
strLoopsGr1 <- makeGRangesFromDataFrame(
  temp %>% dplyr::select(chrom, start = start1, end = end1)
)
strLoopsGr2 <- makeGRangesFromDataFrame(
  temp %>% dplyr::select(chrom, start = start2, end = end2)
)

# IMPORT CTCF MOTIF ANNOTATION
ctcfMotifs <- fread(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed\))
colnames(ctcfMotifs) <- c(\chrom\, \start\, \end\, \motif\)
ctcfGr <- makeGRangesFromDataFrame(ctcfMotifs, keep.extra.columns = TRUE)

# Annotate each loop anchor with CTCF motifs
anchor1_with_ctcf <- findOverlaps(strLoopsGr1, ctcfGr)
anchor2_with_ctcf <- findOverlaps(strLoopsGr2, ctcfGr)

# Get motif information for anchor1 overlaps
anchor1_ctcf_motif <- rep(NA, length(strLoopsGr1))  # Initialize motif vector
anchor1_ctcf_motif[queryHits(anchor1_with_ctcf)] <- ctcfGr[subjectHits(anchor1_with_ctcf)]$motif

# Get motif information for anchor2 overlaps
anchor2_ctcf_motif <- rep(NA, length(strLoopsGr2))  # Initialize motif vector
anchor2_ctcf_motif[queryHits(anchor2_with_ctcf)] <- ctcfGr[subjectHits(anchor2_with_ctcf)]$motif

# Add motif information to strLoops
strLoops <- strLoops %>%
  mutate(
    anchor1_motif = anchor1_ctcf_motif,
    anchor2_motif = anchor2_ctcf_motif
  )

# Filter for convergent CTCF interactions (forward in anchor1, reverse in anchor2)
convergent_loops <- strLoops %>%
  filter(anchor1_motif == \fwd\ & anchor2_motif == \rev\) %>% dplyr::filter(Anno2 %in% c(\S-S\))



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWJtRnRaU0E4TFNCY1hHTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhsY1hGeHVYRzRqSUVsTlVFOVNWQ0JUTFZNZ1RFOVBVRk5jYm1Gc2JFeHZiM0J6SUR3dElHWnlaV0ZrS0dobGNtVW9ZMjl1YzJWdWMzVnpSR2x5TENCY1hHTm9jbTl0YjE5amIyNXpYMkZ1Ym05SWFXVnlZWEpqYUhrdWRITjJYRndwS1Z4dWMzUnlURzl2Y0hNZ1BDMGdZV3hzVEc5dmNITWdKVDRsSUdSd2JIbHlPanBtYVd4MFpYSW9RVzV1YnpJZ0pXbHVKU0JqS0Z4Y1V5MVRYRndwS1Z4dWRHVnRjQ0E4TFNCemRISk1iMjl3Y3lBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoaktERXNJRElzSURNc0lEVXNJRFlwS1NBZ0l5QkJjM04xYldsdVp5QmpiMngxYlc1eklHbHVZMngxWkdVZ1lXNWphRzl5SUhCdmMybDBhVzl1YzF4dVkyOXNibUZ0WlhNb2RHVnRjQ2tnUEMwZ1l5aGNYR05vY205dFhGd3NJRnhjYzNSaGNuUXhYRndzSUZ4Y1pXNWtNVnhjTENCY1hITjBZWEowTWx4Y0xDQmNYR1Z1WkRKY1hDbGNibk4wY2t4dmIzQnpSM0l4SUR3dElHMWhhMlZIVW1GdVoyVnpSbkp2YlVSaGRHRkdjbUZ0WlNoY2JpQWdkR1Z0Y0NBbFBpVWdaSEJzZVhJNk9uTmxiR1ZqZENoamFISnZiU3dnYzNSaGNuUWdQU0J6ZEdGeWRERXNJR1Z1WkNBOUlHVnVaREVwWEc0cFhHNXpkSEpNYjI5d2MwZHlNaUE4TFNCdFlXdGxSMUpoYm1kbGMwWnliMjFFWVhSaFJuSmhiV1VvWEc0Z0lIUmxiWEFnSlQ0bElHUndiSGx5T2pwelpXeGxZM1FvWTJoeWIyMHNJSE4wWVhKMElEMGdjM1JoY25ReUxDQmxibVFnUFNCbGJtUXlLVnh1S1Z4dVhHNGpJRWxOVUU5U1ZDQkRWRU5HSUUxUFZFbEdJRUZPVGs5VVFWUkpUMDVjYm1OMFkyWk5iM1JwWm5NZ1BDMGdabkpsWVdRb2FHVnlaU2h5WldaRWFYSXNJRnhjTXpNeU5EaGZRMVJEUmw4d055MDNNamxmUW5KMVkyVXRORjl3WldGcmN5NXRaWEpuWlZCbFlXc3ViVzkwYVdaQmJtNXZkR0YwWldRdVltVmtYRndwS1Z4dVkyOXNibUZ0WlhNb1kzUmpaazF2ZEdsbWN5a2dQQzBnWXloY1hHTm9jbTl0WEZ3c0lGeGNjM1JoY25SY1hDd2dYRnhsYm1SY1hDd2dYRnh0YjNScFpseGNLVnh1WTNSalprZHlJRHd0SUcxaGEyVkhVbUZ1WjJWelJuSnZiVVJoZEdGR2NtRnRaU2hqZEdObVRXOTBhV1p6TENCclpXVndMbVY0ZEhKaExtTnZiSFZ0Ym5NZ1BTQlVVbFZGS1Z4dVhHNGpJRUZ1Ym05MFlYUmxJR1ZoWTJnZ2JHOXZjQ0JoYm1Ob2IzSWdkMmwwYUNCRFZFTkdJRzF2ZEdsbWMxeHVZVzVqYUc5eU1WOTNhWFJvWDJOMFkyWWdQQzBnWm1sdVpFOTJaWEpzWVhCektITjBja3h2YjNCelIzSXhMQ0JqZEdObVIzSXBYRzVoYm1Ob2IzSXlYM2RwZEdoZlkzUmpaaUE4TFNCbWFXNWtUM1psY214aGNITW9jM1J5VEc5dmNITkhjaklzSUdOMFkyWkhjaWxjYmx4dUl5QkhaWFFnYlc5MGFXWWdhVzVtYjNKdFlYUnBiMjRnWm05eUlHRnVZMmh2Y2pFZ2IzWmxjbXhoY0hOY2JtRnVZMmh2Y2pGZlkzUmpabDl0YjNScFppQThMU0J5WlhBb1RrRXNJR3hsYm1kMGFDaHpkSEpNYjI5d2MwZHlNU2twSUNBaklFbHVhWFJwWVd4cGVtVWdiVzkwYVdZZ2RtVmpkRzl5WEc1aGJtTm9iM0l4WDJOMFkyWmZiVzkwYVdaYmNYVmxjbmxJYVhSektHRnVZMmh2Y2pGZmQybDBhRjlqZEdObUtWMGdQQzBnWTNSalprZHlXM04xWW1wbFkzUklhWFJ6S0dGdVkyaHZjakZmZDJsMGFGOWpkR05tS1Ywa2JXOTBhV1pjYmx4dUl5QkhaWFFnYlc5MGFXWWdhVzVtYjNKdFlYUnBiMjRnWm05eUlHRnVZMmh2Y2pJZ2IzWmxjbXhoY0hOY2JtRnVZMmh2Y2pKZlkzUmpabDl0YjNScFppQThMU0J5WlhBb1RrRXNJR3hsYm1kMGFDaHpkSEpNYjI5d2MwZHlNaWtwSUNBaklFbHVhWFJwWVd4cGVtVWdiVzkwYVdZZ2RtVmpkRzl5WEc1aGJtTm9iM0l5WDJOMFkyWmZiVzkwYVdaYmNYVmxjbmxJYVhSektHRnVZMmh2Y2pKZmQybDBhRjlqZEdObUtWMGdQQzBnWTNSalprZHlXM04xWW1wbFkzUklhWFJ6S0dGdVkyaHZjakpmZDJsMGFGOWpkR05tS1Ywa2JXOTBhV1pjYmx4dUl5QkJaR1FnYlc5MGFXWWdhVzVtYjNKdFlYUnBiMjRnZEc4Z2MzUnlURzl2Y0hOY2JuTjBja3h2YjNCeklEd3RJSE4wY2t4dmIzQnpJQ1UrSlZ4dUlDQnRkWFJoZEdVb1hHNGdJQ0FnWVc1amFHOXlNVjl0YjNScFppQTlJR0Z1WTJodmNqRmZZM1JqWmw5dGIzUnBaaXhjYmlBZ0lDQmhibU5vYjNJeVgyMXZkR2xtSUQwZ1lXNWphRzl5TWw5amRHTm1YMjF2ZEdsbVhHNGdJQ2xjYmx4dUl5QkdhV3gwWlhJZ1ptOXlJR052Ym5abGNtZGxiblFnUTFSRFJpQnBiblJsY21GamRHbHZibk1nS0dadmNuZGhjbVFnYVc0Z1lXNWphRzl5TVN3Z2NtVjJaWEp6WlNCcGJpQmhibU5vYjNJeUtWeHVZMjl1ZG1WeVoyVnVkRjlzYjI5d2N5QThMU0J6ZEhKTWIyOXdjeUFsUGlWY2JpQWdabWxzZEdWeUtHRnVZMmh2Y2pGZmJXOTBhV1lnUFQwZ1hGeG1kMlJjWENBbUlHRnVZMmh2Y2pKZmJXOTBhV1lnUFQwZ1hGeHlaWFpjWENrZ0pUNGxJR1J3YkhseU9qcG1hV3gwWlhJb1FXNXVieklnSldsdUpTQmpLRnhjVXkxVFhGd3BLVnh1WUdCZ1hHNWdZR0FpZlE9PSAtLT5cblxuYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG4jIElNUE9SVCBTLVMgTE9PUFNcbmFsbExvb3BzIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHkudHN2XFwpKVxuc3RyTG9vcHMgPC0gYWxsTG9vcHMgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUy1TXFwpKVxudGVtcCA8LSBzdHJMb29wcyAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMsIDUsIDYpKSAgIyBBc3N1bWluZyBjb2x1bW5zIGluY2x1ZGUgYW5jaG9yIHBvc2l0aW9uc1xuY29sbmFtZXModGVtcCkgPC0gYyhcXGNocm9tXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXClcbnN0ckxvb3BzR3IxIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShcbiAgdGVtcCAlPiUgZHBseXI6OnNlbGVjdChjaHJvbSwgc3RhcnQgPSBzdGFydDEsIGVuZCA9IGVuZDEpXG4pXG5zdHJMb29wc0dyMiA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoXG4gIHRlbXAgJT4lIGRwbHlyOjpzZWxlY3QoY2hyb20sIHN0YXJ0ID0gc3RhcnQyLCBlbmQgPSBlbmQyKVxuKVxuXG4jIElNUE9SVCBDVENGIE1PVElGIEFOTk9UQVRJT05cbmN0Y2ZNb3RpZnMgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcMzMyNDhfQ1RDRl8wNy03MjlfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsubW90aWZBbm5vdGF0ZWQuYmVkXFwpKVxuY29sbmFtZXMoY3RjZk1vdGlmcykgPC0gYyhcXGNocm9tXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxtb3RpZlxcKVxuY3RjZkdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShjdGNmTW90aWZzLCBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFKVxuXG4jIEFubm90YXRlIGVhY2ggbG9vcCBhbmNob3Igd2l0aCBDVENGIG1vdGlmc1xuYW5jaG9yMV93aXRoX2N0Y2YgPC0gZmluZE92ZXJsYXBzKHN0ckxvb3BzR3IxLCBjdGNmR3IpXG5hbmNob3IyX3dpdGhfY3RjZiA8LSBmaW5kT3ZlcmxhcHMoc3RyTG9vcHNHcjIsIGN0Y2ZHcilcblxuIyBHZXQgbW90aWYgaW5mb3JtYXRpb24gZm9yIGFuY2hvcjEgb3ZlcmxhcHNcbmFuY2hvcjFfY3RjZl9tb3RpZiA8LSByZXAoTkEsIGxlbmd0aChzdHJMb29wc0dyMSkpICAjIEluaXRpYWxpemUgbW90aWYgdmVjdG9yXG5hbmNob3IxX2N0Y2ZfbW90aWZbcXVlcnlIaXRzKGFuY2hvcjFfd2l0aF9jdGNmKV0gPC0gY3RjZkdyW3N1YmplY3RIaXRzKGFuY2hvcjFfd2l0aF9jdGNmKV0kbW90aWZcblxuIyBHZXQgbW90aWYgaW5mb3JtYXRpb24gZm9yIGFuY2hvcjIgb3ZlcmxhcHNcbmFuY2hvcjJfY3RjZl9tb3RpZiA8LSByZXAoTkEsIGxlbmd0aChzdHJMb29wc0dyMikpICAjIEluaXRpYWxpemUgbW90aWYgdmVjdG9yXG5hbmNob3IyX2N0Y2ZfbW90aWZbcXVlcnlIaXRzKGFuY2hvcjJfd2l0aF9jdGNmKV0gPC0gY3RjZkdyW3N1YmplY3RIaXRzKGFuY2hvcjJfd2l0aF9jdGNmKV0kbW90aWZcblxuIyBBZGQgbW90aWYgaW5mb3JtYXRpb24gdG8gc3RyTG9vcHNcbnN0ckxvb3BzIDwtIHN0ckxvb3BzICU+JVxuICBtdXRhdGUoXG4gICAgYW5jaG9yMV9tb3RpZiA9IGFuY2hvcjFfY3RjZl9tb3RpZixcbiAgICBhbmNob3IyX21vdGlmID0gYW5jaG9yMl9jdGNmX21vdGlmXG4gIClcblxuIyBGaWx0ZXIgZm9yIGNvbnZlcmdlbnQgQ1RDRiBpbnRlcmFjdGlvbnMgKGZvcndhcmQgaW4gYW5jaG9yMSwgcmV2ZXJzZSBpbiBhbmNob3IyKVxuY29udmVyZ2VudF9sb29wcyA8LSBzdHJMb29wcyAlPiVcbiAgZmlsdGVyKGFuY2hvcjFfbW90aWYgPT0gXFxmd2RcXCAmIGFuY2hvcjJfbW90aWYgPT0gXFxyZXZcXCkgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUy1TXFwpKVxuYGBgXG5gYGBcblxuPCEtLSBybmItc291cmNlLWVuZCAtLT5cbiJ9 -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxubmFtZSA8LSBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHlcXFxuXG4jIElNUE9SVCBTLVMgTE9PUFNcbmFsbExvb3BzIDwtIGZyZWFkKGhlcmUoY29uc2Vuc3VzRGlyLCBcXGNocm9tb19jb25zX2Fubm9IaWVyYXJjaHkudHN2XFwpKVxuc3RyTG9vcHMgPC0gYWxsTG9vcHMgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUy1TXFwpKVxudGVtcCA8LSBzdHJMb29wcyAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMsIDUsIDYpKSAgIyBBc3N1bWluZyBjb2x1bW5zIGluY2x1ZGUgYW5jaG9yIHBvc2l0aW9uc1xuY29sbmFtZXModGVtcCkgPC0gYyhcXGNocm9tXFwsIFxcc3RhcnQxXFwsIFxcZW5kMVxcLCBcXHN0YXJ0MlxcLCBcXGVuZDJcXClcbnN0ckxvb3BzR3IxIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShcbiAgdGVtcCAlPiUgZHBseXI6OnNlbGVjdChjaHJvbSwgc3RhcnQgPSBzdGFydDEsIGVuZCA9IGVuZDEpXG4pXG5zdHJMb29wc0dyMiA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoXG4gIHRlbXAgJT4lIGRwbHlyOjpzZWxlY3QoY2hyb20sIHN0YXJ0ID0gc3RhcnQyLCBlbmQgPSBlbmQyKVxuKVxuXG4jIElNUE9SVCBDVENGIE1PVElGIEFOTk9UQVRJT05cbmN0Y2ZNb3RpZnMgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcMzMyNDhfQ1RDRl8wNy03MjlfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsubW90aWZBbm5vdGF0ZWQuYmVkXFwpKVxuY29sbmFtZXMoY3RjZk1vdGlmcykgPC0gYyhcXGNocm9tXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxtb3RpZlxcKVxuY3RjZkdyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShjdGNmTW90aWZzLCBrZWVwLmV4dHJhLmNvbHVtbnMgPSBUUlVFKVxuXG4jIEFubm90YXRlIGVhY2ggbG9vcCBhbmNob3Igd2l0aCBDVENGIG1vdGlmc1xuYW5jaG9yMV93aXRoX2N0Y2YgPC0gZmluZE92ZXJsYXBzKHN0ckxvb3BzR3IxLCBjdGNmR3IpXG5hbmNob3IyX3dpdGhfY3RjZiA8LSBmaW5kT3ZlcmxhcHMoc3RyTG9vcHNHcjIsIGN0Y2ZHcilcblxuIyBHZXQgbW90aWYgaW5mb3JtYXRpb24gZm9yIGFuY2hvcjEgb3ZlcmxhcHNcbmFuY2hvcjFfY3RjZl9tb3RpZiA8LSByZXAoTkEsIGxlbmd0aChzdHJMb29wc0dyMSkpICAjIEluaXRpYWxpemUgbW90aWYgdmVjdG9yXG5hbmNob3IxX2N0Y2ZfbW90aWZbcXVlcnlIaXRzKGFuY2hvcjFfd2l0aF9jdGNmKV0gPC0gY3RjZkdyW3N1YmplY3RIaXRzKGFuY2hvcjFfd2l0aF9jdGNmKV0kbW90aWZcblxuIyBHZXQgbW90aWYgaW5mb3JtYXRpb24gZm9yIGFuY2hvcjIgb3ZlcmxhcHNcbmFuY2hvcjJfY3RjZl9tb3RpZiA8LSByZXAoTkEsIGxlbmd0aChzdHJMb29wc0dyMikpICAjIEluaXRpYWxpemUgbW90aWYgdmVjdG9yXG5hbmNob3IyX2N0Y2ZfbW90aWZbcXVlcnlIaXRzKGFuY2hvcjJfd2l0aF9jdGNmKV0gPC0gY3RjZkdyW3N1YmplY3RIaXRzKGFuY2hvcjJfd2l0aF9jdGNmKV0kbW90aWZcblxuIyBBZGQgbW90aWYgaW5mb3JtYXRpb24gdG8gc3RyTG9vcHNcbnN0ckxvb3BzIDwtIHN0ckxvb3BzICU+JVxuICBtdXRhdGUoXG4gICAgYW5jaG9yMV9tb3RpZiA9IGFuY2hvcjFfY3RjZl9tb3RpZixcbiAgICBhbmNob3IyX21vdGlmID0gYW5jaG9yMl9jdGNmX21vdGlmXG4gIClcblxuIyBGaWx0ZXIgZm9yIGNvbnZlcmdlbnQgQ1RDRiBpbnRlcmFjdGlvbnMgKGZvcndhcmQgaW4gYW5jaG9yMSwgcmV2ZXJzZSBpbiBhbmNob3IyKVxuY29udmVyZ2VudF9sb29wcyA8LSBzdHJMb29wcyAlPiVcbiAgZmlsdGVyKGFuY2hvcjFfbW90aWYgPT0gXFxmd2RcXCAmIGFuY2hvcjJfbW90aWYgPT0gXFxyZXZcXCkgJT4lIGRwbHlyOjpmaWx0ZXIoQW5ubzIgJWluJSBjKFxcUy1TXFwpKVxuYGBgXG5gYGAifQ== -->

```r
```r
name <- \chromo_cons_annoHierarchy\

# IMPORT S-S LOOPS
allLoops <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\))
strLoops <- allLoops %>% dplyr::filter(Anno2 %in% c(\S-S\))
temp <- strLoops %>% dplyr::select(c(1, 2, 3, 5, 6))  # Assuming columns include anchor positions
colnames(temp) <- c(\chrom\, \start1\, \end1\, \start2\, \end2\)
strLoopsGr1 <- makeGRangesFromDataFrame(
  temp %>% dplyr::select(chrom, start = start1, end = end1)
)
strLoopsGr2 <- makeGRangesFromDataFrame(
  temp %>% dplyr::select(chrom, start = start2, end = end2)
)

# IMPORT CTCF MOTIF ANNOTATION
ctcfMotifs <- fread(here(refDir, \33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed\))
colnames(ctcfMotifs) <- c(\chrom\, \start\, \end\, \motif\)
ctcfGr <- makeGRangesFromDataFrame(ctcfMotifs, keep.extra.columns = TRUE)

# Annotate each loop anchor with CTCF motifs
anchor1_with_ctcf <- findOverlaps(strLoopsGr1, ctcfGr)
anchor2_with_ctcf <- findOverlaps(strLoopsGr2, ctcfGr)

# Get motif information for anchor1 overlaps
anchor1_ctcf_motif <- rep(NA, length(strLoopsGr1))  # Initialize motif vector
anchor1_ctcf_motif[queryHits(anchor1_with_ctcf)] <- ctcfGr[subjectHits(anchor1_with_ctcf)]$motif

# Get motif information for anchor2 overlaps
anchor2_ctcf_motif <- rep(NA, length(strLoopsGr2))  # Initialize motif vector
anchor2_ctcf_motif[queryHits(anchor2_with_ctcf)] <- ctcfGr[subjectHits(anchor2_with_ctcf)]$motif

# Add motif information to strLoops
strLoops <- strLoops %>%
  mutate(
    anchor1_motif = anchor1_ctcf_motif,
    anchor2_motif = anchor2_ctcf_motif
  )

# Filter for convergent CTCF interactions (forward in anchor1, reverse in anchor2)
convergent_loops <- strLoops %>%
  filter(anchor1_motif == \fwd\ & anchor2_motif == \rev\) %>% dplyr::filter(Anno2 %in% c(\S-S\))
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBFeHRyYWN0IGxvb3AgYm91bmRhcnkgZnJvbSBsZWZ0IHRvIHJpZ2h0XG50ZW1wIDwtIGNvbnZlcmdlbnRfbG9vcHMgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCA2KSlcbmNvbG5hbWVzKHRlbXApIDwtIGMoXCJjaHJvbVwiLCBcInN0YXJ0XCIsIFwiZW5kXCIpXG5zdHJMb29wc0dyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxuXG4jIElNUE9SVCBUU1NcbmZsYW5rU2l6ZSA8LSAxMFxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXCJtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcIikpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcIitcIiwgVjIsIFYzKSxcbiAgICAgICAgICAgICAgICBUU1NzdGFydCA9IFRTUyAtIGZsYW5rU2l6ZSxcbiAgICAgICAgICAgICAgICBUU1NlbmQgPSBUU1MgKyBmbGFua1NpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBUU1NzdGFydCwgVFNTZW5kLCBWNiwgVjUpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFwiY2hyb21cIiwgXCJzdGFydFwiLCBcImVuZFwiLCBcImVuc2VtYmxcIiwgXCJnZW5lXCIpXG5nZW5lR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGdlbmUudGIsIGtlZXAuZXh0cmEuY29sdW1ucyA9IFRSVUUpXG5cblxuIyBGaW5kIG92ZXJsYXBzIGJldHdlZW4gbG9vcHMgYW5kIFRTU1xub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGdlbmVHciwgc3RyTG9vcHNHcilcblxuIyBBbm5vdGF0ZSBvdmVybGFwc1xudHNzX3dpdGhfbG9vcHMgPC0gZ2VuZUdyW3F1ZXJ5SGl0cyhvdmVybGFwcyldXG5sb29wc193aXRoX3RzcyA8LSBzdHJMb29wc0dyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV1cblxuIyBDb21iaW5lIGludG8gYSBkYXRhIGZyYW1lIGZvciBwcm9jZXNzaW5nXG5sb29wX2RhdGEgPC0gZGF0YS5mcmFtZShnZW5lID0gdHNzX3dpdGhfbG9vcHMkZW5zZW1ibCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BfY2hyID0gc2VxbmFtZXMobG9vcHNfd2l0aF90c3MpLFxuICAgICAgICAgICAgICAgICAgICAgICAgbG9vcF9zdGFydCA9IHN0YXJ0KGxvb3BzX3dpdGhfdHNzKSxcbiAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BfZW5kID0gZW5kKGxvb3BzX3dpdGhfdHNzKSxcbiAgICAgICAgICAgICAgICAgICAgICAgIGxvb3Bfd2lkdGggPSB3aWR0aChsb29wc193aXRoX3RzcykpXG5cbiMgSWRlbnRpZnkgdGhlIGxhcmdlc3QgbG9vcCBmb3IgZWFjaCBnZW5lXG5sYXJnZXN0X2xvb3BzIDwtIGxvb3BfZGF0YVtvcmRlcihsb29wX2RhdGEkZ2VuZSwgLWxvb3BfZGF0YSRsb29wX3dpZHRoKSwgXVxubGFyZ2VzdF9sb29wcyA8LSBsYXJnZXN0X2xvb3BzWyFkdXBsaWNhdGVkKGxhcmdlc3RfbG9vcHMkZ2VuZSksIF1cbmxhcmdlc3RfbG9vcHMgPC0gbGFyZ2VzdF9sb29wcyAlPiUgZHBseXI6Om11dGF0ZShsb29wSUQgPSBwYXN0ZShsb29wX2NociwgbG9vcF9zdGFydCwgbG9vcF9lbmQsIHNlcCA9IFwiX1wiKSlcbmxhcmdlc3RfbG9vcHMgPC0gbGFyZ2VzdF9sb29wc1tvcmRlcihsYXJnZXN0X2xvb3BzJGxvb3BfY2hyLCBsYXJnZXN0X2xvb3BzJGxvb3Bfc3RhcnQpLF1cbnJvd25hbWVzKGxhcmdlc3RfbG9vcHMpIDwtIE5VTExcblxuIyBDaGVja2luZyBzbWFsbGVyIGxvb3BzXG5hbGxMb29wc0dyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhbGxMb29wcywgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzZXFuYW1lcy5maWVsZCA9IFwiY2hyb20xXCIsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3RhcnQuZmllbGQgPSBcInN0YXJ0MVwiLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZC5maWVsZCA9IFwiZW5kMlwiKVxubGFyZ2VzdExvb3BzR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGxhcmdlc3RfbG9vcHMsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNlcW5hbWVzLmZpZWxkID0gXCJsb29wX2NoclwiLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdGFydC5maWVsZCA9IFwibG9vcF9zdGFydFwiLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmQuZmllbGQgPSBcImxvb3BfZW5kXCIpXG5sYXJnZXN0TG9vcHNHciA8LSBzb3J0KHVuaXF1ZShsYXJnZXN0TG9vcHNHcikpXG5jb21wbGV0ZV9vdmVybGFwcyA8LSBzdWJzZXRCeU92ZXJsYXBzKGFsbExvb3BzR3IsIGxhcmdlc3RMb29wc0dyLCB0eXBlID0gXCJ3aXRoaW5cIilcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhjb21wbGV0ZV9vdmVybGFwcywgbGFyZ2VzdExvb3BzR3IpXG5cblxuY29tcGxldGVPdmVybGFwRGYgPC0gYXMuZGF0YS5mcmFtZShjb21wbGV0ZV9vdmVybGFwcykgJT4lIGRwbHlyOjptdXRhdGUobG9vcElEQWxsID0gcGFzdGUoc2VxbmFtZXMsIHN0YXJ0LCBlbmQsIHNlcCA9IFwiX1wiKSlcbmxhcmdlc3RMb29wc0RmIDwtIGFzLmRhdGEuZnJhbWUobGFyZ2VzdExvb3BzR3IpICU+JSBkcGx5cjo6bXV0YXRlKGxvb3BJRCA9IHBhc3RlKHNlcW5hbWVzLCBzdGFydCwgZW5kLCBzZXAgPSBcIl9cIikpXG5cbmxvb3BJRHBhaXJzIDwtIGRhdGEuZnJhbWUobG9vcElEID0gY29tcGxldGVPdmVybGFwRGYkbG9vcElEQWxsW3F1ZXJ5SGl0cyhvdmVybGFwcyldLFxuICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wSUQyID0gbGFyZ2VzdExvb3BzRGYkbG9vcElEW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbiMgYWxsTG9vcHNBbm5vdGF0ZWQgPC0gYWxsTG9vcHMgJT4lIGRwbHlyOjptdXRhdGUobG9vcElEID0gcGFzdGUoY2hyb20xLCBzdGFydDEsIGVuZDIsIHNlcCA9IFwiX1wiKSkgJT4lIGRwbHlyOjpsZWZ0X2pvaW4obG9vcElEcGFpcnMsIGJ5ID0gYyhcImxvb3BJRFwiKSlcblxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5kaWZmQ3V0b2ZmIDwtIDAuMlxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcIl9wLW5fZW5zZW1ibExpc3QudHN2XCIpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IGRpZmZDdXRvZmYsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9MaXN0ID0gYyhcIlAtUFwiLCBcIlAtRVwiLCBcIlAtU1wiLCBcIlAtWFwiKSkgJT4lIHVubmVzdChnZW5lKSAlPiVcbiAgZHBseXI6Om11dGF0ZShsb29wSUQgPSBwYXN0ZShjaHJvbTEsIHN0YXJ0MSwgZW5kMiwgc2VwID0gXCJfXCIpKVxudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4obG9vcElEcGFpcnMsIGJ5ID0gYyhcImxvb3BJRFwiKSlcbnRlbXAyIDwtIHRlbXAgJT4lIGRwbHlyOjpzZWxlY3QoZ2VuZSwgbG9vcElEMikgJT4lXG4gIGdyb3VwX2J5KGdlbmUpICU+JSAgICAgICAgICAgICAgIyBHcm91cCBkYXRhIGJ5IHRoZSAnZ2VuZScgY29sdW1uXG4gIHN1bW1hcml6ZShnZW5lSGFzU1MgPSAhYWxsKGlzLm5hKGxvb3BJRDIpKSkgICMgQ2hlY2sgaWYgYWxsIGxvb3BJRDIgdmFsdWVzIGZvciBlYWNoIGdlbmUgYXJlIE5BXG50ZW1wIDwtIHRlbXAgJT4lIGxlZnRfam9pbih0ZW1wMiwgYnkgPSBjKFwiZ2VuZVwiKSlcbmRhdGEuYWxsIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBpZmVsc2UoIWdlbmVIYXNTUywgXCJOb1wiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShpcy5uYShsb29wSUQyKSwgXCJPdXRzaWRlXCIsIFwiV2l0aGluXCIpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzaXplID0gc3RhcnQyIC0gc3RhcnQxKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5vdXRmaWxlIDwtIGRhdGEuYWxsICU+JSBkcGx5cjo6c2VsZWN0KGxvb3BJRDIsIGdlbmUpICU+JSBkcGx5cjo6ZmlsdGVyKCFpcy5uYShsb29wSUQyKSkgJT4lXG4gIHNlcGFyYXRlKGxvb3BJRDIsIGludG8gPSBjKFwiY2hyb21cIiwgXCJzdGFydFwiLCBcImVuZFwiKSwgc2VwID0gXCJfXCIsIGNvbnZlcnQgPSBUUlVFKVxuIyBmd3JpdGUob3V0ZmlsZSwgaGVyZShjb25zZW5zdXNEaXIsIFwiY29udmVyZ2VudF9zc19kb21haW4uYmVkXCIpLCBzZXAgPSBcIlxcdFwiLCBjb2wubmFtZXMgPSBGQUxTRSlcbmBgYCJ9 -->\n\n```r\n# Extract loop boundary from left to right\ntemp <- convergent_loops %>% dplyr::select(c(1, 2, 6))\ncolnames(temp) <- c(\\chrom\\, \\start\\, \\end\\)\nstrLoopsGr <- makeGRangesFromDataFrame(temp)\n\n# IMPORT TSS\nflankSize <- 10\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6, V5)\ncolnames(gene.tb) <- c(\\chrom\\, \\start\\, \\end\\, \\ensembl\\, \\gene\\)\ngeneGr <- makeGRangesFromDataFrame(gene.tb, keep.extra.columns = TRUE)\n\n\n# Find overlaps between loops and TSS\noverlaps <- findOverlaps(geneGr, strLoopsGr)\n\n# Annotate overlaps\ntss_with_loops <- geneGr[queryHits(overlaps)]\nloops_with_tss <- strLoopsGr[subjectHits(overlaps)]\n\n# Combine into a data frame for processing\nloop_data <- data.frame(gene = tss_with_loops$ensembl,\n                        loop_chr = seqnames(loops_with_tss),\n                        loop_start = start(loops_with_tss),\n                        loop_end = end(loops_with_tss),\n                        loop_width = width(loops_with_tss))\n\n# Identify the largest loop for each gene\nlargest_loops <- loop_data[order(loop_data$gene, -loop_data$loop_width), ]\nlargest_loops <- largest_loops[!duplicated(largest_loops$gene), ]\nlargest_loops <- largest_loops %>% dplyr::mutate(loopID = paste(loop_chr, loop_start, loop_end, sep = \\_\\))\nlargest_loops <- largest_loops[order(largest_loops$loop_chr, largest_loops$loop_start),]\nrownames(largest_loops) <- NULL\n\n# Checking smaller loops\nallLoopsGr <- makeGRangesFromDataFrame(allLoops, \n                                       seqnames.field = \\chrom1\\, \n                                       start.field = \\start1\\, \n                                       end.field = \\end2\\)\nlargestLoopsGr <- makeGRangesFromDataFrame(largest_loops, \n                                           seqnames.field = \\loop_chr\\, \n                                           start.field = \\loop_start\\, \n                                           end.field = \\loop_end\\)\nlargestLoopsGr <- sort(unique(largestLoopsGr))\ncomplete_overlaps <- subsetByOverlaps(allLoopsGr, largestLoopsGr, type = \\within\\)\noverlaps <- findOverlaps(complete_overlaps, largestLoopsGr)\n\n\ncompleteOverlapDf <- as.data.frame(complete_overlaps) %>% dplyr::mutate(loopIDAll = paste(seqnames, start, end, sep = \\_\\))\nlargestLoopsDf <- as.data.frame(largestLoopsGr) %>% dplyr::mutate(loopID = paste(seqnames, start, end, sep = \\_\\))\n\nloopIDpairs <- data.frame(loopID = completeOverlapDf$loopIDAll[queryHits(overlaps)],\n                          loopID2 = largestLoopsDf$loopID[subjectHits(overlaps)])\n\n# allLoopsAnnotated <- allLoops %>% dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \\_\\)) %>% dplyr::left_join(loopIDpairs, by = c(\\loopID\\))\n\n\n##################################\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>% unnest(gene) %>%\n  dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \\_\\))\ntemp <- geneAnnoData %>% dplyr::left_join(loopIDpairs, by = c(\\loopID\\))\ntemp2 <- temp %>% dplyr::select(gene, loopID2) %>%\n  group_by(gene) %>%              # Group data by the 'gene' column\n  summarize(geneHasSS = !all(is.na(loopID2)))  # Check if all loopID2 values for each gene are NA\ntemp <- temp %>% left_join(temp2, by = c(\\gene\\))\ndata.all <- temp %>% dplyr::mutate(group = ifelse(!geneHasSS, \\No\\,\n                                              ifelse(is.na(loopID2), \\Outside\\, \\Within\\)),\n                               size = start2 - start1)\n\n##################################\noutfile <- data.all %>% dplyr::select(loopID2, gene) %>% dplyr::filter(!is.na(loopID2)) %>%\n  separate(loopID2, into = c(\\chrom\\, \\start\\, \\end\\), sep = \\_\\, convert = TRUE)\n# fwrite(outfile, here(consensusDir, \\convergent_ss_domain.bed\\), sep = \\\\t\\, col.names = FALSE)\n```\n\n<!-- rnb-source-end -->\n"} -->
# Extract loop boundary from left to right
temp <- convergent_loops %>% dplyr::select(c(1, 2, 6))
colnames(temp) <- c(\chrom\, \start\, \end\)
strLoopsGr <- makeGRangesFromDataFrame(temp)

# IMPORT TSS
flankSize <- 10
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c(\chrom\, \start\, \end\, \ensembl\, \gene\)
geneGr <- makeGRangesFromDataFrame(gene.tb, keep.extra.columns = TRUE)


# Find overlaps between loops and TSS
overlaps <- findOverlaps(geneGr, strLoopsGr)

# Annotate overlaps
tss_with_loops <- geneGr[queryHits(overlaps)]
loops_with_tss <- strLoopsGr[subjectHits(overlaps)]

# Combine into a data frame for processing
loop_data <- data.frame(gene = tss_with_loops$ensembl,
                        loop_chr = seqnames(loops_with_tss),
                        loop_start = start(loops_with_tss),
                        loop_end = end(loops_with_tss),
                        loop_width = width(loops_with_tss))

# Identify the largest loop for each gene
largest_loops <- loop_data[order(loop_data$gene, -loop_data$loop_width), ]
largest_loops <- largest_loops[!duplicated(largest_loops$gene), ]
largest_loops <- largest_loops %>% dplyr::mutate(loopID = paste(loop_chr, loop_start, loop_end, sep = \_\))
largest_loops <- largest_loops[order(largest_loops$loop_chr, largest_loops$loop_start),]
rownames(largest_loops) <- NULL

# Checking smaller loops
allLoopsGr <- makeGRangesFromDataFrame(allLoops, 
                                       seqnames.field = \chrom1\, 
                                       start.field = \start1\, 
                                       end.field = \end2\)
largestLoopsGr <- makeGRangesFromDataFrame(largest_loops, 
                                           seqnames.field = \loop_chr\, 
                                           start.field = \loop_start\, 
                                           end.field = \loop_end\)
largestLoopsGr <- sort(unique(largestLoopsGr))
complete_overlaps <- subsetByOverlaps(allLoopsGr, largestLoopsGr, type = \within\)
overlaps <- findOverlaps(complete_overlaps, largestLoopsGr)


completeOverlapDf <- as.data.frame(complete_overlaps) %>% dplyr::mutate(loopIDAll = paste(seqnames, start, end, sep = \_\))
largestLoopsDf <- as.data.frame(largestLoopsGr) %>% dplyr::mutate(loopID = paste(seqnames, start, end, sep = \_\))

loopIDpairs <- data.frame(loopID = completeOverlapDf$loopIDAll[queryHits(overlaps)],
                          loopID2 = largestLoopsDf$loopID[subjectHits(overlaps)])

# allLoopsAnnotated <- allLoops %>% dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \_\)) %>% dplyr::left_join(loopIDpairs, by = c(\loopID\))


##################################
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\)) %>% unnest(gene) %>%
  dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \_\))
temp <- geneAnnoData %>% dplyr::left_join(loopIDpairs, by = c(\loopID\))
temp2 <- temp %>% dplyr::select(gene, loopID2) %>%
  group_by(gene) %>%              # Group data by the 'gene' column
  summarize(geneHasSS = !all(is.na(loopID2)))  # Check if all loopID2 values for each gene are NA
temp <- temp %>% left_join(temp2, by = c(\gene\))
data.all <- temp %>% dplyr::mutate(group = ifelse(!geneHasSS, \No\,
                                              ifelse(is.na(loopID2), \Outside\, \Within\)),
                               size = start2 - start1)

##################################
outfile <- data.all %>% dplyr::select(loopID2, gene) %>% dplyr::filter(!is.na(loopID2)) %>%
  separate(loopID2, into = c(\chrom\, \start\, \end\), sep = \_\, convert = TRUE)
# fwrite(outfile, here(consensusDir, \convergent_ss_domain.bed\), sep = \\t\, col.names = FALSE)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBFeHRyYWN0IGxvb3AgYm91bmRhcnkgZnJvbSBsZWZ0IHRvIHJpZ2h0XG50ZW1wIDwtIGNvbnZlcmdlbnRfbG9vcHMgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCA2KSlcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxjaHJvbVxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5zdHJMb29wc0dyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxuXG4jIElNUE9SVCBUU1NcbmZsYW5rU2l6ZSA8LSAxMFxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSxcbiAgICAgICAgICAgICAgICBUU1NzdGFydCA9IFRTUyAtIGZsYW5rU2l6ZSxcbiAgICAgICAgICAgICAgICBUU1NlbmQgPSBUU1MgKyBmbGFua1NpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBUU1NzdGFydCwgVFNTZW5kLCBWNiwgVjUpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFxcY2hyb21cXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGVuc2VtYmxcXCwgXFxnZW5lXFwpXG5nZW5lR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGdlbmUudGIsIGtlZXAuZXh0cmEuY29sdW1ucyA9IFRSVUUpXG5cblxuIyBGaW5kIG92ZXJsYXBzIGJldHdlZW4gbG9vcHMgYW5kIFRTU1xub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGdlbmVHciwgc3RyTG9vcHNHcilcblxuIyBBbm5vdGF0ZSBvdmVybGFwc1xudHNzX3dpdGhfbG9vcHMgPC0gZ2VuZUdyW3F1ZXJ5SGl0cyhvdmVybGFwcyldXG5sb29wc193aXRoX3RzcyA8LSBzdHJMb29wc0dyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV1cblxuIyBDb21iaW5lIGludG8gYSBkYXRhIGZyYW1lIGZvciBwcm9jZXNzaW5nXG5sb29wX2RhdGEgPC0gZGF0YS5mcmFtZShnZW5lID0gdHNzX3dpdGhfbG9vcHMkZW5zZW1ibCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BfY2hyID0gc2VxbmFtZXMobG9vcHNfd2l0aF90c3MpLFxuICAgICAgICAgICAgICAgICAgICAgICAgbG9vcF9zdGFydCA9IHN0YXJ0KGxvb3BzX3dpdGhfdHNzKSxcbiAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BfZW5kID0gZW5kKGxvb3BzX3dpdGhfdHNzKSxcbiAgICAgICAgICAgICAgICAgICAgICAgIGxvb3Bfd2lkdGggPSB3aWR0aChsb29wc193aXRoX3RzcykpXG5cbiMgSWRlbnRpZnkgdGhlIGxhcmdlc3QgbG9vcCBmb3IgZWFjaCBnZW5lXG5sYXJnZXN0X2xvb3BzIDwtIGxvb3BfZGF0YVtvcmRlcihsb29wX2RhdGEkZ2VuZSwgLWxvb3BfZGF0YSRsb29wX3dpZHRoKSwgXVxubGFyZ2VzdF9sb29wcyA8LSBsYXJnZXN0X2xvb3BzWyFkdXBsaWNhdGVkKGxhcmdlc3RfbG9vcHMkZ2VuZSksIF1cbmxhcmdlc3RfbG9vcHMgPC0gbGFyZ2VzdF9sb29wcyAlPiUgZHBseXI6Om11dGF0ZShsb29wSUQgPSBwYXN0ZShsb29wX2NociwgbG9vcF9zdGFydCwgbG9vcF9lbmQsIHNlcCA9IFxcX1xcKSlcbmxhcmdlc3RfbG9vcHMgPC0gbGFyZ2VzdF9sb29wc1tvcmRlcihsYXJnZXN0X2xvb3BzJGxvb3BfY2hyLCBsYXJnZXN0X2xvb3BzJGxvb3Bfc3RhcnQpLF1cbnJvd25hbWVzKGxhcmdlc3RfbG9vcHMpIDwtIE5VTExcblxuIyBDaGVja2luZyBzbWFsbGVyIGxvb3BzXG5hbGxMb29wc0dyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhbGxMb29wcywgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzZXFuYW1lcy5maWVsZCA9IFxcY2hyb20xXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3RhcnQuZmllbGQgPSBcXHN0YXJ0MVxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZC5maWVsZCA9IFxcZW5kMlxcKVxubGFyZ2VzdExvb3BzR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGxhcmdlc3RfbG9vcHMsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNlcW5hbWVzLmZpZWxkID0gXFxsb29wX2NoclxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdGFydC5maWVsZCA9IFxcbG9vcF9zdGFydFxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmQuZmllbGQgPSBcXGxvb3BfZW5kXFwpXG5sYXJnZXN0TG9vcHNHciA8LSBzb3J0KHVuaXF1ZShsYXJnZXN0TG9vcHNHcikpXG5jb21wbGV0ZV9vdmVybGFwcyA8LSBzdWJzZXRCeU92ZXJsYXBzKGFsbExvb3BzR3IsIGxhcmdlc3RMb29wc0dyLCB0eXBlID0gXFx3aXRoaW5cXClcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhjb21wbGV0ZV9vdmVybGFwcywgbGFyZ2VzdExvb3BzR3IpXG5cblxuY29tcGxldGVPdmVybGFwRGYgPC0gYXMuZGF0YS5mcmFtZShjb21wbGV0ZV9vdmVybGFwcykgJT4lIGRwbHlyOjptdXRhdGUobG9vcElEQWxsID0gcGFzdGUoc2VxbmFtZXMsIHN0YXJ0LCBlbmQsIHNlcCA9IFxcX1xcKSlcbmxhcmdlc3RMb29wc0RmIDwtIGFzLmRhdGEuZnJhbWUobGFyZ2VzdExvb3BzR3IpICU+JSBkcGx5cjo6bXV0YXRlKGxvb3BJRCA9IHBhc3RlKHNlcW5hbWVzLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCkpXG5cbmxvb3BJRHBhaXJzIDwtIGRhdGEuZnJhbWUobG9vcElEID0gY29tcGxldGVPdmVybGFwRGYkbG9vcElEQWxsW3F1ZXJ5SGl0cyhvdmVybGFwcyldLFxuICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wSUQyID0gbGFyZ2VzdExvb3BzRGYkbG9vcElEW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbiMgYWxsTG9vcHNBbm5vdGF0ZWQgPC0gYWxsTG9vcHMgJT4lIGRwbHlyOjptdXRhdGUobG9vcElEID0gcGFzdGUoY2hyb20xLCBzdGFydDEsIGVuZDIsIHNlcCA9IFxcX1xcKSkgJT4lIGRwbHlyOjpsZWZ0X2pvaW4obG9vcElEcGFpcnMsIGJ5ID0gYyhcXGxvb3BJRFxcKSlcblxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5kaWZmQ3V0b2ZmIDwtIDAuMlxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLW5fZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IGRpZmZDdXRvZmYsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9MaXN0ID0gYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcKSkgJT4lIHVubmVzdChnZW5lKSAlPiVcbiAgZHBseXI6Om11dGF0ZShsb29wSUQgPSBwYXN0ZShjaHJvbTEsIHN0YXJ0MSwgZW5kMiwgc2VwID0gXFxfXFwpKVxudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4obG9vcElEcGFpcnMsIGJ5ID0gYyhcXGxvb3BJRFxcKSlcbnRlbXAyIDwtIHRlbXAgJT4lIGRwbHlyOjpzZWxlY3QoZ2VuZSwgbG9vcElEMikgJT4lXG4gIGdyb3VwX2J5KGdlbmUpICU+JSAgICAgICAgICAgICAgIyBHcm91cCBkYXRhIGJ5IHRoZSAnZ2VuZScgY29sdW1uXG4gIHN1bW1hcml6ZShnZW5lSGFzU1MgPSAhYWxsKGlzLm5hKGxvb3BJRDIpKSkgICMgQ2hlY2sgaWYgYWxsIGxvb3BJRDIgdmFsdWVzIGZvciBlYWNoIGdlbmUgYXJlIE5BXG50ZW1wIDwtIHRlbXAgJT4lIGxlZnRfam9pbih0ZW1wMiwgYnkgPSBjKFxcZ2VuZVxcKSlcbmRhdGEuYWxsIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBpZmVsc2UoIWdlbmVIYXNTUywgXFxOb1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShpcy5uYShsb29wSUQyKSwgXFxPdXRzaWRlXFwsIFxcV2l0aGluXFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzaXplID0gc3RhcnQyIC0gc3RhcnQxKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5vdXRmaWxlIDwtIGRhdGEuYWxsICU+JSBkcGx5cjo6c2VsZWN0KGxvb3BJRDIsIGdlbmUpICU+JSBkcGx5cjo6ZmlsdGVyKCFpcy5uYShsb29wSUQyKSkgJT4lXG4gIHNlcGFyYXRlKGxvb3BJRDIsIGludG8gPSBjKFxcY2hyb21cXCwgXFxzdGFydFxcLCBcXGVuZFxcKSwgc2VwID0gXFxfXFwsIGNvbnZlcnQgPSBUUlVFKVxuIyBmd3JpdGUob3V0ZmlsZSwgaGVyZShjb25zZW5zdXNEaXIsIFxcY29udmVyZ2VudF9zc19kb21haW4uYmVkXFwpLCBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBGQUxTRSlcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\n# Extract loop boundary from left to right\ntemp <- convergent_loops %>% dplyr::select(c(1, 2, 6))\ncolnames(temp) <- c(\\chrom\\, \\start\\, \\end\\)\nstrLoopsGr <- makeGRangesFromDataFrame(temp)\n\n# IMPORT TSS\nflankSize <- 10\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V1, TSSstart, TSSend, V6, V5)\ncolnames(gene.tb) <- c(\\chrom\\, \\start\\, \\end\\, \\ensembl\\, \\gene\\)\ngeneGr <- makeGRangesFromDataFrame(gene.tb, keep.extra.columns = TRUE)\n\n\n# Find overlaps between loops and TSS\noverlaps <- findOverlaps(geneGr, strLoopsGr)\n\n# Annotate overlaps\ntss_with_loops <- geneGr[queryHits(overlaps)]\nloops_with_tss <- strLoopsGr[subjectHits(overlaps)]\n\n# Combine into a data frame for processing\nloop_data <- data.frame(gene = tss_with_loops$ensembl,\n                        loop_chr = seqnames(loops_with_tss),\n                        loop_start = start(loops_with_tss),\n                        loop_end = end(loops_with_tss),\n                        loop_width = width(loops_with_tss))\n\n# Identify the largest loop for each gene\nlargest_loops <- loop_data[order(loop_data$gene, -loop_data$loop_width), ]\nlargest_loops <- largest_loops[!duplicated(largest_loops$gene), ]\nlargest_loops <- largest_loops %>% dplyr::mutate(loopID = paste(loop_chr, loop_start, loop_end, sep = \\_\\))\nlargest_loops <- largest_loops[order(largest_loops$loop_chr, largest_loops$loop_start),]\nrownames(largest_loops) <- NULL\n\n# Checking smaller loops\nallLoopsGr <- makeGRangesFromDataFrame(allLoops, \n                                       seqnames.field = \\chrom1\\, \n                                       start.field = \\start1\\, \n                                       end.field = \\end2\\)\nlargestLoopsGr <- makeGRangesFromDataFrame(largest_loops, \n                                           seqnames.field = \\loop_chr\\, \n                                           start.field = \\loop_start\\, \n                                           end.field = \\loop_end\\)\nlargestLoopsGr <- sort(unique(largestLoopsGr))\ncomplete_overlaps <- subsetByOverlaps(allLoopsGr, largestLoopsGr, type = \\within\\)\noverlaps <- findOverlaps(complete_overlaps, largestLoopsGr)\n\n\ncompleteOverlapDf <- as.data.frame(complete_overlaps) %>% dplyr::mutate(loopIDAll = paste(seqnames, start, end, sep = \\_\\))\nlargestLoopsDf <- as.data.frame(largestLoopsGr) %>% dplyr::mutate(loopID = paste(seqnames, start, end, sep = \\_\\))\n\nloopIDpairs <- data.frame(loopID = completeOverlapDf$loopIDAll[queryHits(overlaps)],\n                          loopID2 = largestLoopsDf$loopID[subjectHits(overlaps)])\n\n# allLoopsAnnotated <- allLoops %>% dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \\_\\)) %>% dplyr::left_join(loopIDpairs, by = c(\\loopID\\))\n\n\n##################################\ndiffCutoff <- 0.2\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = diffCutoff,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\)) %>% unnest(gene) %>%\n  dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \\_\\))\ntemp <- geneAnnoData %>% dplyr::left_join(loopIDpairs, by = c(\\loopID\\))\ntemp2 <- temp %>% dplyr::select(gene, loopID2) %>%\n  group_by(gene) %>%              # Group data by the 'gene' column\n  summarize(geneHasSS = !all(is.na(loopID2)))  # Check if all loopID2 values for each gene are NA\ntemp <- temp %>% left_join(temp2, by = c(\\gene\\))\ndata.all <- temp %>% dplyr::mutate(group = ifelse(!geneHasSS, \\No\\,\n                                              ifelse(is.na(loopID2), \\Outside\\, \\Within\\)),\n                               size = start2 - start1)\n\n##################################\noutfile <- data.all %>% dplyr::select(loopID2, gene) %>% dplyr::filter(!is.na(loopID2)) %>%\n  separate(loopID2, into = c(\\chrom\\, \\start\\, \\end\\), sep = \\_\\, convert = TRUE)\n# fwrite(outfile, here(consensusDir, \\convergent_ss_domain.bed\\), sep = \\\\t\\, col.names = FALSE)\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuIyBFeHRyYWN0IGxvb3AgYm91bmRhcnkgZnJvbSBsZWZ0IHRvIHJpZ2h0XG50ZW1wIDwtIGNvbnZlcmdlbnRfbG9vcHMgJT4lIGRwbHlyOjpzZWxlY3QoYygxLCAyLCA2KSlcbmNvbG5hbWVzKHRlbXApIDwtIGMoXFxjaHJvbVxcLCBcXHN0YXJ0XFwsIFxcZW5kXFwpXG5zdHJMb29wc0dyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZSh0ZW1wKVxuXG4jIElNUE9SVCBUU1NcbmZsYW5rU2l6ZSA8LSAxMFxuZ2VuZS50YiA8LSBmcmVhZChoZXJlKHJlZkRpciwgXFxtbTEwX0dSQ20zOC5wNl9nZW5lX3NvcnRlZC5iZWRcXCkpICU+JVxuICBkcGx5cjo6bXV0YXRlKFRTUyA9IGlmZWxzZShWNCA9PSBcXCtcXCwgVjIsIFYzKSxcbiAgICAgICAgICAgICAgICBUU1NzdGFydCA9IFRTUyAtIGZsYW5rU2l6ZSxcbiAgICAgICAgICAgICAgICBUU1NlbmQgPSBUU1MgKyBmbGFua1NpemUpICU+JVxuICBkcGx5cjo6c2VsZWN0KFYxLCBUU1NzdGFydCwgVFNTZW5kLCBWNiwgVjUpXG5jb2xuYW1lcyhnZW5lLnRiKSA8LSBjKFxcY2hyb21cXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGVuc2VtYmxcXCwgXFxnZW5lXFwpXG5nZW5lR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGdlbmUudGIsIGtlZXAuZXh0cmEuY29sdW1ucyA9IFRSVUUpXG5cblxuIyBGaW5kIG92ZXJsYXBzIGJldHdlZW4gbG9vcHMgYW5kIFRTU1xub3ZlcmxhcHMgPC0gZmluZE92ZXJsYXBzKGdlbmVHciwgc3RyTG9vcHNHcilcblxuIyBBbm5vdGF0ZSBvdmVybGFwc1xudHNzX3dpdGhfbG9vcHMgPC0gZ2VuZUdyW3F1ZXJ5SGl0cyhvdmVybGFwcyldXG5sb29wc193aXRoX3RzcyA8LSBzdHJMb29wc0dyW3N1YmplY3RIaXRzKG92ZXJsYXBzKV1cblxuIyBDb21iaW5lIGludG8gYSBkYXRhIGZyYW1lIGZvciBwcm9jZXNzaW5nXG5sb29wX2RhdGEgPC0gZGF0YS5mcmFtZShnZW5lID0gdHNzX3dpdGhfbG9vcHMkZW5zZW1ibCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BfY2hyID0gc2VxbmFtZXMobG9vcHNfd2l0aF90c3MpLFxuICAgICAgICAgICAgICAgICAgICAgICAgbG9vcF9zdGFydCA9IHN0YXJ0KGxvb3BzX3dpdGhfdHNzKSxcbiAgICAgICAgICAgICAgICAgICAgICAgIGxvb3BfZW5kID0gZW5kKGxvb3BzX3dpdGhfdHNzKSxcbiAgICAgICAgICAgICAgICAgICAgICAgIGxvb3Bfd2lkdGggPSB3aWR0aChsb29wc193aXRoX3RzcykpXG5cbiMgSWRlbnRpZnkgdGhlIGxhcmdlc3QgbG9vcCBmb3IgZWFjaCBnZW5lXG5sYXJnZXN0X2xvb3BzIDwtIGxvb3BfZGF0YVtvcmRlcihsb29wX2RhdGEkZ2VuZSwgLWxvb3BfZGF0YSRsb29wX3dpZHRoKSwgXVxubGFyZ2VzdF9sb29wcyA8LSBsYXJnZXN0X2xvb3BzWyFkdXBsaWNhdGVkKGxhcmdlc3RfbG9vcHMkZ2VuZSksIF1cbmxhcmdlc3RfbG9vcHMgPC0gbGFyZ2VzdF9sb29wcyAlPiUgZHBseXI6Om11dGF0ZShsb29wSUQgPSBwYXN0ZShsb29wX2NociwgbG9vcF9zdGFydCwgbG9vcF9lbmQsIHNlcCA9IFxcX1xcKSlcbmxhcmdlc3RfbG9vcHMgPC0gbGFyZ2VzdF9sb29wc1tvcmRlcihsYXJnZXN0X2xvb3BzJGxvb3BfY2hyLCBsYXJnZXN0X2xvb3BzJGxvb3Bfc3RhcnQpLF1cbnJvd25hbWVzKGxhcmdlc3RfbG9vcHMpIDwtIE5VTExcblxuIyBDaGVja2luZyBzbWFsbGVyIGxvb3BzXG5hbGxMb29wc0dyIDwtIG1ha2VHUmFuZ2VzRnJvbURhdGFGcmFtZShhbGxMb29wcywgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzZXFuYW1lcy5maWVsZCA9IFxcY2hyb20xXFwsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc3RhcnQuZmllbGQgPSBcXHN0YXJ0MVxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZC5maWVsZCA9IFxcZW5kMlxcKVxubGFyZ2VzdExvb3BzR3IgPC0gbWFrZUdSYW5nZXNGcm9tRGF0YUZyYW1lKGxhcmdlc3RfbG9vcHMsIFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHNlcW5hbWVzLmZpZWxkID0gXFxsb29wX2NoclxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzdGFydC5maWVsZCA9IFxcbG9vcF9zdGFydFxcLCBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmQuZmllbGQgPSBcXGxvb3BfZW5kXFwpXG5sYXJnZXN0TG9vcHNHciA8LSBzb3J0KHVuaXF1ZShsYXJnZXN0TG9vcHNHcikpXG5jb21wbGV0ZV9vdmVybGFwcyA8LSBzdWJzZXRCeU92ZXJsYXBzKGFsbExvb3BzR3IsIGxhcmdlc3RMb29wc0dyLCB0eXBlID0gXFx3aXRoaW5cXClcbm92ZXJsYXBzIDwtIGZpbmRPdmVybGFwcyhjb21wbGV0ZV9vdmVybGFwcywgbGFyZ2VzdExvb3BzR3IpXG5cblxuY29tcGxldGVPdmVybGFwRGYgPC0gYXMuZGF0YS5mcmFtZShjb21wbGV0ZV9vdmVybGFwcykgJT4lIGRwbHlyOjptdXRhdGUobG9vcElEQWxsID0gcGFzdGUoc2VxbmFtZXMsIHN0YXJ0LCBlbmQsIHNlcCA9IFxcX1xcKSlcbmxhcmdlc3RMb29wc0RmIDwtIGFzLmRhdGEuZnJhbWUobGFyZ2VzdExvb3BzR3IpICU+JSBkcGx5cjo6bXV0YXRlKGxvb3BJRCA9IHBhc3RlKHNlcW5hbWVzLCBzdGFydCwgZW5kLCBzZXAgPSBcXF9cXCkpXG5cbmxvb3BJRHBhaXJzIDwtIGRhdGEuZnJhbWUobG9vcElEID0gY29tcGxldGVPdmVybGFwRGYkbG9vcElEQWxsW3F1ZXJ5SGl0cyhvdmVybGFwcyldLFxuICAgICAgICAgICAgICAgICAgICAgICAgICBsb29wSUQyID0gbGFyZ2VzdExvb3BzRGYkbG9vcElEW3N1YmplY3RIaXRzKG92ZXJsYXBzKV0pXG5cbiMgYWxsTG9vcHNBbm5vdGF0ZWQgPC0gYWxsTG9vcHMgJT4lIGRwbHlyOjptdXRhdGUobG9vcElEID0gcGFzdGUoY2hyb20xLCBzdGFydDEsIGVuZDIsIHNlcCA9IFxcX1xcKSkgJT4lIGRwbHlyOjpsZWZ0X2pvaW4obG9vcElEcGFpcnMsIGJ5ID0gYyhcXGxvb3BJRFxcKSlcblxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5kaWZmQ3V0b2ZmIDwtIDAuMlxuZ2VuZUFubm9EYXRhIDwtIGxvYWRMb29wQW5ub0RhdGEoaGVyZShjb25zZW5zdXNEaXIsIHBhc3RlMChuYW1lLCBcXF9wLW5fZW5zZW1ibExpc3QudHN2XFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZGlmZkN1dG9mZiA9IGRpZmZDdXRvZmYsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9MaXN0ID0gYyhcXFAtUFxcLCBcXFAtRVxcLCBcXFAtU1xcLCBcXFAtWFxcKSkgJT4lIHVubmVzdChnZW5lKSAlPiVcbiAgZHBseXI6Om11dGF0ZShsb29wSUQgPSBwYXN0ZShjaHJvbTEsIHN0YXJ0MSwgZW5kMiwgc2VwID0gXFxfXFwpKVxudGVtcCA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpsZWZ0X2pvaW4obG9vcElEcGFpcnMsIGJ5ID0gYyhcXGxvb3BJRFxcKSlcbnRlbXAyIDwtIHRlbXAgJT4lIGRwbHlyOjpzZWxlY3QoZ2VuZSwgbG9vcElEMikgJT4lXG4gIGdyb3VwX2J5KGdlbmUpICU+JSAgICAgICAgICAgICAgIyBHcm91cCBkYXRhIGJ5IHRoZSAnZ2VuZScgY29sdW1uXG4gIHN1bW1hcml6ZShnZW5lSGFzU1MgPSAhYWxsKGlzLm5hKGxvb3BJRDIpKSkgICMgQ2hlY2sgaWYgYWxsIGxvb3BJRDIgdmFsdWVzIGZvciBlYWNoIGdlbmUgYXJlIE5BXG50ZW1wIDwtIHRlbXAgJT4lIGxlZnRfam9pbih0ZW1wMiwgYnkgPSBjKFxcZ2VuZVxcKSlcbmRhdGEuYWxsIDwtIHRlbXAgJT4lIGRwbHlyOjptdXRhdGUoZ3JvdXAgPSBpZmVsc2UoIWdlbmVIYXNTUywgXFxOb1xcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmZWxzZShpcy5uYShsb29wSUQyKSwgXFxPdXRzaWRlXFwsIFxcV2l0aGluXFwpKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzaXplID0gc3RhcnQyIC0gc3RhcnQxKVxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5vdXRmaWxlIDwtIGRhdGEuYWxsICU+JSBkcGx5cjo6c2VsZWN0KGxvb3BJRDIsIGdlbmUpICU+JSBkcGx5cjo6ZmlsdGVyKCFpcy5uYShsb29wSUQyKSkgJT4lXG4gIHNlcGFyYXRlKGxvb3BJRDIsIGludG8gPSBjKFxcY2hyb21cXCwgXFxzdGFydFxcLCBcXGVuZFxcKSwgc2VwID0gXFxfXFwsIGNvbnZlcnQgPSBUUlVFKVxuIyBmd3JpdGUob3V0ZmlsZSwgaGVyZShjb25zZW5zdXNEaXIsIFxcY29udmVyZ2VudF9zc19kb21haW4uYmVkXFwpLCBzZXAgPSBcXFxcdFxcLCBjb2wubmFtZXMgPSBGQUxTRSlcbmBgYFxuYGBgIn0= -->

```r
```r
# Extract loop boundary from left to right
temp <- convergent_loops %>% dplyr::select(c(1, 2, 6))
colnames(temp) <- c(\chrom\, \start\, \end\)
strLoopsGr <- makeGRangesFromDataFrame(temp)

# IMPORT TSS
flankSize <- 10
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c(\chrom\, \start\, \end\, \ensembl\, \gene\)
geneGr <- makeGRangesFromDataFrame(gene.tb, keep.extra.columns = TRUE)


# Find overlaps between loops and TSS
overlaps <- findOverlaps(geneGr, strLoopsGr)

# Annotate overlaps
tss_with_loops <- geneGr[queryHits(overlaps)]
loops_with_tss <- strLoopsGr[subjectHits(overlaps)]

# Combine into a data frame for processing
loop_data <- data.frame(gene = tss_with_loops$ensembl,
                        loop_chr = seqnames(loops_with_tss),
                        loop_start = start(loops_with_tss),
                        loop_end = end(loops_with_tss),
                        loop_width = width(loops_with_tss))

# Identify the largest loop for each gene
largest_loops <- loop_data[order(loop_data$gene, -loop_data$loop_width), ]
largest_loops <- largest_loops[!duplicated(largest_loops$gene), ]
largest_loops <- largest_loops %>% dplyr::mutate(loopID = paste(loop_chr, loop_start, loop_end, sep = \_\))
largest_loops <- largest_loops[order(largest_loops$loop_chr, largest_loops$loop_start),]
rownames(largest_loops) <- NULL

# Checking smaller loops
allLoopsGr <- makeGRangesFromDataFrame(allLoops, 
                                       seqnames.field = \chrom1\, 
                                       start.field = \start1\, 
                                       end.field = \end2\)
largestLoopsGr <- makeGRangesFromDataFrame(largest_loops, 
                                           seqnames.field = \loop_chr\, 
                                           start.field = \loop_start\, 
                                           end.field = \loop_end\)
largestLoopsGr <- sort(unique(largestLoopsGr))
complete_overlaps <- subsetByOverlaps(allLoopsGr, largestLoopsGr, type = \within\)
overlaps <- findOverlaps(complete_overlaps, largestLoopsGr)


completeOverlapDf <- as.data.frame(complete_overlaps) %>% dplyr::mutate(loopIDAll = paste(seqnames, start, end, sep = \_\))
largestLoopsDf <- as.data.frame(largestLoopsGr) %>% dplyr::mutate(loopID = paste(seqnames, start, end, sep = \_\))

loopIDpairs <- data.frame(loopID = completeOverlapDf$loopIDAll[queryHits(overlaps)],
                          loopID2 = largestLoopsDf$loopID[subjectHits(overlaps)])

# allLoopsAnnotated <- allLoops %>% dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \_\)) %>% dplyr::left_join(loopIDpairs, by = c(\loopID\))


##################################
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = diffCutoff,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\)) %>% unnest(gene) %>%
  dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \_\))
temp <- geneAnnoData %>% dplyr::left_join(loopIDpairs, by = c(\loopID\))
temp2 <- temp %>% dplyr::select(gene, loopID2) %>%
  group_by(gene) %>%              # Group data by the 'gene' column
  summarize(geneHasSS = !all(is.na(loopID2)))  # Check if all loopID2 values for each gene are NA
temp <- temp %>% left_join(temp2, by = c(\gene\))
data.all <- temp %>% dplyr::mutate(group = ifelse(!geneHasSS, \No\,
                                              ifelse(is.na(loopID2), \Outside\, \Within\)),
                               size = start2 - start1)

##################################
outfile <- data.all %>% dplyr::select(loopID2, gene) %>% dplyr::filter(!is.na(loopID2)) %>%
  separate(loopID2, into = c(\chrom\, \start\, \end\), sep = \_\, convert = TRUE)
# fwrite(outfile, here(consensusDir, \convergent_ss_domain.bed\), sep = \\t\, col.names = FALSE)
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [3.41] Finding largest convergent encompassing S-S
#### Filtering convergent S-S loops

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ndata <- data.all %>% dplyr::filter(Anno2 %in% c(\"P-E\"))\n\ntemp <- data %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()\n\ntemp1 <- temp %>% dplyr::filter(group == \"No\") %>% dplyr::select(-group)\nfwrite(temp1, here(consensusDir, \"insulated_domain_ss_no.bedpe\"), sep = \"\\t\", col.names = FALSE)\ntemp2 <- temp %>% dplyr::filter(group == \"Within\") %>% dplyr::select(-group)\nfwrite(temp2, here(consensusDir, \"insulated_domain_ss_within.bedpe\"), sep = \"\\t\", col.names = FALSE)\ntemp3 <- temp %>% dplyr::filter(group == \"Outside\") %>% dplyr::select(-group)\nfwrite(temp3, here(consensusDir, \"insulated_domain_ss_outside.bedpe\"), sep = \"\\t\", col.names = FALSE)\n\ntemp <- data %>% dplyr::select(id, group, size) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$size\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$size\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nconvPvalue(getPvalWilcox(temp, \"No\", \"Within\"))\nconvPvalue(getPvalWilcox(temp, \"No\", \"Outside\"))\nconvPvalue(getPvalWilcox(temp, \"Outside\", \"Within\"))\n\n\np <- ggplot(temp, aes(x = group, y = size, fill = group)) + \n  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \"square\", alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \"black\",\n                 linewidth = lineMedium * mmToLineUnit, lineend = \"square\",\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n  scale_fill_manual(values = c(\"#777777\", \"#F28E2C\", \"#F28E2C\")) +\n  stat_summary(\n      aes(group = group), fun = mean,\n      geom = \"point\", shape = 21, size = 0.5,\n      fill = \"black\", color = \"black\", position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \"Loop size\")\n\nfileName <- paste0(\"insulationBoundary_size_convSS_PE\")\nwidth <-33*mmToInch\nheight <- 35*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntemp <- data %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()\n\nconvPvalue(getPvalWilcox(temp, \"No\", \"Within\"))\nconvPvalue(getPvalWilcox(temp, \"No\", \"Outside\"))\nconvPvalue(getPvalWilcox(temp, \"Outside\", \"Within\"))\n\np <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineMedium * mmToLineUnit, lineend = \"square\", alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \"black\",\n               linewidth = lineMedium * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() +   \n    scale_fill_manual(values = c(\"#777777\", \"#F28E2C\", \"#F28E2C\")) +\n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \"point\", shape = 21, size = 0.5,\n    fill = \"black\", color = \"black\", position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \"Δ loop score\") +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\") + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\", linetype = \"dashed\") +\n  coord_cartesian(ylim = c(-0.8, 0.5))\n    \nfileName <- paste0(\"insulationBoundary_delta_convSS_pe\")\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n###################### \n\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\"loopScore_cons_obsexp.tsv\"))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ndata2 <- data %>% left_join(obsexp, by = c(\"id\"))\n\ntemp <- data2 %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nconvPvalue(getPvalWilcox(temp, \"No\", \"Within\"))\nconvPvalue(getPvalWilcox(temp, \"No\", \"Outside\"))\nconvPvalue(getPvalWilcox(temp, \"Outside\", \"Within\"))\n\n\np <- ggplot(temp, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \"square\", alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \"black\",\n               linewidth = lineMedium * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  scale_fill_manual(values = c(\"#777777\", \"#F28E2C\", \"#F28E2C\")) +\n  \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \"point\", shape = 21, size = 0.5,\n    fill = \"black\", color = \"black\", position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \"log2(fc of obs/exp)\") +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\") + \n  coord_cartesian(ylim = c(-2, 2))\n    width <-30*mmToInch\nheight <- 35*mmToInch\nfileName <- paste0(\"insulationBoundary_obsexp_convSS_pe\")\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n\n\n\n#####################\n\ndata <- data.all\ngene.withinBoundary <- unique((data %>% dplyr::filter(group == \"Within\"))$gene)\ngene.outsideBoundary <- unique((data %>% dplyr::filter(group == \"Outside\"))$gene)\ngene.noBoundary <- unique((data %>% dplyr::filter(group == \"No\"))$gene)\n\ngene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))\n\ngene.group1 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\"))$gene\ngene.group2 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\"))$gene\n\nprint(\"perc of gene with loop within Boundary\")\nsum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100\n\nprint(\"perc of gene with loop outside Boundary\")\nsum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100\n\nprint(\"perc of gene with loop with no Boundary\")\nsum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100\n\n\ndiff.RNA <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%\n  dplyr::mutate(group = case_when(\n    ensembl_gene_id %in% gene.wBoundary ~ \"withinBoundary\",\n    ensembl_gene_id %in% gene.noBoundary ~ \"noBoundary\",\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group)) %>%\n  dplyr::mutate(absLog2FC = abs(log2FoldChange))\nks_result <- ks.test(\n  diff.RNA %>% dplyr::filter(group == \"withinBoundary\") %>% pull(absLog2FC),\n  diff.RNA %>% dplyr::filter(group == \"noBoundary\") %>% pull(absLog2FC)\n)\n\nggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)\n\n# getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC\n#   distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n# convPvalue(getPvalWilcox(diff.RNA, \"withBoundary\", \"noBoundary\"))\n# \n\n# Create the CDF plot\np <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +\n  scale_color_manual(values = (c(\"#777777\", \"#F28E2C\"))) +\n\nstat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \"square\"  ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \"Abs. log2(fold change)\",\n    y = \"Cumulative Probability\"\n  ) + coord_cartesian(xlim = c(0, 1)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.position = \"none\",\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\nfileName <- paste0(\"log2FC_cdf_insulationBoundary_convSS_pe\")\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()\n```"} -->\n\n```r\ndata <- data.all %>% dplyr::filter(Anno2 %in% c(\\P-E\\))\n\ntemp <- data %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()\n\ntemp1 <- temp %>% dplyr::filter(group == \\No\\) %>% dplyr::select(-group)\nfwrite(temp1, here(consensusDir, \\insulated_domain_ss_no.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp2 <- temp %>% dplyr::filter(group == \\Within\\) %>% dplyr::select(-group)\nfwrite(temp2, here(consensusDir, \\insulated_domain_ss_within.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp3 <- temp %>% dplyr::filter(group == \\Outside\\) %>% dplyr::select(-group)\nfwrite(temp3, here(consensusDir, \\insulated_domain_ss_outside.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- data %>% dplyr::select(id, group, size) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$size\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$size\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Within\\))\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Outside\\))\nconvPvalue(getPvalWilcox(temp, \\Outside\\, \\Within\\))\n\n\np <- ggplot(temp, aes(x = group, y = size, fill = group)) + \n  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n  scale_fill_manual(values = c(\\#777777\\, \\#F28E2C\\, \\#F28E2C\\)) +\n  stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Loop size\\)\n\nfileName <- paste0(\\insulationBoundary_size_convSS_PE\\)\nwidth <-33*mmToInch\nheight <- 35*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntemp <- data %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()\n\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Within\\))\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Outside\\))\nconvPvalue(getPvalWilcox(temp, \\Outside\\, \\Within\\))\n\np <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineMedium * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() +   \n    scale_fill_manual(values = c(\\#777777\\, \\#F28E2C\\, \\#F28E2C\\)) +\n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\) +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.8, 0.5))\n    \nfileName <- paste0(\\insulationBoundary_delta_convSS_pe\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n###################### \n\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ndata2 <- data %>% left_join(obsexp, by = c(\\id\\))\n\ntemp <- data2 %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Within\\))\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Outside\\))\nconvPvalue(getPvalWilcox(temp, \\Outside\\, \\Within\\))\n\n\np <- ggplot(temp, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  scale_fill_manual(values = c(\\#777777\\, \\#F28E2C\\, \\#F28E2C\\)) +\n  \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\) +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n    width <-30*mmToInch\nheight <- 35*mmToInch\nfileName <- paste0(\\insulationBoundary_obsexp_convSS_pe\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n\n\n\n#####################\n\ndata <- data.all\ngene.withinBoundary <- unique((data %>% dplyr::filter(group == \\Within\\))$gene)\ngene.outsideBoundary <- unique((data %>% dplyr::filter(group == \\Outside\\))$gene)\ngene.noBoundary <- unique((data %>% dplyr::filter(group == \\No\\))$gene)\n\ngene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nprint(\\perc of gene with loop within Boundary\\)\nsum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop outside Boundary\\)\nsum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop with no Boundary\\)\nsum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100\n\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%\n  dplyr::mutate(group = case_when(\n    ensembl_gene_id %in% gene.wBoundary ~ \\withinBoundary\\,\n    ensembl_gene_id %in% gene.noBoundary ~ \\noBoundary\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group)) %>%\n  dplyr::mutate(absLog2FC = abs(log2FoldChange))\nks_result <- ks.test(\n  diff.RNA %>% dplyr::filter(group == \\withinBoundary\\) %>% pull(absLog2FC),\n  diff.RNA %>% dplyr::filter(group == \\noBoundary\\) %>% pull(absLog2FC)\n)\n\nggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)\n\n# getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC\n#   distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n# convPvalue(getPvalWilcox(diff.RNA, \\withBoundary\\, \\noBoundary\\))\n# \n\n# Create the CDF plot\np <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +\n  scale_color_manual(values = (c(\\#777777\\, \\#F28E2C\\))) +\n\nstat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\  ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\nfileName <- paste0(\\log2FC_cdf_insulationBoundary_convSS_pe\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
data <- data.all %>% dplyr::filter(Anno2 %in% c(\P-E\))

temp <- data %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()

temp1 <- temp %>% dplyr::filter(group == \No\) %>% dplyr::select(-group)
fwrite(temp1, here(consensusDir, \insulated_domain_ss_no.bedpe\), sep = \\t\, col.names = FALSE)
temp2 <- temp %>% dplyr::filter(group == \Within\) %>% dplyr::select(-group)
fwrite(temp2, here(consensusDir, \insulated_domain_ss_within.bedpe\), sep = \\t\, col.names = FALSE)
temp3 <- temp %>% dplyr::filter(group == \Outside\) %>% dplyr::select(-group)
fwrite(temp3, here(consensusDir, \insulated_domain_ss_outside.bedpe\), sep = \\t\, col.names = FALSE)

temp <- data %>% dplyr::select(id, group, size) %>% distinct()


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$size
  distance2 <- (data %>% dplyr::filter(group ==group2) )$size
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

convPvalue(getPvalWilcox(temp, \No\, \Within\))
convPvalue(getPvalWilcox(temp, \No\, \Outside\))
convPvalue(getPvalWilcox(temp, \Outside\, \Within\))


p <- ggplot(temp, aes(x = group, y = size, fill = group)) + 
  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
                 linewidth = lineMedium * mmToLineUnit, lineend = \square\,
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  scale_fill_manual(values = c(\#777777\, \#F28E2C\, \#F28E2C\)) +
  stat_summary(
      aes(group = group), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \Loop size\)

fileName <- paste0(\insulationBoundary_size_convSS_PE\)
width <-33*mmToInch
height <- 35*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

temp <- data %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()

convPvalue(getPvalWilcox(temp, \No\, \Within\))
convPvalue(getPvalWilcox(temp, \No\, \Outside\))
convPvalue(getPvalWilcox(temp, \Outside\, \Within\))

p <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineMedium * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() +   
    scale_fill_manual(values = c(\#777777\, \#F28E2C\, \#F28E2C\)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \Δ loop score\) +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  geom_hline(yintercept = -0.2,
             alpha = 0.5, 
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\, linetype = \dashed\) +
  coord_cartesian(ylim = c(-0.8, 0.5))
    
fileName <- paste0(\insulationBoundary_delta_convSS_pe\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()  


###################### 

minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

data2 <- data %>% left_join(obsexp, by = c(\id\))

temp <- data2 %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

convPvalue(getPvalWilcox(temp, \No\, \Within\))
convPvalue(getPvalWilcox(temp, \No\, \Outside\))
convPvalue(getPvalWilcox(temp, \Outside\, \Within\))


p <- ggplot(temp, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  scale_fill_manual(values = c(\#777777\, \#F28E2C\, \#F28E2C\)) +
  
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \log2(fc of obs/exp)\) +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  coord_cartesian(ylim = c(-2, 2))
    width <-30*mmToInch
height <- 35*mmToInch
fileName <- paste0(\insulationBoundary_obsexp_convSS_pe\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()  





#####################

data <- data.all
gene.withinBoundary <- unique((data %>% dplyr::filter(group == \Within\))$gene)
gene.outsideBoundary <- unique((data %>% dplyr::filter(group == \Outside\))$gene)
gene.noBoundary <- unique((data %>% dplyr::filter(group == \No\))$gene)

gene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

print(\perc of gene with loop within Boundary\)
sum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100

print(\perc of gene with loop outside Boundary\)
sum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100

print(\perc of gene with loop with no Boundary\)
sum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100


diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%
  dplyr::mutate(group = case_when(
    ensembl_gene_id %in% gene.wBoundary ~ \withinBoundary\,
    ensembl_gene_id %in% gene.noBoundary ~ \noBoundary\,
    TRUE ~ NA
  )) %>%
  dplyr::filter(!is.na(group)) %>%
  dplyr::mutate(absLog2FC = abs(log2FoldChange))
ks_result <- ks.test(
  diff.RNA %>% dplyr::filter(group == \withinBoundary\) %>% pull(absLog2FC),
  diff.RNA %>% dplyr::filter(group == \noBoundary\) %>% pull(absLog2FC)
)

ggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)

# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC
#   distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# convPvalue(getPvalWilcox(diff.RNA, \withBoundary\, \noBoundary\))
# 

# Create the CDF plot
p <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +
  scale_color_manual(values = (c(\#777777\, \#F28E2C\))) +

stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \square\  ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Abs. log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.position = \none\,
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )

fileName <- paste0(\log2FC_cdf_insulationBoundary_convSS_pe\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ndata <- data.all %>% dplyr::filter(Anno2 %in% c(\\P-E\\))\n\ntemp <- data %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()\n\ntemp1 <- temp %>% dplyr::filter(group == \\No\\) %>% dplyr::select(-group)\nfwrite(temp1, here(consensusDir, \\insulated_domain_ss_no.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp2 <- temp %>% dplyr::filter(group == \\Within\\) %>% dplyr::select(-group)\nfwrite(temp2, here(consensusDir, \\insulated_domain_ss_within.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp3 <- temp %>% dplyr::filter(group == \\Outside\\) %>% dplyr::select(-group)\nfwrite(temp3, here(consensusDir, \\insulated_domain_ss_outside.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- data %>% dplyr::select(id, group, size) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$size\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$size\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Within\\))\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Outside\\))\nconvPvalue(getPvalWilcox(temp, \\Outside\\, \\Within\\))\n\n\np <- ggplot(temp, aes(x = group, y = size, fill = group)) + \n  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n  scale_fill_manual(values = c(\\#777777\\, \\#F28E2C\\, \\#F28E2C\\)) +\n  stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Loop size\\)\n\nfileName <- paste0(\\insulationBoundary_size_convSS_PE\\)\nwidth <-33*mmToInch\nheight <- 35*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntemp <- data %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()\n\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Within\\))\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Outside\\))\nconvPvalue(getPvalWilcox(temp, \\Outside\\, \\Within\\))\n\np <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineMedium * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() +   \n    scale_fill_manual(values = c(\\#777777\\, \\#F28E2C\\, \\#F28E2C\\)) +\n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\) +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.8, 0.5))\n    \nfileName <- paste0(\\insulationBoundary_delta_convSS_pe\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n###################### \n\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ndata2 <- data %>% left_join(obsexp, by = c(\\id\\))\n\ntemp <- data2 %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Within\\))\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Outside\\))\nconvPvalue(getPvalWilcox(temp, \\Outside\\, \\Within\\))\n\n\np <- ggplot(temp, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  scale_fill_manual(values = c(\\#777777\\, \\#F28E2C\\, \\#F28E2C\\)) +\n  \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\) +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n    width <-30*mmToInch\nheight <- 35*mmToInch\nfileName <- paste0(\\insulationBoundary_obsexp_convSS_pe\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n\n\n\n#####################\n\ndata <- data.all\ngene.withinBoundary <- unique((data %>% dplyr::filter(group == \\Within\\))$gene)\ngene.outsideBoundary <- unique((data %>% dplyr::filter(group == \\Outside\\))$gene)\ngene.noBoundary <- unique((data %>% dplyr::filter(group == \\No\\))$gene)\n\ngene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nprint(\\perc of gene with loop within Boundary\\)\nsum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop outside Boundary\\)\nsum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop with no Boundary\\)\nsum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100\n\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%\n  dplyr::mutate(group = case_when(\n    ensembl_gene_id %in% gene.wBoundary ~ \\withinBoundary\\,\n    ensembl_gene_id %in% gene.noBoundary ~ \\noBoundary\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group)) %>%\n  dplyr::mutate(absLog2FC = abs(log2FoldChange))\nks_result <- ks.test(\n  diff.RNA %>% dplyr::filter(group == \\withinBoundary\\) %>% pull(absLog2FC),\n  diff.RNA %>% dplyr::filter(group == \\noBoundary\\) %>% pull(absLog2FC)\n)\n\nggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)\n\n# getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC\n#   distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n# convPvalue(getPvalWilcox(diff.RNA, \\withBoundary\\, \\noBoundary\\))\n# \n\n# Create the CDF plot\np <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +\n  scale_color_manual(values = (c(\\#777777\\, \\#F28E2C\\))) +\n\nstat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\  ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\nfileName <- paste0(\\log2FC_cdf_insulationBoundary_convSS_pe\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->\n\n```r\n```r\ndata <- data.all %>% dplyr::filter(Anno2 %in% c(\\P-E\\))\n\ntemp <- data %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()\n\ntemp1 <- temp %>% dplyr::filter(group == \\No\\) %>% dplyr::select(-group)\nfwrite(temp1, here(consensusDir, \\insulated_domain_ss_no.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp2 <- temp %>% dplyr::filter(group == \\Within\\) %>% dplyr::select(-group)\nfwrite(temp2, here(consensusDir, \\insulated_domain_ss_within.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp3 <- temp %>% dplyr::filter(group == \\Outside\\) %>% dplyr::select(-group)\nfwrite(temp3, here(consensusDir, \\insulated_domain_ss_outside.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- data %>% dplyr::select(id, group, size) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$size\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$size\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Within\\))\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Outside\\))\nconvPvalue(getPvalWilcox(temp, \\Outside\\, \\Within\\))\n\n\np <- ggplot(temp, aes(x = group, y = size, fill = group)) + \n  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n  scale_fill_manual(values = c(\\#777777\\, \\#F28E2C\\, \\#F28E2C\\)) +\n  stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Loop size\\)\n\nfileName <- paste0(\\insulationBoundary_size_convSS_PE\\)\nwidth <-33*mmToInch\nheight <- 35*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntemp <- data %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()\n\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Within\\))\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Outside\\))\nconvPvalue(getPvalWilcox(temp, \\Outside\\, \\Within\\))\n\np <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineMedium * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() +   \n    scale_fill_manual(values = c(\\#777777\\, \\#F28E2C\\, \\#F28E2C\\)) +\n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\) +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.8, 0.5))\n    \nfileName <- paste0(\\insulationBoundary_delta_convSS_pe\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n###################### \n\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ndata2 <- data %>% left_join(obsexp, by = c(\\id\\))\n\ntemp <- data2 %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Within\\))\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Outside\\))\nconvPvalue(getPvalWilcox(temp, \\Outside\\, \\Within\\))\n\n\np <- ggplot(temp, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  scale_fill_manual(values = c(\\#777777\\, \\#F28E2C\\, \\#F28E2C\\)) +\n  \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\) +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n    width <-30*mmToInch\nheight <- 35*mmToInch\nfileName <- paste0(\\insulationBoundary_obsexp_convSS_pe\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n\n\n\n#####################\n\ndata <- data.all\ngene.withinBoundary <- unique((data %>% dplyr::filter(group == \\Within\\))$gene)\ngene.outsideBoundary <- unique((data %>% dplyr::filter(group == \\Outside\\))$gene)\ngene.noBoundary <- unique((data %>% dplyr::filter(group == \\No\\))$gene)\n\ngene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nprint(\\perc of gene with loop within Boundary\\)\nsum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop outside Boundary\\)\nsum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop with no Boundary\\)\nsum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100\n\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%\n  dplyr::mutate(group = case_when(\n    ensembl_gene_id %in% gene.wBoundary ~ \\withinBoundary\\,\n    ensembl_gene_id %in% gene.noBoundary ~ \\noBoundary\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group)) %>%\n  dplyr::mutate(absLog2FC = abs(log2FoldChange))\nks_result <- ks.test(\n  diff.RNA %>% dplyr::filter(group == \\withinBoundary\\) %>% pull(absLog2FC),\n  diff.RNA %>% dplyr::filter(group == \\noBoundary\\) %>% pull(absLog2FC)\n)\n\nggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)\n\n# getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC\n#   distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n# convPvalue(getPvalWilcox(diff.RNA, \\withBoundary\\, \\noBoundary\\))\n# \n\n# Create the CDF plot\np <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +\n  scale_color_manual(values = (c(\\#777777\\, \\#F28E2C\\))) +\n\nstat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\  ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\nfileName <- paste0(\\log2FC_cdf_insulationBoundary_convSS_pe\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ndata <- data.all %>% dplyr::filter(Anno2 %in% c(\\P-E\\))\n\ntemp <- data %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()\n\ntemp1 <- temp %>% dplyr::filter(group == \\No\\) %>% dplyr::select(-group)\nfwrite(temp1, here(consensusDir, \\insulated_domain_ss_no.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp2 <- temp %>% dplyr::filter(group == \\Within\\) %>% dplyr::select(-group)\nfwrite(temp2, here(consensusDir, \\insulated_domain_ss_within.bedpe\\), sep = \\\\t\\, col.names = FALSE)\ntemp3 <- temp %>% dplyr::filter(group == \\Outside\\) %>% dplyr::select(-group)\nfwrite(temp3, here(consensusDir, \\insulated_domain_ss_outside.bedpe\\), sep = \\\\t\\, col.names = FALSE)\n\ntemp <- data %>% dplyr::select(id, group, size) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$size\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$size\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Within\\))\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Outside\\))\nconvPvalue(getPvalWilcox(temp, \\Outside\\, \\Within\\))\n\n\np <- ggplot(temp, aes(x = group, y = size, fill = group)) + \n  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n                 linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + scale_y_continuous(labels = label_kb_mb) +\n  scale_fill_manual(values = c(\\#777777\\, \\#F28E2C\\, \\#F28E2C\\)) +\n  stat_summary(\n      aes(group = group), fun = mean,\n      geom = \\point\\, shape = 21, size = 0.5,\n      fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Loop size\\)\n\nfileName <- paste0(\\insulationBoundary_size_convSS_PE\\)\nwidth <-33*mmToInch\nheight <- 35*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\ntemp <- data %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()\n\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Within\\))\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Outside\\))\nconvPvalue(getPvalWilcox(temp, \\Outside\\, \\Within\\))\n\np <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineMedium * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() +   \n    scale_fill_manual(values = c(\\#777777\\, \\#F28E2C\\, \\#F28E2C\\)) +\n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\) +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.8, 0.5))\n    \nfileName <- paste0(\\insulationBoundary_delta_convSS_pe\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n###################### \n\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\ndata2 <- data %>% left_join(obsexp, by = c(\\id\\))\n\ntemp <- data2 %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()\n\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Within\\))\nconvPvalue(getPvalWilcox(temp, \\No\\, \\Outside\\))\nconvPvalue(getPvalWilcox(temp, \\Outside\\, \\Within\\))\n\n\np <- ggplot(temp, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  scale_fill_manual(values = c(\\#777777\\, \\#F28E2C\\, \\#F28E2C\\)) +\n  \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\) +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n    width <-30*mmToInch\nheight <- 35*mmToInch\nfileName <- paste0(\\insulationBoundary_obsexp_convSS_pe\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n\n\n\n\n#####################\n\ndata <- data.all\ngene.withinBoundary <- unique((data %>% dplyr::filter(group == \\Within\\))$gene)\ngene.outsideBoundary <- unique((data %>% dplyr::filter(group == \\Outside\\))$gene)\ngene.noBoundary <- unique((data %>% dplyr::filter(group == \\No\\))$gene)\n\ngene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\nprint(\\perc of gene with loop within Boundary\\)\nsum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop outside Boundary\\)\nsum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100\n\nprint(\\perc of gene with loop with no Boundary\\)\nsum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100\nsum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100\n\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%\n  dplyr::mutate(group = case_when(\n    ensembl_gene_id %in% gene.wBoundary ~ \\withinBoundary\\,\n    ensembl_gene_id %in% gene.noBoundary ~ \\noBoundary\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group)) %>%\n  dplyr::mutate(absLog2FC = abs(log2FoldChange))\nks_result <- ks.test(\n  diff.RNA %>% dplyr::filter(group == \\withinBoundary\\) %>% pull(absLog2FC),\n  diff.RNA %>% dplyr::filter(group == \\noBoundary\\) %>% pull(absLog2FC)\n)\n\nggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)\n\n# getPvalWilcox <- function(data, group1, group2){\n#   distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC\n#   distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC\n#   wil <- wilcox.test(distance1, distance2)\n#   return(wil$p.value)\n# }\n# convPvalue(getPvalWilcox(diff.RNA, \\withBoundary\\, \\noBoundary\\))\n# \n\n# Create the CDF plot\np <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +\n  scale_color_manual(values = (c(\\#777777\\, \\#F28E2C\\))) +\n\nstat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \\square\\  ) + # Use stat_ecdf to plot the empirical CDF\n  labs(\n    x = \\Abs. log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.position = \\none\\,\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\nfileName <- paste0(\\log2FC_cdf_insulationBoundary_convSS_pe\\)\nwidth <- 33*mmToInch\nheight <-33*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```"} -->

```r
```r
data <- data.all %>% dplyr::filter(Anno2 %in% c(\P-E\))

temp <- data %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()

temp1 <- temp %>% dplyr::filter(group == \No\) %>% dplyr::select(-group)
fwrite(temp1, here(consensusDir, \insulated_domain_ss_no.bedpe\), sep = \\t\, col.names = FALSE)
temp2 <- temp %>% dplyr::filter(group == \Within\) %>% dplyr::select(-group)
fwrite(temp2, here(consensusDir, \insulated_domain_ss_within.bedpe\), sep = \\t\, col.names = FALSE)
temp3 <- temp %>% dplyr::filter(group == \Outside\) %>% dplyr::select(-group)
fwrite(temp3, here(consensusDir, \insulated_domain_ss_outside.bedpe\), sep = \\t\, col.names = FALSE)

temp <- data %>% dplyr::select(id, group, size) %>% distinct()


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$size
  distance2 <- (data %>% dplyr::filter(group ==group2) )$size
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

convPvalue(getPvalWilcox(temp, \No\, \Within\))
convPvalue(getPvalWilcox(temp, \No\, \Outside\))
convPvalue(getPvalWilcox(temp, \Outside\, \Within\))


p <- ggplot(temp, aes(x = group, y = size, fill = group)) + 
  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
                 linewidth = lineMedium * mmToLineUnit, lineend = \square\,
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  scale_fill_manual(values = c(\#777777\, \#F28E2C\, \#F28E2C\)) +
  stat_summary(
      aes(group = group), fun = mean,
      geom = \point\, shape = 21, size = 0.5,
      fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \Loop size\)

fileName <- paste0(\insulationBoundary_size_convSS_PE\)
width <-33*mmToInch
height <- 35*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

temp <- data %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()

convPvalue(getPvalWilcox(temp, \No\, \Within\))
convPvalue(getPvalWilcox(temp, \No\, \Outside\))
convPvalue(getPvalWilcox(temp, \Outside\, \Within\))

p <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineMedium * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() +   
    scale_fill_manual(values = c(\#777777\, \#F28E2C\, \#F28E2C\)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \Δ loop score\) +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  geom_hline(yintercept = -0.2,
             alpha = 0.5, 
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\, linetype = \dashed\) +
  coord_cartesian(ylim = c(-0.8, 0.5))
    
fileName <- paste0(\insulationBoundary_delta_convSS_pe\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()  


###################### 

minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

data2 <- data %>% left_join(obsexp, by = c(\id\))

temp <- data2 %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

convPvalue(getPvalWilcox(temp, \No\, \Within\))
convPvalue(getPvalWilcox(temp, \No\, \Outside\))
convPvalue(getPvalWilcox(temp, \Outside\, \Within\))


p <- ggplot(temp, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  scale_fill_manual(values = c(\#777777\, \#F28E2C\, \#F28E2C\)) +
  
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \log2(fc of obs/exp)\) +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  coord_cartesian(ylim = c(-2, 2))
    width <-30*mmToInch
height <- 35*mmToInch
fileName <- paste0(\insulationBoundary_obsexp_convSS_pe\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()  





#####################

data <- data.all
gene.withinBoundary <- unique((data %>% dplyr::filter(group == \Within\))$gene)
gene.outsideBoundary <- unique((data %>% dplyr::filter(group == \Outside\))$gene)
gene.noBoundary <- unique((data %>% dplyr::filter(group == \No\))$gene)

gene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

print(\perc of gene with loop within Boundary\)
sum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100

print(\perc of gene with loop outside Boundary\)
sum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100

print(\perc of gene with loop with no Boundary\)
sum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100


diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%
  dplyr::mutate(group = case_when(
    ensembl_gene_id %in% gene.wBoundary ~ \withinBoundary\,
    ensembl_gene_id %in% gene.noBoundary ~ \noBoundary\,
    TRUE ~ NA
  )) %>%
  dplyr::filter(!is.na(group)) %>%
  dplyr::mutate(absLog2FC = abs(log2FoldChange))
ks_result <- ks.test(
  diff.RNA %>% dplyr::filter(group == \withinBoundary\) %>% pull(absLog2FC),
  diff.RNA %>% dplyr::filter(group == \noBoundary\) %>% pull(absLog2FC)
)

ggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)

# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC
#   distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# convPvalue(getPvalWilcox(diff.RNA, \withBoundary\, \noBoundary\))
# 

# Create the CDF plot
p <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +
  scale_color_manual(values = (c(\#777777\, \#F28E2C\))) +

stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \square\  ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Abs. log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.position = \none\,
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )

fileName <- paste0(\log2FC_cdf_insulationBoundary_convSS_pe\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Processing

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\ntemp <- allLoopsAnnotated %>% dplyr::filter(Anno2 %in% c(\"P-E\")) %>% dplyr::mutate(hasSS = !is.na(loopID2))\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(hasSS ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(hasSS ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, TRUE, FALSE))\nggplot(temp, aes(x = hasSS, y = diff_dTAG_DMSO)) + geom_violin(aes(fill = hasSS), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = hasSS), fun = mean, \n               geom = \"point\", shape = 21, size = 2, fill = \"red\", color = \"black\") +\n  theme_classic() +\n  annotate(\"text\", x = 1, y = 0, label = pv, size = 5, color = \"black\") +\n  ggtitle(\"PE\") + geom_hline(yintercept = 0)\n\n\n\n\n# Counting loop types\nallLoopsAnnotatedFiltered <- allLoopsAnnotated %>% dplyr::filter(!is.na(loopID2)) %>%\n  dplyr::filter(!(loopID == loopID2))\ntemp <- allLoopsAnnotatedFiltered %>% dplyr::select(loopID2, Anno2)\nresult <- temp %>%\n  group_by(loopID2, Anno2) %>%\n  summarise(count = n(), .groups = 'drop') %>%\n  group_by(loopID2) %>%\n  mutate(frequency = count / sum(count)) %>%\n  arrange(loopID2, Anno2)\n\nresult <- largest_loops %>% dplyr::left_join(result, by = c(\"loopID\" = \"loopID2\"))\n\ngene.group1 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\"))$gene\ngene.group2 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\"))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\"group1\", length(gene.group1)),\n            rep(\"group2\", length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(result, by = c(\"gene\"))\ndata <- data %>% filter(complete.cases(.))\n\nall_anno2 <- unique(data$Anno2)\n\n# Calculate average frequency of Anno2 for each gene in each group\nresult <- data %>%\n  # Ensure all possible Anno2 values are present for each gene and group\n  complete(gene, Anno2 = all_anno2, fill = list(frequency = 0)) %>% \n  dplyr::mutate(group = case_when(\n    gene %in% gene.group1 ~ \"group1\",\n    gene %in% gene.group2 ~ \"group2\",\n    TRUE ~ NA\n  )) %>%\n  dplyr::select(group, Anno2, frequency)\n  \n\nggplot(result, aes(x = Anno2, fill = group, y = frequency)) + geom_boxplot()\n\n\n\n# View results\nggplot(largest_loops, aes(x = loop_width)) + geom_histogram()\n\n\n### Checking how many genes from each group has encompassing S-S\ngene.group1 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\"))$gene\ngene.group2 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\"))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\"group1\", length(gene.group1)),\n            rep(\"group2\", length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\"gene\"))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \"NO\", \"YES\")\n)\n\ndata_summary <- data %>%\n  group_by(group) %>%\n  summarize(\n    total = n(),\n    hasSS_yes = sum(hasSS == \"YES\"),\n    percentage_yes = (hasSS_yes / total) * 100\n  )\n\nggplot(data_summary, aes(x = group, y = percentage_yes, fill = group)) +\n  geom_bar(stat = \"identity\", color = \"black\") +\n  labs(\n    title = \"Percentage of Each Group with hasSS = YES\",\n    x = \"Group\",\n    y = \"Percentage (%)\"\n  ) + ylim(0, 100) +\n  theme_minimal()\n\ntemp <- data %>% dplyr::filter(hasSS == \"YES\")\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$loop_width\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$loop_width\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, \"group1\", \"group2\"))\n\nggplot(temp, aes(x = group, y = loop_width)) + geom_violin() + geom_boxplot(width = 0.5) +\n  annotate(\"text\", x = 1, y = 0, label = pv, size = 5, color = \"black\")\n\n\n### Comparing RNA perturbation\n\ndiff.RNA <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(c(1, 4, 5)) %>%\n  dplyr::mutate(hasSS = ifelse(ensembl_gene_id %in% largest_loops$gene, \"hasSS\", \"noSS\"))\n\n\nggplot(diff.RNA, aes(x = abs(log2FoldChange), color = hasSS)) +\n  stat_ecdf(size = 0.4) +\n  labs(\n    x = \"Absolute log2(fold change)\",\n    y = \"Cumulative Probability\"\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\n\n\n### Checking ChIP peak density\nlargest_loopsGr <- makeGRangesFromDataFrame(largest_loops, \n                                            seqnames.field = \"loop_chr\", \n                                            start.field = \"loop_start\", \n                                            end.field = \"loop_end\", \n                                            keep.extra.columns = TRUE)\n\n# Find overlaps between ChIP-seq peaks and the largest loops\nchip_overlaps <- findOverlaps(largest_loopsGr, peak.H3K4me3)\n\n# Count the number of ChIP-seq peaks per loop\nloop_peak_counts <- table(queryHits(chip_overlaps))\n\n# Create a data frame with the counts and loop details\nlargest_loops$density <- 0  # Initialize density column\nlargest_loops$count <- 0    # Initialize peak count column\n\n# Add peak counts to the corresponding loops\nlargest_loops[as.numeric(names(loop_peak_counts)), \"count\"] <- as.integer(loop_peak_counts)\n\n# Calculate the density (peaks per kilobase)\nlargest_loops$density <- largest_loops$count / ((largest_loops$loop_width-1) / 1000)\n\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\"group1\", length(gene.group1)),\n            rep(\"group2\", length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\"gene\"))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \"NO\", \"YES\")\n) %>% dplyr::filter(hasSS == \"YES\")\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$density\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$density\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\npv <- convPvalue(getPvalWilcox(data, \"group1\", \"group2\"))\n\nggplot(data, aes(x = group, y = density)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = group), fun = mean, \n               geom = \"point\", shape = 21, size = 2, fill = \"red\", color = \"black\") +\n  theme_classic() +\n  annotate(\"text\", x = 1, y = 0, label = pv, size = 5, color = \"black\") +\n  ggtitle(\"H3K4me3\")\n\n\n```"} -->\n\n```r\ntemp <- allLoopsAnnotated %>% dplyr::filter(Anno2 %in% c(\\P-E\\)) %>% dplyr::mutate(hasSS = !is.na(loopID2))\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(hasSS ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(hasSS ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, TRUE, FALSE))\nggplot(temp, aes(x = hasSS, y = diff_dTAG_DMSO)) + geom_violin(aes(fill = hasSS), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = hasSS), fun = mean, \n               geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme_classic() +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\) +\n  ggtitle(\\PE\\) + geom_hline(yintercept = 0)\n\n\n\n\n# Counting loop types\nallLoopsAnnotatedFiltered <- allLoopsAnnotated %>% dplyr::filter(!is.na(loopID2)) %>%\n  dplyr::filter(!(loopID == loopID2))\ntemp <- allLoopsAnnotatedFiltered %>% dplyr::select(loopID2, Anno2)\nresult <- temp %>%\n  group_by(loopID2, Anno2) %>%\n  summarise(count = n(), .groups = 'drop') %>%\n  group_by(loopID2) %>%\n  mutate(frequency = count / sum(count)) %>%\n  arrange(loopID2, Anno2)\n\nresult <- largest_loops %>% dplyr::left_join(result, by = c(\\loopID\\ = \\loopID2\\))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(result, by = c(\\gene\\))\ndata <- data %>% filter(complete.cases(.))\n\nall_anno2 <- unique(data$Anno2)\n\n# Calculate average frequency of Anno2 for each gene in each group\nresult <- data %>%\n  # Ensure all possible Anno2 values are present for each gene and group\n  complete(gene, Anno2 = all_anno2, fill = list(frequency = 0)) %>% \n  dplyr::mutate(group = case_when(\n    gene %in% gene.group1 ~ \\group1\\,\n    gene %in% gene.group2 ~ \\group2\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::select(group, Anno2, frequency)\n  \n\nggplot(result, aes(x = Anno2, fill = group, y = frequency)) + geom_boxplot()\n\n\n\n# View results\nggplot(largest_loops, aes(x = loop_width)) + geom_histogram()\n\n\n### Checking how many genes from each group has encompassing S-S\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\\gene\\))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \\NO\\, \\YES\\)\n)\n\ndata_summary <- data %>%\n  group_by(group) %>%\n  summarize(\n    total = n(),\n    hasSS_yes = sum(hasSS == \\YES\\),\n    percentage_yes = (hasSS_yes / total) * 100\n  )\n\nggplot(data_summary, aes(x = group, y = percentage_yes, fill = group)) +\n  geom_bar(stat = \\identity\\, color = \\black\\) +\n  labs(\n    title = \\Percentage of Each Group with hasSS = YES\\,\n    x = \\Group\\,\n    y = \\Percentage (%)\\\n  ) + ylim(0, 100) +\n  theme_minimal()\n\ntemp <- data %>% dplyr::filter(hasSS == \\YES\\)\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$loop_width\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$loop_width\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, \\group1\\, \\group2\\))\n\nggplot(temp, aes(x = group, y = loop_width)) + geom_violin() + geom_boxplot(width = 0.5) +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\)\n\n\n### Comparing RNA perturbation\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(c(1, 4, 5)) %>%\n  dplyr::mutate(hasSS = ifelse(ensembl_gene_id %in% largest_loops$gene, \\hasSS\\, \\noSS\\))\n\n\nggplot(diff.RNA, aes(x = abs(log2FoldChange), color = hasSS)) +\n  stat_ecdf(size = 0.4) +\n  labs(\n    x = \\Absolute log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\n\n\n### Checking ChIP peak density\nlargest_loopsGr <- makeGRangesFromDataFrame(largest_loops, \n                                            seqnames.field = \\loop_chr\\, \n                                            start.field = \\loop_start\\, \n                                            end.field = \\loop_end\\, \n                                            keep.extra.columns = TRUE)\n\n# Find overlaps between ChIP-seq peaks and the largest loops\nchip_overlaps <- findOverlaps(largest_loopsGr, peak.H3K4me3)\n\n# Count the number of ChIP-seq peaks per loop\nloop_peak_counts <- table(queryHits(chip_overlaps))\n\n# Create a data frame with the counts and loop details\nlargest_loops$density <- 0  # Initialize density column\nlargest_loops$count <- 0    # Initialize peak count column\n\n# Add peak counts to the corresponding loops\nlargest_loops[as.numeric(names(loop_peak_counts)), \\count\\] <- as.integer(loop_peak_counts)\n\n# Calculate the density (peaks per kilobase)\nlargest_loops$density <- largest_loops$count / ((largest_loops$loop_width-1) / 1000)\n\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\\gene\\))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \\NO\\, \\YES\\)\n) %>% dplyr::filter(hasSS == \\YES\\)\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$density\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$density\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\npv <- convPvalue(getPvalWilcox(data, \\group1\\, \\group2\\))\n\nggplot(data, aes(x = group, y = density)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = group), fun = mean, \n               geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme_classic() +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\) +\n  ggtitle(\\H3K4me3\\)\n\n\n```\n\n<!-- rnb-source-end -->\n"} -->
temp <- allLoopsAnnotated %>% dplyr::filter(Anno2 %in% c(\P-E\)) %>% dplyr::mutate(hasSS = !is.na(loopID2))
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(hasSS ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(hasSS ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
pv <- convPvalue(getPvalWilcox(temp, TRUE, FALSE))
ggplot(temp, aes(x = hasSS, y = diff_dTAG_DMSO)) + geom_violin(aes(fill = hasSS), show.legend = FALSE) + 
  geom_boxplot(width = 0.1, outlier.shape = NA) +
  stat_summary(aes(group = hasSS), fun = mean, 
               geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  theme_classic() +
  annotate(\text\, x = 1, y = 0, label = pv, size = 5, color = \black\) +
  ggtitle(\PE\) + geom_hline(yintercept = 0)




# Counting loop types
allLoopsAnnotatedFiltered <- allLoopsAnnotated %>% dplyr::filter(!is.na(loopID2)) %>%
  dplyr::filter(!(loopID == loopID2))
temp <- allLoopsAnnotatedFiltered %>% dplyr::select(loopID2, Anno2)
result <- temp %>%
  group_by(loopID2, Anno2) %>%
  summarise(count = n(), .groups = 'drop') %>%
  group_by(loopID2) %>%
  mutate(frequency = count / sum(count)) %>%
  arrange(loopID2, Anno2)

result <- largest_loops %>% dplyr::left_join(result, by = c(\loopID\ = \loopID2\))

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep(\group1\, length(gene.group1)),
            rep(\group2\, length(gene.group2)))
)

data <- data %>% dplyr::left_join(result, by = c(\gene\))
data <- data %>% filter(complete.cases(.))

all_anno2 <- unique(data$Anno2)

# Calculate average frequency of Anno2 for each gene in each group
result <- data %>%
  # Ensure all possible Anno2 values are present for each gene and group
  complete(gene, Anno2 = all_anno2, fill = list(frequency = 0)) %>% 
  dplyr::mutate(group = case_when(
    gene %in% gene.group1 ~ \group1\,
    gene %in% gene.group2 ~ \group2\,
    TRUE ~ NA
  )) %>%
  dplyr::select(group, Anno2, frequency)
  

ggplot(result, aes(x = Anno2, fill = group, y = frequency)) + geom_boxplot()



# View results
ggplot(largest_loops, aes(x = loop_width)) + geom_histogram()


### Checking how many genes from each group has encompassing S-S
gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep(\group1\, length(gene.group1)),
            rep(\group2\, length(gene.group2)))
)

data <- data %>% dplyr::left_join(largest_loops, by = c(\gene\))
data <- data %>% dplyr::mutate(
  hasSS = ifelse(is.na(loop_width), \NO\, \YES\)
)

data_summary <- data %>%
  group_by(group) %>%
  summarize(
    total = n(),
    hasSS_yes = sum(hasSS == \YES\),
    percentage_yes = (hasSS_yes / total) * 100
  )

ggplot(data_summary, aes(x = group, y = percentage_yes, fill = group)) +
  geom_bar(stat = \identity\, color = \black\) +
  labs(
    title = \Percentage of Each Group with hasSS = YES\,
    x = \Group\,
    y = \Percentage (%)\
  ) + ylim(0, 100) +
  theme_minimal()

temp <- data %>% dplyr::filter(hasSS == \YES\)
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$loop_width
  distance2 <- (data %>% dplyr::filter(group ==group2) )$loop_width
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
pv <- convPvalue(getPvalWilcox(temp, \group1\, \group2\))

ggplot(temp, aes(x = group, y = loop_width)) + geom_violin() + geom_boxplot(width = 0.5) +
  annotate(\text\, x = 1, y = 0, label = pv, size = 5, color = \black\)


### Comparing RNA perturbation

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(c(1, 4, 5)) %>%
  dplyr::mutate(hasSS = ifelse(ensembl_gene_id %in% largest_loops$gene, \hasSS\, \noSS\))


ggplot(diff.RNA, aes(x = abs(log2FoldChange), color = hasSS)) +
  stat_ecdf(size = 0.4) +
  labs(
    x = \Absolute log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )



### Checking ChIP peak density
largest_loopsGr <- makeGRangesFromDataFrame(largest_loops, 
                                            seqnames.field = \loop_chr\, 
                                            start.field = \loop_start\, 
                                            end.field = \loop_end\, 
                                            keep.extra.columns = TRUE)

# Find overlaps between ChIP-seq peaks and the largest loops
chip_overlaps <- findOverlaps(largest_loopsGr, peak.H3K4me3)

# Count the number of ChIP-seq peaks per loop
loop_peak_counts <- table(queryHits(chip_overlaps))

# Create a data frame with the counts and loop details
largest_loops$density <- 0  # Initialize density column
largest_loops$count <- 0    # Initialize peak count column

# Add peak counts to the corresponding loops
largest_loops[as.numeric(names(loop_peak_counts)), \count\] <- as.integer(loop_peak_counts)

# Calculate the density (peaks per kilobase)
largest_loops$density <- largest_loops$count / ((largest_loops$loop_width-1) / 1000)


data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep(\group1\, length(gene.group1)),
            rep(\group2\, length(gene.group2)))
)

data <- data %>% dplyr::left_join(largest_loops, by = c(\gene\))
data <- data %>% dplyr::mutate(
  hasSS = ifelse(is.na(loop_width), \NO\, \YES\)
) %>% dplyr::filter(hasSS == \YES\)

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$density
  distance2 <- (data %>% dplyr::filter(group ==group2) )$density
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv <- convPvalue(getPvalWilcox(data, \group1\, \group2\))

ggplot(data, aes(x = group, y = density)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
  geom_boxplot(width = 0.1, outlier.shape = NA) +
  stat_summary(aes(group = group), fun = mean, 
               geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  theme_classic() +
  annotate(\text\, x = 1, y = 0, label = pv, size = 5, color = \black\) +
  ggtitle(\H3K4me3\)



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\ntemp <- allLoopsAnnotated %>% dplyr::filter(Anno2 %in% c(\\P-E\\)) %>% dplyr::mutate(hasSS = !is.na(loopID2))\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(hasSS ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(hasSS ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, TRUE, FALSE))\nggplot(temp, aes(x = hasSS, y = diff_dTAG_DMSO)) + geom_violin(aes(fill = hasSS), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = hasSS), fun = mean, \n               geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme_classic() +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\) +\n  ggtitle(\\PE\\) + geom_hline(yintercept = 0)\n\n\n\n\n# Counting loop types\nallLoopsAnnotatedFiltered <- allLoopsAnnotated %>% dplyr::filter(!is.na(loopID2)) %>%\n  dplyr::filter(!(loopID == loopID2))\ntemp <- allLoopsAnnotatedFiltered %>% dplyr::select(loopID2, Anno2)\nresult <- temp %>%\n  group_by(loopID2, Anno2) %>%\n  summarise(count = n(), .groups = 'drop') %>%\n  group_by(loopID2) %>%\n  mutate(frequency = count / sum(count)) %>%\n  arrange(loopID2, Anno2)\n\nresult <- largest_loops %>% dplyr::left_join(result, by = c(\\loopID\\ = \\loopID2\\))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(result, by = c(\\gene\\))\ndata <- data %>% filter(complete.cases(.))\n\nall_anno2 <- unique(data$Anno2)\n\n# Calculate average frequency of Anno2 for each gene in each group\nresult <- data %>%\n  # Ensure all possible Anno2 values are present for each gene and group\n  complete(gene, Anno2 = all_anno2, fill = list(frequency = 0)) %>% \n  dplyr::mutate(group = case_when(\n    gene %in% gene.group1 ~ \\group1\\,\n    gene %in% gene.group2 ~ \\group2\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::select(group, Anno2, frequency)\n  \n\nggplot(result, aes(x = Anno2, fill = group, y = frequency)) + geom_boxplot()\n\n\n\n# View results\nggplot(largest_loops, aes(x = loop_width)) + geom_histogram()\n\n\n### Checking how many genes from each group has encompassing S-S\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\\gene\\))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \\NO\\, \\YES\\)\n)\n\ndata_summary <- data %>%\n  group_by(group) %>%\n  summarize(\n    total = n(),\n    hasSS_yes = sum(hasSS == \\YES\\),\n    percentage_yes = (hasSS_yes / total) * 100\n  )\n\nggplot(data_summary, aes(x = group, y = percentage_yes, fill = group)) +\n  geom_bar(stat = \\identity\\, color = \\black\\) +\n  labs(\n    title = \\Percentage of Each Group with hasSS = YES\\,\n    x = \\Group\\,\n    y = \\Percentage (%)\\\n  ) + ylim(0, 100) +\n  theme_minimal()\n\ntemp <- data %>% dplyr::filter(hasSS == \\YES\\)\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$loop_width\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$loop_width\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, \\group1\\, \\group2\\))\n\nggplot(temp, aes(x = group, y = loop_width)) + geom_violin() + geom_boxplot(width = 0.5) +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\)\n\n\n### Comparing RNA perturbation\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(c(1, 4, 5)) %>%\n  dplyr::mutate(hasSS = ifelse(ensembl_gene_id %in% largest_loops$gene, \\hasSS\\, \\noSS\\))\n\n\nggplot(diff.RNA, aes(x = abs(log2FoldChange), color = hasSS)) +\n  stat_ecdf(size = 0.4) +\n  labs(\n    x = \\Absolute log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\n\n\n### Checking ChIP peak density\nlargest_loopsGr <- makeGRangesFromDataFrame(largest_loops, \n                                            seqnames.field = \\loop_chr\\, \n                                            start.field = \\loop_start\\, \n                                            end.field = \\loop_end\\, \n                                            keep.extra.columns = TRUE)\n\n# Find overlaps between ChIP-seq peaks and the largest loops\nchip_overlaps <- findOverlaps(largest_loopsGr, peak.H3K4me3)\n\n# Count the number of ChIP-seq peaks per loop\nloop_peak_counts <- table(queryHits(chip_overlaps))\n\n# Create a data frame with the counts and loop details\nlargest_loops$density <- 0  # Initialize density column\nlargest_loops$count <- 0    # Initialize peak count column\n\n# Add peak counts to the corresponding loops\nlargest_loops[as.numeric(names(loop_peak_counts)), \\count\\] <- as.integer(loop_peak_counts)\n\n# Calculate the density (peaks per kilobase)\nlargest_loops$density <- largest_loops$count / ((largest_loops$loop_width-1) / 1000)\n\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\\gene\\))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \\NO\\, \\YES\\)\n) %>% dplyr::filter(hasSS == \\YES\\)\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$density\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$density\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\npv <- convPvalue(getPvalWilcox(data, \\group1\\, \\group2\\))\n\nggplot(data, aes(x = group, y = density)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = group), fun = mean, \n               geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme_classic() +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\) +\n  ggtitle(\\H3K4me3\\)\n\n\n```\n```"} -->\n\n```r\n```r\ntemp <- allLoopsAnnotated %>% dplyr::filter(Anno2 %in% c(\\P-E\\)) %>% dplyr::mutate(hasSS = !is.na(loopID2))\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(hasSS ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(hasSS ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, TRUE, FALSE))\nggplot(temp, aes(x = hasSS, y = diff_dTAG_DMSO)) + geom_violin(aes(fill = hasSS), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = hasSS), fun = mean, \n               geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme_classic() +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\) +\n  ggtitle(\\PE\\) + geom_hline(yintercept = 0)\n\n\n\n\n# Counting loop types\nallLoopsAnnotatedFiltered <- allLoopsAnnotated %>% dplyr::filter(!is.na(loopID2)) %>%\n  dplyr::filter(!(loopID == loopID2))\ntemp <- allLoopsAnnotatedFiltered %>% dplyr::select(loopID2, Anno2)\nresult <- temp %>%\n  group_by(loopID2, Anno2) %>%\n  summarise(count = n(), .groups = 'drop') %>%\n  group_by(loopID2) %>%\n  mutate(frequency = count / sum(count)) %>%\n  arrange(loopID2, Anno2)\n\nresult <- largest_loops %>% dplyr::left_join(result, by = c(\\loopID\\ = \\loopID2\\))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(result, by = c(\\gene\\))\ndata <- data %>% filter(complete.cases(.))\n\nall_anno2 <- unique(data$Anno2)\n\n# Calculate average frequency of Anno2 for each gene in each group\nresult <- data %>%\n  # Ensure all possible Anno2 values are present for each gene and group\n  complete(gene, Anno2 = all_anno2, fill = list(frequency = 0)) %>% \n  dplyr::mutate(group = case_when(\n    gene %in% gene.group1 ~ \\group1\\,\n    gene %in% gene.group2 ~ \\group2\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::select(group, Anno2, frequency)\n  \n\nggplot(result, aes(x = Anno2, fill = group, y = frequency)) + geom_boxplot()\n\n\n\n# View results\nggplot(largest_loops, aes(x = loop_width)) + geom_histogram()\n\n\n### Checking how many genes from each group has encompassing S-S\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\\gene\\))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \\NO\\, \\YES\\)\n)\n\ndata_summary <- data %>%\n  group_by(group) %>%\n  summarize(\n    total = n(),\n    hasSS_yes = sum(hasSS == \\YES\\),\n    percentage_yes = (hasSS_yes / total) * 100\n  )\n\nggplot(data_summary, aes(x = group, y = percentage_yes, fill = group)) +\n  geom_bar(stat = \\identity\\, color = \\black\\) +\n  labs(\n    title = \\Percentage of Each Group with hasSS = YES\\,\n    x = \\Group\\,\n    y = \\Percentage (%)\\\n  ) + ylim(0, 100) +\n  theme_minimal()\n\ntemp <- data %>% dplyr::filter(hasSS == \\YES\\)\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$loop_width\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$loop_width\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, \\group1\\, \\group2\\))\n\nggplot(temp, aes(x = group, y = loop_width)) + geom_violin() + geom_boxplot(width = 0.5) +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\)\n\n\n### Comparing RNA perturbation\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(c(1, 4, 5)) %>%\n  dplyr::mutate(hasSS = ifelse(ensembl_gene_id %in% largest_loops$gene, \\hasSS\\, \\noSS\\))\n\n\nggplot(diff.RNA, aes(x = abs(log2FoldChange), color = hasSS)) +\n  stat_ecdf(size = 0.4) +\n  labs(\n    x = \\Absolute log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\n\n\n### Checking ChIP peak density\nlargest_loopsGr <- makeGRangesFromDataFrame(largest_loops, \n                                            seqnames.field = \\loop_chr\\, \n                                            start.field = \\loop_start\\, \n                                            end.field = \\loop_end\\, \n                                            keep.extra.columns = TRUE)\n\n# Find overlaps between ChIP-seq peaks and the largest loops\nchip_overlaps <- findOverlaps(largest_loopsGr, peak.H3K4me3)\n\n# Count the number of ChIP-seq peaks per loop\nloop_peak_counts <- table(queryHits(chip_overlaps))\n\n# Create a data frame with the counts and loop details\nlargest_loops$density <- 0  # Initialize density column\nlargest_loops$count <- 0    # Initialize peak count column\n\n# Add peak counts to the corresponding loops\nlargest_loops[as.numeric(names(loop_peak_counts)), \\count\\] <- as.integer(loop_peak_counts)\n\n# Calculate the density (peaks per kilobase)\nlargest_loops$density <- largest_loops$count / ((largest_loops$loop_width-1) / 1000)\n\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\\gene\\))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \\NO\\, \\YES\\)\n) %>% dplyr::filter(hasSS == \\YES\\)\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$density\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$density\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\npv <- convPvalue(getPvalWilcox(data, \\group1\\, \\group2\\))\n\nggplot(data, aes(x = group, y = density)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = group), fun = mean, \n               geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme_classic() +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\) +\n  ggtitle(\\H3K4me3\\)\n\n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\ntemp <- allLoopsAnnotated %>% dplyr::filter(Anno2 %in% c(\\P-E\\)) %>% dplyr::mutate(hasSS = !is.na(loopID2))\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(hasSS ==group1) )$diff_dTAG_DMSO\n  distance2 <- (data %>% dplyr::filter(hasSS ==group2) )$diff_dTAG_DMSO\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, TRUE, FALSE))\nggplot(temp, aes(x = hasSS, y = diff_dTAG_DMSO)) + geom_violin(aes(fill = hasSS), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = hasSS), fun = mean, \n               geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme_classic() +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\) +\n  ggtitle(\\PE\\) + geom_hline(yintercept = 0)\n\n\n\n\n# Counting loop types\nallLoopsAnnotatedFiltered <- allLoopsAnnotated %>% dplyr::filter(!is.na(loopID2)) %>%\n  dplyr::filter(!(loopID == loopID2))\ntemp <- allLoopsAnnotatedFiltered %>% dplyr::select(loopID2, Anno2)\nresult <- temp %>%\n  group_by(loopID2, Anno2) %>%\n  summarise(count = n(), .groups = 'drop') %>%\n  group_by(loopID2) %>%\n  mutate(frequency = count / sum(count)) %>%\n  arrange(loopID2, Anno2)\n\nresult <- largest_loops %>% dplyr::left_join(result, by = c(\\loopID\\ = \\loopID2\\))\n\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(result, by = c(\\gene\\))\ndata <- data %>% filter(complete.cases(.))\n\nall_anno2 <- unique(data$Anno2)\n\n# Calculate average frequency of Anno2 for each gene in each group\nresult <- data %>%\n  # Ensure all possible Anno2 values are present for each gene and group\n  complete(gene, Anno2 = all_anno2, fill = list(frequency = 0)) %>% \n  dplyr::mutate(group = case_when(\n    gene %in% gene.group1 ~ \\group1\\,\n    gene %in% gene.group2 ~ \\group2\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::select(group, Anno2, frequency)\n  \n\nggplot(result, aes(x = Anno2, fill = group, y = frequency)) + geom_boxplot()\n\n\n\n# View results\nggplot(largest_loops, aes(x = loop_width)) + geom_histogram()\n\n\n### Checking how many genes from each group has encompassing S-S\ngene.group1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngene.group2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\\gene\\))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \\NO\\, \\YES\\)\n)\n\ndata_summary <- data %>%\n  group_by(group) %>%\n  summarize(\n    total = n(),\n    hasSS_yes = sum(hasSS == \\YES\\),\n    percentage_yes = (hasSS_yes / total) * 100\n  )\n\nggplot(data_summary, aes(x = group, y = percentage_yes, fill = group)) +\n  geom_bar(stat = \\identity\\, color = \\black\\) +\n  labs(\n    title = \\Percentage of Each Group with hasSS = YES\\,\n    x = \\Group\\,\n    y = \\Percentage (%)\\\n  ) + ylim(0, 100) +\n  theme_minimal()\n\ntemp <- data %>% dplyr::filter(hasSS == \\YES\\)\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$loop_width\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$loop_width\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\npv <- convPvalue(getPvalWilcox(temp, \\group1\\, \\group2\\))\n\nggplot(temp, aes(x = group, y = loop_width)) + geom_violin() + geom_boxplot(width = 0.5) +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\)\n\n\n### Comparing RNA perturbation\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(c(1, 4, 5)) %>%\n  dplyr::mutate(hasSS = ifelse(ensembl_gene_id %in% largest_loops$gene, \\hasSS\\, \\noSS\\))\n\n\nggplot(diff.RNA, aes(x = abs(log2FoldChange), color = hasSS)) +\n  stat_ecdf(size = 0.4) +\n  labs(\n    x = \\Absolute log2(fold change)\\,\n    y = \\Cumulative Probability\\\n  ) + coord_cartesian(xlim = c(0, 1.5)) +\n  theme_classic() + # Clean theme\n  theme(\n      axis.title = element_text(\n        size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n    )\n\n\n\n### Checking ChIP peak density\nlargest_loopsGr <- makeGRangesFromDataFrame(largest_loops, \n                                            seqnames.field = \\loop_chr\\, \n                                            start.field = \\loop_start\\, \n                                            end.field = \\loop_end\\, \n                                            keep.extra.columns = TRUE)\n\n# Find overlaps between ChIP-seq peaks and the largest loops\nchip_overlaps <- findOverlaps(largest_loopsGr, peak.H3K4me3)\n\n# Count the number of ChIP-seq peaks per loop\nloop_peak_counts <- table(queryHits(chip_overlaps))\n\n# Create a data frame with the counts and loop details\nlargest_loops$density <- 0  # Initialize density column\nlargest_loops$count <- 0    # Initialize peak count column\n\n# Add peak counts to the corresponding loops\nlargest_loops[as.numeric(names(loop_peak_counts)), \\count\\] <- as.integer(loop_peak_counts)\n\n# Calculate the density (peaks per kilobase)\nlargest_loops$density <- largest_loops$count / ((largest_loops$loop_width-1) / 1000)\n\n\ndata <- tibble(\n  gene = c(gene.group1, gene.group2),\n  group = c(rep(\\group1\\, length(gene.group1)),\n            rep(\\group2\\, length(gene.group2)))\n)\n\ndata <- data %>% dplyr::left_join(largest_loops, by = c(\\gene\\))\ndata <- data %>% dplyr::mutate(\n  hasSS = ifelse(is.na(loop_width), \\NO\\, \\YES\\)\n) %>% dplyr::filter(hasSS == \\YES\\)\n\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(group ==group1) )$density\n  distance2 <- (data %>% dplyr::filter(group ==group2) )$density\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\npv <- convPvalue(getPvalWilcox(data, \\group1\\, \\group2\\))\n\nggplot(data, aes(x = group, y = density)) + geom_violin(aes(fill = group), show.legend = FALSE) + \n  geom_boxplot(width = 0.1, outlier.shape = NA) +\n  stat_summary(aes(group = group), fun = mean, \n               geom = \\point\\, shape = 21, size = 2, fill = \\red\\, color = \\black\\) +\n  theme_classic() +\n  annotate(\\text\\, x = 1, y = 0, label = pv, size = 5, color = \\black\\) +\n  ggtitle(\\H3K4me3\\)\n\n\n```\n```"} -->

```r
```r
temp <- allLoopsAnnotated %>% dplyr::filter(Anno2 %in% c(\P-E\)) %>% dplyr::mutate(hasSS = !is.na(loopID2))
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(hasSS ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(hasSS ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
pv <- convPvalue(getPvalWilcox(temp, TRUE, FALSE))
ggplot(temp, aes(x = hasSS, y = diff_dTAG_DMSO)) + geom_violin(aes(fill = hasSS), show.legend = FALSE) + 
  geom_boxplot(width = 0.1, outlier.shape = NA) +
  stat_summary(aes(group = hasSS), fun = mean, 
               geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  theme_classic() +
  annotate(\text\, x = 1, y = 0, label = pv, size = 5, color = \black\) +
  ggtitle(\PE\) + geom_hline(yintercept = 0)




# Counting loop types
allLoopsAnnotatedFiltered <- allLoopsAnnotated %>% dplyr::filter(!is.na(loopID2)) %>%
  dplyr::filter(!(loopID == loopID2))
temp <- allLoopsAnnotatedFiltered %>% dplyr::select(loopID2, Anno2)
result <- temp %>%
  group_by(loopID2, Anno2) %>%
  summarise(count = n(), .groups = 'drop') %>%
  group_by(loopID2) %>%
  mutate(frequency = count / sum(count)) %>%
  arrange(loopID2, Anno2)

result <- largest_loops %>% dplyr::left_join(result, by = c(\loopID\ = \loopID2\))

gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep(\group1\, length(gene.group1)),
            rep(\group2\, length(gene.group2)))
)

data <- data %>% dplyr::left_join(result, by = c(\gene\))
data <- data %>% filter(complete.cases(.))

all_anno2 <- unique(data$Anno2)

# Calculate average frequency of Anno2 for each gene in each group
result <- data %>%
  # Ensure all possible Anno2 values are present for each gene and group
  complete(gene, Anno2 = all_anno2, fill = list(frequency = 0)) %>% 
  dplyr::mutate(group = case_when(
    gene %in% gene.group1 ~ \group1\,
    gene %in% gene.group2 ~ \group2\,
    TRUE ~ NA
  )) %>%
  dplyr::select(group, Anno2, frequency)
  

ggplot(result, aes(x = Anno2, fill = group, y = frequency)) + geom_boxplot()



# View results
ggplot(largest_loops, aes(x = loop_width)) + geom_histogram()


### Checking how many genes from each group has encompassing S-S
gene.group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
gene.group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep(\group1\, length(gene.group1)),
            rep(\group2\, length(gene.group2)))
)

data <- data %>% dplyr::left_join(largest_loops, by = c(\gene\))
data <- data %>% dplyr::mutate(
  hasSS = ifelse(is.na(loop_width), \NO\, \YES\)
)

data_summary <- data %>%
  group_by(group) %>%
  summarize(
    total = n(),
    hasSS_yes = sum(hasSS == \YES\),
    percentage_yes = (hasSS_yes / total) * 100
  )

ggplot(data_summary, aes(x = group, y = percentage_yes, fill = group)) +
  geom_bar(stat = \identity\, color = \black\) +
  labs(
    title = \Percentage of Each Group with hasSS = YES\,
    x = \Group\,
    y = \Percentage (%)\
  ) + ylim(0, 100) +
  theme_minimal()

temp <- data %>% dplyr::filter(hasSS == \YES\)
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$loop_width
  distance2 <- (data %>% dplyr::filter(group ==group2) )$loop_width
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
pv <- convPvalue(getPvalWilcox(temp, \group1\, \group2\))

ggplot(temp, aes(x = group, y = loop_width)) + geom_violin() + geom_boxplot(width = 0.5) +
  annotate(\text\, x = 1, y = 0, label = pv, size = 5, color = \black\)


### Comparing RNA perturbation

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(c(1, 4, 5)) %>%
  dplyr::mutate(hasSS = ifelse(ensembl_gene_id %in% largest_loops$gene, \hasSS\, \noSS\))


ggplot(diff.RNA, aes(x = abs(log2FoldChange), color = hasSS)) +
  stat_ecdf(size = 0.4) +
  labs(
    x = \Absolute log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )



### Checking ChIP peak density
largest_loopsGr <- makeGRangesFromDataFrame(largest_loops, 
                                            seqnames.field = \loop_chr\, 
                                            start.field = \loop_start\, 
                                            end.field = \loop_end\, 
                                            keep.extra.columns = TRUE)

# Find overlaps between ChIP-seq peaks and the largest loops
chip_overlaps <- findOverlaps(largest_loopsGr, peak.H3K4me3)

# Count the number of ChIP-seq peaks per loop
loop_peak_counts <- table(queryHits(chip_overlaps))

# Create a data frame with the counts and loop details
largest_loops$density <- 0  # Initialize density column
largest_loops$count <- 0    # Initialize peak count column

# Add peak counts to the corresponding loops
largest_loops[as.numeric(names(loop_peak_counts)), \count\] <- as.integer(loop_peak_counts)

# Calculate the density (peaks per kilobase)
largest_loops$density <- largest_loops$count / ((largest_loops$loop_width-1) / 1000)


data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep(\group1\, length(gene.group1)),
            rep(\group2\, length(gene.group2)))
)

data <- data %>% dplyr::left_join(largest_loops, by = c(\gene\))
data <- data %>% dplyr::mutate(
  hasSS = ifelse(is.na(loop_width), \NO\, \YES\)
) %>% dplyr::filter(hasSS == \YES\)

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$density
  distance2 <- (data %>% dplyr::filter(group ==group2) )$density
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv <- convPvalue(getPvalWilcox(data, \group1\, \group2\))

ggplot(data, aes(x = group, y = density)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
  geom_boxplot(width = 0.1, outlier.shape = NA) +
  stat_summary(aes(group = group), fun = mean, 
               geom = \point\, shape = 21, size = 2, fill = \red\, color = \black\) +
  theme_classic() +
  annotate(\text\, x = 1, y = 0, label = pv, size = 5, color = \black\) +
  ggtitle(\H3K4me3\)

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


#### Plotting

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\nname <- \"chromo_cons_annoHierarchy\"\n# UP loop\nloop.up <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\")) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \"_\"))\n# NO loop\nloop.no <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\")) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \"_\"))\n# UP NO\nloop.upno <- bind_rows(loop.up, loop.no)\n# DOWN loop\nloop.down <- fread(here(consensusDir, \"chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\")) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \"_\"))\n\n\nallLoops <- fread(here(consensusDir, \"chromo_cons_annoHierarchy.tsv\")) %>%\n  dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \"_\")) %>%\n  dplyr::mutate(group = case_when(\n    loopID %in% loop.upno$loopID ~ \"UP&NO\",\n    loopID %in% loop.down$loopID ~ \"DOWN\",\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group))\n\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\"loopScore_cons_obsexp.tsv\"))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\nallLoops <- allLoops %>% left_join(obsexp, by = c(\"id\"))\nallLoops$group <- factor(allLoops$group, levels = c(\"UP&NO\", \"DOWN\"))\n\n\n### Plotting\np1 <- ggplot(allLoops, aes(x = group, y = diff_A485_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \"square\", alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \"point\", shape = 21, size = 0.5,\n    fill = \"black\", color = \"black\", position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\"grey50\", \"grey50\")) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \"Δ loop score\")  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\") + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\", linetype = \"dashed\") +\n  coord_cartesian(ylim = c(-0.5, 0.5))\n    \n\n####\np2 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_A485_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \"square\", alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \"point\", shape = 21, size = 0.5,\n    fill = \"black\", color = \"black\", position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\"grey50\", \"grey50\")) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \"log2(fc of obs/exp)\")  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\") + \n  coord_cartesian(ylim = c(-2, 2))\n  \n\n\n#############\n\n### Plotting\np3 <- ggplot(allLoops, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \"square\", alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \"point\", shape = 21, size = 0.5,\n    fill = \"black\", color = \"black\", position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\"grey50\", \"grey50\")) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \"Δ loop score\")  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\") + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\", linetype = \"dashed\") +\n  coord_cartesian(ylim = c(-0.5, 0.5))\n    \n\n####\np4 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \"square\", alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \"black\",\n               linewidth = lineThick * mmToLineUnit, lineend = \"square\",\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \"point\", shape = 21, size = 0.5,\n    fill = \"black\", color = \"black\", position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\"grey50\", \"grey50\")) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \"#000000\"\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\",\n      size = lineThick*mmToLineUnit,\n      lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \"log2(fc of obs/exp)\")  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \"black\",\n             size = lineThick*mmToLineUnit,\n             lineend = \"square\") + \n  coord_cartesian(ylim = c(-2, 2))\n  \nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\"regLoopScorefromdTAG_dTAG\")\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(plot_grid(p1, p2))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(plot_grid(p1, p2))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\"regLoopScorefromdTAG_A485\")\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(plot_grid(p3, p4))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(plot_grid(p3, p4))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\"regLoopScorefromdTAG_loopScore\")\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(plot_grid(p1, p3))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(plot_grid(p1, p3))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\"regLoopScorefromdTAG_log2fc\")\npng(here(figDir, paste0(fileName, \".png\")), res = 600, unit = \"in\", height = height, width = width)\nprint(plot_grid(p2, p4))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(plot_grid(p2, p4))\ndev.off()  \n\n```"} -->\n\n```r\nname <- \\chromo_cons_annoHierarchy\\\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \\_\\))\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \\_\\))\n# UP NO\nloop.upno <- bind_rows(loop.up, loop.no)\n# DOWN loop\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \\_\\))\n\n\nallLoops <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\)) %>%\n  dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \\_\\)) %>%\n  dplyr::mutate(group = case_when(\n    loopID %in% loop.upno$loopID ~ \\UP&NO\\,\n    loopID %in% loop.down$loopID ~ \\DOWN\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group))\n\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\nallLoops <- allLoops %>% left_join(obsexp, by = c(\\id\\))\nallLoops$group <- factor(allLoops$group, levels = c(\\UP&NO\\, \\DOWN\\))\n\n\n### Plotting\np1 <- ggplot(allLoops, aes(x = group, y = diff_A485_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.5, 0.5))\n    \n\n####\np2 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_A485_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n  \n\n\n#############\n\n### Plotting\np3 <- ggplot(allLoops, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.5, 0.5))\n    \n\n####\np4 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n  \nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_dTAG\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p1, p2))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p1, p2))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_A485\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p3, p4))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p3, p4))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_loopScore\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p1, p3))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p1, p3))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_log2fc\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p2, p4))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p2, p4))\ndev.off()  \n\n```\n\n<!-- rnb-source-end -->\n"} -->
name <- \chromo_cons_annoHierarchy\
# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>%
  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \_\))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>%
  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \_\))
# UP NO
loop.upno <- bind_rows(loop.up, loop.no)
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>%
  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \_\))


allLoops <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\)) %>%
  dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \_\)) %>%
  dplyr::mutate(group = case_when(
    loopID %in% loop.upno$loopID ~ \UP&NO\,
    loopID %in% loop.down$loopID ~ \DOWN\,
    TRUE ~ NA
  )) %>%
  dplyr::filter(!is.na(group))

minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

allLoops <- allLoops %>% left_join(obsexp, by = c(\id\))
allLoops$group <- factor(allLoops$group, levels = c(\UP&NO\, \DOWN\))


### Plotting
p1 <- ggplot(allLoops, aes(x = group, y = diff_A485_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c(\grey50\, \grey50\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \Δ loop score\)  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  geom_hline(yintercept = -0.2,
             alpha = 0.5, 
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\, linetype = \dashed\) +
  coord_cartesian(ylim = c(-0.5, 0.5))
    

####
p2 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_A485_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c(\grey50\, \grey50\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \log2(fc of obs/exp)\)  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  coord_cartesian(ylim = c(-2, 2))
  


#############

### Plotting
p3 <- ggplot(allLoops, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c(\grey50\, \grey50\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \Δ loop score\)  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  geom_hline(yintercept = -0.2,
             alpha = 0.5, 
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\, linetype = \dashed\) +
  coord_cartesian(ylim = c(-0.5, 0.5))
    

####
p4 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c(\grey50\, \grey50\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \log2(fc of obs/exp)\)  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  coord_cartesian(ylim = c(-2, 2))
  
width <- panelSize(2)*mmToInch
height <- panelSize(1.5)*mmToInch
fileName <- paste0(\regLoopScorefromdTAG_dTAG\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(plot_grid(p1, p2))
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(plot_grid(p1, p2))
dev.off()  

width <- panelSize(2)*mmToInch
height <- panelSize(1.5)*mmToInch
fileName <- paste0(\regLoopScorefromdTAG_A485\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(plot_grid(p3, p4))
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(plot_grid(p3, p4))
dev.off()  

width <- panelSize(2)*mmToInch
height <- panelSize(1.5)*mmToInch
fileName <- paste0(\regLoopScorefromdTAG_loopScore\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(plot_grid(p1, p3))
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(plot_grid(p1, p3))
dev.off()  

width <- panelSize(2)*mmToInch
height <- panelSize(1.5)*mmToInch
fileName <- paste0(\regLoopScorefromdTAG_log2fc\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(plot_grid(p2, p4))
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(plot_grid(p2, p4))
dev.off()  



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \\_\\))\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \\_\\))\n# UP NO\nloop.upno <- bind_rows(loop.up, loop.no)\n# DOWN loop\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \\_\\))\n\n\nallLoops <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\)) %>%\n  dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \\_\\)) %>%\n  dplyr::mutate(group = case_when(\n    loopID %in% loop.upno$loopID ~ \\UP&NO\\,\n    loopID %in% loop.down$loopID ~ \\DOWN\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group))\n\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\nallLoops <- allLoops %>% left_join(obsexp, by = c(\\id\\))\nallLoops$group <- factor(allLoops$group, levels = c(\\UP&NO\\, \\DOWN\\))\n\n\n### Plotting\np1 <- ggplot(allLoops, aes(x = group, y = diff_A485_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.5, 0.5))\n    \n\n####\np2 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_A485_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n  \n\n\n#############\n\n### Plotting\np3 <- ggplot(allLoops, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.5, 0.5))\n    \n\n####\np4 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n  \nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_dTAG\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p1, p2))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p1, p2))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_A485\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p3, p4))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p3, p4))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_loopScore\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p1, p3))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p1, p3))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_log2fc\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p2, p4))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p2, p4))\ndev.off()  \n\n```\n```"} -->\n\n```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \\_\\))\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \\_\\))\n# UP NO\nloop.upno <- bind_rows(loop.up, loop.no)\n# DOWN loop\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \\_\\))\n\n\nallLoops <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\)) %>%\n  dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \\_\\)) %>%\n  dplyr::mutate(group = case_when(\n    loopID %in% loop.upno$loopID ~ \\UP&NO\\,\n    loopID %in% loop.down$loopID ~ \\DOWN\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group))\n\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\nallLoops <- allLoops %>% left_join(obsexp, by = c(\\id\\))\nallLoops$group <- factor(allLoops$group, levels = c(\\UP&NO\\, \\DOWN\\))\n\n\n### Plotting\np1 <- ggplot(allLoops, aes(x = group, y = diff_A485_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.5, 0.5))\n    \n\n####\np2 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_A485_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n  \n\n\n#############\n\n### Plotting\np3 <- ggplot(allLoops, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.5, 0.5))\n    \n\n####\np4 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n  \nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_dTAG\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p1, p2))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p1, p2))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_A485\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p3, p4))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p3, p4))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_loopScore\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p1, p3))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p1, p3))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_log2fc\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p2, p4))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p2, p4))\ndev.off()  \n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\nname <- \\chromo_cons_annoHierarchy\\\n# UP loop\nloop.up <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \\_\\))\n# NO loop\nloop.no <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \\_\\))\n# UP NO\nloop.upno <- bind_rows(loop.up, loop.no)\n# DOWN loop\nloop.down <- fread(here(consensusDir, \\chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\\)) %>%\n  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \\_\\))\n\n\nallLoops <- fread(here(consensusDir, \\chromo_cons_annoHierarchy.tsv\\)) %>%\n  dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \\_\\)) %>%\n  dplyr::mutate(group = case_when(\n    loopID %in% loop.upno$loopID ~ \\UP&NO\\,\n    loopID %in% loop.down$loopID ~ \\DOWN\\,\n    TRUE ~ NA\n  )) %>%\n  dplyr::filter(!is.na(group))\n\nminValue <- -4\nobsexp <- fread(here(consensusDir, paste0(\\loopScore_cons_obsexp.tsv\\))) %>%\n  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),\n                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),\n                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),\n                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,\n                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)\n\nallLoops <- allLoops %>% left_join(obsexp, by = c(\\id\\))\nallLoops$group <- factor(allLoops$group, levels = c(\\UP&NO\\, \\DOWN\\))\n\n\n### Plotting\np1 <- ggplot(allLoops, aes(x = group, y = diff_A485_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.5, 0.5))\n    \n\n####\np2 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_A485_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n  \n\n\n#############\n\n### Plotting\np3 <- ggplot(allLoops, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\Δ loop score\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  geom_hline(yintercept = -0.2,\n             alpha = 0.5, \n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\, linetype = \\dashed\\) +\n  coord_cartesian(ylim = c(-0.5, 0.5))\n    \n\n####\np4 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + \n  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \\square\\, alpha = .4, , show.legend = FALSE) + \n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineThick * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + \n  theme_classic() + \n  stat_summary(\n    aes(group = group), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\, position = position_dodge(.3)\n  ) +\n  scale_fill_manual(values = c(\\grey50\\, \\grey50\\)) +\n\n  theme(\n    axis.title.x = element_blank(),\n    axis.title.y = element_text(\n      size = fontSizeM,\n      family = fontType,\n      color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS,\n      family = fontType,\n      color = \\#000000\\\n    ),    \n    axis.text.x = element_text(\n      size = fontSizeM,\n      angle = 45,      # Rotate x-axis labels 45 degrees\n      hjust = 1,       # Adjust horizontal justification\n      vjust = 1        # Adjust vertical justification\n    ),\n    axis.line = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\,\n      size = lineThick*mmToLineUnit,\n      lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +labs(y = \\log2(fc of obs/exp)\\)  +    \n  geom_hline(yintercept = 0,\n             alpha = 1,\n             color = \\black\\,\n             size = lineThick*mmToLineUnit,\n             lineend = \\square\\) + \n  coord_cartesian(ylim = c(-2, 2))\n  \nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_dTAG\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p1, p2))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p1, p2))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_A485\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p3, p4))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p3, p4))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_loopScore\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p1, p3))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p1, p3))\ndev.off()  \n\nwidth <- panelSize(2)*mmToInch\nheight <- panelSize(1.5)*mmToInch\nfileName <- paste0(\\regLoopScorefromdTAG_log2fc\\)\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(plot_grid(p2, p4))\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(plot_grid(p2, p4))\ndev.off()  \n\n```\n```"} -->

```r
```r
name <- \chromo_cons_annoHierarchy\
# UP loop
loop.up <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe\)) %>%
  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \_\))
# NO loop
loop.no <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe\)) %>%
  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \_\))
# UP NO
loop.upno <- bind_rows(loop.up, loop.no)
# DOWN loop
loop.down <- fread(here(consensusDir, \chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe\)) %>%
  dplyr::mutate(loopID = paste(V1, V2, V6, sep = \_\))


allLoops <- fread(here(consensusDir, \chromo_cons_annoHierarchy.tsv\)) %>%
  dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = \_\)) %>%
  dplyr::mutate(group = case_when(
    loopID %in% loop.upno$loopID ~ \UP&NO\,
    loopID %in% loop.down$loopID ~ \DOWN\,
    TRUE ~ NA
  )) %>%
  dplyr::filter(!is.na(group))

minValue <- -4
obsexp <- fread(here(consensusDir, paste0(\loopScore_cons_obsexp.tsv\))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

allLoops <- allLoops %>% left_join(obsexp, by = c(\id\))
allLoops$group <- factor(allLoops$group, levels = c(\UP&NO\, \DOWN\))


### Plotting
p1 <- ggplot(allLoops, aes(x = group, y = diff_A485_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c(\grey50\, \grey50\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \Δ loop score\)  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  geom_hline(yintercept = -0.2,
             alpha = 0.5, 
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\, linetype = \dashed\) +
  coord_cartesian(ylim = c(-0.5, 0.5))
    

####
p2 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_A485_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c(\grey50\, \grey50\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \log2(fc of obs/exp)\)  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  coord_cartesian(ylim = c(-2, 2))
  


#############

### Plotting
p3 <- ggplot(allLoops, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c(\grey50\, \grey50\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \Δ loop score\)  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  geom_hline(yintercept = -0.2,
             alpha = 0.5, 
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\, linetype = \dashed\) +
  coord_cartesian(ylim = c(-0.5, 0.5))
    

####
p4 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = \square\, alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineThick * mmToLineUnit, lineend = \square\,
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\, position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c(\grey50\, \grey50\)) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = \log2(fc of obs/exp)\)  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = \black\,
             size = lineThick*mmToLineUnit,
             lineend = \square\) + 
  coord_cartesian(ylim = c(-2, 2))
  
width <- panelSize(2)*mmToInch
height <- panelSize(1.5)*mmToInch
fileName <- paste0(\regLoopScorefromdTAG_dTAG\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(plot_grid(p1, p2))
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(plot_grid(p1, p2))
dev.off()  

width <- panelSize(2)*mmToInch
height <- panelSize(1.5)*mmToInch
fileName <- paste0(\regLoopScorefromdTAG_A485\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(plot_grid(p3, p4))
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(plot_grid(p3, p4))
dev.off()  

width <- panelSize(2)*mmToInch
height <- panelSize(1.5)*mmToInch
fileName <- paste0(\regLoopScorefromdTAG_loopScore\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(plot_grid(p1, p3))
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(plot_grid(p1, p3))
dev.off()  

width <- panelSize(2)*mmToInch
height <- panelSize(1.5)*mmToInch
fileName <- paste0(\regLoopScorefromdTAG_log2fc\)
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(plot_grid(p2, p4))
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(plot_grid(p2, p4))
dev.off()  

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->




<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n\npeak.RAD21 <- importPeak(here(refDir, \"33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\"))\n\n##########################################################\nflankSize <- 5000\ngene.tb <- fread(here(refDir, \"mm10_GRCm38.p6_gene_sorted.bed\")) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \"+\", V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V6, V5, V1, TSSstart, TSSend)\ncolnames(gene.tb) <- c(\"ensembl_gene_id\", \"external_gene_name\", \"chr\", \"start\", \"end\")\n\n\n# Convert gene.tb to a GRanges object\ngene_gr <- GRanges(\n  seqnames = gene.tb$chr,\n  ranges = IRanges(start = gene.tb$start, end = gene.tb$end),\n  gene_id = gene.tb$ensembl_gene_id\n)\n\n# Count overlaps between peaks and genes\noverlap_counts <- countOverlaps(gene_gr, peak.RAD21)\n\n# Add overlap counts to the original gene.tb data\ngene.tb$peak_count <- overlap_counts\n\n###############################################################################\n\npeakNum0 <- (gene.tb %>% dplyr::filter(peak_count == 0))$ensembl_gene_id\npeakNum1 <- (gene.tb %>% dplyr::filter(peak_count == 1))$ensembl_gene_id\npeakNum2 <- (gene.tb %>% dplyr::filter(peak_count == 2))$ensembl_gene_id\npeakNum3 <- (gene.tb %>% dplyr::filter(peak_count == 3))$ensembl_gene_id\npeakNumOver4 <- (gene.tb %>% dplyr::filter(peak_count >= 4))$ensembl_gene_id\n\n\n###############################################################################\nname <- \"chromo_cons_annoHierarchy\"\n\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.dTAG <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::filter(padj < alpha)\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\"P-P\", \"P-E\", \"P-S\", \"P-X\"))%>% \n  dplyr::mutate(distance = start2 - start1,\n                peakID = paste(chrom1, start1, start2, sep = \"_\"))\n\n\n## Dividing genes into groups\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO),\n            mean_distance = mean(distance),\n            .groups = 'drop')\n\ndiff.RNA <- fread(here(refDir, \"diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\")) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nmaxLog2FC = 2\n\ntemp <- left_join(temp, diff.RNA, by = c(\"gene\" = \"ensembl_gene_id\")) %>% \n  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \"2DOWN\", \"0NO\"),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag) %>%\n  drop_na(shrinked_log2FC)\n\ntemp <- temp %>% dplyr::mutate(\n  pnOver = ifelse(gene %in% peakNum0, \"peakNum0\",\n                  ifelse(gene %in% peakNum1, \"peakNum1\",\n                         ifelse(gene %in% peakNum2, \"peakNum2\",\n                                ifelse(gene %in% peakNum3, \"peakNum3\",\n                                       ifelse(gene %in% peakNumOver4, \"peakNumOver4\", NA)))))) %>%\n  drop_na(pnOver)\n\n###############################################################################\n# Checking percentage of genes with RAD21 peaks\ngroup1 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\"))$gene\ngroup2 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\"))$gene\n\naaa <- temp %>% dplyr::mutate(group = case_when(\n  gene %in% group1 ~ \"group1\",\n  gene %in% group2 ~ \"group2\",\n  TRUE ~ NA\n)) %>%\n  dplyr::select(group, pnOver, gene) %>%\n  dplyr::filter(group %in% c(\"group1\", \"group2\")) %>%\n  dplyr::mutate(hasPeak = ifelse(pnOver == \"peakNum0\", FALSE, TRUE))\n\nbbb <- aaa %>% dplyr::filter(group == \"group1\") \n\nsum(bbb$hasPeak)\nbbb <- aaa %>% dplyr::filter(group == \"group2\") \nsum(bbb$hasPeak)\n\naaa_summary <- aaa %>%\n  group_by(group, pnOver) %>%\n  summarize(count = n(), .groups = \"drop\")\n\n# Create the stacked barplot\naaa_summary <- aaa %>%\n  group_by(group, pnOver) %>%\n  summarize(count = n(), .groups = \"drop\") %>%\n  group_by(group) %>%\n  mutate(ratio = count / sum(count))\n\n# Define the gradient colors\ngradient_colors <- c(\"#D4D4D4\", \"#DCB0AF\", \"#E48D8A\", \"#EC6965\", \"#F44641\")\n# gradient_colors <- c(\"#D4D4D4\", \"#A2BBCA\", \"#71A2C0\", \"#3F89B7\", \"#0E71AD\")\n\n# Create the stacked barplot with gradient colors\np <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = pnOver)) +\n  geom_bar(stat = \"identity\", position = \"stack\",\n           linewidth = lineMedium * mmToLineUnit, lineend = \"square\") +\n  theme_classic() + labs(x = NULL , y = \"Ratio\") +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +\n  scale_fill_manual(values = gradient_colors, \n                    guide = guide_legend(\n      override.aes = list(size = 0.5), # Adjust legend key symbol size\n      keywidth = 2 / 2.54, # Convert 2mm to cm\n      keyheight = 2 / 2.54 # Convert 2mm to cm\n    )) \n\nwidth <- panelSize(1.7)*mmToInch\nheight <- panelSize(1.3)*mmToInch\nfileName <- paste0(\"rad21perc_promoter\")\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()  \n\n```"} -->\n\n```r\n\npeak.RAD21 <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n\n##########################################################\nflankSize <- 5000\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V6, V5, V1, TSSstart, TSSend)\ncolnames(gene.tb) <- c(\\ensembl_gene_id\\, \\external_gene_name\\, \\chr\\, \\start\\, \\end\\)\n\n\n# Convert gene.tb to a GRanges object\ngene_gr <- GRanges(\n  seqnames = gene.tb$chr,\n  ranges = IRanges(start = gene.tb$start, end = gene.tb$end),\n  gene_id = gene.tb$ensembl_gene_id\n)\n\n# Count overlaps between peaks and genes\noverlap_counts <- countOverlaps(gene_gr, peak.RAD21)\n\n# Add overlap counts to the original gene.tb data\ngene.tb$peak_count <- overlap_counts\n\n###############################################################################\n\npeakNum0 <- (gene.tb %>% dplyr::filter(peak_count == 0))$ensembl_gene_id\npeakNum1 <- (gene.tb %>% dplyr::filter(peak_count == 1))$ensembl_gene_id\npeakNum2 <- (gene.tb %>% dplyr::filter(peak_count == 2))$ensembl_gene_id\npeakNum3 <- (gene.tb %>% dplyr::filter(peak_count == 3))$ensembl_gene_id\npeakNumOver4 <- (gene.tb %>% dplyr::filter(peak_count >= 4))$ensembl_gene_id\n\n\n###############################################################################\nname <- \\chromo_cons_annoHierarchy\\\n\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1,\n                peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n\n## Dividing genes into groups\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO),\n            mean_distance = mean(distance),\n            .groups = 'drop')\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nmaxLog2FC = 2\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \\2DOWN\\, \\0NO\\),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag) %>%\n  drop_na(shrinked_log2FC)\n\ntemp <- temp %>% dplyr::mutate(\n  pnOver = ifelse(gene %in% peakNum0, \\peakNum0\\,\n                  ifelse(gene %in% peakNum1, \\peakNum1\\,\n                         ifelse(gene %in% peakNum2, \\peakNum2\\,\n                                ifelse(gene %in% peakNum3, \\peakNum3\\,\n                                       ifelse(gene %in% peakNumOver4, \\peakNumOver4\\, NA)))))) %>%\n  drop_na(pnOver)\n\n###############################################################################\n# Checking percentage of genes with RAD21 peaks\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\naaa <- temp %>% dplyr::mutate(group = case_when(\n  gene %in% group1 ~ \\group1\\,\n  gene %in% group2 ~ \\group2\\,\n  TRUE ~ NA\n)) %>%\n  dplyr::select(group, pnOver, gene) %>%\n  dplyr::filter(group %in% c(\\group1\\, \\group2\\)) %>%\n  dplyr::mutate(hasPeak = ifelse(pnOver == \\peakNum0\\, FALSE, TRUE))\n\nbbb <- aaa %>% dplyr::filter(group == \\group1\\) \n\nsum(bbb$hasPeak)\nbbb <- aaa %>% dplyr::filter(group == \\group2\\) \nsum(bbb$hasPeak)\n\naaa_summary <- aaa %>%\n  group_by(group, pnOver) %>%\n  summarize(count = n(), .groups = \\drop\\)\n\n# Create the stacked barplot\naaa_summary <- aaa %>%\n  group_by(group, pnOver) %>%\n  summarize(count = n(), .groups = \\drop\\) %>%\n  group_by(group) %>%\n  mutate(ratio = count / sum(count))\n\n# Define the gradient colors\ngradient_colors <- c(\\#D4D4D4\\, \\#DCB0AF\\, \\#E48D8A\\, \\#EC6965\\, \\#F44641\\)\n# gradient_colors <- c(\\#D4D4D4\\, \\#A2BBCA\\, \\#71A2C0\\, \\#3F89B7\\, \\#0E71AD\\)\n\n# Create the stacked barplot with gradient colors\np <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = pnOver)) +\n  geom_bar(stat = \\identity\\, position = \\stack\\,\n           linewidth = lineMedium * mmToLineUnit, lineend = \\square\\) +\n  theme_classic() + labs(x = NULL , y = \\Ratio\\) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +\n  scale_fill_manual(values = gradient_colors, \n                    guide = guide_legend(\n      override.aes = list(size = 0.5), # Adjust legend key symbol size\n      keywidth = 2 / 2.54, # Convert 2mm to cm\n      keyheight = 2 / 2.54 # Convert 2mm to cm\n    )) \n\nwidth <- panelSize(1.7)*mmToInch\nheight <- panelSize(1.3)*mmToInch\nfileName <- paste0(\\rad21perc_promoter\\)\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n```\n\n<!-- rnb-source-end -->\n"} -->

peak.RAD21 <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))

##########################################################
flankSize <- 5000
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V6, V5, V1, TSSstart, TSSend)
colnames(gene.tb) <- c(\ensembl_gene_id\, \external_gene_name\, \chr\, \start\, \end\)


# Convert gene.tb to a GRanges object
gene_gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$start, end = gene.tb$end),
  gene_id = gene.tb$ensembl_gene_id
)

# Count overlaps between peaks and genes
overlap_counts <- countOverlaps(gene_gr, peak.RAD21)

# Add overlap counts to the original gene.tb data
gene.tb$peak_count <- overlap_counts

###############################################################################

peakNum0 <- (gene.tb %>% dplyr::filter(peak_count == 0))$ensembl_gene_id
peakNum1 <- (gene.tb %>% dplyr::filter(peak_count == 1))$ensembl_gene_id
peakNum2 <- (gene.tb %>% dplyr::filter(peak_count == 2))$ensembl_gene_id
peakNum3 <- (gene.tb %>% dplyr::filter(peak_count == 3))$ensembl_gene_id
peakNumOver4 <- (gene.tb %>% dplyr::filter(peak_count >= 4))$ensembl_gene_id


###############################################################################
name <- \chromo_cons_annoHierarchy\

alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))


## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \2DOWN\, \0NO\),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  pnOver = ifelse(gene %in% peakNum0, \peakNum0\,
                  ifelse(gene %in% peakNum1, \peakNum1\,
                         ifelse(gene %in% peakNum2, \peakNum2\,
                                ifelse(gene %in% peakNum3, \peakNum3\,
                                       ifelse(gene %in% peakNumOver4, \peakNumOver4\, NA)))))) %>%
  drop_na(pnOver)

###############################################################################
# Checking percentage of genes with RAD21 peaks
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

aaa <- temp %>% dplyr::mutate(group = case_when(
  gene %in% group1 ~ \group1\,
  gene %in% group2 ~ \group2\,
  TRUE ~ NA
)) %>%
  dplyr::select(group, pnOver, gene) %>%
  dplyr::filter(group %in% c(\group1\, \group2\)) %>%
  dplyr::mutate(hasPeak = ifelse(pnOver == \peakNum0\, FALSE, TRUE))

bbb <- aaa %>% dplyr::filter(group == \group1\) 

sum(bbb$hasPeak)
bbb <- aaa %>% dplyr::filter(group == \group2\) 
sum(bbb$hasPeak)

aaa_summary <- aaa %>%
  group_by(group, pnOver) %>%
  summarize(count = n(), .groups = \drop\)

# Create the stacked barplot
aaa_summary <- aaa %>%
  group_by(group, pnOver) %>%
  summarize(count = n(), .groups = \drop\) %>%
  group_by(group) %>%
  mutate(ratio = count / sum(count))

# Define the gradient colors
gradient_colors <- c(\#D4D4D4\, \#DCB0AF\, \#E48D8A\, \#EC6965\, \#F44641\)
# gradient_colors <- c(\#D4D4D4\, \#A2BBCA\, \#71A2C0\, \#3F89B7\, \#0E71AD\)

# Create the stacked barplot with gradient colors
p <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = pnOver)) +
  geom_bar(stat = \identity\, position = \stack\,
           linewidth = lineMedium * mmToLineUnit, lineend = \square\) +
  theme_classic() + labs(x = NULL , y = \Ratio\) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +
  scale_fill_manual(values = gradient_colors, 
                    guide = guide_legend(
      override.aes = list(size = 0.5), # Adjust legend key symbol size
      keywidth = 2 / 2.54, # Convert 2mm to cm
      keyheight = 2 / 2.54 # Convert 2mm to cm
    )) 

width <- panelSize(1.7)*mmToInch
height <- panelSize(1.3)*mmToInch
fileName <- paste0(\rad21perc_promoter\)
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()  



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin {"data":"```r\n```r\n\npeak.RAD21 <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n\n##########################################################\nflankSize <- 5000\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V6, V5, V1, TSSstart, TSSend)\ncolnames(gene.tb) <- c(\\ensembl_gene_id\\, \\external_gene_name\\, \\chr\\, \\start\\, \\end\\)\n\n\n# Convert gene.tb to a GRanges object\ngene_gr <- GRanges(\n  seqnames = gene.tb$chr,\n  ranges = IRanges(start = gene.tb$start, end = gene.tb$end),\n  gene_id = gene.tb$ensembl_gene_id\n)\n\n# Count overlaps between peaks and genes\noverlap_counts <- countOverlaps(gene_gr, peak.RAD21)\n\n# Add overlap counts to the original gene.tb data\ngene.tb$peak_count <- overlap_counts\n\n###############################################################################\n\npeakNum0 <- (gene.tb %>% dplyr::filter(peak_count == 0))$ensembl_gene_id\npeakNum1 <- (gene.tb %>% dplyr::filter(peak_count == 1))$ensembl_gene_id\npeakNum2 <- (gene.tb %>% dplyr::filter(peak_count == 2))$ensembl_gene_id\npeakNum3 <- (gene.tb %>% dplyr::filter(peak_count == 3))$ensembl_gene_id\npeakNumOver4 <- (gene.tb %>% dplyr::filter(peak_count >= 4))$ensembl_gene_id\n\n\n###############################################################################\nname <- \\chromo_cons_annoHierarchy\\\n\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1,\n                peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n\n## Dividing genes into groups\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO),\n            mean_distance = mean(distance),\n            .groups = 'drop')\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nmaxLog2FC = 2\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \\2DOWN\\, \\0NO\\),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag) %>%\n  drop_na(shrinked_log2FC)\n\ntemp <- temp %>% dplyr::mutate(\n  pnOver = ifelse(gene %in% peakNum0, \\peakNum0\\,\n                  ifelse(gene %in% peakNum1, \\peakNum1\\,\n                         ifelse(gene %in% peakNum2, \\peakNum2\\,\n                                ifelse(gene %in% peakNum3, \\peakNum3\\,\n                                       ifelse(gene %in% peakNumOver4, \\peakNumOver4\\, NA)))))) %>%\n  drop_na(pnOver)\n\n###############################################################################\n# Checking percentage of genes with RAD21 peaks\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\naaa <- temp %>% dplyr::mutate(group = case_when(\n  gene %in% group1 ~ \\group1\\,\n  gene %in% group2 ~ \\group2\\,\n  TRUE ~ NA\n)) %>%\n  dplyr::select(group, pnOver, gene) %>%\n  dplyr::filter(group %in% c(\\group1\\, \\group2\\)) %>%\n  dplyr::mutate(hasPeak = ifelse(pnOver == \\peakNum0\\, FALSE, TRUE))\n\nbbb <- aaa %>% dplyr::filter(group == \\group1\\) \n\nsum(bbb$hasPeak)\nbbb <- aaa %>% dplyr::filter(group == \\group2\\) \nsum(bbb$hasPeak)\n\naaa_summary <- aaa %>%\n  group_by(group, pnOver) %>%\n  summarize(count = n(), .groups = \\drop\\)\n\n# Create the stacked barplot\naaa_summary <- aaa %>%\n  group_by(group, pnOver) %>%\n  summarize(count = n(), .groups = \\drop\\) %>%\n  group_by(group) %>%\n  mutate(ratio = count / sum(count))\n\n# Define the gradient colors\ngradient_colors <- c(\\#D4D4D4\\, \\#DCB0AF\\, \\#E48D8A\\, \\#EC6965\\, \\#F44641\\)\n# gradient_colors <- c(\\#D4D4D4\\, \\#A2BBCA\\, \\#71A2C0\\, \\#3F89B7\\, \\#0E71AD\\)\n\n# Create the stacked barplot with gradient colors\np <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = pnOver)) +\n  geom_bar(stat = \\identity\\, position = \\stack\\,\n           linewidth = lineMedium * mmToLineUnit, lineend = \\square\\) +\n  theme_classic() + labs(x = NULL , y = \\Ratio\\) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +\n  scale_fill_manual(values = gradient_colors, \n                    guide = guide_legend(\n      override.aes = list(size = 0.5), # Adjust legend key symbol size\n      keywidth = 2 / 2.54, # Convert 2mm to cm\n      keyheight = 2 / 2.54 # Convert 2mm to cm\n    )) \n\nwidth <- panelSize(1.7)*mmToInch\nheight <- panelSize(1.3)*mmToInch\nfileName <- paste0(\\rad21perc_promoter\\)\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n```\n```"} -->\n\n```r\n```r\n\npeak.RAD21 <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n\n##########################################################\nflankSize <- 5000\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V6, V5, V1, TSSstart, TSSend)\ncolnames(gene.tb) <- c(\\ensembl_gene_id\\, \\external_gene_name\\, \\chr\\, \\start\\, \\end\\)\n\n\n# Convert gene.tb to a GRanges object\ngene_gr <- GRanges(\n  seqnames = gene.tb$chr,\n  ranges = IRanges(start = gene.tb$start, end = gene.tb$end),\n  gene_id = gene.tb$ensembl_gene_id\n)\n\n# Count overlaps between peaks and genes\noverlap_counts <- countOverlaps(gene_gr, peak.RAD21)\n\n# Add overlap counts to the original gene.tb data\ngene.tb$peak_count <- overlap_counts\n\n###############################################################################\n\npeakNum0 <- (gene.tb %>% dplyr::filter(peak_count == 0))$ensembl_gene_id\npeakNum1 <- (gene.tb %>% dplyr::filter(peak_count == 1))$ensembl_gene_id\npeakNum2 <- (gene.tb %>% dplyr::filter(peak_count == 2))$ensembl_gene_id\npeakNum3 <- (gene.tb %>% dplyr::filter(peak_count == 3))$ensembl_gene_id\npeakNumOver4 <- (gene.tb %>% dplyr::filter(peak_count >= 4))$ensembl_gene_id\n\n\n###############################################################################\nname <- \\chromo_cons_annoHierarchy\\\n\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1,\n                peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n\n## Dividing genes into groups\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO),\n            mean_distance = mean(distance),\n            .groups = 'drop')\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nmaxLog2FC = 2\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \\2DOWN\\, \\0NO\\),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag) %>%\n  drop_na(shrinked_log2FC)\n\ntemp <- temp %>% dplyr::mutate(\n  pnOver = ifelse(gene %in% peakNum0, \\peakNum0\\,\n                  ifelse(gene %in% peakNum1, \\peakNum1\\,\n                         ifelse(gene %in% peakNum2, \\peakNum2\\,\n                                ifelse(gene %in% peakNum3, \\peakNum3\\,\n                                       ifelse(gene %in% peakNumOver4, \\peakNumOver4\\, NA)))))) %>%\n  drop_na(pnOver)\n\n###############################################################################\n# Checking percentage of genes with RAD21 peaks\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\naaa <- temp %>% dplyr::mutate(group = case_when(\n  gene %in% group1 ~ \\group1\\,\n  gene %in% group2 ~ \\group2\\,\n  TRUE ~ NA\n)) %>%\n  dplyr::select(group, pnOver, gene) %>%\n  dplyr::filter(group %in% c(\\group1\\, \\group2\\)) %>%\n  dplyr::mutate(hasPeak = ifelse(pnOver == \\peakNum0\\, FALSE, TRUE))\n\nbbb <- aaa %>% dplyr::filter(group == \\group1\\) \n\nsum(bbb$hasPeak)\nbbb <- aaa %>% dplyr::filter(group == \\group2\\) \nsum(bbb$hasPeak)\n\naaa_summary <- aaa %>%\n  group_by(group, pnOver) %>%\n  summarize(count = n(), .groups = \\drop\\)\n\n# Create the stacked barplot\naaa_summary <- aaa %>%\n  group_by(group, pnOver) %>%\n  summarize(count = n(), .groups = \\drop\\) %>%\n  group_by(group) %>%\n  mutate(ratio = count / sum(count))\n\n# Define the gradient colors\ngradient_colors <- c(\\#D4D4D4\\, \\#DCB0AF\\, \\#E48D8A\\, \\#EC6965\\, \\#F44641\\)\n# gradient_colors <- c(\\#D4D4D4\\, \\#A2BBCA\\, \\#71A2C0\\, \\#3F89B7\\, \\#0E71AD\\)\n\n# Create the stacked barplot with gradient colors\np <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = pnOver)) +\n  geom_bar(stat = \\identity\\, position = \\stack\\,\n           linewidth = lineMedium * mmToLineUnit, lineend = \\square\\) +\n  theme_classic() + labs(x = NULL , y = \\Ratio\\) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +\n  scale_fill_manual(values = gradient_colors, \n                    guide = guide_legend(\n      override.aes = list(size = 0.5), # Adjust legend key symbol size\n      keywidth = 2 / 2.54, # Convert 2mm to cm\n      keyheight = 2 / 2.54 # Convert 2mm to cm\n    )) \n\nwidth <- panelSize(1.7)*mmToInch\nheight <- panelSize(1.3)*mmToInch\nfileName <- paste0(\\rad21perc_promoter\\)\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin {"data":"```r\n```r\n\npeak.RAD21 <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\n\n##########################################################\nflankSize <- 5000\ngene.tb <- fread(here(refDir, \\mm10_GRCm38.p6_gene_sorted.bed\\)) %>%\n  dplyr::mutate(TSS = ifelse(V4 == \\+\\, V2, V3),\n                TSSstart = TSS - flankSize,\n                TSSend = TSS + flankSize) %>%\n  dplyr::select(V6, V5, V1, TSSstart, TSSend)\ncolnames(gene.tb) <- c(\\ensembl_gene_id\\, \\external_gene_name\\, \\chr\\, \\start\\, \\end\\)\n\n\n# Convert gene.tb to a GRanges object\ngene_gr <- GRanges(\n  seqnames = gene.tb$chr,\n  ranges = IRanges(start = gene.tb$start, end = gene.tb$end),\n  gene_id = gene.tb$ensembl_gene_id\n)\n\n# Count overlaps between peaks and genes\noverlap_counts <- countOverlaps(gene_gr, peak.RAD21)\n\n# Add overlap counts to the original gene.tb data\ngene.tb$peak_count <- overlap_counts\n\n###############################################################################\n\npeakNum0 <- (gene.tb %>% dplyr::filter(peak_count == 0))$ensembl_gene_id\npeakNum1 <- (gene.tb %>% dplyr::filter(peak_count == 1))$ensembl_gene_id\npeakNum2 <- (gene.tb %>% dplyr::filter(peak_count == 2))$ensembl_gene_id\npeakNum3 <- (gene.tb %>% dplyr::filter(peak_count == 3))$ensembl_gene_id\npeakNumOver4 <- (gene.tb %>% dplyr::filter(peak_count >= 4))$ensembl_gene_id\n\n\n###############################################################################\nname <- \\chromo_cons_annoHierarchy\\\n\nalpha <- 0.05\nfcCutoff <- 0.5\ndiff.RNA.G1.dTAG <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)\ndiff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::filter(padj < alpha)\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\\P-P\\, \\P-E\\, \\P-S\\, \\P-X\\))%>% \n  dplyr::mutate(distance = start2 - start1,\n                peakID = paste(chrom1, start1, start2, sep = \\_\\))\n\n\n## Dividing genes into groups\ntemp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% \n  unnest(gene) %>% group_by(gene) %>%\n  summarize(mean_diff_score = mean(diff_dTAG_DMSO),\n            mean_distance = mean(distance),\n            .groups = 'drop')\n\ndiff.RNA <- fread(here(refDir, \\diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\\)) %>%\n  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)\n\nmaxLog2FC = 2\n\ntemp <- left_join(temp, diff.RNA, by = c(\\gene\\ = \\ensembl_gene_id\\)) %>% \n  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \\2DOWN\\, \\0NO\\),\n                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),\n                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% \n  dplyr::arrange(flag) %>%\n  drop_na(shrinked_log2FC)\n\ntemp <- temp %>% dplyr::mutate(\n  pnOver = ifelse(gene %in% peakNum0, \\peakNum0\\,\n                  ifelse(gene %in% peakNum1, \\peakNum1\\,\n                         ifelse(gene %in% peakNum2, \\peakNum2\\,\n                                ifelse(gene %in% peakNum3, \\peakNum3\\,\n                                       ifelse(gene %in% peakNumOver4, \\peakNumOver4\\, NA)))))) %>%\n  drop_na(pnOver)\n\n###############################################################################\n# Checking percentage of genes with RAD21 peaks\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\naaa <- temp %>% dplyr::mutate(group = case_when(\n  gene %in% group1 ~ \\group1\\,\n  gene %in% group2 ~ \\group2\\,\n  TRUE ~ NA\n)) %>%\n  dplyr::select(group, pnOver, gene) %>%\n  dplyr::filter(group %in% c(\\group1\\, \\group2\\)) %>%\n  dplyr::mutate(hasPeak = ifelse(pnOver == \\peakNum0\\, FALSE, TRUE))\n\nbbb <- aaa %>% dplyr::filter(group == \\group1\\) \n\nsum(bbb$hasPeak)\nbbb <- aaa %>% dplyr::filter(group == \\group2\\) \nsum(bbb$hasPeak)\n\naaa_summary <- aaa %>%\n  group_by(group, pnOver) %>%\n  summarize(count = n(), .groups = \\drop\\)\n\n# Create the stacked barplot\naaa_summary <- aaa %>%\n  group_by(group, pnOver) %>%\n  summarize(count = n(), .groups = \\drop\\) %>%\n  group_by(group) %>%\n  mutate(ratio = count / sum(count))\n\n# Define the gradient colors\ngradient_colors <- c(\\#D4D4D4\\, \\#DCB0AF\\, \\#E48D8A\\, \\#EC6965\\, \\#F44641\\)\n# gradient_colors <- c(\\#D4D4D4\\, \\#A2BBCA\\, \\#71A2C0\\, \\#3F89B7\\, \\#0E71AD\\)\n\n# Create the stacked barplot with gradient colors\np <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = pnOver)) +\n  geom_bar(stat = \\identity\\, position = \\stack\\,\n           linewidth = lineMedium * mmToLineUnit, lineend = \\square\\) +\n  theme_classic() + labs(x = NULL , y = \\Ratio\\) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +\n  scale_fill_manual(values = gradient_colors, \n                    guide = guide_legend(\n      override.aes = list(size = 0.5), # Adjust legend key symbol size\n      keywidth = 2 / 2.54, # Convert 2mm to cm\n      keyheight = 2 / 2.54 # Convert 2mm to cm\n    )) \n\nwidth <- panelSize(1.7)*mmToInch\nheight <- panelSize(1.3)*mmToInch\nfileName <- paste0(\\rad21perc_promoter\\)\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n```\n```"} -->

```r
```r

peak.RAD21 <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))

##########################################################
flankSize <- 5000
gene.tb <- fread(here(refDir, \mm10_GRCm38.p6_gene_sorted.bed\)) %>%
  dplyr::mutate(TSS = ifelse(V4 == \+\, V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V6, V5, V1, TSSstart, TSSend)
colnames(gene.tb) <- c(\ensembl_gene_id\, \external_gene_name\, \chr\, \start\, \end\)


# Convert gene.tb to a GRanges object
gene_gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$start, end = gene.tb$end),
  gene_id = gene.tb$ensembl_gene_id
)

# Count overlaps between peaks and genes
overlap_counts <- countOverlaps(gene_gr, peak.RAD21)

# Add overlap counts to the original gene.tb data
gene.tb$peak_count <- overlap_counts

###############################################################################

peakNum0 <- (gene.tb %>% dplyr::filter(peak_count == 0))$ensembl_gene_id
peakNum1 <- (gene.tb %>% dplyr::filter(peak_count == 1))$ensembl_gene_id
peakNum2 <- (gene.tb %>% dplyr::filter(peak_count == 2))$ensembl_gene_id
peakNum3 <- (gene.tb %>% dplyr::filter(peak_count == 3))$ensembl_gene_id
peakNumOver4 <- (gene.tb %>% dplyr::filter(peak_count >= 4))$ensembl_gene_id


###############################################################################
name <- \chromo_cons_annoHierarchy\

alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.G1.dTAG <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::filter(padj < alpha)
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-P\, \P-E\, \P-S\, \P-X\))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = \_\))


## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, \diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv\)) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c(\gene\ = \ensembl_gene_id\)) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, \2DOWN\, \0NO\),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  pnOver = ifelse(gene %in% peakNum0, \peakNum0\,
                  ifelse(gene %in% peakNum1, \peakNum1\,
                         ifelse(gene %in% peakNum2, \peakNum2\,
                                ifelse(gene %in% peakNum3, \peakNum3\,
                                       ifelse(gene %in% peakNumOver4, \peakNumOver4\, NA)))))) %>%
  drop_na(pnOver)

###############################################################################
# Checking percentage of genes with RAD21 peaks
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene

aaa <- temp %>% dplyr::mutate(group = case_when(
  gene %in% group1 ~ \group1\,
  gene %in% group2 ~ \group2\,
  TRUE ~ NA
)) %>%
  dplyr::select(group, pnOver, gene) %>%
  dplyr::filter(group %in% c(\group1\, \group2\)) %>%
  dplyr::mutate(hasPeak = ifelse(pnOver == \peakNum0\, FALSE, TRUE))

bbb <- aaa %>% dplyr::filter(group == \group1\) 

sum(bbb$hasPeak)
bbb <- aaa %>% dplyr::filter(group == \group2\) 
sum(bbb$hasPeak)

aaa_summary <- aaa %>%
  group_by(group, pnOver) %>%
  summarize(count = n(), .groups = \drop\)

# Create the stacked barplot
aaa_summary <- aaa %>%
  group_by(group, pnOver) %>%
  summarize(count = n(), .groups = \drop\) %>%
  group_by(group) %>%
  mutate(ratio = count / sum(count))

# Define the gradient colors
gradient_colors <- c(\#D4D4D4\, \#DCB0AF\, \#E48D8A\, \#EC6965\, \#F44641\)
# gradient_colors <- c(\#D4D4D4\, \#A2BBCA\, \#71A2C0\, \#3F89B7\, \#0E71AD\)

# Create the stacked barplot with gradient colors
p <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = pnOver)) +
  geom_bar(stat = \identity\, position = \stack\,
           linewidth = lineMedium * mmToLineUnit, lineend = \square\) +
  theme_classic() + labs(x = NULL , y = \Ratio\) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +
  scale_fill_manual(values = gradient_colors, 
                    guide = guide_legend(
      override.aes = list(size = 0.5), # Adjust legend key symbol size
      keywidth = 2 / 2.54, # Convert 2mm to cm
      keyheight = 2 / 2.54 # Convert 2mm to cm
    )) 

width <- panelSize(1.7)*mmToInch
height <- panelSize(1.3)*mmToInch
fileName <- paste0(\rad21perc_promoter\)
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()  

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [3.42] Comparing to Reg loops to A485

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXCJwZWFrTnVtMFwiLCBcInBlYWtOdW0xXCIpLCA1KVxucHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFwicGVha051bTFcIiwgXCJwZWFrTnVtMlwiKSwgNSlcbnBzMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcInBlYWtOdW0yXCIsIFwicGVha051bTNcIiksIDUpXG5wczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXCJwZWFrTnVtM1wiLCBcInBlYWtOdW1PdmVyNFwiKSwgNSlcbnBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcInBlYWtOdW0yXCIsIFwicGVha051bU92ZXI0XCIpLCA1KVxucHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFwicGVha051bTFcIiwgXCJwZWFrTnVtT3ZlcjRcIiksIDUpXG5wczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXCJwZWFrTnVtMFwiLCBcInBlYWtOdW1PdmVyNFwiKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBuT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgXG4gIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcG5PdmVyKSwgXG4gICAgICAgICAgICAgIGNvbG9yID0gXCJibGFja1wiLFxuICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIixcbiAgICAgICAgICAgICAgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXCJibGFja1wiLFxuICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZU1lZGl1bSAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCIsXG4gICAgICAgICAgICAgICBvdXRsaWVyLnNoYXBlID0gTkFcbiAgKSArIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXCJBdmVyYWdlIM6UIGxvb3Agc2NvcmVcIikgK1xuICBzdGF0X3N1bW1hcnkoXG4gICAgYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXCJwb2ludFwiLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcImJsYWNrXCIsIGNvbG9yID0gXCJibGFja1wiXG4gICkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFwiIzAwMDAwMFwiXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIiwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFwiIzAwMDAwMFwiLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXCJzcXVhcmVcIlxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXCJ0cmFuc3BhcmVudFwiKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApK1xuICBhbm5vdGF0ZShcInRleHRcIiwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcInBzMDE6IFwiLCBjb252UHZhbHVlKHBzMDEpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczEyOiBcIiwgY29udlB2YWx1ZShwczEyKSwgXCJcXG5cIixcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFwicHMyMzogXCIsIGNvbnZQdmFsdWUocHMyMyksIFwiXFxuXCIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMzQ6IFwiLCBjb252UHZhbHVlKHBzMzQpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczI0OiBcIiwgY29udlB2YWx1ZShwczI0KSwgXCJcXG5cIiwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcInBzMTQ6IFwiLCBjb252UHZhbHVlKHBzMTQpLCBcIlxcblwiLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXCJwczA0OiBcIiwgY29udlB2YWx1ZShwczA0KSwgXCJcXG5cIiksIFxuICAgICAgICAgICBjb2xvciA9IFwiYmxhY2tcIiwgaGp1c3QgPSAwLCBzaXplID0gMikgK1xuICAgIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGMoXCIjNzc3Nzc3XCIsIFwiIzhCN0U2NVwiLCBcIiNBMjg0NTJcIiwgXCIjQzI4ODREXCIsIFwiI0YyOEUyQ1wiKSkgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTAuNSwgMC4xKSlcblxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcImRpZmZTY29yZV9iYXJwbG90X1JBRDIxcGVha1dpdGhpbjEwa2JfZFRBR192c19ETVNPXCIpXG53aWR0aCA8LSAzMyptbVRvSW5jaFxuaGVpZ2h0IDwtMzgqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcIi5wbmdcIikpLCByZXMgPSA2MDAsIHVuaXQgPSBcImluXCIsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXCIuc3ZnXCIpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYCJ9 -->\n\n```r\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$mean_diff_score\n  distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$mean_diff_score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nps01 <- round(getPvalWilcox(temp, \\peakNum0\\, \\peakNum1\\), 5)\nps12 <- round(getPvalWilcox(temp, \\peakNum1\\, \\peakNum2\\), 5)\nps23 <- round(getPvalWilcox(temp, \\peakNum2\\, \\peakNum3\\), 5)\nps34 <- round(getPvalWilcox(temp, \\peakNum3\\, \\peakNumOver4\\), 5)\nps24 <- round(getPvalWilcox(temp, \\peakNum2\\, \\peakNumOver4\\), 5)\nps14 <- round(getPvalWilcox(temp, \\peakNum1\\, \\peakNumOver4\\), 5)\nps04 <- round(getPvalWilcox(temp, \\peakNum0\\, \\peakNumOver4\\), 5)\n\n\np <- ggplot(temp, aes(x = pnOver, y = mean_diff_score)) + \n  geom_violin(aes(fill = pnOver), \n              color = \\black\\,\n              linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\Average Δ loop score\\) +\n  stat_summary(\n    aes(group = pnOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) +\n    scale_fill_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)) +\n  coord_cartesian(ylim = c(-0.5, 0.1))\n\n\n\nfileName <- paste0(\\diffScore_barplot_RAD21peakWithin10kb_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-38*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n\n<!-- rnb-source-end -->\n"} -->
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

ps01 <- round(getPvalWilcox(temp, \peakNum0\, \peakNum1\), 5)
ps12 <- round(getPvalWilcox(temp, \peakNum1\, \peakNum2\), 5)
ps23 <- round(getPvalWilcox(temp, \peakNum2\, \peakNum3\), 5)
ps34 <- round(getPvalWilcox(temp, \peakNum3\, \peakNumOver4\), 5)
ps24 <- round(getPvalWilcox(temp, \peakNum2\, \peakNumOver4\), 5)
ps14 <- round(getPvalWilcox(temp, \peakNum1\, \peakNumOver4\), 5)
ps04 <- round(getPvalWilcox(temp, \peakNum0\, \peakNumOver4\), 5)


p <- ggplot(temp, aes(x = pnOver, y = mean_diff_score)) + 
  geom_violin(aes(fill = pnOver), 
              color = \black\,
              linewidth = lineMedium * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \Average Δ loop score\) +
  stat_summary(
    aes(group = pnOver), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) +
    scale_fill_manual(values = c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\)) +
  coord_cartesian(ylim = c(-0.5, 0.1))



fileName <- paste0(\diffScore_barplot_RAD21peakWithin10kb_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-38*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwZWFrTnVtMFxcLCBcXHBlYWtOdW0xXFwpLCA1KVxucHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccGVha051bTFcXCwgXFxwZWFrTnVtMlxcKSwgNSlcbnBzMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBlYWtOdW0yXFwsIFxccGVha051bTNcXCksIDUpXG5wczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwZWFrTnVtM1xcLCBcXHBlYWtOdW1PdmVyNFxcKSwgNSlcbnBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBlYWtOdW0yXFwsIFxccGVha051bU92ZXI0XFwpLCA1KVxucHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccGVha051bTFcXCwgXFxwZWFrTnVtT3ZlcjRcXCksIDUpXG5wczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwZWFrTnVtMFxcLCBcXHBlYWtOdW1PdmVyNFxcKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBuT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgXG4gIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcG5PdmVyKSwgXG4gICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZU1lZGl1bSAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsXG4gICAgICAgICAgICAgICBvdXRsaWVyLnNoYXBlID0gTkFcbiAgKSArIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXFxBdmVyYWdlIM6UIGxvb3Agc2NvcmVcXCkgK1xuICBzdGF0X3N1bW1hcnkoXG4gICAgYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMikgK1xuICAgIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGMoXFwjNzc3Nzc3XFwsIFxcIzhCN0U2NVxcLCBcXCNBMjg0NTJcXCwgXFwjQzI4ODREXFwsIFxcI0YyOEUyQ1xcKSkgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTAuNSwgMC4xKSlcblxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGRpZmZTY29yZV9iYXJwbG90X1JBRDIxcGVha1dpdGhpbjEwa2JfZFRBR192c19ETVNPXFwpXG53aWR0aCA8LSAzMyptbVRvSW5jaFxuaGVpZ2h0IDwtMzgqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->\n\n```r\n```r\ngetPvalWilcox <- function(data, group1, group2){\n  distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$mean_diff_score\n  distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$mean_diff_score\n  wil <- wilcox.test(distance1, distance2)\n  return(wil$p.value)\n}\n\nps01 <- round(getPvalWilcox(temp, \\peakNum0\\, \\peakNum1\\), 5)\nps12 <- round(getPvalWilcox(temp, \\peakNum1\\, \\peakNum2\\), 5)\nps23 <- round(getPvalWilcox(temp, \\peakNum2\\, \\peakNum3\\), 5)\nps34 <- round(getPvalWilcox(temp, \\peakNum3\\, \\peakNumOver4\\), 5)\nps24 <- round(getPvalWilcox(temp, \\peakNum2\\, \\peakNumOver4\\), 5)\nps14 <- round(getPvalWilcox(temp, \\peakNum1\\, \\peakNumOver4\\), 5)\nps04 <- round(getPvalWilcox(temp, \\peakNum0\\, \\peakNumOver4\\), 5)\n\n\np <- ggplot(temp, aes(x = pnOver, y = mean_diff_score)) + \n  geom_violin(aes(fill = pnOver), \n              color = \\black\\,\n              linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n              show.legend = FALSE) +\n  geom_boxplot(width = 0.3, color = \\black\\,\n               linewidth = lineMedium * mmToLineUnit, lineend = \\square\\,\n               outlier.shape = NA\n  ) + theme_classic() + labs(x = NULL , y = \\Average Δ loop score\\) +\n  stat_summary(\n    aes(group = pnOver), fun = mean,\n    geom = \\point\\, shape = 21, size = 0.5,\n    fill = \\black\\, color = \\black\\\n  ) +\n  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.text.x = element_text(\n      angle = 45, hjust = 1, vjust = 1\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  )+\n  annotate(\\text\\, x = 1, y = 0, label = paste0(\\ps01: \\, convPvalue(ps01), \\\\n\\,\n                                                \\ps12: \\, convPvalue(ps12), \\\\n\\,\n                                                \\ps23: \\, convPvalue(ps23), \\\\n\\,\n                                                \\ps34: \\, convPvalue(ps34), \\\\n\\,\n                                                \\ps24: \\, convPvalue(ps24), \\\\n\\, \n                                                \\ps14: \\, convPvalue(ps14), \\\\n\\,\n                                                \\ps04: \\, convPvalue(ps04), \\\\n\\), \n           color = \\black\\, hjust = 0, size = 2) +\n    scale_fill_manual(values = c(\\#777777\\, \\#8B7E65\\, \\#A28452\\, \\#C2884D\\, \\#F28E2C\\)) +\n  coord_cartesian(ylim = c(-0.5, 0.1))\n\n\n\nfileName <- paste0(\\diffScore_barplot_RAD21peakWithin10kb_dTAG_vs_DMSO\\)\nwidth <- 33*mmToInch\nheight <-38*mmToInch\npng(here(figDir, paste0(fileName, \\.png\\)), res = 600, unit = \\in\\, height = height, width = width)\nprint(p)\ndev.off()\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuZ2V0UHZhbFdpbGNveCA8LSBmdW5jdGlvbihkYXRhLCBncm91cDEsIGdyb3VwMil7XG4gIGRpc3RhbmNlMSA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDEpICkkbWVhbl9kaWZmX3Njb3JlXG4gIGRpc3RhbmNlMiA8LSAoZGF0YSAlPiUgZHBseXI6OmZpbHRlcihwbk92ZXIgPT1ncm91cDIpICkkbWVhbl9kaWZmX3Njb3JlXG4gIHdpbCA8LSB3aWxjb3gudGVzdChkaXN0YW5jZTEsIGRpc3RhbmNlMilcbiAgcmV0dXJuKHdpbCRwLnZhbHVlKVxufVxuXG5wczAxIDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwZWFrTnVtMFxcLCBcXHBlYWtOdW0xXFwpLCA1KVxucHMxMiA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccGVha051bTFcXCwgXFxwZWFrTnVtMlxcKSwgNSlcbnBzMjMgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBlYWtOdW0yXFwsIFxccGVha051bTNcXCksIDUpXG5wczM0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwZWFrTnVtM1xcLCBcXHBlYWtOdW1PdmVyNFxcKSwgNSlcbnBzMjQgPC0gcm91bmQoZ2V0UHZhbFdpbGNveCh0ZW1wLCBcXHBlYWtOdW0yXFwsIFxccGVha051bU92ZXI0XFwpLCA1KVxucHMxNCA8LSByb3VuZChnZXRQdmFsV2lsY294KHRlbXAsIFxccGVha051bTFcXCwgXFxwZWFrTnVtT3ZlcjRcXCksIDUpXG5wczA0IDwtIHJvdW5kKGdldFB2YWxXaWxjb3godGVtcCwgXFxwZWFrTnVtMFxcLCBcXHBlYWtOdW1PdmVyNFxcKSwgNSlcblxuXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IHBuT3ZlciwgeSA9IG1lYW5fZGlmZl9zY29yZSkpICsgXG4gIGdlb21fdmlvbGluKGFlcyhmaWxsID0gcG5PdmVyKSwgXG4gICAgICAgICAgICAgIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCxcbiAgICAgICAgICAgICAgc2hvdy5sZWdlbmQgPSBGQUxTRSkgK1xuICBnZW9tX2JveHBsb3Qod2lkdGggPSAwLjMsIGNvbG9yID0gXFxibGFja1xcLFxuICAgICAgICAgICAgICAgbGluZXdpZHRoID0gbGluZU1lZGl1bSAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFwsXG4gICAgICAgICAgICAgICBvdXRsaWVyLnNoYXBlID0gTkFcbiAgKSArIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXFxBdmVyYWdlIM6UIGxvb3Agc2NvcmVcXCkgK1xuICBzdGF0X3N1bW1hcnkoXG4gICAgYWVzKGdyb3VwID0gcG5PdmVyKSwgZnVuID0gbWVhbixcbiAgICBnZW9tID0gXFxwb2ludFxcLCBzaGFwZSA9IDIxLCBzaXplID0gMC41LFxuICAgIGZpbGwgPSBcXGJsYWNrXFwsIGNvbG9yID0gXFxibGFja1xcXG4gICkgK1xuICBnZW9tX2hsaW5lKHlpbnRlcmNlcHQgPSAwLCBsaW5ld2lkdGggPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQpICtcbiAgdGhlbWUoXG4gICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgIHNpemUgPSBmb250U2l6ZU0sIGZhbWlseSA9IGZvbnRUeXBlLCBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoXG4gICAgICBhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMVxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLCBzaXplID0gbGluZVRoaWNrICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICApK1xuICBhbm5vdGF0ZShcXHRleHRcXCwgeCA9IDEsIHkgPSAwLCBsYWJlbCA9IHBhc3RlMChcXHBzMDE6IFxcLCBjb252UHZhbHVlKHBzMDEpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczEyOiBcXCwgY29udlB2YWx1ZShwczEyKSwgXFxcXG5cXCxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxccHMyMzogXFwsIGNvbnZQdmFsdWUocHMyMyksIFxcXFxuXFwsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMzQ6IFxcLCBjb252UHZhbHVlKHBzMzQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczI0OiBcXCwgY29udlB2YWx1ZShwczI0KSwgXFxcXG5cXCwgXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcXHBzMTQ6IFxcLCBjb252UHZhbHVlKHBzMTQpLCBcXFxcblxcLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXFxwczA0OiBcXCwgY29udlB2YWx1ZShwczA0KSwgXFxcXG5cXCksIFxuICAgICAgICAgICBjb2xvciA9IFxcYmxhY2tcXCwgaGp1c3QgPSAwLCBzaXplID0gMikgK1xuICAgIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGMoXFwjNzc3Nzc3XFwsIFxcIzhCN0U2NVxcLCBcXCNBMjg0NTJcXCwgXFwjQzI4ODREXFwsIFxcI0YyOEUyQ1xcKSkgK1xuICBjb29yZF9jYXJ0ZXNpYW4oeWxpbSA9IGMoLTAuNSwgMC4xKSlcblxuXG5cbmZpbGVOYW1lIDwtIHBhc3RlMChcXGRpZmZTY29yZV9iYXJwbG90X1JBRDIxcGVha1dpdGhpbjEwa2JfZFRBR192c19ETVNPXFwpXG53aWR0aCA8LSAzMyptbVRvSW5jaFxuaGVpZ2h0IDwtMzgqbW1Ub0luY2hcbnBuZyhoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5wbmdcXCkpLCByZXMgPSA2MDAsIHVuaXQgPSBcXGluXFwsIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbnN2Z2xpdGUoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwuc3ZnXFwpKSwgIGhlaWdodCA9IGhlaWdodCwgd2lkdGggPSB3aWR0aClcbnByaW50KHApXG5kZXYub2ZmKClcbmBgYFxuYGBgIn0= -->

```r
```r
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

ps01 <- round(getPvalWilcox(temp, \peakNum0\, \peakNum1\), 5)
ps12 <- round(getPvalWilcox(temp, \peakNum1\, \peakNum2\), 5)
ps23 <- round(getPvalWilcox(temp, \peakNum2\, \peakNum3\), 5)
ps34 <- round(getPvalWilcox(temp, \peakNum3\, \peakNumOver4\), 5)
ps24 <- round(getPvalWilcox(temp, \peakNum2\, \peakNumOver4\), 5)
ps14 <- round(getPvalWilcox(temp, \peakNum1\, \peakNumOver4\), 5)
ps04 <- round(getPvalWilcox(temp, \peakNum0\, \peakNumOver4\), 5)


p <- ggplot(temp, aes(x = pnOver, y = mean_diff_score)) + 
  geom_violin(aes(fill = pnOver), 
              color = \black\,
              linewidth = lineMedium * mmToLineUnit, lineend = \square\,
              show.legend = FALSE) +
  geom_boxplot(width = 0.3, color = \black\,
               linewidth = lineMedium * mmToLineUnit, lineend = \square\,
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = \Average Δ loop score\) +
  stat_summary(
    aes(group = pnOver), fun = mean,
    geom = \point\, shape = 21, size = 0.5,
    fill = \black\, color = \black\
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate(\text\, x = 1, y = 0, label = paste0(\ps01: \, convPvalue(ps01), \\n\,
                                                \ps12: \, convPvalue(ps12), \\n\,
                                                \ps23: \, convPvalue(ps23), \\n\,
                                                \ps34: \, convPvalue(ps34), \\n\,
                                                \ps24: \, convPvalue(ps24), \\n\, 
                                                \ps14: \, convPvalue(ps14), \\n\,
                                                \ps04: \, convPvalue(ps04), \\n\), 
           color = \black\, hjust = 0, size = 2) +
    scale_fill_manual(values = c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\)) +
  coord_cartesian(ylim = c(-0.5, 0.1))



fileName <- paste0(\diffScore_barplot_RAD21peakWithin10kb_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-38*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()
```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [3.43] Checking RAD21 peak density at group1 and group2 promoter

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVkR1Z0Y0NBOExTQjBaVzF3SUNVK0pTQmtjR3g1Y2pvNmJYVjBZWFJsS0dGaWMweHZaekpHUXlBOUlHRmljeWhzYjJjeVJtOXNaRU5vWVc1blpTa3BYRzV3SUR3dElHZG5jR3h2ZENoMFpXMXdMQ0JoWlhNb2VDQTlJR0ZpYzB4dlp6SkdReXdnWTI5c2IzSWdQU0J3Yms5MlpYSXBLU0FyWEc1elkyRnNaVjlqYjJ4dmNsOXRZVzUxWVd3b2RtRnNkV1Z6SUQwZ0tHTW9YQ0lqTnpjM056YzNYQ0lzSUZ3aUl6aENOMFUyTlZ3aUxDQmNJaU5CTWpnME5USmNJaXdnWENJalF6STRPRFJFWENJc0lGd2lJMFl5T0VVeVExd2lLU2twSUN0Y2JpQWdjM1JoZEY5bFkyUm1LSE5wZW1VZ1BTQXdMalFzSUd4cGJtVjNhV1IwYUNBOUlHeHBibVZOWldScGRXMGdLaUJ0YlZSdlRHbHVaVlZ1YVhRc0lHeHBibVZsYm1RZ1BTQmNJbk54ZFdGeVpWd2lJQ2tnS3lBaklGVnpaU0J6ZEdGMFgyVmpaR1lnZEc4Z2NHeHZkQ0IwYUdVZ1pXMXdhWEpwWTJGc0lFTkVSbHh1SUNCc1lXSnpLRnh1SUNBZ0lIZ2dQU0JjSWtGaWN5NGdiRzluTWlobWIyeGtJR05vWVc1blpTbGNJaXhjYmlBZ0lDQjVJRDBnWENKRGRXMTFiR0YwYVhabElGQnliMkpoWW1sc2FYUjVYQ0pjYmlBZ0tTQXJJR052YjNKa1gyTmhjblJsYzJsaGJpaDRiR2x0SUQwZ1l5Z3dMQ0F4TGpVcEtTQXJYRzRnSUhSb1pXMWxYMk5zWVhOemFXTW9LU0FySUNNZ1EyeGxZVzRnZEdobGJXVmNiaUFnZEdobGJXVW9YRzRnSUNBZ0lDQmhlR2x6TG5ScGRHeGxJRDBnWld4bGJXVnVkRjkwWlhoMEtGeHVJQ0FnSUNBZ0lDQnphWHBsSUQwZ1ptOXVkRk5wZW1WTkxGeHVJQ0FnSUNBZ1ptRnRhV3g1SUQwZ1ptOXVkRlI1Y0dVc1hHNGdJQ0FnSUNCamIyeHZjaUE5SUZ3aUl6QXdNREF3TUZ3aVhHNGdJQ0FnS1N4Y2JpQWdJQ0JoZUdsekxuUmxlSFFnUFNCbGJHVnRaVzUwWDNSbGVIUW9YRzRnSUNBZ0lDQnphWHBsSUQwZ1ptOXVkRk5wZW1WVExGeHVJQ0FnSUNBZ1ptRnRhV3g1SUQwZ1ptOXVkRlI1Y0dVc1hHNGdJQ0FnSUNCamIyeHZjaUE5SUZ3aUl6QXdNREF3TUZ3aVhHNGdJQ0FnS1N4Y2JpQWdJQ0JoZUdsekxteHBibVVnUFNCbGJHVnRaVzUwWDJ4cGJtVW9YRzRnSUNBZ0lDQmpiMnh2Y2lBOUlGd2lJekF3TURBd01Gd2lMRnh1SUNBZ0lDQWdjMmw2WlNBOUlHeHBibVZVYUdsamF5cHRiVlJ2VEdsdVpWVnVhWFFzWEc0Z0lDQWdJQ0JzYVc1bFpXNWtJRDBnWENKemNYVmhjbVZjSWx4dUlDQWdJQ2tzWEc0Z0lDQWdZWGhwY3k1MGFXTnJjeUE5SUdWc1pXMWxiblJmYkdsdVpTaGNiaUFnSUNBZ0lHTnZiRzl5SUQwZ1hDSWpNREF3TURBd1hDSXNYRzRnSUNBZ0lDQnphWHBsSUQwZ2JHbHVaVlJvYVdOckttMXRWRzlNYVc1bFZXNXBkQ3hjYmlBZ0lDQWdJR3hwYm1WbGJtUWdQU0JjSW5OeGRXRnlaVndpWEc0Z0lDQWdLU3hjYmlBZ0lDQndZVzVsYkM1aVlXTnJaM0p2ZFc1a0lEMGdaV3hsYldWdWRGOXlaV04wS0dacGJHd2dQU0JjSW5SeVlXNXpjR0Z5Wlc1MFhDSXBMRnh1SUNBZ0lHeGxaMlZ1WkM1d2IzTnBkR2x2YmlBOUlGd2libTl1WlZ3aUxGeHVJQ0FnSUd4bFoyVnVaQzUwWlhoMElEMGdaV3hsYldWdWRGOTBaWGgwS0daaGJXbHNlU0E5SUdadmJuUlVlWEJsTENCemFYcGxJRDBnWm05dWRGTnBlbVZUS1N4Y2JpQWdJQ0JzWldkbGJtUXVkR2wwYkdVZ1BTQmxiR1Z0Wlc1MFgzUmxlSFFvWm1GdGFXeDVJRDBnWm05dWRGUjVjR1VzSUhOcGVtVWdQU0JtYjI1MFUybDZaVk1wWEc0Z0lDQWdLU0FySUhOallXeGxYM2xmWTI5dWRHbHVkVzkxY3loc1lXSmxiSE1nUFNCelkyRnNaWE02T201MWJXSmxjbDltYjNKdFlYUW9ZV05qZFhKaFkza2dQU0F3TGpFcEtWeHVabWxzWlU1aGJXVWdQQzBnY0dGemRHVXdLRndpYkc5bk1rWkRYMk5rWmw5d2MwZHliM1Z3WDJSVVFVZGZkbk5mUkUxVFQxd2lLVnh1ZDJsa2RHZ2dQQzBnTXpNcWJXMVViMGx1WTJoY2JtaGxhV2RvZENBOExUTXpLbTF0Vkc5SmJtTm9YRzV3Ym1jb2FHVnlaU2htYVdkRWFYSXNJSEJoYzNSbE1DaG1hV3hsVG1GdFpTd2dYQ0l1Y0c1blhDSXBLU3dnY21WeklEMGdOakF3TENCMWJtbDBJRDBnWENKcGJsd2lMQ0JvWldsbmFIUWdQU0JvWldsbmFIUXNJSGRwWkhSb0lEMGdkMmxrZEdncFhHNXdjbWx1ZENod0tWeHVaR1YyTG05bVppZ3BYRzV6ZG1kc2FYUmxLR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ3aUxuTjJaMXdpS1Nrc0lDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc1d2NtbHVkQ2h3S1Z4dVpHVjJMbTltWmlncFhHNWNibUJnWUNKOSAtLT5cblxuYGBgclxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6bXV0YXRlKGFic0xvZzJGQyA9IGFicyhsb2cyRm9sZENoYW5nZSkpXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGFic0xvZzJGQywgY29sb3IgPSBwbk92ZXIpKSArXG5zY2FsZV9jb2xvcl9tYW51YWwodmFsdWVzID0gKGMoXFwjNzc3Nzc3XFwsIFxcIzhCN0U2NVxcLCBcXCNBMjg0NTJcXCwgXFwjQzI4ODREXFwsIFxcI0YyOEUyQ1xcKSkpICtcbiAgc3RhdF9lY2RmKHNpemUgPSAwLjQsIGxpbmV3aWR0aCA9IGxpbmVNZWRpdW0gKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcXHNxdWFyZVxcICkgKyAjIFVzZSBzdGF0X2VjZGYgdG8gcGxvdCB0aGUgZW1waXJpY2FsIENERlxuICBsYWJzKFxuICAgIHggPSBcXEFicy4gbG9nMihmb2xkIGNoYW5nZSlcXCxcbiAgICB5ID0gXFxDdW11bGF0aXZlIFByb2JhYmlsaXR5XFxcbiAgKSArIGNvb3JkX2NhcnRlc2lhbih4bGltID0gYygwLCAxLjUpKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArICMgQ2xlYW4gdGhlbWVcbiAgdGhlbWUoXG4gICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcXHRyYW5zcGFyZW50XFwpLFxuICAgIGxlZ2VuZC5wb3NpdGlvbiA9IFxcbm9uZVxcLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gICAgKSArIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBzY2FsZXM6Om51bWJlcl9mb3JtYXQoYWNjdXJhY3kgPSAwLjEpKVxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcbG9nMkZDX2NkZl9wc0dyb3VwX2RUQUdfdnNfRE1TT1xcKVxud2lkdGggPC0gMzMqbW1Ub0luY2hcbmhlaWdodCA8LTMzKm1tVG9JbmNoXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
temp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))
p <- ggplot(temp, aes(x = absLog2FC, color = pnOver)) +
scale_color_manual(values = (c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \square\ ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Abs. log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.position = \none\,
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))
fileName <- paste0(\log2FC_cdf_psGroup_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()



<!-- rnb-output-end -->

<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVZR0JnY2x4dWRHVnRjQ0E4TFNCMFpXMXdJQ1UrSlNCa2NHeDVjam82YlhWMFlYUmxLR0ZpYzB4dlp6SkdReUE5SUdGaWN5aHNiMmN5Um05c1pFTm9ZVzVuWlNrcFhHNXdJRHd0SUdkbmNHeHZkQ2gwWlcxd0xDQmhaWE1vZUNBOUlHRmljMHh2WnpKR1F5d2dZMjlzYjNJZ1BTQndiazkyWlhJcEtTQXJYRzV6WTJGc1pWOWpiMnh2Y2w5dFlXNTFZV3dvZG1Gc2RXVnpJRDBnS0dNb1hGd2pOemMzTnpjM1hGd3NJRnhjSXpoQ04wVTJOVnhjTENCY1hDTkJNamcwTlRKY1hDd2dYRndqUXpJNE9EUkVYRndzSUZ4Y0kwWXlPRVV5UTF4Y0tTa3BJQ3RjYmlBZ2MzUmhkRjlsWTJSbUtITnBlbVVnUFNBd0xqUXNJR3hwYm1WM2FXUjBhQ0E5SUd4cGJtVk5aV1JwZFcwZ0tpQnRiVlJ2VEdsdVpWVnVhWFFzSUd4cGJtVmxibVFnUFNCY1hITnhkV0Z5WlZ4Y0lDa2dLeUFqSUZWelpTQnpkR0YwWDJWalpHWWdkRzhnY0d4dmRDQjBhR1VnWlcxd2FYSnBZMkZzSUVORVJseHVJQ0JzWVdKektGeHVJQ0FnSUhnZ1BTQmNYRUZpY3k0Z2JHOW5NaWhtYjJ4a0lHTm9ZVzVuWlNsY1hDeGNiaUFnSUNCNUlEMGdYRnhEZFcxMWJHRjBhWFpsSUZCeWIySmhZbWxzYVhSNVhGeGNiaUFnS1NBcklHTnZiM0prWDJOaGNuUmxjMmxoYmloNGJHbHRJRDBnWXlnd0xDQXhMalVwS1NBclhHNGdJSFJvWlcxbFgyTnNZWE56YVdNb0tTQXJJQ01nUTJ4bFlXNGdkR2hsYldWY2JpQWdkR2hsYldVb1hHNGdJQ0FnSUNCaGVHbHpMblJwZEd4bElEMGdaV3hsYldWdWRGOTBaWGgwS0Z4dUlDQWdJQ0FnSUNCemFYcGxJRDBnWm05dWRGTnBlbVZOTEZ4dUlDQWdJQ0FnWm1GdGFXeDVJRDBnWm05dWRGUjVjR1VzWEc0Z0lDQWdJQ0JqYjJ4dmNpQTlJRnhjSXpBd01EQXdNRnhjWEc0Z0lDQWdLU3hjYmlBZ0lDQmhlR2x6TG5SbGVIUWdQU0JsYkdWdFpXNTBYM1JsZUhRb1hHNGdJQ0FnSUNCemFYcGxJRDBnWm05dWRGTnBlbVZUTEZ4dUlDQWdJQ0FnWm1GdGFXeDVJRDBnWm05dWRGUjVjR1VzWEc0Z0lDQWdJQ0JqYjJ4dmNpQTlJRnhjSXpBd01EQXdNRnhjWEc0Z0lDQWdLU3hjYmlBZ0lDQmhlR2x6TG14cGJtVWdQU0JsYkdWdFpXNTBYMnhwYm1Vb1hHNGdJQ0FnSUNCamIyeHZjaUE5SUZ4Y0l6QXdNREF3TUZ4Y0xGeHVJQ0FnSUNBZ2MybDZaU0E5SUd4cGJtVlVhR2xqYXlwdGJWUnZUR2x1WlZWdWFYUXNYRzRnSUNBZ0lDQnNhVzVsWlc1a0lEMGdYRnh6Y1hWaGNtVmNYRnh1SUNBZ0lDa3NYRzRnSUNBZ1lYaHBjeTUwYVdOcmN5QTlJR1ZzWlcxbGJuUmZiR2x1WlNoY2JpQWdJQ0FnSUdOdmJHOXlJRDBnWEZ3ak1EQXdNREF3WEZ3c1hHNGdJQ0FnSUNCemFYcGxJRDBnYkdsdVpWUm9hV05yS20xdFZHOU1hVzVsVlc1cGRDeGNiaUFnSUNBZ0lHeHBibVZsYm1RZ1BTQmNYSE54ZFdGeVpWeGNYRzRnSUNBZ0tTeGNiaUFnSUNCd1lXNWxiQzVpWVdOclozSnZkVzVrSUQwZ1pXeGxiV1Z1ZEY5eVpXTjBLR1pwYkd3Z1BTQmNYSFJ5WVc1emNHRnlaVzUwWEZ3cExGeHVJQ0FnSUd4bFoyVnVaQzV3YjNOcGRHbHZiaUE5SUZ4Y2JtOXVaVnhjTEZ4dUlDQWdJR3hsWjJWdVpDNTBaWGgwSUQwZ1pXeGxiV1Z1ZEY5MFpYaDBLR1poYldsc2VTQTlJR1p2Ym5SVWVYQmxMQ0J6YVhwbElEMGdabTl1ZEZOcGVtVlRLU3hjYmlBZ0lDQnNaV2RsYm1RdWRHbDBiR1VnUFNCbGJHVnRaVzUwWDNSbGVIUW9abUZ0YVd4NUlEMGdabTl1ZEZSNWNHVXNJSE5wZW1VZ1BTQm1iMjUwVTJsNlpWTXBYRzRnSUNBZ0tTQXJJSE5qWVd4bFgzbGZZMjl1ZEdsdWRXOTFjeWhzWVdKbGJITWdQU0J6WTJGc1pYTTZPbTUxYldKbGNsOW1iM0p0WVhRb1lXTmpkWEpoWTNrZ1BTQXdMakVwS1Z4dVptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGeGNiRzluTWtaRFgyTmtabDl3YzBkeWIzVndYMlJVUVVkZmRuTmZSRTFUVDF4Y0tWeHVkMmxrZEdnZ1BDMGdNek1xYlcxVWIwbHVZMmhjYm1obGFXZG9kQ0E4TFRNekttMXRWRzlKYm1Ob1hHNXdibWNvYUdWeVpTaG1hV2RFYVhJc0lIQmhjM1JsTUNobWFXeGxUbUZ0WlN3Z1hGd3VjRzVuWEZ3cEtTd2djbVZ6SUQwZ05qQXdMQ0IxYm1sMElEMGdYRnhwYmx4Y0xDQm9aV2xuYUhRZ1BTQm9aV2xuYUhRc0lIZHBaSFJvSUQwZ2QybGtkR2dwWEc1d2NtbHVkQ2h3S1Z4dVpHVjJMbTltWmlncFhHNXpkbWRzYVhSbEtHaGxjbVVvWm1sblJHbHlMQ0J3WVhOMFpUQW9abWxzWlU1aGJXVXNJRnhjTG5OMloxeGNLU2tzSUNCb1pXbG5hSFFnUFNCb1pXbG5hSFFzSUhkcFpIUm9JRDBnZDJsa2RHZ3BYRzV3Y21sdWRDaHdLVnh1WkdWMkxtOW1aaWdwWEc1Y2JtQmdZRnh1WUdCZ0luMD0gLS0+XG5cbmBgYHJcbmBgYHJcbnRlbXAgPC0gdGVtcCAlPiUgZHBseXI6Om11dGF0ZShhYnNMb2cyRkMgPSBhYnMobG9nMkZvbGRDaGFuZ2UpKVxucCA8LSBnZ3Bsb3QodGVtcCwgYWVzKHggPSBhYnNMb2cyRkMsIGNvbG9yID0gcG5PdmVyKSkgK1xuc2NhbGVfY29sb3JfbWFudWFsKHZhbHVlcyA9IChjKFxcIzc3Nzc3N1xcLCBcXCM4QjdFNjVcXCwgXFwjQTI4NDUyXFwsIFxcI0MyODg0RFxcLCBcXCNGMjhFMkNcXCkpKSArXG4gIHN0YXRfZWNkZihzaXplID0gMC40LCBsaW5ld2lkdGggPSBsaW5lTWVkaXVtICogbW1Ub0xpbmVVbml0LCBsaW5lZW5kID0gXFxzcXVhcmVcXCApICsgIyBVc2Ugc3RhdF9lY2RmIHRvIHBsb3QgdGhlIGVtcGlyaWNhbCBDREZcbiAgbGFicyhcbiAgICB4ID0gXFxBYnMuIGxvZzIoZm9sZCBjaGFuZ2UpXFwsXG4gICAgeSA9IFxcQ3VtdWxhdGl2ZSBQcm9iYWJpbGl0eVxcXG4gICkgKyBjb29yZF9jYXJ0ZXNpYW4oeGxpbSA9IGMoMCwgMS41KSkgK1xuICB0aGVtZV9jbGFzc2ljKCkgKyAjIENsZWFuIHRoZW1lXG4gIHRoZW1lKFxuICAgICAgYXhpcy50aXRsZSA9IGVsZW1lbnRfdGV4dChcbiAgICAgICAgc2l6ZSA9IGZvbnRTaXplTSxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUyxcbiAgICAgIGZhbWlseSA9IGZvbnRUeXBlLFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy5saW5lID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCxcbiAgICAgIHNpemUgPSBsaW5lVGhpY2sqbW1Ub0xpbmVVbml0LFxuICAgICAgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIGF4aXMudGlja3MgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgcGFuZWwuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsID0gXFx0cmFuc3BhcmVudFxcKSxcbiAgICBsZWdlbmQucG9zaXRpb24gPSBcXG5vbmVcXCxcbiAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUyksXG4gICAgbGVnZW5kLnRpdGxlID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKVxuICAgICkgKyBzY2FsZV95X2NvbnRpbnVvdXMobGFiZWxzID0gc2NhbGVzOjpudW1iZXJfZm9ybWF0KGFjY3VyYWN5ID0gMC4xKSlcbmZpbGVOYW1lIDwtIHBhc3RlMChcXGxvZzJGQ19jZGZfcHNHcm91cF9kVEFHX3ZzX0RNU09cXClcbndpZHRoIDwtIDMzKm1tVG9JbmNoXG5oZWlnaHQgPC0zMyptbVRvSW5jaFxucG5nKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnBuZ1xcKSksIHJlcyA9IDYwMCwgdW5pdCA9IFxcaW5cXCwgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuc3ZnbGl0ZShoZXJlKGZpZ0RpciwgcGFzdGUwKGZpbGVOYW1lLCBcXC5zdmdcXCkpLCAgaGVpZ2h0ID0gaGVpZ2h0LCB3aWR0aCA9IHdpZHRoKVxucHJpbnQocClcbmRldi5vZmYoKVxuXG5gYGBcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxudGVtcCA8LSB0ZW1wICU+JSBkcGx5cjo6bXV0YXRlKGFic0xvZzJGQyA9IGFicyhsb2cyRm9sZENoYW5nZSkpXG5wIDwtIGdncGxvdCh0ZW1wLCBhZXMoeCA9IGFic0xvZzJGQywgY29sb3IgPSBwbk92ZXIpKSArXG5zY2FsZV9jb2xvcl9tYW51YWwodmFsdWVzID0gKGMoXFwjNzc3Nzc3XFwsIFxcIzhCN0U2NVxcLCBcXCNBMjg0NTJcXCwgXFwjQzI4ODREXFwsIFxcI0YyOEUyQ1xcKSkpICtcbiAgc3RhdF9lY2RmKHNpemUgPSAwLjQsIGxpbmV3aWR0aCA9IGxpbmVNZWRpdW0gKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcXHNxdWFyZVxcICkgKyAjIFVzZSBzdGF0X2VjZGYgdG8gcGxvdCB0aGUgZW1waXJpY2FsIENERlxuICBsYWJzKFxuICAgIHggPSBcXEFicy4gbG9nMihmb2xkIGNoYW5nZSlcXCxcbiAgICB5ID0gXFxDdW11bGF0aXZlIFByb2JhYmlsaXR5XFxcbiAgKSArIGNvb3JkX2NhcnRlc2lhbih4bGltID0gYygwLCAxLjUpKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArICMgQ2xlYW4gdGhlbWVcbiAgdGhlbWUoXG4gICAgICBheGlzLnRpdGxlID0gZWxlbWVudF90ZXh0KFxuICAgICAgICBzaXplID0gZm9udFNpemVNLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVTLFxuICAgICAgZmFtaWx5ID0gZm9udFR5cGUsXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcXG4gICAgKSxcbiAgICBheGlzLmxpbmUgPSBlbGVtZW50X2xpbmUoXG4gICAgICBjb2xvciA9IFxcIzAwMDAwMFxcLFxuICAgICAgc2l6ZSA9IGxpbmVUaGljayptbVRvTGluZVVuaXQsXG4gICAgICBsaW5lZW5kID0gXFxzcXVhcmVcXFxuICAgICksXG4gICAgYXhpcy50aWNrcyA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsXG4gICAgICBzaXplID0gbGluZVRoaWNrKm1tVG9MaW5lVW5pdCxcbiAgICAgIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBwYW5lbC5iYWNrZ3JvdW5kID0gZWxlbWVudF9yZWN0KGZpbGwgPSBcXHRyYW5zcGFyZW50XFwpLFxuICAgIGxlZ2VuZC5wb3NpdGlvbiA9IFxcbm9uZVxcLFxuICAgIGxlZ2VuZC50ZXh0ID0gZWxlbWVudF90ZXh0KGZhbWlseSA9IGZvbnRUeXBlLCBzaXplID0gZm9udFNpemVTKSxcbiAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpXG4gICAgKSArIHNjYWxlX3lfY29udGludW91cyhsYWJlbHMgPSBzY2FsZXM6Om51bWJlcl9mb3JtYXQoYWNjdXJhY3kgPSAwLjEpKVxuZmlsZU5hbWUgPC0gcGFzdGUwKFxcbG9nMkZDX2NkZl9wc0dyb3VwX2RUQUdfdnNfRE1TT1xcKVxud2lkdGggPC0gMzMqbW1Ub0luY2hcbmhlaWdodCA8LTMzKm1tVG9JbmNoXG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5cbmBgYFxuYGBgIn0= -->

```r
```r
temp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))
p <- ggplot(temp, aes(x = absLog2FC, color = pnOver)) +
scale_color_manual(values = (c(\#777777\, \#8B7E65\, \#A28452\, \#C2884D\, \#F28E2C\))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = \square\ ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = \Abs. log2(fold change)\,
    y = \Cumulative Probability\
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\,
      size = lineThick*mmToLineUnit,
      lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.position = \none\,
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))
fileName <- paste0(\log2FC_cdf_psGroup_dTAG_vs_DMSO\)
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### loop score

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5wZWFrLlJBRDIxIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFwiMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXCIpKVxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XCIpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcIikpJGdlbmVcblxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5uYW1lIDwtIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVwiXG5cbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXCJfcC1uX2Vuc2VtYmxMaXN0LnRzdlwiKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9MaXN0ID0gYyhcIlAtRVwiKSlcblxudGVtcDEgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEExID09IFwiRVwiKSAlPiUgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgZ2VuZSlcbmNvbG5hbWVzKHRlbXAxKSA8LSBjKFwiY2hyXCIsIFwic3RhcnRcIiwgXCJlbmRcIiwgXCJnZW5lXCIpXG50ZW1wMiA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoQTIgPT0gXCJFXCIpICU+JSBkcGx5cjo6c2VsZWN0KGNocm9tMiwgc3RhcnQyLCBlbmQyLCBnZW5lKVxuY29sbmFtZXModGVtcDIpIDwtIGMoXCJjaHJcIiwgXCJzdGFydFwiLCBcImVuZFwiLCBcImdlbmVcIilcblxuZW5oQW5jaG9ycyA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyKSAlPiUgdW5uZXN0KGdlbmUpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGdyb3VwID0gY2FzZV93aGVuKFxuICAgICAgZ2VuZSAlaW4lIGdyb3VwMSB+IFwiR3JwMVwiLFxuICAgICAgZ2VuZSAlaW4lIGdyb3VwMiB+IFwiR3JwMlwiLFxuICAgICAgVFJVRSB+IE5BXG4gICAgKVxuICApICU+JSBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cbmVuaCA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZW5oQW5jaG9ycyAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKSlcblxuIyBDb3VudCBvdmVybGFwcyBiZXR3ZWVuIHBlYWtzIGFuZCBnZW5lc1xub3ZlcmxhcF9jb3VudHMgPC0gY291bnRPdmVybGFwcyhlbmgsIHBlYWsuUkFEMjEpXG5cbiMgQWRkIG92ZXJsYXAgY291bnRzIHRvIHRoZSBvcmlnaW5hbCBnZW5lLnRiIGRhdGFcbmVuaEFuY2hvcnMkcGVha19jb3VudCA8LSBvdmVybGFwX2NvdW50c1xuXG5lbmhBbmNob3JzIDwtIGVuaEFuY2hvcnMgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBlYWtHcm91cCA9IGNhc2Vfd2hlbihcbiAgICBwZWFrX2NvdW50ID09IDAgfiBcInBlYWtOdW0wXCIsXG4gICAgcGVha19jb3VudCA9PSAxIH4gXCJwZWFrTnVtMVwiLFxuICAgIHBlYWtfY291bnQgPT0gMiB+IFwicGVha051bTJcIixcbiAgICBwZWFrX2NvdW50ID09IDMgfiBcInBlYWtOdW0zXCIsXG4gICAgcGVha19jb3VudCA+PSA0IH4gXCJwZWFrTnVtT3ZlcjRcIlxuICApXG4pXG5cbmFhYSA8LSBlbmhBbmNob3JzICU+JSBcbiAgZHBseXI6OnNlbGVjdChncm91cCwgcGVha0dyb3VwLCBnZW5lKSAlPiVcbiAgZHBseXI6Om11dGF0ZShoYXNQZWFrID0gaWZlbHNlKHBlYWtHcm91cCA9PSBcInBlYWtOdW0wXCIsIEZBTFNFLCBUUlVFKSlcblxuYmJiIDwtIGFhYSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcIkdycDFcIikgXG5zdW0oYmJiJGhhc1BlYWspL25yb3coYmJiKVxuYmJiIDwtIGFhYSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcIkdycDJcIikgXG5zdW0oYmJiJGhhc1BlYWspL25yb3coYmJiKVxuXG5cbmFhYV9zdW1tYXJ5IDwtIGFhYSAlPiVcbiAgZ3JvdXBfYnkoZ3JvdXAsIHBlYWtHcm91cCkgJT4lXG4gIHN1bW1hcml6ZShjb3VudCA9IG4oKSwgLmdyb3VwcyA9IFwiZHJvcFwiKVxuXG4jIENyZWF0ZSB0aGUgc3RhY2tlZCBiYXJwbG90XG5hYWFfc3VtbWFyeSA8LSBhYWEgJT4lXG4gIGdyb3VwX2J5KGdyb3VwLCBwZWFrR3JvdXApICU+JVxuICBzdW1tYXJpemUoY291bnQgPSBuKCksIC5ncm91cHMgPSBcImRyb3BcIikgJT4lXG4gIGdyb3VwX2J5KGdyb3VwKSAlPiVcbiAgbXV0YXRlKHJhdGlvID0gY291bnQgLyBzdW0oY291bnQpKVxuXG4jIERlZmluZSB0aGUgZ3JhZGllbnQgY29sb3JzXG4jIGdyYWRpZW50X2NvbG9ycyA8LSBjKFwiI0Q0RDRENFwiLCBcIiNEQ0IwQUZcIiwgXCIjRTQ4RDhBXCIsIFwiI0VDNjk2NVwiLCBcIiNGNDQ2NDFcIilcbmdyYWRpZW50X2NvbG9ycyA8LSBjKFwiI0Q0RDRENFwiLCBcIiNBMkJCQ0FcIiwgXCIjNzFBMkMwXCIsIFwiIzNGODlCN1wiLCBcIiMwRTcxQURcIilcblxuIyBDcmVhdGUgdGhlIHN0YWNrZWQgYmFycGxvdCB3aXRoIGdyYWRpZW50IGNvbG9yc1xucCA8LSBnZ3Bsb3QoYWFhX3N1bW1hcnksIGFlcyh4ID0gZ3JvdXAsIHkgPSByYXRpbywgZmlsbCA9IHBlYWtHcm91cCkpICtcbiAgZ2VvbV9iYXIoc3RhdCA9IFwiaWRlbnRpdHlcIiwgcG9zaXRpb24gPSBcInN0YWNrXCIsXG4gICAgICAgICAgIGxpbmV3aWR0aCA9IGxpbmVNZWRpdW0gKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcInNxdWFyZVwiKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXCJSYXRpb1wiKSArXG4gIHRoZW1lKFxuICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgZmFtaWx5ID0gZm9udFR5cGUsIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCIsIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcInNxdWFyZVwiXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIiwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFwidHJhbnNwYXJlbnRcIiksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKSArXG4gIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGdyYWRpZW50X2NvbG9ycywgXG4gICAgICAgICAgICAgICAgICAgIGd1aWRlID0gZ3VpZGVfbGVnZW5kKFxuICAgICAgb3ZlcnJpZGUuYWVzID0gbGlzdChzaXplID0gMC41KSwgIyBBZGp1c3QgbGVnZW5kIGtleSBzeW1ib2wgc2l6ZVxuICAgICAga2V5d2lkdGggPSAyIC8gMi41NCwgIyBDb252ZXJ0IDJtbSB0byBjbVxuICAgICAga2V5aGVpZ2h0ID0gMiAvIDIuNTQgIyBDb252ZXJ0IDJtbSB0byBjbVxuICAgICkpIFxuXG53aWR0aCA8LSBwYW5lbFNpemUoMS43KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjMpKm1tVG9JbmNoXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJyYWQyMXBlcmNfZW5oXCIpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpICBcblxuYGBgIn0= -->\n\n```r\n\npeak.RAD21 <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\n##########################################################\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\\P-E\\))\n\ntemp1 <- geneAnnoData %>% dplyr::filter(A1 == \\E\\) %>% dplyr::select(chrom1, start1, end1, gene)\ncolnames(temp1) <- c(\\chr\\, \\start\\, \\end\\, \\gene\\)\ntemp2 <- geneAnnoData %>% dplyr::filter(A2 == \\E\\) %>% dplyr::select(chrom2, start2, end2, gene)\ncolnames(temp2) <- c(\\chr\\, \\start\\, \\end\\, \\gene\\)\n\nenhAnchors <- bind_rows(temp1, temp2) %>% unnest(gene) %>%\n  dplyr::mutate(\n    group = case_when(\n      gene %in% group1 ~ \\Grp1\\,\n      gene %in% group2 ~ \\Grp2\\,\n      TRUE ~ NA\n    )\n  ) %>% dplyr::filter(!is.na(group))\n\nenh <- makeGRangesFromDataFrame(enhAnchors %>% dplyr::select(c(1, 2, 3)))\n\n# Count overlaps between peaks and genes\noverlap_counts <- countOverlaps(enh, peak.RAD21)\n\n# Add overlap counts to the original gene.tb data\nenhAnchors$peak_count <- overlap_counts\n\nenhAnchors <- enhAnchors %>% dplyr::mutate(\n  peakGroup = case_when(\n    peak_count == 0 ~ \\peakNum0\\,\n    peak_count == 1 ~ \\peakNum1\\,\n    peak_count == 2 ~ \\peakNum2\\,\n    peak_count == 3 ~ \\peakNum3\\,\n    peak_count >= 4 ~ \\peakNumOver4\\\n  )\n)\n\naaa <- enhAnchors %>% \n  dplyr::select(group, peakGroup, gene) %>%\n  dplyr::mutate(hasPeak = ifelse(peakGroup == \\peakNum0\\, FALSE, TRUE))\n\nbbb <- aaa %>% dplyr::filter(group == \\Grp1\\) \nsum(bbb$hasPeak)/nrow(bbb)\nbbb <- aaa %>% dplyr::filter(group == \\Grp2\\) \nsum(bbb$hasPeak)/nrow(bbb)\n\n\naaa_summary <- aaa %>%\n  group_by(group, peakGroup) %>%\n  summarize(count = n(), .groups = \\drop\\)\n\n# Create the stacked barplot\naaa_summary <- aaa %>%\n  group_by(group, peakGroup) %>%\n  summarize(count = n(), .groups = \\drop\\) %>%\n  group_by(group) %>%\n  mutate(ratio = count / sum(count))\n\n# Define the gradient colors\n# gradient_colors <- c(\\#D4D4D4\\, \\#DCB0AF\\, \\#E48D8A\\, \\#EC6965\\, \\#F44641\\)\ngradient_colors <- c(\\#D4D4D4\\, \\#A2BBCA\\, \\#71A2C0\\, \\#3F89B7\\, \\#0E71AD\\)\n\n# Create the stacked barplot with gradient colors\np <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = peakGroup)) +\n  geom_bar(stat = \\identity\\, position = \\stack\\,\n           linewidth = lineMedium * mmToLineUnit, lineend = \\square\\) +\n  theme_classic() + labs(x = NULL , y = \\Ratio\\) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +\n  scale_fill_manual(values = gradient_colors, \n                    guide = guide_legend(\n      override.aes = list(size = 0.5), # Adjust legend key symbol size\n      keywidth = 2 / 2.54, # Convert 2mm to cm\n      keyheight = 2 / 2.54 # Convert 2mm to cm\n    )) \n\nwidth <- panelSize(1.7)*mmToInch\nheight <- panelSize(1.3)*mmToInch\nfileName <- paste0(\\rad21perc_enh\\)\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n```\n\n<!-- rnb-source-end -->\n"} -->

peak.RAD21 <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


##########################################################
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-E\))

temp1 <- geneAnnoData %>% dplyr::filter(A1 == \E\) %>% dplyr::select(chrom1, start1, end1, gene)
colnames(temp1) <- c(\chr\, \start\, \end\, \gene\)
temp2 <- geneAnnoData %>% dplyr::filter(A2 == \E\) %>% dplyr::select(chrom2, start2, end2, gene)
colnames(temp2) <- c(\chr\, \start\, \end\, \gene\)

enhAnchors <- bind_rows(temp1, temp2) %>% unnest(gene) %>%
  dplyr::mutate(
    group = case_when(
      gene %in% group1 ~ \Grp1\,
      gene %in% group2 ~ \Grp2\,
      TRUE ~ NA
    )
  ) %>% dplyr::filter(!is.na(group))

enh <- makeGRangesFromDataFrame(enhAnchors %>% dplyr::select(c(1, 2, 3)))

# Count overlaps between peaks and genes
overlap_counts <- countOverlaps(enh, peak.RAD21)

# Add overlap counts to the original gene.tb data
enhAnchors$peak_count <- overlap_counts

enhAnchors <- enhAnchors %>% dplyr::mutate(
  peakGroup = case_when(
    peak_count == 0 ~ \peakNum0\,
    peak_count == 1 ~ \peakNum1\,
    peak_count == 2 ~ \peakNum2\,
    peak_count == 3 ~ \peakNum3\,
    peak_count >= 4 ~ \peakNumOver4\
  )
)

aaa <- enhAnchors %>% 
  dplyr::select(group, peakGroup, gene) %>%
  dplyr::mutate(hasPeak = ifelse(peakGroup == \peakNum0\, FALSE, TRUE))

bbb <- aaa %>% dplyr::filter(group == \Grp1\) 
sum(bbb$hasPeak)/nrow(bbb)
bbb <- aaa %>% dplyr::filter(group == \Grp2\) 
sum(bbb$hasPeak)/nrow(bbb)


aaa_summary <- aaa %>%
  group_by(group, peakGroup) %>%
  summarize(count = n(), .groups = \drop\)

# Create the stacked barplot
aaa_summary <- aaa %>%
  group_by(group, peakGroup) %>%
  summarize(count = n(), .groups = \drop\) %>%
  group_by(group) %>%
  mutate(ratio = count / sum(count))

# Define the gradient colors
# gradient_colors <- c(\#D4D4D4\, \#DCB0AF\, \#E48D8A\, \#EC6965\, \#F44641\)
gradient_colors <- c(\#D4D4D4\, \#A2BBCA\, \#71A2C0\, \#3F89B7\, \#0E71AD\)

# Create the stacked barplot with gradient colors
p <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = peakGroup)) +
  geom_bar(stat = \identity\, position = \stack\,
           linewidth = lineMedium * mmToLineUnit, lineend = \square\) +
  theme_classic() + labs(x = NULL , y = \Ratio\) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +
  scale_fill_manual(values = gradient_colors, 
                    guide = guide_legend(
      override.aes = list(size = 0.5), # Adjust legend key symbol size
      keywidth = 2 / 2.54, # Convert 2mm to cm
      keyheight = 2 / 2.54 # Convert 2mm to cm
    )) 

width <- panelSize(1.7)*mmToInch
height <- panelSize(1.3)*mmToInch
fileName <- paste0(\rad21perc_enh\)
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()  



<!-- rnb-output-end -->

<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5wZWFrLlJBRDIxIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKVxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5cbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1uX2Vuc2VtYmxMaXN0LnRzdlxcKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9MaXN0ID0gYyhcXFAtRVxcKSlcblxudGVtcDEgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEExID09IFxcRVxcKSAlPiUgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgZ2VuZSlcbmNvbG5hbWVzKHRlbXAxKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxnZW5lXFwpXG50ZW1wMiA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoQTIgPT0gXFxFXFwpICU+JSBkcGx5cjo6c2VsZWN0KGNocm9tMiwgc3RhcnQyLCBlbmQyLCBnZW5lKVxuY29sbmFtZXModGVtcDIpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGdlbmVcXClcblxuZW5oQW5jaG9ycyA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyKSAlPiUgdW5uZXN0KGdlbmUpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGdyb3VwID0gY2FzZV93aGVuKFxuICAgICAgZ2VuZSAlaW4lIGdyb3VwMSB+IFxcR3JwMVxcLFxuICAgICAgZ2VuZSAlaW4lIGdyb3VwMiB+IFxcR3JwMlxcLFxuICAgICAgVFJVRSB+IE5BXG4gICAgKVxuICApICU+JSBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cbmVuaCA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZW5oQW5jaG9ycyAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKSlcblxuIyBDb3VudCBvdmVybGFwcyBiZXR3ZWVuIHBlYWtzIGFuZCBnZW5lc1xub3ZlcmxhcF9jb3VudHMgPC0gY291bnRPdmVybGFwcyhlbmgsIHBlYWsuUkFEMjEpXG5cbiMgQWRkIG92ZXJsYXAgY291bnRzIHRvIHRoZSBvcmlnaW5hbCBnZW5lLnRiIGRhdGFcbmVuaEFuY2hvcnMkcGVha19jb3VudCA8LSBvdmVybGFwX2NvdW50c1xuXG5lbmhBbmNob3JzIDwtIGVuaEFuY2hvcnMgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBlYWtHcm91cCA9IGNhc2Vfd2hlbihcbiAgICBwZWFrX2NvdW50ID09IDAgfiBcXHBlYWtOdW0wXFwsXG4gICAgcGVha19jb3VudCA9PSAxIH4gXFxwZWFrTnVtMVxcLFxuICAgIHBlYWtfY291bnQgPT0gMiB+IFxccGVha051bTJcXCxcbiAgICBwZWFrX2NvdW50ID09IDMgfiBcXHBlYWtOdW0zXFwsXG4gICAgcGVha19jb3VudCA+PSA0IH4gXFxwZWFrTnVtT3ZlcjRcXFxuICApXG4pXG5cbmFhYSA8LSBlbmhBbmNob3JzICU+JSBcbiAgZHBseXI6OnNlbGVjdChncm91cCwgcGVha0dyb3VwLCBnZW5lKSAlPiVcbiAgZHBseXI6Om11dGF0ZShoYXNQZWFrID0gaWZlbHNlKHBlYWtHcm91cCA9PSBcXHBlYWtOdW0wXFwsIEZBTFNFLCBUUlVFKSlcblxuYmJiIDwtIGFhYSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXEdycDFcXCkgXG5zdW0oYmJiJGhhc1BlYWspL25yb3coYmJiKVxuYmJiIDwtIGFhYSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXEdycDJcXCkgXG5zdW0oYmJiJGhhc1BlYWspL25yb3coYmJiKVxuXG5cbmFhYV9zdW1tYXJ5IDwtIGFhYSAlPiVcbiAgZ3JvdXBfYnkoZ3JvdXAsIHBlYWtHcm91cCkgJT4lXG4gIHN1bW1hcml6ZShjb3VudCA9IG4oKSwgLmdyb3VwcyA9IFxcZHJvcFxcKVxuXG4jIENyZWF0ZSB0aGUgc3RhY2tlZCBiYXJwbG90XG5hYWFfc3VtbWFyeSA8LSBhYWEgJT4lXG4gIGdyb3VwX2J5KGdyb3VwLCBwZWFrR3JvdXApICU+JVxuICBzdW1tYXJpemUoY291bnQgPSBuKCksIC5ncm91cHMgPSBcXGRyb3BcXCkgJT4lXG4gIGdyb3VwX2J5KGdyb3VwKSAlPiVcbiAgbXV0YXRlKHJhdGlvID0gY291bnQgLyBzdW0oY291bnQpKVxuXG4jIERlZmluZSB0aGUgZ3JhZGllbnQgY29sb3JzXG4jIGdyYWRpZW50X2NvbG9ycyA8LSBjKFxcI0Q0RDRENFxcLCBcXCNEQ0IwQUZcXCwgXFwjRTQ4RDhBXFwsIFxcI0VDNjk2NVxcLCBcXCNGNDQ2NDFcXClcbmdyYWRpZW50X2NvbG9ycyA8LSBjKFxcI0Q0RDRENFxcLCBcXCNBMkJCQ0FcXCwgXFwjNzFBMkMwXFwsIFxcIzNGODlCN1xcLCBcXCMwRTcxQURcXClcblxuIyBDcmVhdGUgdGhlIHN0YWNrZWQgYmFycGxvdCB3aXRoIGdyYWRpZW50IGNvbG9yc1xucCA8LSBnZ3Bsb3QoYWFhX3N1bW1hcnksIGFlcyh4ID0gZ3JvdXAsIHkgPSByYXRpbywgZmlsbCA9IHBlYWtHcm91cCkpICtcbiAgZ2VvbV9iYXIoc3RhdCA9IFxcaWRlbnRpdHlcXCwgcG9zaXRpb24gPSBcXHN0YWNrXFwsXG4gICAgICAgICAgIGxpbmV3aWR0aCA9IGxpbmVNZWRpdW0gKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcXHNxdWFyZVxcKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXFxSYXRpb1xcKSArXG4gIHRoZW1lKFxuICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgZmFtaWx5ID0gZm9udFR5cGUsIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKSArXG4gIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGdyYWRpZW50X2NvbG9ycywgXG4gICAgICAgICAgICAgICAgICAgIGd1aWRlID0gZ3VpZGVfbGVnZW5kKFxuICAgICAgb3ZlcnJpZGUuYWVzID0gbGlzdChzaXplID0gMC41KSwgIyBBZGp1c3QgbGVnZW5kIGtleSBzeW1ib2wgc2l6ZVxuICAgICAga2V5d2lkdGggPSAyIC8gMi41NCwgIyBDb252ZXJ0IDJtbSB0byBjbVxuICAgICAga2V5aGVpZ2h0ID0gMiAvIDIuNTQgIyBDb252ZXJ0IDJtbSB0byBjbVxuICAgICkpIFxuXG53aWR0aCA8LSBwYW5lbFNpemUoMS43KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjMpKm1tVG9JbmNoXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxyYWQyMXBlcmNfZW5oXFwpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpICBcblxuYGBgXG5gYGAifQ== -->\n\n```r\n```r\n\npeak.RAD21 <- importPeak(here(refDir, \\33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\\))\ngroup1 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\\))$gene\ngroup2 <- fread(here(refDir, \\geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\\))$gene\n\n\n##########################################################\nname <- \\chromo_cons_annoHierarchy\\\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \\_p-n_ensemblList.tsv\\)),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\\P-E\\))\n\ntemp1 <- geneAnnoData %>% dplyr::filter(A1 == \\E\\) %>% dplyr::select(chrom1, start1, end1, gene)\ncolnames(temp1) <- c(\\chr\\, \\start\\, \\end\\, \\gene\\)\ntemp2 <- geneAnnoData %>% dplyr::filter(A2 == \\E\\) %>% dplyr::select(chrom2, start2, end2, gene)\ncolnames(temp2) <- c(\\chr\\, \\start\\, \\end\\, \\gene\\)\n\nenhAnchors <- bind_rows(temp1, temp2) %>% unnest(gene) %>%\n  dplyr::mutate(\n    group = case_when(\n      gene %in% group1 ~ \\Grp1\\,\n      gene %in% group2 ~ \\Grp2\\,\n      TRUE ~ NA\n    )\n  ) %>% dplyr::filter(!is.na(group))\n\nenh <- makeGRangesFromDataFrame(enhAnchors %>% dplyr::select(c(1, 2, 3)))\n\n# Count overlaps between peaks and genes\noverlap_counts <- countOverlaps(enh, peak.RAD21)\n\n# Add overlap counts to the original gene.tb data\nenhAnchors$peak_count <- overlap_counts\n\nenhAnchors <- enhAnchors %>% dplyr::mutate(\n  peakGroup = case_when(\n    peak_count == 0 ~ \\peakNum0\\,\n    peak_count == 1 ~ \\peakNum1\\,\n    peak_count == 2 ~ \\peakNum2\\,\n    peak_count == 3 ~ \\peakNum3\\,\n    peak_count >= 4 ~ \\peakNumOver4\\\n  )\n)\n\naaa <- enhAnchors %>% \n  dplyr::select(group, peakGroup, gene) %>%\n  dplyr::mutate(hasPeak = ifelse(peakGroup == \\peakNum0\\, FALSE, TRUE))\n\nbbb <- aaa %>% dplyr::filter(group == \\Grp1\\) \nsum(bbb$hasPeak)/nrow(bbb)\nbbb <- aaa %>% dplyr::filter(group == \\Grp2\\) \nsum(bbb$hasPeak)/nrow(bbb)\n\n\naaa_summary <- aaa %>%\n  group_by(group, peakGroup) %>%\n  summarize(count = n(), .groups = \\drop\\)\n\n# Create the stacked barplot\naaa_summary <- aaa %>%\n  group_by(group, peakGroup) %>%\n  summarize(count = n(), .groups = \\drop\\) %>%\n  group_by(group) %>%\n  mutate(ratio = count / sum(count))\n\n# Define the gradient colors\n# gradient_colors <- c(\\#D4D4D4\\, \\#DCB0AF\\, \\#E48D8A\\, \\#EC6965\\, \\#F44641\\)\ngradient_colors <- c(\\#D4D4D4\\, \\#A2BBCA\\, \\#71A2C0\\, \\#3F89B7\\, \\#0E71AD\\)\n\n# Create the stacked barplot with gradient colors\np <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = peakGroup)) +\n  geom_bar(stat = \\identity\\, position = \\stack\\,\n           linewidth = lineMedium * mmToLineUnit, lineend = \\square\\) +\n  theme_classic() + labs(x = NULL , y = \\Ratio\\) +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \\#000000\\\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \\#000000\\\n    ),\n    axis.line = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    axis.ticks = element_line(\n      color = \\#000000\\, size = lineThick * mmToLineUnit, lineend = \\square\\\n    ),\n    panel.background = element_rect(fill = \\transparent\\),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +\n  scale_fill_manual(values = gradient_colors, \n                    guide = guide_legend(\n      override.aes = list(size = 0.5), # Adjust legend key symbol size\n      keywidth = 2 / 2.54, # Convert 2mm to cm\n      keyheight = 2 / 2.54 # Convert 2mm to cm\n    )) \n\nwidth <- panelSize(1.7)*mmToInch\nheight <- panelSize(1.3)*mmToInch\nfileName <- paste0(\\rad21perc_enh\\)\nsvglite(here(figDir, paste0(fileName, \\.svg\\)),  height = height, width = width)\nprint(p)\ndev.off()  \n\n```\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuYGBgclxuXG5wZWFrLlJBRDIxIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFxcMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXFwpKVxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcXGdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XFwpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFxcZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcXCkpJGdlbmVcblxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5uYW1lIDwtIFxcY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVxcXG5cbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXFxfcC1uX2Vuc2VtYmxMaXN0LnRzdlxcKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9MaXN0ID0gYyhcXFAtRVxcKSlcblxudGVtcDEgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEExID09IFxcRVxcKSAlPiUgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgZ2VuZSlcbmNvbG5hbWVzKHRlbXAxKSA8LSBjKFxcY2hyXFwsIFxcc3RhcnRcXCwgXFxlbmRcXCwgXFxnZW5lXFwpXG50ZW1wMiA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoQTIgPT0gXFxFXFwpICU+JSBkcGx5cjo6c2VsZWN0KGNocm9tMiwgc3RhcnQyLCBlbmQyLCBnZW5lKVxuY29sbmFtZXModGVtcDIpIDwtIGMoXFxjaHJcXCwgXFxzdGFydFxcLCBcXGVuZFxcLCBcXGdlbmVcXClcblxuZW5oQW5jaG9ycyA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyKSAlPiUgdW5uZXN0KGdlbmUpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGdyb3VwID0gY2FzZV93aGVuKFxuICAgICAgZ2VuZSAlaW4lIGdyb3VwMSB+IFxcR3JwMVxcLFxuICAgICAgZ2VuZSAlaW4lIGdyb3VwMiB+IFxcR3JwMlxcLFxuICAgICAgVFJVRSB+IE5BXG4gICAgKVxuICApICU+JSBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cbmVuaCA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZW5oQW5jaG9ycyAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKSlcblxuIyBDb3VudCBvdmVybGFwcyBiZXR3ZWVuIHBlYWtzIGFuZCBnZW5lc1xub3ZlcmxhcF9jb3VudHMgPC0gY291bnRPdmVybGFwcyhlbmgsIHBlYWsuUkFEMjEpXG5cbiMgQWRkIG92ZXJsYXAgY291bnRzIHRvIHRoZSBvcmlnaW5hbCBnZW5lLnRiIGRhdGFcbmVuaEFuY2hvcnMkcGVha19jb3VudCA8LSBvdmVybGFwX2NvdW50c1xuXG5lbmhBbmNob3JzIDwtIGVuaEFuY2hvcnMgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBlYWtHcm91cCA9IGNhc2Vfd2hlbihcbiAgICBwZWFrX2NvdW50ID09IDAgfiBcXHBlYWtOdW0wXFwsXG4gICAgcGVha19jb3VudCA9PSAxIH4gXFxwZWFrTnVtMVxcLFxuICAgIHBlYWtfY291bnQgPT0gMiB+IFxccGVha051bTJcXCxcbiAgICBwZWFrX2NvdW50ID09IDMgfiBcXHBlYWtOdW0zXFwsXG4gICAgcGVha19jb3VudCA+PSA0IH4gXFxwZWFrTnVtT3ZlcjRcXFxuICApXG4pXG5cbmFhYSA8LSBlbmhBbmNob3JzICU+JSBcbiAgZHBseXI6OnNlbGVjdChncm91cCwgcGVha0dyb3VwLCBnZW5lKSAlPiVcbiAgZHBseXI6Om11dGF0ZShoYXNQZWFrID0gaWZlbHNlKHBlYWtHcm91cCA9PSBcXHBlYWtOdW0wXFwsIEZBTFNFLCBUUlVFKSlcblxuYmJiIDwtIGFhYSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXEdycDFcXCkgXG5zdW0oYmJiJGhhc1BlYWspL25yb3coYmJiKVxuYmJiIDwtIGFhYSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcXEdycDJcXCkgXG5zdW0oYmJiJGhhc1BlYWspL25yb3coYmJiKVxuXG5cbmFhYV9zdW1tYXJ5IDwtIGFhYSAlPiVcbiAgZ3JvdXBfYnkoZ3JvdXAsIHBlYWtHcm91cCkgJT4lXG4gIHN1bW1hcml6ZShjb3VudCA9IG4oKSwgLmdyb3VwcyA9IFxcZHJvcFxcKVxuXG4jIENyZWF0ZSB0aGUgc3RhY2tlZCBiYXJwbG90XG5hYWFfc3VtbWFyeSA8LSBhYWEgJT4lXG4gIGdyb3VwX2J5KGdyb3VwLCBwZWFrR3JvdXApICU+JVxuICBzdW1tYXJpemUoY291bnQgPSBuKCksIC5ncm91cHMgPSBcXGRyb3BcXCkgJT4lXG4gIGdyb3VwX2J5KGdyb3VwKSAlPiVcbiAgbXV0YXRlKHJhdGlvID0gY291bnQgLyBzdW0oY291bnQpKVxuXG4jIERlZmluZSB0aGUgZ3JhZGllbnQgY29sb3JzXG4jIGdyYWRpZW50X2NvbG9ycyA8LSBjKFxcI0Q0RDRENFxcLCBcXCNEQ0IwQUZcXCwgXFwjRTQ4RDhBXFwsIFxcI0VDNjk2NVxcLCBcXCNGNDQ2NDFcXClcbmdyYWRpZW50X2NvbG9ycyA8LSBjKFxcI0Q0RDRENFxcLCBcXCNBMkJCQ0FcXCwgXFwjNzFBMkMwXFwsIFxcIzNGODlCN1xcLCBcXCMwRTcxQURcXClcblxuIyBDcmVhdGUgdGhlIHN0YWNrZWQgYmFycGxvdCB3aXRoIGdyYWRpZW50IGNvbG9yc1xucCA8LSBnZ3Bsb3QoYWFhX3N1bW1hcnksIGFlcyh4ID0gZ3JvdXAsIHkgPSByYXRpbywgZmlsbCA9IHBlYWtHcm91cCkpICtcbiAgZ2VvbV9iYXIoc3RhdCA9IFxcaWRlbnRpdHlcXCwgcG9zaXRpb24gPSBcXHN0YWNrXFwsXG4gICAgICAgICAgIGxpbmV3aWR0aCA9IGxpbmVNZWRpdW0gKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcXHNxdWFyZVxcKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXFxSYXRpb1xcKSArXG4gIHRoZW1lKFxuICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcXCMwMDAwMDBcXFxuICAgICksXG4gICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgZmFtaWx5ID0gZm9udFR5cGUsIGNvbG9yID0gXFwjMDAwMDAwXFxcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXFwjMDAwMDAwXFwsIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcXHNxdWFyZVxcXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcXCMwMDAwMDBcXCwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFxcc3F1YXJlXFxcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFxcdHJhbnNwYXJlbnRcXCksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKSArXG4gIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGdyYWRpZW50X2NvbG9ycywgXG4gICAgICAgICAgICAgICAgICAgIGd1aWRlID0gZ3VpZGVfbGVnZW5kKFxuICAgICAgb3ZlcnJpZGUuYWVzID0gbGlzdChzaXplID0gMC41KSwgIyBBZGp1c3QgbGVnZW5kIGtleSBzeW1ib2wgc2l6ZVxuICAgICAga2V5d2lkdGggPSAyIC8gMi41NCwgIyBDb252ZXJ0IDJtbSB0byBjbVxuICAgICAga2V5aGVpZ2h0ID0gMiAvIDIuNTQgIyBDb252ZXJ0IDJtbSB0byBjbVxuICAgICkpIFxuXG53aWR0aCA8LSBwYW5lbFNpemUoMS43KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjMpKm1tVG9JbmNoXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxyYWQyMXBlcmNfZW5oXFwpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpICBcblxuYGBgXG5gYGAifQ== -->

```r
```r

peak.RAD21 <- importPeak(here(refDir, \33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\))
group1 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\))$gene
group2 <- fread(here(refDir, \geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\))$gene


##########################################################
name <- \chromo_cons_annoHierarchy\

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \_p-n_ensemblList.tsv\)),
                                      diffCutoff = 0.2,
                                      annoList = c(\P-E\))

temp1 <- geneAnnoData %>% dplyr::filter(A1 == \E\) %>% dplyr::select(chrom1, start1, end1, gene)
colnames(temp1) <- c(\chr\, \start\, \end\, \gene\)
temp2 <- geneAnnoData %>% dplyr::filter(A2 == \E\) %>% dplyr::select(chrom2, start2, end2, gene)
colnames(temp2) <- c(\chr\, \start\, \end\, \gene\)

enhAnchors <- bind_rows(temp1, temp2) %>% unnest(gene) %>%
  dplyr::mutate(
    group = case_when(
      gene %in% group1 ~ \Grp1\,
      gene %in% group2 ~ \Grp2\,
      TRUE ~ NA
    )
  ) %>% dplyr::filter(!is.na(group))

enh <- makeGRangesFromDataFrame(enhAnchors %>% dplyr::select(c(1, 2, 3)))

# Count overlaps between peaks and genes
overlap_counts <- countOverlaps(enh, peak.RAD21)

# Add overlap counts to the original gene.tb data
enhAnchors$peak_count <- overlap_counts

enhAnchors <- enhAnchors %>% dplyr::mutate(
  peakGroup = case_when(
    peak_count == 0 ~ \peakNum0\,
    peak_count == 1 ~ \peakNum1\,
    peak_count == 2 ~ \peakNum2\,
    peak_count == 3 ~ \peakNum3\,
    peak_count >= 4 ~ \peakNumOver4\
  )
)

aaa <- enhAnchors %>% 
  dplyr::select(group, peakGroup, gene) %>%
  dplyr::mutate(hasPeak = ifelse(peakGroup == \peakNum0\, FALSE, TRUE))

bbb <- aaa %>% dplyr::filter(group == \Grp1\) 
sum(bbb$hasPeak)/nrow(bbb)
bbb <- aaa %>% dplyr::filter(group == \Grp2\) 
sum(bbb$hasPeak)/nrow(bbb)


aaa_summary <- aaa %>%
  group_by(group, peakGroup) %>%
  summarize(count = n(), .groups = \drop\)

# Create the stacked barplot
aaa_summary <- aaa %>%
  group_by(group, peakGroup) %>%
  summarize(count = n(), .groups = \drop\) %>%
  group_by(group) %>%
  mutate(ratio = count / sum(count))

# Define the gradient colors
# gradient_colors <- c(\#D4D4D4\, \#DCB0AF\, \#E48D8A\, \#EC6965\, \#F44641\)
gradient_colors <- c(\#D4D4D4\, \#A2BBCA\, \#71A2C0\, \#3F89B7\, \#0E71AD\)

# Create the stacked barplot with gradient colors
p <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = peakGroup)) +
  geom_bar(stat = \identity\, position = \stack\,
           linewidth = lineMedium * mmToLineUnit, lineend = \square\) +
  theme_classic() + labs(x = NULL , y = \Ratio\) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = \#000000\
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = \#000000\
    ),
    axis.line = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    axis.ticks = element_line(
      color = \#000000\, size = lineThick * mmToLineUnit, lineend = \square\
    ),
    panel.background = element_rect(fill = \transparent\),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +
  scale_fill_manual(values = gradient_colors, 
                    guide = guide_legend(
      override.aes = list(size = 0.5), # Adjust legend key symbol size
      keywidth = 2 / 2.54, # Convert 2mm to cm
      keyheight = 2 / 2.54 # Convert 2mm to cm
    )) 

width <- panelSize(1.7)*mmToInch
height <- panelSize(1.3)*mmToInch
fileName <- paste0(\rad21perc_enh\)
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()  

```
```

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


##### log2FC

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVYRzVrWVhSaElEd3RJR1p5WldGa0tHaGxjbVVvY21WemRXeDBSR2x5TENCY0ltTm9jbTl0U0UxTlhDSXNJRndpUVRRNE5WOXdaUzF3WlY5aGJtTm9iM0p6WENJc0lGd2liM1psY214aGNGOWxibkpwWTJoZk1UQXdYM04wWVhSbExuUjRkRndpS1NsY2JtTnZiRzVoYldWektHUmhkR0VwSUR3dElHTW9YQ0p6ZEdGMFpWd2lMQ0JjSW1kbGJtOXRaVndpTENCY0luQmxMWEJsWDBFME9EVmZaRzkzYmx3aUxDQmNJbkJsTFhCbFgwRTBPRFZmYm05Y0lpd2dYQ0p3WlMxd1pWOUJORGcxWDNWd1hDSXBYRzVrWVhSaElEd3RJR1JoZEdFZ0pUNGxJR1J3YkhseU9qcHpaV3hsWTNRb0xXZGxibTl0WlNrZ0pUNGxJR0Z6TG0xaGRISnBlQ2dwWEc1Y2JpQWdZMjlzZFcxdVgzUnZYM0p2ZDI1aGJXVnpLSFpoY2lBOUlGd2ljM1JoZEdWY0lpa2dKVDRsWEc0Z0lHRnpMbTFoZEhKcGVDZ3BYRzVjYm14cFluSmhjbmtvWTJseVkyeHBlbVVwWEc1Y2JtTnZiRjltZFc0Z1BDMGdZMjlzYjNKU1lXMXdNaWhqS0RBc0lERXNJREV3S1N3Z1hHNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnWXloY0ltSnNkV1ZjSWl3Z1hDSjNhR2wwWlZ3aUxDQmNJbkpsWkZ3aUtTbGNibHh1YkdsaWNtRnllU2hqYVhKamJHbDZaU2xjYm1OdmJGOW1kVzRnUEMwZ1kyOXNiM0pTWVcxd01paGpLRzFwYmloa1lYUmhLU3dnYldGNEtHUmhkR0VwS1N3Z1l5aGNJbmRvYVhSbFhDSXNJRndpY21Wa1hDSXBLVnh1WEc1Y2JpTm1kbWw2WDI1aVkyeDFjM1FvWkdGMFlTd2dhMjFsWVc1ekxDQnRaWFJvYjJRZ1BTQmNJbmR6YzF3aUtWeHVYRzV3SUR3dElFaGxZWFJ0WVhBb1hHNGdJR1JoZEdFc1hHNGdJRzVoYldVZ1BTQmNJazlrWkhNZ1VtRjBhVzljSWl3Z0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0l5Qk9ZVzFsSUc5bUlIUm9aU0JvWldGMGJXRndJR3hsWjJWdVpGeHVJQ0JqYkhWemRHVnlYMk52YkhWdGJuTWdQU0JHUVV4VFJTd2dJQ0FnSUNBZ0lDQWdJQ0FqSUZKbGJXOTJaU0JqYjJ4MWJXNGdaR1Z1WkhKdlozSmhiVnh1SUNCeWIzZGZhMjBnUFNBeE1Dd2dJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0l5QkVaV1pwYm1VZ2RHaGxJRzUxYldKbGNpQnZaaUJyTFcxbFlXNXpJR05zZFhOMFpYSnpJR1p2Y2lCeWIzZHpJQ2hoWkdwMWMzUWdZWE1nYm1WbFpHVmtLVnh1SUNCemFHOTNYM0p2ZDE5a1pXNWtJRDBnUmtGTVUwVXNYRzRnSUdOdmJDQTlJR052YkY5bWRXNHNYRzRnSUdKdmNtUmxjaUE5SUZSU1ZVVmNiaWxjYmx4dVptbHNaVTVoYldVZ1BDMGdjR0Z6ZEdVd0tGd2lZVzVqYUc5eVRFOU1RVjlrVkVGSFgzWnpYMFJOVTA5ZlpHbG1aakF1TWw5aGJHeE1iMjl3YzE5bGVIUnlaVzFsWDNKbFowRnVZMmh2Y2tKaFkydG5jbTkxYm1SZllYUmhZMXdpS1Z4dWFHVnBaMmgwSUR3dElEZGNibmRwWkhSb0lEd3RJRE11TlZ4dWNHNW5LR2hsY21Vb1ptbG5SR2x5TENCd1lYTjBaVEFvWm1sc1pVNWhiV1VzSUZ3aUxuQnVaMXdpS1Nrc0lISmxjeUE5SURZd01Dd2dkVzVwZENBOUlGd2lhVzVjSWl3Z2FHVnBaMmgwSUQwZ2FHVnBaMmgwTENCM2FXUjBhQ0E5SUhkcFpIUm9LVnh1Y0hKcGJuUW9jQ2xjYm1SbGRpNXZabVlvS1Z4dWMzWm5iR2wwWlNob1pYSmxLR1pwWjBScGNpd2djR0Z6ZEdVd0tHWnBiR1ZPWVcxbExDQmNJaTV6ZG1kY0lpa3BMQ0FnYUdWcFoyaDBJRDBnYUdWcFoyaDBMQ0IzYVdSMGFDQTlJSGRwWkhSb0tWeHVjSEpwYm5Rb2NDbGNibVJsZGk1dlptWW9LVnh1WEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG5cbmRhdGEgPC0gZnJlYWQoaGVyZShyZXN1bHREaXIsIFxcY2hyb21ITU1cXCwgXFxBNDg1X3BlLXBlX2FuY2hvcnNcXCwgXFxvdmVybGFwX2VucmljaF8xMDBfc3RhdGUudHh0XFwpKVxuY29sbmFtZXMoZGF0YSkgPC0gYyhcXHN0YXRlXFwsIFxcZ2Vub21lXFwsIFxccGUtcGVfQTQ4NV9kb3duXFwsIFxccGUtcGVfQTQ4NV9ub1xcLCBcXHBlLXBlX0E0ODVfdXBcXClcbmRhdGEgPC0gZGF0YSAlPiUgZHBseXI6OnNlbGVjdCgtZ2Vub21lKSAlPiUgYXMubWF0cml4KClcblxuICBjb2x1bW5fdG9fcm93bmFtZXModmFyID0gXFxzdGF0ZVxcKSAlPiVcbiAgYXMubWF0cml4KClcblxubGlicmFyeShjaXJjbGl6ZSlcblxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMoMCwgMSwgMTApLCBcbiAgICAgICAgICAgICAgICAgICAgICBjKFxcYmx1ZVxcLCBcXHdoaXRlXFwsIFxccmVkXFwpKVxuXG5saWJyYXJ5KGNpcmNsaXplKVxuY29sX2Z1biA8LSBjb2xvclJhbXAyKGMobWluKGRhdGEpLCBtYXgoZGF0YSkpLCBjKFxcd2hpdGVcXCwgXFxyZWRcXCkpXG5cblxuI2Z2aXpfbmJjbHVzdChkYXRhLCBrbWVhbnMsIG1ldGhvZCA9IFxcd3NzXFwpXG5cbnAgPC0gSGVhdG1hcChcbiAgZGF0YSxcbiAgbmFtZSA9IFxcT2RkcyBSYXRpb1xcLCAgICAgICAgICAgICAgICAgICAjIE5hbWUgb2YgdGhlIGhlYXRtYXAgbGVnZW5kXG4gIGNsdXN0ZXJfY29sdW1ucyA9IEZBTFNFLCAgICAgICAgICAgICMgUmVtb3ZlIGNvbHVtbiBkZW5kcm9ncmFtXG4gIHJvd19rbSA9IDEwLCAgICAgICAgICAgICAgICAgICAgICAgICAjIERlZmluZSB0aGUgbnVtYmVyIG9mIGstbWVhbnMgY2x1c3RlcnMgZm9yIHJvd3MgKGFkanVzdCBhcyBuZWVkZWQpXG4gIHNob3dfcm93X2RlbmQgPSBGQUxTRSxcbiAgY29sID0gY29sX2Z1bixcbiAgYm9yZGVyID0gVFJVRVxuKVxuXG5maWxlTmFtZSA8LSBwYXN0ZTAoXFxhbmNob3JMT0xBX2RUQUdfdnNfRE1TT19kaWZmMC4yX2FsbExvb3BzX2V4dHJlbWVfcmVnQW5jaG9yQmFja2dyb3VuZF9hdGFjXFwpXG5oZWlnaHQgPC0gN1xud2lkdGggPC0gMy41XG5wbmcoaGVyZShmaWdEaXIsIHBhc3RlMChmaWxlTmFtZSwgXFwucG5nXFwpKSwgcmVzID0gNjAwLCB1bml0ID0gXFxpblxcLCBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFxcLnN2Z1xcKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpXG5cbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->

data <- fread(here(resultDir, \chromHMM\, \A485_pe-pe_anchors\, \overlap_enrich_100_state.txt\))
colnames(data) <- c(\state\, \genome\, \pe-pe_A485_down\, \pe-pe_A485_no\, \pe-pe_A485_up\)
data <- data %>% dplyr::select(-genome) %>% as.matrix()

  column_to_rownames(var = \state\) %>%
  as.matrix()

library(circlize)

col_fun <- colorRamp2(c(0, 1, 10), 
                      c(\blue\, \white\, \red\))

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 10,                         # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)

fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_regAnchorBackground_atac\)
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

````

```r

data <- fread(here(resultDir, \chromHMM\, \A485_pe-pe_anchors\, \overlap_enrich_100_state.txt\))
colnames(data) <- c(\state\, \genome\, \pe-pe_A485_down\, \pe-pe_A485_no\, \pe-pe_A485_up\)
data <- data %>% dplyr::select(-genome) %>% as.matrix()

  column_to_rownames(var = \state\) %>%
  as.matrix()

library(circlize)

col_fun <- colorRamp2(c(0, 1, 10), 
                      c(\blue\, \white\, \red\))

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c(\white\, \red\))


#fviz_nbclust(data, kmeans, method = \wss\)

p <- Heatmap(
  data,
  name = \Odds Ratio\,                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 10,                         # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)

fileName <- paste0(\anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_regAnchorBackground_atac\)
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, \.png\)), res = 600, unit = \in\, height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, \.svg\)),  height = height, width = width)
print(p)
dev.off()

<!-- rnb-source-end -->


<!-- rnb-output-end -->

<!-- rnb-chunk-end -->


<!-- rnb-text-begin -->


### [3.44] Checking RAD21 peak density at group1 and group2 promoter

<!-- rnb-text-end -->


<!-- rnb-chunk-begin -->


<!-- rnb-output-begin {"data":"\n<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5wZWFrLlJBRDIxIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFwiMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXCIpKVxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XCIpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcIikpJGdlbmVcblxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5uYW1lIDwtIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVwiXG5cbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXCJfcC1uX2Vuc2VtYmxMaXN0LnRzdlwiKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9MaXN0ID0gYyhcIlAtRVwiKSlcblxudGVtcDEgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEExID09IFwiRVwiKSAlPiUgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgZ2VuZSlcbmNvbG5hbWVzKHRlbXAxKSA8LSBjKFwiY2hyXCIsIFwic3RhcnRcIiwgXCJlbmRcIiwgXCJnZW5lXCIpXG50ZW1wMiA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoQTIgPT0gXCJFXCIpICU+JSBkcGx5cjo6c2VsZWN0KGNocm9tMiwgc3RhcnQyLCBlbmQyLCBnZW5lKVxuY29sbmFtZXModGVtcDIpIDwtIGMoXCJjaHJcIiwgXCJzdGFydFwiLCBcImVuZFwiLCBcImdlbmVcIilcblxuZW5oQW5jaG9ycyA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyKSAlPiUgdW5uZXN0KGdlbmUpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGdyb3VwID0gY2FzZV93aGVuKFxuICAgICAgZ2VuZSAlaW4lIGdyb3VwMSB+IFwiR3JwMVwiLFxuICAgICAgZ2VuZSAlaW4lIGdyb3VwMiB+IFwiR3JwMlwiLFxuICAgICAgVFJVRSB+IE5BXG4gICAgKVxuICApICU+JSBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cbmVuaCA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZW5oQW5jaG9ycyAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKSlcblxuIyBDb3VudCBvdmVybGFwcyBiZXR3ZWVuIHBlYWtzIGFuZCBnZW5lc1xub3ZlcmxhcF9jb3VudHMgPC0gY291bnRPdmVybGFwcyhlbmgsIHBlYWsuUkFEMjEpXG5cbiMgQWRkIG92ZXJsYXAgY291bnRzIHRvIHRoZSBvcmlnaW5hbCBnZW5lLnRiIGRhdGFcbmVuaEFuY2hvcnMkcGVha19jb3VudCA8LSBvdmVybGFwX2NvdW50c1xuXG5lbmhBbmNob3JzIDwtIGVuaEFuY2hvcnMgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBlYWtHcm91cCA9IGNhc2Vfd2hlbihcbiAgICBwZWFrX2NvdW50ID09IDAgfiBcInBlYWtOdW0wXCIsXG4gICAgcGVha19jb3VudCA9PSAxIH4gXCJwZWFrTnVtMVwiLFxuICAgIHBlYWtfY291bnQgPT0gMiB+IFwicGVha051bTJcIixcbiAgICBwZWFrX2NvdW50ID09IDMgfiBcInBlYWtOdW0zXCIsXG4gICAgcGVha19jb3VudCA+PSA0IH4gXCJwZWFrTnVtT3ZlcjRcIlxuICApXG4pXG5cbmFhYSA8LSBlbmhBbmNob3JzICU+JSBcbiAgZHBseXI6OnNlbGVjdChncm91cCwgcGVha0dyb3VwLCBnZW5lKSAlPiVcbiAgZHBseXI6Om11dGF0ZShoYXNQZWFrID0gaWZlbHNlKHBlYWtHcm91cCA9PSBcInBlYWtOdW0wXCIsIEZBTFNFLCBUUlVFKSlcblxuYmJiIDwtIGFhYSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcIkdycDFcIikgXG5zdW0oYmJiJGhhc1BlYWspL25yb3coYmJiKVxuYmJiIDwtIGFhYSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcIkdycDJcIikgXG5zdW0oYmJiJGhhc1BlYWspL25yb3coYmJiKVxuXG5cbmFhYV9zdW1tYXJ5IDwtIGFhYSAlPiVcbiAgZ3JvdXBfYnkoZ3JvdXAsIHBlYWtHcm91cCkgJT4lXG4gIHN1bW1hcml6ZShjb3VudCA9IG4oKSwgLmdyb3VwcyA9IFwiZHJvcFwiKVxuXG4jIENyZWF0ZSB0aGUgc3RhY2tlZCBiYXJwbG90XG5hYWFfc3VtbWFyeSA8LSBhYWEgJT4lXG4gIGdyb3VwX2J5KGdyb3VwLCBwZWFrR3JvdXApICU+JVxuICBzdW1tYXJpemUoY291bnQgPSBuKCksIC5ncm91cHMgPSBcImRyb3BcIikgJT4lXG4gIGdyb3VwX2J5KGdyb3VwKSAlPiVcbiAgbXV0YXRlKHJhdGlvID0gY291bnQgLyBzdW0oY291bnQpKVxuXG4jIERlZmluZSB0aGUgZ3JhZGllbnQgY29sb3JzXG4jIGdyYWRpZW50X2NvbG9ycyA8LSBjKFwiI0Q0RDRENFwiLCBcIiNEQ0IwQUZcIiwgXCIjRTQ4RDhBXCIsIFwiI0VDNjk2NVwiLCBcIiNGNDQ2NDFcIilcbmdyYWRpZW50X2NvbG9ycyA8LSBjKFwiI0Q0RDRENFwiLCBcIiNBMkJCQ0FcIiwgXCIjNzFBMkMwXCIsIFwiIzNGODlCN1wiLCBcIiMwRTcxQURcIilcblxuIyBDcmVhdGUgdGhlIHN0YWNrZWQgYmFycGxvdCB3aXRoIGdyYWRpZW50IGNvbG9yc1xucCA8LSBnZ3Bsb3QoYWFhX3N1bW1hcnksIGFlcyh4ID0gZ3JvdXAsIHkgPSByYXRpbywgZmlsbCA9IHBlYWtHcm91cCkpICtcbiAgZ2VvbV9iYXIoc3RhdCA9IFwiaWRlbnRpdHlcIiwgcG9zaXRpb24gPSBcInN0YWNrXCIsXG4gICAgICAgICAgIGxpbmV3aWR0aCA9IGxpbmVNZWRpdW0gKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcInNxdWFyZVwiKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXCJSYXRpb1wiKSArXG4gIHRoZW1lKFxuICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgZmFtaWx5ID0gZm9udFR5cGUsIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCIsIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcInNxdWFyZVwiXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIiwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFwidHJhbnNwYXJlbnRcIiksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKSArXG4gIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGdyYWRpZW50X2NvbG9ycywgXG4gICAgICAgICAgICAgICAgICAgIGd1aWRlID0gZ3VpZGVfbGVnZW5kKFxuICAgICAgb3ZlcnJpZGUuYWVzID0gbGlzdChzaXplID0gMC41KSwgIyBBZGp1c3QgbGVnZW5kIGtleSBzeW1ib2wgc2l6ZVxuICAgICAga2V5d2lkdGggPSAyIC8gMi41NCwgIyBDb252ZXJ0IDJtbSB0byBjbVxuICAgICAga2V5aGVpZ2h0ID0gMiAvIDIuNTQgIyBDb252ZXJ0IDJtbSB0byBjbVxuICAgICkpIFxuXG53aWR0aCA8LSBwYW5lbFNpemUoMS43KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjMpKm1tVG9JbmNoXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJyYWQyMXBlcmNfZW5oXCIpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpICBcblxuYGBgIn0= -->\n\n```r\n\npeak.RAD21 <- importPeak(here(refDir, \"33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed\"))\ngroup1 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv\"))$gene\ngroup2 <- fread(here(refDir, \"geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv\"))$gene\n\n\n##########################################################\nname <- \"chromo_cons_annoHierarchy\"\n\ngeneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, \"_p-n_ensemblList.tsv\")),\n                                      diffCutoff = 0.2,\n                                      annoList = c(\"P-E\"))\n\ntemp1 <- geneAnnoData %>% dplyr::filter(A1 == \"E\") %>% dplyr::select(chrom1, start1, end1, gene)\ncolnames(temp1) <- c(\"chr\", \"start\", \"end\", \"gene\")\ntemp2 <- geneAnnoData %>% dplyr::filter(A2 == \"E\") %>% dplyr::select(chrom2, start2, end2, gene)\ncolnames(temp2) <- c(\"chr\", \"start\", \"end\", \"gene\")\n\nenhAnchors <- bind_rows(temp1, temp2) %>% unnest(gene) %>%\n  dplyr::mutate(\n    group = case_when(\n      gene %in% group1 ~ \"Grp1\",\n      gene %in% group2 ~ \"Grp2\",\n      TRUE ~ NA\n    )\n  ) %>% dplyr::filter(!is.na(group))\n\nenh <- makeGRangesFromDataFrame(enhAnchors %>% dplyr::select(c(1, 2, 3)))\n\n# Count overlaps between peaks and genes\noverlap_counts <- countOverlaps(enh, peak.RAD21)\n\n# Add overlap counts to the original gene.tb data\nenhAnchors$peak_count <- overlap_counts\n\nenhAnchors <- enhAnchors %>% dplyr::mutate(\n  peakGroup = case_when(\n    peak_count == 0 ~ \"peakNum0\",\n    peak_count == 1 ~ \"peakNum1\",\n    peak_count == 2 ~ \"peakNum2\",\n    peak_count == 3 ~ \"peakNum3\",\n    peak_count >= 4 ~ \"peakNumOver4\"\n  )\n)\n\naaa <- enhAnchors %>% \n  dplyr::select(group, peakGroup, gene) %>%\n  dplyr::mutate(hasPeak = ifelse(peakGroup == \"peakNum0\", FALSE, TRUE))\n\nbbb <- aaa %>% dplyr::filter(group == \"Grp1\") \nsum(bbb$hasPeak)/nrow(bbb)\nbbb <- aaa %>% dplyr::filter(group == \"Grp2\") \nsum(bbb$hasPeak)/nrow(bbb)\n\n\naaa_summary <- aaa %>%\n  group_by(group, peakGroup) %>%\n  summarize(count = n(), .groups = \"drop\")\n\n# Create the stacked barplot\naaa_summary <- aaa %>%\n  group_by(group, peakGroup) %>%\n  summarize(count = n(), .groups = \"drop\") %>%\n  group_by(group) %>%\n  mutate(ratio = count / sum(count))\n\n# Define the gradient colors\n# gradient_colors <- c(\"#D4D4D4\", \"#DCB0AF\", \"#E48D8A\", \"#EC6965\", \"#F44641\")\ngradient_colors <- c(\"#D4D4D4\", \"#A2BBCA\", \"#71A2C0\", \"#3F89B7\", \"#0E71AD\")\n\n# Create the stacked barplot with gradient colors\np <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = peakGroup)) +\n  geom_bar(stat = \"identity\", position = \"stack\",\n           linewidth = lineMedium * mmToLineUnit, lineend = \"square\") +\n  theme_classic() + labs(x = NULL , y = \"Ratio\") +\n  theme(\n    axis.title = element_text(\n      size = fontSizeM, family = fontType, color = \"#000000\"\n    ),\n    axis.text = element_text(\n      size = fontSizeS, family = fontType, color = \"#000000\"\n    ),\n    axis.line = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    axis.ticks = element_line(\n      color = \"#000000\", size = lineThick * mmToLineUnit, lineend = \"square\"\n    ),\n    panel.background = element_rect(fill = \"transparent\"),\n    legend.text = element_text(family = fontType, size = fontSizeS),\n    legend.title = element_text(family = fontType, size = fontSizeS)\n  ) +\n  scale_fill_manual(values = gradient_colors, \n                    guide = guide_legend(\n      override.aes = list(size = 0.5), # Adjust legend key symbol size\n      keywidth = 2 / 2.54, # Convert 2mm to cm\n      keyheight = 2 / 2.54 # Convert 2mm to cm\n    )) \n\nwidth <- panelSize(1.7)*mmToInch\nheight <- panelSize(1.3)*mmToInch\nfileName <- paste0(\"rad21perc_enh\")\nsvglite(here(figDir, paste0(fileName, \".svg\")),  height = height, width = width)\nprint(p)\ndev.off()  \n\n```\n\n<!-- rnb-source-end -->\n"} -->


<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuXG5wZWFrLlJBRDIxIDwtIGltcG9ydFBlYWsoaGVyZShyZWZEaXIsIFwiMzMyNTBfUkFEMjFfYWI5OTJfQnJ1Y2UtNF9wZWFrcy5tZXJnZVBlYWsuYmVkXCIpKVxuZ3JvdXAxIDwtIGZyZWFkKGhlcmUocmVmRGlyLCBcImdlbmVMaXN0X2RUQUdfdnNfRE1TT19STkFfbG9vcF9iaW5hcnlHcm91cDEudHN2XCIpKSRnZW5lXG5ncm91cDIgPC0gZnJlYWQoaGVyZShyZWZEaXIsIFwiZ2VuZUxpc3RfZFRBR192c19ETVNPX1JOQV9sb29wX2JpbmFyeUdyb3VwMi50c3ZcIikpJGdlbmVcblxuXG4jIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjXG5uYW1lIDwtIFwiY2hyb21vX2NvbnNfYW5ub0hpZXJhcmNoeVwiXG5cbmdlbmVBbm5vRGF0YSA8LSBsb2FkTG9vcEFubm9EYXRhKGhlcmUoY29uc2Vuc3VzRGlyLCBwYXN0ZTAobmFtZSwgXCJfcC1uX2Vuc2VtYmxMaXN0LnRzdlwiKSksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRpZmZDdXRvZmYgPSAwLjIsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFubm9MaXN0ID0gYyhcIlAtRVwiKSlcblxudGVtcDEgPC0gZ2VuZUFubm9EYXRhICU+JSBkcGx5cjo6ZmlsdGVyKEExID09IFwiRVwiKSAlPiUgZHBseXI6OnNlbGVjdChjaHJvbTEsIHN0YXJ0MSwgZW5kMSwgZ2VuZSlcbmNvbG5hbWVzKHRlbXAxKSA8LSBjKFwiY2hyXCIsIFwic3RhcnRcIiwgXCJlbmRcIiwgXCJnZW5lXCIpXG50ZW1wMiA8LSBnZW5lQW5ub0RhdGEgJT4lIGRwbHlyOjpmaWx0ZXIoQTIgPT0gXCJFXCIpICU+JSBkcGx5cjo6c2VsZWN0KGNocm9tMiwgc3RhcnQyLCBlbmQyLCBnZW5lKVxuY29sbmFtZXModGVtcDIpIDwtIGMoXCJjaHJcIiwgXCJzdGFydFwiLCBcImVuZFwiLCBcImdlbmVcIilcblxuZW5oQW5jaG9ycyA8LSBiaW5kX3Jvd3ModGVtcDEsIHRlbXAyKSAlPiUgdW5uZXN0KGdlbmUpICU+JVxuICBkcGx5cjo6bXV0YXRlKFxuICAgIGdyb3VwID0gY2FzZV93aGVuKFxuICAgICAgZ2VuZSAlaW4lIGdyb3VwMSB+IFwiR3JwMVwiLFxuICAgICAgZ2VuZSAlaW4lIGdyb3VwMiB+IFwiR3JwMlwiLFxuICAgICAgVFJVRSB+IE5BXG4gICAgKVxuICApICU+JSBkcGx5cjo6ZmlsdGVyKCFpcy5uYShncm91cCkpXG5cbmVuaCA8LSBtYWtlR1Jhbmdlc0Zyb21EYXRhRnJhbWUoZW5oQW5jaG9ycyAlPiUgZHBseXI6OnNlbGVjdChjKDEsIDIsIDMpKSlcblxuIyBDb3VudCBvdmVybGFwcyBiZXR3ZWVuIHBlYWtzIGFuZCBnZW5lc1xub3ZlcmxhcF9jb3VudHMgPC0gY291bnRPdmVybGFwcyhlbmgsIHBlYWsuUkFEMjEpXG5cbiMgQWRkIG92ZXJsYXAgY291bnRzIHRvIHRoZSBvcmlnaW5hbCBnZW5lLnRiIGRhdGFcbmVuaEFuY2hvcnMkcGVha19jb3VudCA8LSBvdmVybGFwX2NvdW50c1xuXG5lbmhBbmNob3JzIDwtIGVuaEFuY2hvcnMgJT4lIGRwbHlyOjptdXRhdGUoXG4gIHBlYWtHcm91cCA9IGNhc2Vfd2hlbihcbiAgICBwZWFrX2NvdW50ID09IDAgfiBcInBlYWtOdW0wXCIsXG4gICAgcGVha19jb3VudCA9PSAxIH4gXCJwZWFrTnVtMVwiLFxuICAgIHBlYWtfY291bnQgPT0gMiB+IFwicGVha051bTJcIixcbiAgICBwZWFrX2NvdW50ID09IDMgfiBcInBlYWtOdW0zXCIsXG4gICAgcGVha19jb3VudCA+PSA0IH4gXCJwZWFrTnVtT3ZlcjRcIlxuICApXG4pXG5cbmFhYSA8LSBlbmhBbmNob3JzICU+JSBcbiAgZHBseXI6OnNlbGVjdChncm91cCwgcGVha0dyb3VwLCBnZW5lKSAlPiVcbiAgZHBseXI6Om11dGF0ZShoYXNQZWFrID0gaWZlbHNlKHBlYWtHcm91cCA9PSBcInBlYWtOdW0wXCIsIEZBTFNFLCBUUlVFKSlcblxuYmJiIDwtIGFhYSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcIkdycDFcIikgXG5zdW0oYmJiJGhhc1BlYWspL25yb3coYmJiKVxuYmJiIDwtIGFhYSAlPiUgZHBseXI6OmZpbHRlcihncm91cCA9PSBcIkdycDJcIikgXG5zdW0oYmJiJGhhc1BlYWspL25yb3coYmJiKVxuXG5cbmFhYV9zdW1tYXJ5IDwtIGFhYSAlPiVcbiAgZ3JvdXBfYnkoZ3JvdXAsIHBlYWtHcm91cCkgJT4lXG4gIHN1bW1hcml6ZShjb3VudCA9IG4oKSwgLmdyb3VwcyA9IFwiZHJvcFwiKVxuXG4jIENyZWF0ZSB0aGUgc3RhY2tlZCBiYXJwbG90XG5hYWFfc3VtbWFyeSA8LSBhYWEgJT4lXG4gIGdyb3VwX2J5KGdyb3VwLCBwZWFrR3JvdXApICU+JVxuICBzdW1tYXJpemUoY291bnQgPSBuKCksIC5ncm91cHMgPSBcImRyb3BcIikgJT4lXG4gIGdyb3VwX2J5KGdyb3VwKSAlPiVcbiAgbXV0YXRlKHJhdGlvID0gY291bnQgLyBzdW0oY291bnQpKVxuXG4jIERlZmluZSB0aGUgZ3JhZGllbnQgY29sb3JzXG4jIGdyYWRpZW50X2NvbG9ycyA8LSBjKFwiI0Q0RDRENFwiLCBcIiNEQ0IwQUZcIiwgXCIjRTQ4RDhBXCIsIFwiI0VDNjk2NVwiLCBcIiNGNDQ2NDFcIilcbmdyYWRpZW50X2NvbG9ycyA8LSBjKFwiI0Q0RDRENFwiLCBcIiNBMkJCQ0FcIiwgXCIjNzFBMkMwXCIsIFwiIzNGODlCN1wiLCBcIiMwRTcxQURcIilcblxuIyBDcmVhdGUgdGhlIHN0YWNrZWQgYmFycGxvdCB3aXRoIGdyYWRpZW50IGNvbG9yc1xucCA8LSBnZ3Bsb3QoYWFhX3N1bW1hcnksIGFlcyh4ID0gZ3JvdXAsIHkgPSByYXRpbywgZmlsbCA9IHBlYWtHcm91cCkpICtcbiAgZ2VvbV9iYXIoc3RhdCA9IFwiaWRlbnRpdHlcIiwgcG9zaXRpb24gPSBcInN0YWNrXCIsXG4gICAgICAgICAgIGxpbmV3aWR0aCA9IGxpbmVNZWRpdW0gKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcInNxdWFyZVwiKSArXG4gIHRoZW1lX2NsYXNzaWMoKSArIGxhYnMoeCA9IE5VTEwgLCB5ID0gXCJSYXRpb1wiKSArXG4gIHRoZW1lKFxuICAgIGF4aXMudGl0bGUgPSBlbGVtZW50X3RleHQoXG4gICAgICBzaXplID0gZm9udFNpemVNLCBmYW1pbHkgPSBmb250VHlwZSwgY29sb3IgPSBcIiMwMDAwMDBcIlxuICAgICksXG4gICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KFxuICAgICAgc2l6ZSA9IGZvbnRTaXplUywgZmFtaWx5ID0gZm9udFR5cGUsIGNvbG9yID0gXCIjMDAwMDAwXCJcbiAgICApLFxuICAgIGF4aXMubGluZSA9IGVsZW1lbnRfbGluZShcbiAgICAgIGNvbG9yID0gXCIjMDAwMDAwXCIsIHNpemUgPSBsaW5lVGhpY2sgKiBtbVRvTGluZVVuaXQsIGxpbmVlbmQgPSBcInNxdWFyZVwiXG4gICAgKSxcbiAgICBheGlzLnRpY2tzID0gZWxlbWVudF9saW5lKFxuICAgICAgY29sb3IgPSBcIiMwMDAwMDBcIiwgc2l6ZSA9IGxpbmVUaGljayAqIG1tVG9MaW5lVW5pdCwgbGluZWVuZCA9IFwic3F1YXJlXCJcbiAgICApLFxuICAgIHBhbmVsLmJhY2tncm91bmQgPSBlbGVtZW50X3JlY3QoZmlsbCA9IFwidHJhbnNwYXJlbnRcIiksXG4gICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoZmFtaWx5ID0gZm9udFR5cGUsIHNpemUgPSBmb250U2l6ZVMpLFxuICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChmYW1pbHkgPSBmb250VHlwZSwgc2l6ZSA9IGZvbnRTaXplUylcbiAgKSArXG4gIHNjYWxlX2ZpbGxfbWFudWFsKHZhbHVlcyA9IGdyYWRpZW50X2NvbG9ycywgXG4gICAgICAgICAgICAgICAgICAgIGd1aWRlID0gZ3VpZGVfbGVnZW5kKFxuICAgICAgb3ZlcnJpZGUuYWVzID0gbGlzdChzaXplID0gMC41KSwgIyBBZGp1c3QgbGVnZW5kIGtleSBzeW1ib2wgc2l6ZVxuICAgICAga2V5d2lkdGggPSAyIC8gMi41NCwgIyBDb252ZXJ0IDJtbSB0byBjbVxuICAgICAga2V5aGVpZ2h0ID0gMiAvIDIuNTQgIyBDb252ZXJ0IDJtbSB0byBjbVxuICAgICkpIFxuXG53aWR0aCA8LSBwYW5lbFNpemUoMS43KSptbVRvSW5jaFxuaGVpZ2h0IDwtIHBhbmVsU2l6ZSgxLjMpKm1tVG9JbmNoXG5maWxlTmFtZSA8LSBwYXN0ZTAoXCJyYWQyMXBlcmNfZW5oXCIpXG5zdmdsaXRlKGhlcmUoZmlnRGlyLCBwYXN0ZTAoZmlsZU5hbWUsIFwiLnN2Z1wiKSksICBoZWlnaHQgPSBoZWlnaHQsIHdpZHRoID0gd2lkdGgpXG5wcmludChwKVxuZGV2Lm9mZigpICBcblxuYGBgIn0= -->

```r

peak.RAD21 <- importPeak(here(refDir, "33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed"))
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene


##########################################################
name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = 0.2,
                                      annoList = c("P-E"))

temp1 <- geneAnnoData %>% dplyr::filter(A1 == "E") %>% dplyr::select(chrom1, start1, end1, gene)
colnames(temp1) <- c("chr", "start", "end", "gene")
temp2 <- geneAnnoData %>% dplyr::filter(A2 == "E") %>% dplyr::select(chrom2, start2, end2, gene)
colnames(temp2) <- c("chr", "start", "end", "gene")

enhAnchors <- bind_rows(temp1, temp2) %>% unnest(gene) %>%
  dplyr::mutate(
    group = case_when(
      gene %in% group1 ~ "Grp1",
      gene %in% group2 ~ "Grp2",
      TRUE ~ NA
    )
  ) %>% dplyr::filter(!is.na(group))

enh <- makeGRangesFromDataFrame(enhAnchors %>% dplyr::select(c(1, 2, 3)))

# Count overlaps between peaks and genes
overlap_counts <- countOverlaps(enh, peak.RAD21)

# Add overlap counts to the original gene.tb data
enhAnchors$peak_count <- overlap_counts

enhAnchors <- enhAnchors %>% dplyr::mutate(
  peakGroup = case_when(
    peak_count == 0 ~ "peakNum0",
    peak_count == 1 ~ "peakNum1",
    peak_count == 2 ~ "peakNum2",
    peak_count == 3 ~ "peakNum3",
    peak_count >= 4 ~ "peakNumOver4"
  )
)

aaa <- enhAnchors %>% 
  dplyr::select(group, peakGroup, gene) %>%
  dplyr::mutate(hasPeak = ifelse(peakGroup == "peakNum0", FALSE, TRUE))

bbb <- aaa %>% dplyr::filter(group == "Grp1") 
sum(bbb$hasPeak)/nrow(bbb)
bbb <- aaa %>% dplyr::filter(group == "Grp2") 
sum(bbb$hasPeak)/nrow(bbb)


aaa_summary <- aaa %>%
  group_by(group, peakGroup) %>%
  summarize(count = n(), .groups = "drop")

# Create the stacked barplot
aaa_summary <- aaa %>%
  group_by(group, peakGroup) %>%
  summarize(count = n(), .groups = "drop") %>%
  group_by(group) %>%
  mutate(ratio = count / sum(count))

# Define the gradient colors
# gradient_colors <- c("#D4D4D4", "#DCB0AF", "#E48D8A", "#EC6965", "#F44641")
gradient_colors <- c("#D4D4D4", "#A2BBCA", "#71A2C0", "#3F89B7", "#0E71AD")

# Create the stacked barplot with gradient colors
p <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = peakGroup)) +
  geom_bar(stat = "identity", position = "stack",
           linewidth = lineMedium * mmToLineUnit, lineend = "square") +
  theme_classic() + labs(x = NULL , y = "Ratio") +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +
  scale_fill_manual(values = gradient_colors, 
                    guide = guide_legend(
      override.aes = list(size = 0.5), # Adjust legend key symbol size
      keywidth = 2 / 2.54, # Convert 2mm to cm
      keyheight = 2 / 2.54 # Convert 2mm to cm
    )) 

width <- panelSize(1.7)*mmToInch
height <- panelSize(1.3)*mmToInch
fileName <- paste0("rad21perc_enh")
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()  

NOT CONCLUSIVE BELOW HERE


data <- fread(here(resultDir, "chromHMM", "A485_pe-pe_anchors", "overlap_enrich_100_state.txt"))
colnames(data) <- c("state", "genome", "pe-pe_A485_down", "pe-pe_A485_no", "pe-pe_A485_up")
data <- data %>% dplyr::select(-genome) %>% as.matrix()

  column_to_rownames(var = "state") %>%
  as.matrix()

library(circlize)

col_fun <- colorRamp2(c(0, 1, 10), 
                      c("blue", "white", "red"))

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c("white", "red"))


#fviz_nbclust(data, kmeans, method = "wss")

p <- Heatmap(
  data,
  name = "Odds Ratio",                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 10,                         # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)

fileName <- paste0("anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_regAnchorBackground_atac")
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

---
title: "R Notebook"
output: html_notebook
---
# LOADING REQUIREMENTS
## PACKAGES
```{r message=FALSE, warning=FALSE, include=FALSE}
# LIST OF PACKAGES
pkgs = c("tidyverse", "here", "svglite", "ggplot2", "ggrepel",
         "stringr", "BiocManager", "RColorBrewer", "viridis", "magick",
         "nlme", "factoextra", "devtools", "beepr", "remotes",
         "cowplot", "data.table", "strawr", "rtracklayer", "utils",
         "reshape2", "VennDiagram","gridExtra", "eulerr", "scales",
         "InteractionSet", "gplots", "locfdr", "future", "ggbeeswarm", "glossary", "ComplexUpset", "ggnewscale")
bio_pkgs = c("biomaRt", "DESeq2", "ComplexHeatmap", "apeglm", "vsn",
             "rhdf5", "InteractionSet", "plotgardener", "HiCDCPlus",
             "GenomicInteractions", "LOLA", "AnnotationHub",
             "org.Mm.eg.db", "enrichplot", "DOSE", "clusterProfiler",
             "HiCExperiment", "HiCool", "HiContacts", "HiContactsData", "fourDNData", "DNAZooData",
             "MotifDb", "Biostrings")

# INSTALL PACKAGES
# install.packages(pkgs)
# BiocManager::install(bio_pkgs)

# INSTALL HiC related packages
# remotes::install_github("robinweide/GENOVA")
# devtools::install_github("thomasp85/scico")
# devtools::install_github("psyteachr/introdataviz")

# LOAD PACKAGES
lapply(pkgs, require, character.only = TRUE)
lapply(bio_pkgs, require, character.only = TRUE)
require(GENOVA)
require(scico)
require(introdataviz)

# CLEANING
rm(pkgs, bio_pkgs)

options(scipen=999)



```
## ENSEMBL
```{r}
# ENSEMBL DATABASE
# v102 is for the latest mm10 version
# ensembl.v102 <- useMart(host = "https://nov2020.archive.ensembl.org",
#                        biomart = "ENSEMBL_MART_ENSEMBL",
#                        dataset = "mmusculus_gene_ensembl")
```
## COLOR PALETTE
```{r}
palette_1 = list(red = "#E9002D",
                 amber = "#FFAA00",
                 green = "#00B000")
palette_2 = list(red = "#FF1F5B",
                 green = "#00CD6C",
                 blue = "#009ADE",
                 purple = "#AF58BA",
                 yellow = "#FFC61E",
                 orange = "#F28522",
                 grey = "#A0B1BA",
                 brown = "#A6761D")
palette_3 = list(grey1 = "#a0b1ba",
                 grey2 = "#c5d0d5",
                 grey3 = "#eceff1")

colorListLoop <-  c(palette_3[["grey3"]], palette_3[["grey2"]], palette_3[["grey1"]],
                     "#C5E1EF", "#6CB0D6", "#226E9C",
                     "#06592A", 
                     "#FED976", "#FD8D3C", "#E31A1C")
colorListPromoter <- c(palette_3[["grey3"]],"#E88587", "#E31A1C")
colorListEnhancer <- c(palette_3[["grey3"]],"#87AFC7", "#226E9C")
colorListStructure <- c(palette_3[["grey3"]], palette_3[["grey2"]], palette_3[["grey1"]])
```

## DIR LIST
```{r}
refDir <- here("reference")
```
## FIGURE PARAMETERS
```{r}
library(colorspace)

fontType <- "Helvetica"

fontSizeL <- 10 # pt
fontSizeM <- 8
fontSizeS <- 6

lineThick <- 0.75 # pt
lineMedium <- 0.5
lineThin <- 0.25

panelUnit <- 30 # mm
panelMargin <- 1.5

mmToInch <- 0.03937007874
mmToLineUnit <- 1/2.13
mmToLinePlotgarden <- 1/0.75
ptToMM <- 1/2.845


strong_red <- "#CB333A"
strong_blue <- "#4851A0"
weak_red <- lighten(strong_red, amount = 0.4)   # FF7D81
weak_blue <- lighten(strong_blue, amount = 0.4) # 8A91DD
no_grey <- "#A8A8A8"

strong_teel <- "#0892A5"
strong_green <- "#23CE6B" # A485
strong_darkgreen <- "#054A29"
strong_yellow <- "#FFBA49"
strong_orange <- "#F18F01" # dTAG
strong_lightpurple <- "#BD93D8"
strong_purple <- "#9E33CB" # Epi

panelSize <- function(num, unit = panelUnit, margin = panelMargin){
  return(num*unit - 2*margin)
}

```
## FUNCTIONS
```{r}
importBedpe = function(bedpe){
  a1 = makeGRangesFromDataFrame(data.frame(
    chr = bedpe$V1,
    start = bedpe$V2 +1,
    end = bedpe$V3))
  a2 = makeGRangesFromDataFrame(data.frame(
    chr = bedpe$V4,
    start = bedpe$V5 +1,
    end = bedpe$V6))
  GInteractions(a1, a2)
}

get_density <- function(x, y, ...) {
  dens <- MASS::kde2d(x, y, ...)
  ix <- findInterval(x, dens$x)
  iy <- findInterval(y, dens$y)
  ii <- cbind(ix, iy)
  return(dens$z[ii])
}
label_kb_mb <- function(x) {
  ifelse(x >= 1000000, paste0(x / 1000000, "Mb"), paste0(x / 1000, "kb"))
}

importPeak = function(fileName){
  df = fread(fileName)
  gr = makeGRangesFromDataFrame(data.frame(
    chr = df$V1, start = df$V2, end = df$V3
  ))
}
```

# PREPROCESSING
## Adding +ooe +geneAnno
Loop should be dropped from specific comparison if ooe in any of the condition are NA
If ooe is 0, fixed pseudo value of 0.01 will be used.
log2(ooe) should be plotted in range (-5, 8) if plotted in scatterplot
### Common stuffs
```{r}
# Parameters
commonLoopDir <- here("../data/loop_analysis")

# Defining gene neighborhood
flankSize <- 2500
gene.TSS.tb <- fread(here(refDir, "mm10", "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)
colnames(gene.TSS.tb) <- c("chr", "start", "end", "strand", "gene", "ensembl")
fwrite(gene.TSS.tb, here(refDir, "mm10", "mm10_GRCm38.p6_TSS2.5kb.bed"), sep = "\t", col.names = FALSE, row.names = FALSE)

# Functions for calculating gene overlap
findOverlapGene <- function(gene.TSS.tb, chrom1, start1, end1){
  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%
    dplyr::filter((start <= end1) & (end >= start1))
  return(temp$gene)
}
findOverlapEnsembl <- function(gene.TSS.tb, chrom1, start1, end1){
  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%
    dplyr::filter((start <= end1) & (end >= start1))
  return(temp$ensembl)
}
```
### Preparing 
#### [1] Chromosight
```{r}
################################################################################
# Import annotated postprocessed loops with chromosight score
loopDir <- here("../data/loop_chromosight")
data <- as_tibble(fread(here(loopDir, "chromo_union_allRes_postprocessed_annotated.tsv")))

################################################################################
# Integrate chromosight score from asynchronous experiment
resolutions  <- c(25000, 10000, 5000)

# helper: read, filter, select and rename for one experiment
annotate_scores <- function(experiment, suffix) {
  map_dfr(resolutions, function(res) {
    fread(here(loopDir,
               sprintf("GSE178982_%s_pooled_union_%dbp_pu100pz100.tsv",
                       experiment, res))
    ) %>%
      mutate(id = paste(chrom1, start1, end1, chrom2, start2, end2, sep = "_")) %>%
      filter(start2 - start1 <= 2e6) %>%
      select(id, score, pvalue, qvalue) %>%
      rename_with(~ paste0(., "_", suffix),
                  c(score, pvalue, qvalue))
  })
}

data <- data %>%
  left_join(annotate_scores("AsyncUT", "UT"), by = "id")
data <- data %>%
  left_join(annotate_scores("AsyncAID", "AID"), by = "id")
data <- data %>%
  relocate(score_UT:qvalue_AID, .after = qvalue_EpidTAG)
data <- data %>% dplyr::select(-seq(29, 41))
data <- data %>% relocate(A1:Anno_simple, .after = id)

################################################################################
# Adding obs/exp
import_obsexp <- function(experiment, suffix) {
  map_dfr(resolutions, function(res) {
    fread(here(loopDir,
               sprintf("chromo_union_allRes_postprocessed_%dbp_obxexp_%s_pooled.tsv",
                       res, experiment))
    ) %>%
      mutate(id = paste(chrom1, start1, end1, chrom2, start2, end2, sep = "_")) %>%
      select(id, ooe) %>%
      rename_with(~ paste0(., "_", suffix),
                  c(ooe))
  })
}

data <- data %>%
  left_join(import_obsexp("G1DMSO", "DMSO"), by = "id")
data <- data %>%
  left_join(import_obsexp("G1dTAG", "dTAG"), by = "id")
data <- data %>%
  left_join(import_obsexp("G1A485", "A485"), by = "id")
data <- data %>%
  left_join(import_obsexp("EpiG1DMSO", "EpiDMSO"), by = "id")
data <- data %>%
  left_join(import_obsexp("EpiG1dTAG", "EpidTAG"), by = "id")
data <- data %>%
  left_join(import_obsexp("GSE178982_AsyncUT", "UT"), by = "id")
data <- data %>%
  left_join(import_obsexp("GSE178982_AsyncAID", "AID"), by = "id")

fwrite(data, here(commonLoopDir, "loopScore_chromosight.tsv"),
       sep = "\t", col.names = TRUE)

################################################################################
# Annotate genes for p-n loops
name <- "chromosight"
gene.TSS.tb <- fread(here(refDir, "mm10", "mm10_GRCm38.p6_TSS2.5kb.bed"))
colnames(gene.TSS.tb) <- c("chr", "start", "end", "strand", "gene", "ensembl")

# Simple annotation
temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1_simple == "P",
                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2_simple == "P",
                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno_simple %in% c("P-P", "P-E", "P-S", "P-X")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_geneList.tsv")), sep = "\t")

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1_simple == "P",
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2_simple == "P",
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno_simple %in% c("P-P", "P-E", "P-S", "P-X")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_ensemblList.tsv")), sep = "\t")

# complex annotation
temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 %in% c("P", "SP"),
                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 %in% c("P", "SP"),
                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(str_detect(Anno, "P")) %>%
  dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_geneList.tsv")), sep = "\t")

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 %in% c("P", "SP"),
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 %in% c("P", "SP"),
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(str_detect(Anno, "P")) %>%
  dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_ensemblList.tsv")), sep = "\t")

```

#### [2] hicdcp
```{r}
################################################################################
loopDir <- here("../data/loop_hicdcp")

################################################################################
# Import annotated postprocessed loops with chromosight score
data <- as_tibble(fread(here(loopDir, "hicdcp_union_10000bp_annotated.tsv"))) %>%
  mutate(id = paste(chrom1, start1, end1, chrom2, start2, end2, sep = "_")) %>%
  relocate(id, .after = end2) %>%
  dplyr::select(-c("anchor_id_1", "anchor_id_2"))

resolutions  <- c(10000)

# Adding obs/exp
import_obsexp <- function(experiment, suffix) {
  map_dfr(resolutions, function(res) {
    fread(here(loopDir,
               sprintf("hicdcp_union_%dbp_obxexp_%s_pooled.tsv",
                       res, experiment))
    ) %>%
      mutate(id = paste(chrom1, start1, end1, chrom2, start2, end2, sep = "_")) %>%
      select(id, ooe) %>%
      rename_with(~ paste0(., "_", suffix),
                  c(ooe))
  })
}

data <- data %>%
  left_join(import_obsexp("G1DMSO", "DMSO"), by = "id")
data <- data %>%
  left_join(import_obsexp("G1dTAG", "dTAG"), by = "id")
data <- data %>%
  left_join(import_obsexp("G1A485", "A485"), by = "id")
data <- data %>%
  left_join(import_obsexp("EpiG1DMSO", "EpiDMSO"), by = "id")
data <- data %>%
  left_join(import_obsexp("EpiG1dTAG", "EpidTAG"), by = "id")
data <- data %>%
  left_join(import_obsexp("GSE178982_AsyncUT", "UT"), by = "id")
data <- data %>%
  left_join(import_obsexp("GSE178982_AsyncAID", "AID"), by = "id")

fwrite(data, here(commonLoopDir, "loopScore_hicdcp.tsv"),
       sep = "\t", col.names = TRUE)

################################################################################
# Annotate genes for p-n loops
name <- "hicdcp"
gene.TSS.tb <- fread(here(refDir, "mm10", "mm10_GRCm38.p6_TSS2.5kb.bed"))
colnames(gene.TSS.tb) <- c("chr", "start", "end", "strand", "gene", "ensembl")


# Simple annotation
temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1_simple == "P",
                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2_simple == "P",
                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno_simple %in% c("P-P", "P-E", "P-S", "P-X")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_geneList.tsv")), sep = "\t")

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1_simple == "P",
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2_simple == "P",
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno_simple %in% c("P-P", "P-E", "P-S", "P-X")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_ensemblList.tsv")), sep = "\t")

# complex annotation
temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 %in% c("P", "SP"),
                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 %in% c("P", "SP"),
                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(str_detect(Anno, "P")) %>%
  dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_geneList.tsv")), sep = "\t")

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 %in% c("P", "SP"),
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 %in% c("P", "SP"),
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(str_detect(Anno, "P")) %>%
  dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_ensemblList.tsv")), sep = "\t")


```
#### [3] Hansen
Loops with 
```{r}
################################################################################
loopDir <- here("../data/loop_Hansen")

################################################################################
# Import annotated postprocessed loops with chromosight score
data <- as_tibble(fread(here(loopDir, "Hansen_union_allRes_postprocessed_annotated.tsv"))) %>%
  mutate(id = paste(chrom1, start1, end1, chrom2, start2, end2, sep = "_")) %>%
  relocate(id, .after = end2) %>%
  dplyr::select(-c("anchor_id_1", "anchor_id_2"))

resolutions  <- c(5000, 2000, 1000)

# Adding obs/exp
import_obsexp <- function(experiment, suffix) {
  map_dfr(resolutions, function(res) {
    fread(here(loopDir,
               sprintf("Hansen_union_allRes_postprocessed_%dbp_obxexp_%s_pooled.tsv",
                       res, experiment))
    ) %>%
      mutate(id = paste(chrom1, start1, end1, chrom2, start2, end2, sep = "_")) %>%
      select(id, ooe) %>%
      rename_with(~ paste0(., "_", suffix),
                  c(ooe))
  })
}

data <- data %>%
  left_join(import_obsexp("G1DMSO", "DMSO") %>% distinct(), by = "id")
data <- data %>%
  left_join(import_obsexp("G1dTAG", "dTAG") %>% distinct(), by = "id")
data <- data %>%
  left_join(import_obsexp("G1A485", "A485") %>% distinct(), by = "id")
data <- data %>%
  left_join(import_obsexp("EpiG1DMSO", "EpiDMSO") %>% distinct(), by = "id")
data <- data %>%
  left_join(import_obsexp("EpiG1dTAG", "EpidTAG") %>% distinct(), by = "id")
data <- data %>%
  left_join(import_obsexp("GSE178982_AsyncUT", "UT") %>% distinct(), by = "id")
data <- data %>%
  left_join(import_obsexp("GSE178982_AsyncAID", "AID") %>% distinct(), by = "id")

data <- data %>% 
  filter(
    !if_all(starts_with("ooe"), ~ .x == 0)   # drop rows where every ooe value is 0 or NA
  )

fwrite(data, here(commonLoopDir, "loopScore_Hansen.tsv"),
       sep = "\t", col.names = TRUE)

################################################################################
# Annotate genes for p-n loops
name <- "Hansen"
gene.TSS.tb <- fread(here(refDir, "mm10", "mm10_GRCm38.p6_TSS2.5kb.bed"))
colnames(gene.TSS.tb) <- c("chr", "start", "end", "strand", "gene", "ensembl")


# Simple annotation
temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1_simple == "P",
                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2_simple == "P",
                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno_simple %in% c("P-P", "P-E", "P-S", "P-X")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_geneList.tsv")), sep = "\t")

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1_simple == "P",
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2_simple == "P",
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno_simple %in% c("P-P", "P-E", "P-S", "P-X")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_ensemblList.tsv")), sep = "\t")

# complex annotation
temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 %in% c("P", "SP"),
                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 %in% c("P", "SP"),
                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(str_detect(Anno, "P")) %>%
  dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_geneList.tsv")), sep = "\t")

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 %in% c("P", "SP"),
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 %in% c("P", "SP"),
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(str_detect(Anno, "P")) %>%
  dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_ensemblList.tsv")), sep = "\t")

```

# ANALYSIS
## [1] Comparing loops
### Common stuffs
```{r}
# Parameters
commonLoopDir <- here("../data/loop_analysis")
pseudoOoe <- 0.01

figDir <- here("../figure/loop_analysis")

```
### Import loops
```{r}
loop_chromo <- as_tibble(fread(here(commonLoopDir, "loopScore_chromosight.tsv")))
loop_hicdcp <- as_tibble(fread(here(commonLoopDir, "loopScore_hicdcp.tsv")))
loop_Hansen <- as_tibble(fread(here(commonLoopDir, "loopScore_Hansen.tsv")))
loop_Tjian_chromo <- as_tibble(fread(here(commonLoopDir, "../loop_Tjian/TjianChromo_union_allRes.bedpe"))) %>%
  dplyr::filter(abs(V5-V2) <= 2000000)
colnames(loop_Tjian_chromo) <- c("chrom1", "start1", "end1", "chrom2", "start2", "end2")
loop_Tjian_mustache <- as_tibble(fread(here(commonLoopDir, "../loop_Tjian/TjianMustache_union_allRes.bedpe"))) %>%
  dplyr::filter(abs(V5-V2) <= 2000000)
colnames(loop_Tjian_mustache) <- c("chrom1", "start1", "end1", "chrom2", "start2", "end2")

```
### [FIG] Offset plot
#### Function
```{r}
# helper that only uses the two anchors
make_gi <- function(df) {
  a1 <- GRanges(df$chrom1, IRanges(df$start1, df$end1))
  a2 <- GRanges(df$chrom2, IRanges(df$start2, df$end2))
  GInteractions(a1, a2)
}

# Expand each anchor to 10 kb for comparison
expand_anchor <- function(gi) {
  a1 <- anchors(gi, "first")
  a2 <- anchors(gi, "second")
  a1r <- resize(a1, width = pmax(width(a1), expandSize), fix = "center")
  a2r <- resize(a2, width = pmax(width(a2), expandSize), fix = "center")
  GInteractions(a1r, a2r)
}
```
#### HiCDC+, Hansen
```{r}
for(expandSize in c(5000, 10000, 25000)){
  gi1 <- expand_anchor(make_gi(loop_chromo))
  gi2 <- expand_anchor(make_gi(loop_hicdcp))
  gi3 <- expand_anchor(make_gi(loop_Hansen))
  
  gi_all <- c(gi1, gi2, gi3)
  
  # 4) determine membership via Chebyshev distance = 1 bin(10 kb)
  in1 <- overlapsAny(gi_all, gi1,    maxgap=expandSize, type="equal")
  in2 <- overlapsAny(gi_all, gi2,    maxgap=expandSize, type="equal")
  in3 <- overlapsAny(gi_all, gi3,    maxgap=expandSize, type="equal")
  
  membership_df <- tibble(
    loop = seq_along(gi_all),
    set1 = in1,
    set2 = in2,
    set3 = in3
  )
  
  membership_df <- membership_df %>%
    rename(
      Chromosight     = set1,
      HiCDCP     = set2,
      Hansen = set3
    )
  
  # 5) UpSet plot of all combinations
  p <- upset(
    membership_df,
    intersect = c("Chromosight","HiCDCP","Hansen"),
    name = "",
    base_annotations = list(
      'Loop #' = intersection_size()
    )
  ) + ggtitle(paste0(expandSize, "bp expanded, 1 Chebychev dist"))
  
  
  fileName <- here(figDir, paste0("offSet_", expandSize, "bp_expanded"))
  width <- panelSize(5.5)*mmToInch
  height <- panelSize(3)*mmToInch
  svglite(paste0(fileName, ".svg"), width = width, height = height)
  print(p)
  dev.off()
}
```
#### Tjian
```{r}
for(expandSize in c(5000, 10000, 25000)){
  gi1 <- expand_anchor(make_gi(loop_chromo))
  gi2 <- expand_anchor(make_gi(loop_Tjian_chromo))
  gi3 <- expand_anchor(make_gi(loop_Tjian_mustache))
  
  gi_all <- c(gi1, gi2, gi3)
  
  # 4) determine membership via Chebyshev distance = 1 bin(10 kb)
  in1 <- overlapsAny(gi_all, gi1,    maxgap=expandSize, type="equal")
  in2 <- overlapsAny(gi_all, gi2,    maxgap=expandSize, type="equal")
  in3 <- overlapsAny(gi_all, gi3,    maxgap=expandSize, type="equal")
  
  membership_df <- tibble(
    loop = seq_along(gi_all),
    set1 = in1,
    set2 = in2,
    set3 = in3
  )
  
  membership_df <- membership_df %>%
    rename(
      Lee_chromo     = set1,
      Tjian_chromo     = set2,
      Tjian_mustache = set3
    )
  
  # 5) UpSet plot of all combinations
  p <- upset(
    membership_df,
    intersect = c("Lee_chromo","Tjian_chromo","Tjian_mustache"),
    name = "",
    base_annotations = list(
      'Loop #' = intersection_size()
    )
  ) + ggtitle(paste0(expandSize, "bp expanded, 1 Chebychev dist"))
  
  
  fileName <- here(figDir, paste0("offSet2_", expandSize, "bp_expanded"))
  width <- panelSize(5.5)*mmToInch
  height <- panelSize(3)*mmToInch
  svglite(paste0(fileName, ".svg"), width = width, height = height)
  print(p)
  dev.off()
}
```
## [2] Visualizing loop annotation
### [FIG] Loop Anno pie chart
```{r}

draw_donut <- function(loop, name){
  n <- nrow(loop)
  temp <- loop %>% dplyr::select(id, Anno) %>%
    dplyr::mutate(AnnoGroup = case_when(
      Anno %in% c("P-P", "P-E", "E-E") ~ "reg_reg",
      Anno %in% c("P-SP", "P-SE", "E-SP", "E-SE") ~ "reg_strReg",
      Anno %in% c("P-S", "E-S") ~ "reg_str",
      Anno %in% c("SP-SP", "SP-SE", "SE-SE") ~ "strReg_strReg",
      Anno %in% c("SP-S", "SE-S") ~ "strReg_str",
      Anno %in% c("P-X", "E-X") ~ "reg_other",
      Anno %in% c("SP-X", "SE-X") ~ "strReg_other",
      Anno %in% c("S-S", "S-X") ~ "str",
      Anno %in% c("X-X") ~ "other",
      TRUE ~ NA
    ))
  
  
  temp$AnnoGroup <- factor(temp$AnnoGroup, levels = c("reg_reg",
                                                      "reg_strReg", "reg_str",
                                                      "strReg_strReg", "strReg_str",
                                                      "reg_other", "strReg_other", 
                                                      "str", "other"))
  
  
  pie_df <- temp %>%
    as_tibble() %>%                          # if temp was a list, this will error early
    group_by(AnnoGroup) %>%
    summarise(n = n(), .groups = "drop") %>%
    mutate(label = paste0(AnnoGroup, "\n(", n, ")"))
  
  p <- ggplot(pie_df, aes(x = 2, y = n, fill = AnnoGroup)) +
    geom_col(color = "black", width = 1) +
    coord_polar(theta = "y") +
    xlim(0.5, 2.5) +                # <- creates the “hole” by clipping the center
    geom_text(aes(label = label),
              position = position_stack(vjust = 0.5),
              size = 3) +
    theme_void() +
    theme(legend.position = "none",
          plot.title = element_text(hjust = 0.5)
    ) +
    ggtitle(paste0(name, "\n", n, " loops"))
  
  
  width = 3
  height = 3
  svglite(here(figDir,
               paste0("donut_loopAnno_", name, ".svg")),
          width = width, height = height)
  plot(p)
  dev.off()
}

draw_donut(loop_chromo, "chromosight")
draw_donut(loop_hicdcp, "hicdcp")
draw_donut(loop_Hansen, "Hansen")

```
## [3] Loop analysis
### Chromosight
#### [FIG] Scatterplot
```{r}
plot_loop_scores_and_save_bedpe <- function(df, col_x, col_y, 
                                            col_x_ooe, col_y_ooe, pseudo_ooe = 0.01,
                                            annoList,
                                            name, title, figDir, loopDir,
                                            diffCutoff = 0.2, density_n = 200,
                                            xmin = -0.5, xmax = 1,
                                            ymin = -0.5, ymax = 1, anno_col = "Anno_simple") {
  col_x_q <- enquo(col_x)
  col_y_q <- enquo(col_y)
  
  col_x_ooe_q <- enquo(col_x_ooe)
  col_y_ooe_q <- enquo(col_y_ooe)
  
  anno_col_sym <- sym(anno_col)
  
  
  # Create a single, unified dataframe for plotting and saving as bedpe
  df_temp <- df %>%
    dplyr::filter(!!anno_col_sym %in% annoList) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, x = !!col_x_q, y = !!col_y_q,
                  x_ooe = !!col_x_ooe_q, y_ooe = !!col_y_ooe_q) %>%
    dplyr::mutate(diff = y-x,
                  density = get_density(x, y, n = density_n)) %>%
    dplyr::mutate(updown = case_when(
      diff > diffCutoff  ~ "UP",
      diff < -diffCutoff ~ "DOWN",
      TRUE               ~ "NO"))
  
  # Export as bedpe
  bedpeUP <- df_temp %>% dplyr::filter(updown == "UP") %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)
  fwrite(bedpeUP, here(loopDir, paste0(name, "_diffCutoff", diffCutoff, "_UP.bedpe")), sep = "\t", col.names = FALSE)
  bedpeNO <- df_temp %>% dplyr::filter(updown == "NO") %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)
  fwrite(bedpeNO, here(loopDir, paste0(name, "_diffCutoff", diffCutoff, "_NO.bedpe")), sep = "\t", col.names = FALSE)
  bedpeDOWN <- df_temp %>% dplyr::filter(updown == "DOWN") %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2)
  fwrite(bedpeDOWN, here(loopDir, paste0(name, "_diffCutoff", diffCutoff, "_DOWN.bedpe")), sep = "\t", col.names = FALSE)
  
  
  plot_df <- df_temp %>%
    dplyr::select(id, x, y, updown, density) %>%
    arrange(density)
  
  plot_df$updown <- factor(plot_df$updown, c("UP", "NO", "DOWN"))
  
  # Calculate a global density range to make scales comparable
  density_limits <- range(plot_df$density, na.rm = TRUE)
  
  # ------ Scatterplot ------ 
  p1 <- ggplot(plot_df, aes(x = x, y = y)) +
    # Layer 1: Plot "NO" points with a grey scale
    geom_point(data = . %>% filter(updown == "NO") %>% arrange(density),
               aes(color = density), size = 0.1) +
    scale_color_gradient(
      low = "grey85", high = "grey30",
      limits = density_limits, name = "Density (NO)"
    ) +
    
    # Introduce a new scale for the "UP" points
    new_scale_color() +
    # Layer 2: Plot "UP" points with a red scale
    geom_point(data = . %>% filter(updown == "UP") %>% arrange(density),
               aes(color = density), size = 0.1) +
    scale_color_gradient(
      low = weak_red, high = strong_red, # Light to dark red
      limits = density_limits, name = "Density (UP)"
    ) +
    
    # Introduce a new scale for the "DOWN" points
    new_scale_color() +
    # Layer 3: Plot "DOWN" points with a blue scale
    geom_point(data = . %>% filter(updown == "DOWN") %>% arrange(density),
               aes(color = density), size = 0.1) +
    scale_color_gradient(
      low = weak_blue, high = strong_blue, # Light to dark blue
      limits = density_limits, name = "Density (DOWN)"
    ) +
    
    # Add annotations and theme elements
    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
    geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    geom_hline(yintercept = 0, alpha = 0.5, color = "grey",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    geom_vline(xintercept = 0, alpha = 0.5, color = "grey",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    theme_classic() +
    theme(
      legend.position = "none",
      plot.title = element_text(
        hjust = 0.5,
        size = fontSizeS,
        family = fontType
      ),
      axis.title = element_text(
        size = fontSizeS,
        family = fontType,
        color = "#000000"
      ),
      axis.text = element_text(
        size = fontSizeS,
        family = fontType,
        color = "#000000"
      ),
      axis.line = element_line(
        color = "#000000",
        size = lineThick*mmToLineUnit,
        lineend = "square"
      ),
      axis.ticks = element_line(
        color = "#000000",
        size = lineThick*mmToLineUnit,
        lineend = "square"
      ),
      panel.background = element_rect(fill = "transparent"),
    ) +
    labs(x = quo_name(col_x_q), y = quo_name(col_y_q)) +
    ggtitle(title)
  
  width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.5)*mmToInch  
  
  fileName <- paste0("scatterplot_", name)
  svglite(here(figDir, paste0(fileName, ".svg")), 
          width = width, height = height)
  print(p1)
  dev.off()
  
  png(here(figDir, paste0(fileName, ".png")), 
      width = width, height = height, units = "in", res = 600)
  print(p1)
  dev.off()
  
  # ------ Pie chart ------ 
  pie_df <- plot_df %>%
    dplyr::count(updown) %>%
    mutate(
      pct   = n / sum(n) * 100,
      label = paste0(updown, "\n", n, "\n(", round(pct, 1), "%)")
    )
  
  p2 <- ggplot(pie_df, aes(x = "", y = n, fill = updown)) +
    geom_col(color = "white") +
    coord_polar(theta = "y") +
    geom_text(
      aes(label = label),
      position = position_stack(vjust = 0.5),
      size     = fontSizeM / 2
    ) +
    theme_void() + theme(legend.position = "none") +
    scale_fill_manual(values = c("UP" = strong_red, "NO" = no_grey, "DOWN" = strong_blue))
  
  fileName <- here(figDir, paste0("piechart_", name))
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  svglite(paste0(fileName, ".svg"), width = width, height = height)
  print(p2)
  dev.off()
  
  
  # ------ Violin plot of ooe ------ 
  plot_df_ooe <- df_temp %>%
    dplyr::select(id, x_ooe, y_ooe, updown) %>%
    dplyr::filter(!is.na(x_ooe), !is.na(y_ooe)) %>%
    dplyr::mutate(
      x_ooe = if_else(x_ooe == 0, pseudo_ooe, x_ooe),
      y_ooe = if_else(y_ooe == 0, pseudo_ooe, y_ooe),
      fc    = log2(y_ooe / x_ooe)
    )
  
  plot_df_ooe$updown <- factor(plot_df_ooe$updown, levels = c("UP", "NO", "DOWN"))
  
  p3 <- ggplot(plot_df_ooe, aes(x = updown, y = fc, fill = updown)) +
    geom_violin(linewidth = lineThick * mmToLineUnit, lineend = "square", alpha = .4, show.legend = FALSE) + 
    geom_boxplot(width = 0.3, color = "black",
                 linewidth = lineThick * mmToLineUnit, lineend = "square",
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
    theme_classic() + 
    stat_summary(
      aes(group = updown), fun = mean,
      geom = "point", shape = 21, size = 0.5,
      fill = "black", color = "black", position = position_dodge(.3)
    ) +
    coord_cartesian(ylim = c(-3, 3)) +
    scale_fill_manual(values = c(strong_red, "grey30", strong_blue)) +
    theme(
      axis.title.x = element_blank(),
      axis.title.y = element_text(
        size = fontSizeM,
        family = fontType,
        color = "#000000"
      ),
      axis.text = element_text(
        size = fontSizeS,
        family = fontType,
        color = "#000000"
      ),
      axis.text.x = element_text(
        size = fontSizeM,
        angle = 45,      # Rotate x-axis labels 45 degrees
        hjust = 1,       # Adjust horizontal justification
        vjust = 1        # Adjust vertical justification
      ),
      axis.line = element_line(
        color = "#000000",
        size = lineThick*mmToLineUnit,
        lineend = "square"
      ),
      axis.ticks = element_line(
        color = "#000000",
        size = lineThick*mmToLineUnit,
        lineend = "square"
      ),
      panel.background = element_rect(fill = "transparent"),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    ) +labs(y = "log2 fc of obs/exp")  +
    geom_hline(yintercept = 0,
               alpha = 1,
               color = "black",
               size = lineThick*mmToLineUnit,
               lineend = "square") +
    geom_hline(yintercept = c(-0.5, 0.5),
               alpha = 0.5,
               color = "black",
               size = lineThick*mmToLineUnit,
               lineend = "square", linetype = "dashed")
   
  
  width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.5)*mmToInch
  fileName <- paste0("violin_", name)
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p3)
  dev.off()  
}


commonLoopDir <- here("../data/loop_analysis")
figDir <- here("../figure/loop_analysis")
dir.create(figDir, showWarnings = FALSE, recursive = TRUE)

data <- fread(here(commonLoopDir, "loopScore_chromosight.tsv"))
plot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, 
                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,
                                c("P-P", "P-E", "P-S", "P-X",
                                  "E-E", "E-S", "E-X",
                                  "S-S", "S-X",
                                  "X-X"),
                                name = "chromosight_score_all_dTAGvsDMSO",
                                title = "chromo_score_all_dTAGvsDMSO", figDir, commonLoopDir)


plot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, 
                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,
                                c("P-P", "P-E", "E-E"),
                                name = "chromosight_score_complex_reg_dTAGvsDMSO",
                                title = "chromo_score_complex_reg_dTAGvsDMSO", figDir, commonLoopDir,
                                anno_col = "Anno")



plot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, 
                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,
                                c("S-S", "S-X"),
                                name = "chromosight_score_complex_str_dTAGvsDMSO",
                                title = "chromo_score_complex_str_dTAGvsDMSO", figDir, commonLoopDir,
                                anno_col = "Anno")

plot_loop_scores_and_save_bedpe(data, score_DMSO, score_dTAG, 
                                ooe_DMSO, ooe_dTAG, pseudo_ooe = 0.01,
                                c("S-S"),
                                name = "chromosight_score_complex_str2_dTAGvsDMSO",
                                title = "chromo_score_complex_str2__dTAGvsDMSO", figDir, commonLoopDir,
                                anno_col = "Anno")


```
#### [FIG] LOLA on anchor
```{r}
#-------------------------------------------------------------------------------
# LOADING LOLA DB
library("simpleCache")
library("LOLA")
lolaDB = loadRegionDB("/Volumes/UKJIN_SSD/MtoG1_analysis_code/reference/LOLACore_cached/mm10")

# FUNCTIONS
extractAnchor <- function(loop){
  anchor1 <- loop %>% dplyr::select(c(1, 2, 3))
  colnames(anchor1) <- c("chr", "start", "end")
  anchor2 <- loop %>% dplyr::select(c(4, 5, 6))
  colnames(anchor2) <- c("chr", "start", "end")
  anchors <- reduce(makeGRangesFromDataFrame(bind_rows(anchor1, anchor2)))
    return(anchors)
}

atac <- fread(here(refDir, "mm10", "GSM3106257_ATAC_ESC_1.bed")) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c("chr", "start", "end")
atac.gr <- makeGRangesFromDataFrame(atac)
```
##### All loops
```{r}
#-------------------------------------------------------------------------------
# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
commonLoopDir <- here("../data/loop_analysis")
loop.all <- fread(here(commonLoopDir, "loopScore_chromosight.tsv"))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(commonLoopDir, "chromosight_score_all_dTAGvsDMSO_diffCutoff0.2_UP.bedpe"))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(commonLoopDir, "chromosight_score_all_dTAGvsDMSO_diffCutoff0.2_NO.bedpe"))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.upno <- bind_rows(loop.up, loop.no)
anchor.upno <- (extractAnchor(loop.upno))
overlaps <- findOverlaps(anchor.upno, atac.gr)
anchor.upno <- pintersect(anchor.upno[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loopNum <- nrow(loop.upno)

# Selecting same number of extreme down loops
diffCutoff <- 0.2
loop.down <- loop.all %>% dplyr::mutate(diff = score_dTAG - score_DMSO) %>%
  dplyr::filter(diff < -diffCutoff) %>% dplyr::arrange(diff) %>% slice_head(n = loopNum)
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


#-------------------------------------------------------------------------------
# RUNNING LOLA
# UP
lolaDir <- here(commonLoopDir, "LOLA")
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)


name <- "chromosight_score_all_dTAGvsDMSO_diffCutoff0.2"
result <- runLOLA(anchor.up, anchor.all, lolaDB)
tb <- as_tibble(result)
fwrite(tb, here(lolaDir, paste0("LOLA_", name, "UP_ATAC.tsv")), sep = "\t")

# NO
result <- runLOLA(anchor.no, anchor.all, lolaDB)
tb <- as_tibble(result)
fwrite(tb, here(lolaDir, paste0("LOLA_", name, "NO_ATAC.tsv")), sep = "\t")

# UPNO
result <- runLOLA(anchor.upno, anchor.all, lolaDB)
tb <- as_tibble(result)
fwrite(tb, here(lolaDir, paste0("LOLA_", name, "UPNO_ATAC.tsv")), sep = "\t")

# DOWN
result <- runLOLA(anchor.down, anchor.all, lolaDB)
tb <- as_tibble(result)
fwrite(tb, here(lolaDir, paste0("LOLA_", name, "DOWN_ATAC.tsv")), sep = "\t")


### Visualizing p-value and OR
alpha <- 0.05
tb.up <- fread(here(lolaDir, paste0("LOLA_", name, "UP_ATAC.tsv"))) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "UP") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, paste0("LOLA_", name, "NO_ATAC.tsv"))) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "NO") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.upno <- fread(here(lolaDir, paste0("LOLA_", name, "UPNO_ATAC.tsv"))) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = "UP/NO") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

fwrite(tb.upno %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, paste0("LOLA_", name, "UPNO_ATAC_pub.tsv")), sep = "\t")

tb.down <- fread(here(lolaDir, paste0("LOLA_", name, "DOWN_ATAC.tsv"))) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = "DOWN") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.down %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, paste0("LOLA_", name, "DOWN_ATAC__pub.tsv")), sep = "\t")


temp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.upno, temp.down)

order <- c((temp %>% dplyr::filter(group == "UP/NO") %>% arrange(desc(oddsRatio)))$target,
           (temp %>% dplyr::filter(group == "DOWN") %>% arrange(desc(oddsRatio)))$target)

temp$target <- factor(temp$target, levels = rev(order))
temp$group <- factor(temp$group, levels = c("UP/NO", "DOWN"))

targetList <- c("POLR2A", "CTR9",
                "AFF4", "ELL2",
                "MED1", "MED12",
                "TBP", "TAF1", "TAF3",
                "ESRRB", "KLF4", "NANOG", "POU5F1", "SOX2", "STAT3", "E2F1", "YY1",
                "EP300", "DPY30", "RBBP5", "KDM2B", "KDB4B", "KDM4C", "KDM6B", 
                "EZH2", "JARID2", "SUZ12", 
                "RAD21", "SMC1A", "SMC3", "CTCF"
)

temp <- temp %>% dplyr::filter(target %in% targetList)
temp$target <- factor(temp$target, levels = rev(targetList))


qValueLogMax <- 50
temp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))

p <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = "white", high = "#CB333A",
                      limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

figDir <- here("../figure/loop_analysis")

fileName <- paste0("LOLA_", name)
width <- panelSize(1.5)*mmToInch
height <- panelSize(1.9)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### Reg loops
```{r}
#-------------------------------------------------------------------------------
# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
commonLoopDir <- here("../data/loop_analysis")
loop.all <- fread(here(commonLoopDir, "loopScore_chromosight.tsv"))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(commonLoopDir, "chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_UP.bedpe"))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(commonLoopDir, "chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_NO.bedpe"))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.upno <- bind_rows(loop.up, loop.no)
anchor.upno <- (extractAnchor(loop.upno))
overlaps <- findOverlaps(anchor.upno, atac.gr)
anchor.upno <- pintersect(anchor.upno[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.down <- fread(here(commonLoopDir, "chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2_DOWN.bedpe"))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

#-------------------------------------------------------------------------------
# RUNNING LOLA
# UP
lolaDir <- here(commonLoopDir, "LOLA")
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)


name <- "chromosight_score_complex_reg_dTAGvsDMSO_diffCutoff0.2"
result <- runLOLA(anchor.up, anchor.all, lolaDB)
tb <- as_tibble(result)
fwrite(tb, here(lolaDir, paste0("LOLA_", name, "UP_ATAC.tsv")), sep = "\t")

# NO
result <- runLOLA(anchor.no, anchor.all, lolaDB)
tb <- as_tibble(result)
fwrite(tb, here(lolaDir, paste0("LOLA_", name, "NO_ATAC.tsv")), sep = "\t")

# UPNO
result <- runLOLA(anchor.upno, anchor.all, lolaDB)
tb <- as_tibble(result)
fwrite(tb, here(lolaDir, paste0("LOLA_", name, "UPNO_ATAC.tsv")), sep = "\t")

# DOWN
result <- runLOLA(anchor.down, anchor.all, lolaDB)
tb <- as_tibble(result)
fwrite(tb, here(lolaDir, paste0("LOLA_", name, "DOWN_ATAC.tsv")), sep = "\t")


### Visualizing p-value and OR
alpha <- 0.05
tb.up <- fread(here(lolaDir, paste0("LOLA_", name, "UP_ATAC.tsv"))) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "UP") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, paste0("LOLA_", name, "NO_ATAC.tsv"))) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "NO") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.upno <- fread(here(lolaDir, paste0("LOLA_", name, "UPNO_ATAC.tsv"))) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = "UP/NO") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

fwrite(tb.upno %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, paste0("LOLA_", name, "UPNO_ATAC_pub.tsv")), sep = "\t")

tb.down <- fread(here(lolaDir, paste0("LOLA_", name, "DOWN_ATAC.tsv"))) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = "DOWN") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.down %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, paste0("LOLA_", name, "DOWN_ATAC__pub.tsv")), sep = "\t")


temp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.upno, temp.down)

order <- c((temp %>% dplyr::filter(group == "UP/NO") %>% arrange(desc(oddsRatio)))$target,
           (temp %>% dplyr::filter(group == "DOWN") %>% arrange(desc(oddsRatio)))$target)
order <- unique(order)

temp$target <- factor(temp$target, levels = rev(order))
temp$group <- factor(temp$group, levels = c("UP/NO", "DOWN"))

targetList <- c("POLR2A", "CTR9", "ARR4", "ELL2",
                "MED1", "MED12", "TBP", "TAF1", "TAF2",
                "ESRRB", "KLF4", "NANOG", "POU5F1", "SOX2", "MYCN", "GASTA4", "STAT3", "E2F1", "YY1",
                "P300", "DPY30", "RBBP5", "KDM2B", "KDM4B", "KDM6B", "TET1",
                "CBX7", "RING1B", "RNF2", "EZH2", "SUZ12", "JARID2", "MTF2", "PHF19")

temp <- temp %>% dplyr::filter(target %in% targetList)
temp$target <- factor(temp$target, levels = rev(targetList))


qValueLogMax <- 50
temp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))

p <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = "white", high = "#CB333A",
                      limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

figDir <- here("../figure/loop_analysis")

fileName <- paste0("LOLA_", name)
width <- panelSize(1.5)*mmToInch
height <- panelSize(1.9)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```
#### [FIG] Distance vs OOE plot per group
```{r}
# Import annotation
commonLoopDir <- here("../data/loop_analysis")
figDir <- here("../figure/loop_analysis")

pseudo_ooe <- 0.01

data <- fread(here(commonLoopDir, "loopScore_chromosight.tsv")) %>%
  dplyr::filter(!is.na(ooe_DMSO), !is.na(ooe_dTAG)) %>%
  dplyr::mutate(
    x_ooe = if_else(ooe_DMSO == 0, pseudo_ooe, ooe_DMSO),
    y_ooe = if_else(ooe_dTAG == 0, pseudo_ooe, ooe_dTAG),
    fc    = log2(y_ooe / x_ooe),
    distance = start2 - start1,
    dist_bin = cut(
      distance,
      breaks = c(seq(0, 1e6, by = 1e5), Inf),
      labels = c(
        paste0(seq(0, 9e5, 1e5) / 1e3, "-", seq(1e5, 1e6, 1e5) / 1e3, "kb"),
        ">1Mb"
      ),
      right = FALSE
    )) %>%
  dplyr::select(distance, dist_bin, fc, Anno)

data <- data %>% dplyr::mutate(
  group = case_when(
    Anno %in% c("P-P", "P-E", "E-E") ~ "reg_reg",
    Anno %in% c("P-SP", "P-SE", "E-SP", "E-SE") ~ "reg_strReg",
    Anno %in% c("P-S", "E-S") ~ "reg_str",
    Anno %in% c("SP-SP", "SP-SE", "SE-SE") ~ "strReg_strReg",
    Anno %in% c("SP-S", "SE-S") ~ "strReg_str",
    Anno %in% c("P-X", "E-X") ~ "reg_other",
    Anno %in% c("SP-X", "SE-X") ~ "strReg_other",
    Anno %in% c("S-S", "S-X") ~ "str",
    Anno %in% c("X-X") ~ "other",
    
    TRUE ~ "XXX")
  ) %>%
  dplyr::mutate(group2 = case_when(
    group %in% c("reg_reg") ~ "reg_reg",
    group %in% c("reg_strReg", "reg_str", "reg_other") ~ "reg_nonReg",
    group %in% c("strReg_strReg", "strReg_str", "strReg_other") ~ "strReg_nonReg",
    group %in% c("str") ~ "str",
    TRUE ~ "XXXXX"
  ))





data$group2 <- factor(data$group2, levels = c("reg_reg", "reg_nonReg", "strReg_nonReg", "str"))
# ggplot(data %>% dplyr::filter(group2 != "XXXXX"), aes(x = dist_bin, y = fc, fill = group2)) +
#   geom_boxplot(outliers = FALSE) +
#   # optional: overlay the individual points
#   facet_wrap(~ group2, scales = "free_x", ncol = 4) +
#   scale_x_discrete(drop = FALSE) +                # keep empty bins visible
#   labs(
#     x = "Distance bin",
#     y = "Δ log2(obs/exp)",
#     title = "Structural/Regulatory loop perturbation by loop‐size bin"
#   ) +
#   theme_classic() +
#   theme(
#     axis.text.x  = element_text(angle = 45, hjust = 1),
#     strip.background = element_rect(fill = "white", colour = "black"),
#     strip.text = element_text(face = "bold")
#   ) + geom_hline(yintercept = 0) +
#       coord_cartesian(ylim = c(-3, 2))
p <- ggplot(
  data %>% dplyr::filter(group2 %in% c("reg_reg", "str")),
  aes(x = dist_bin, y = fc, fill = group2)
) +
  # remove outliers with outlier.shape = NA (there is no "outliers" argument)
  geom_boxplot(outlier.shape = NA) +
  # keep empty bins
  scale_x_discrete(drop = FALSE) +
  # add red‐filled mean points, dodged by group
  stat_summary(
    aes(group = group2),
    fun = mean,
    geom = "point",
    shape = 21,
    size = 0.5,
    fill = "red",
    color = "red",
    position = position_dodge(0.8)
  ) +
  labs(
    x = "Distance bin",
    y = "Δ log2(obs/exp)",
  ) +
  theme_classic() +
  theme(
    axis.text.x        = element_text(angle = 45, hjust = 1),
    strip.background   = element_rect(fill = "white", color = "black"),
    strip.text         = element_text(face = "bold")
  ) +
  geom_hline(yintercept = 0) +
  coord_cartesian(ylim = c(-3, 2)) +
  theme(
    axis.title       = element_text(size = fontSizeS, family = fontType),
    axis.text        = element_text(size = fontSizeS, family = fontType),
    axis.line        = element_line(size = lineThick * mmToLineUnit, lineend = "square"),
    axis.ticks       = element_line(size = lineThick * mmToLineUnit, lineend = "square"),
    panel.background = element_rect(fill = "transparent"),
    legend.title     = element_text(family = fontType, size = fontSizeS),
    legend.text      = element_text(family = fontType, size = fontSizeS)
  ) +
  # close the guides(...) call properly and map the correct aesthetic
  guides(
    fill = guide_legend(
      keywidth  = 0.5,
      keyheight = 0.5
    )
  )

name <- "chromosight_score_all_dTAGvsDMSO_diffCutoff0.2"


fileName <- paste0("dist_vs_score_binned_reg_str_", name)

width <- panelSize(2.5)*mmToInch
height <- panelSize(1.75)*mmToInch
png(here(figDir, paste0(fileName, ".png")), 
    res = 600, units = "in", width = width, height = height)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")), 
        width = width, height = height)
print(p)
dev.off()


```


## EXPLORATORY
### Chromosight scores
#### Scatterplots
```{r}




plot_loop_scores(data, score_DMSO, score_dTAG, c("S-S"),
                 name = "chromosight_score_str_dTAGvDMSO",
                 title = "chromo_score_str_dTAGvDMSO", figDir)
plot_loop_scores(data, score_DMSO, score_dTAG, c("S-S", "S-X"),
                 name = "chromosight_score_str2_dTAGvDMSO",
                 title = "chromo_score_str2_dTAGvDMSO", figDir)
plot_loop_scores(data, score_DMSO, score_dTAG, c("P-P", "P-E", "E-E"),
                 name = "chromosight_score_reg_dTAGvDMSO",
                 title = "chromo_score_reg_dTAGvDMSO", figDir)
plot_loop_scores(data, score_DMSO, score_dTAG, c("P-S", "E-S"),
                 name = "chromosight_score_regStr_dTAGvDMSO",
                 title = "chromo_score_regStr_dTAGvDMSO", figDir)

plot_loop_scores(data, score_DMSO, score_A485, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "chromosight_score_all_A485vDMSO",
                 title = "chromo_score_all_A485vDMSO", figDir)
plot_loop_scores(data, score_DMSO, score_A485, c("S-S"),
                 name = "chromosight_score_str_A485vDMSO",
                 title = "chromo_score_str_A485vDMSO", figDir)
plot_loop_scores(data, score_DMSO, score_A485, c("S-S", "S-X"),
                 name = "chromosight_score_str2_A485vDMSO",
                 title = "chromo_score_str2_A485vDMSO", figDir)
plot_loop_scores(data, score_DMSO, score_A485, c("P-P", "P-E", "E-E"),
                 name = "chromosight_score_reg_A485vDMSO",
                 title = "chromo_score_reg_A485vDMSO", figDir)
plot_loop_scores(data, score_DMSO, score_A485, c("P-S", "E-S"),
                 name = "chromosight_score_regStr_A485vDMSO",
                 title = "chromo_score_regStr_A485vDMSO", figDir)


plot_loop_scores(data, score_EpiDMSO, score_EpidTAG, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "chromosight_score_all_EpidTAGvEpiDMSO",
                 title = "chromo_score_all_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, score_EpiDMSO, score_EpidTAG, c("S-S"),
                 name = "chromosight_score_str_EpidTAGvEpiDMSO",
                 title = "chromo_score_str_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, score_EpiDMSO, score_EpidTAG, c("S-S", "S-X"),
                 name = "chromosight_score_str2_EpidTAGvEpiDMSO",
                 title = "chromo_score_str2_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, score_EpiDMSO, score_EpidTAG, c("P-P", "P-E", "E-E"),
                 name = "chromosight_score_reg_EpidTAGvEpiDMSO",
                 title = "chromo_score_reg_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, score_EpiDMSO, score_EpidTAG, c("P-S", "E-S"),
                 name = "chromosight_score_regStr_EpidTAGvEpiDMSO",
                 title = "chromo_score_regStr_EpidTAGvEpiDMSO", figDir)


plot_loop_scores(data, score_UT, score_AID, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "chromosight_score_all_AIDvUT",
                 title = "chromo_score_all_AIDvUT", figDir)
plot_loop_scores(data, score_UT, score_AID, c("S-S"),
                 name = "chromosight_score_str_AIDvUT",
                 title = "chromo_score_str_AIDvUT", figDir)
plot_loop_scores(data, score_UT, score_AID, c("S-S", "S-X"),
                 name = "chromosight_score_str2_AIDvUT",
                 title = "chromo_score_str2_AIDvUT", figDir)
plot_loop_scores(data, score_UT, score_AID, c("P-P", "P-E", "E-E"),
                 name = "chromosight_score_reg_AIDvUT",
                 title = "chromo_score_reg_AIDvUT", figDir)
plot_loop_scores(data, score_UT, score_AID, c("P-S", "E-S"),
                 name = "chromosight_score_regStr_AIDvUT",
                 title = "chromo_score_regStr_AIDvUT", figDir)


```
#### RNA-seq loopscore scatterplot
```{r}
loadLoopAnnoData <- function(fileName){
  data <- as_tibble(fread(fileName)) %>%
    dplyr::mutate(gene = strsplit(gene, '\\|'))
  return(data)
}
```

```{r}
alpha <- 0.05
fcCutoff <- 0.5

commonLoopDir <- here("../data/loop_analysis")
diffDir <- here("../data/RNA_diff")
name <- "chromosight"
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_ensemblList.tsv"))) %>%
  dplyr::mutate(diff = score_dTAG - score_DMSO)

diff.RNA <- fread(here(diffDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, "_score_simpleAnno")) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("RNAvsLoop_", name, "_score_simpleAnno")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

```{r}
alpha <- 0.05
fcCutoff <- 0.5

commonLoopDir <- here("../data/loop_analysis")
diffDir <- here("../data/RNA_diff")
name <- "chromosight"
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_ensemblList.tsv"))) %>%
  dplyr::mutate(diff = score_dTAG - score_DMSO)

diff.RNA <- fread(here(diffDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, "_score_complexAnno")) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("RNAvsLoop_", name, "_score_complexAnno")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

### Obs/exp score
#### Scatterplot - Chromosight
```{r}
plot_loop_scores <- function(df, col_x, col_y, annoList,
                             name, title, figDir,
                             diffCutoff = 0.5, density_n = 200,
                             xmin = -0.5, xmax = 1,
                             ymin = -0.5, ymax = 1) {
  col_x_q <- enquo(col_x)
  col_y_q <- enquo(col_y)
  
  # Scatterplot
  df2 <- df %>%
    filter(Anno_simple %in% annoList) %>%
    select(id, x = !!col_x_q, y = !!col_y_q) %>%
    mutate(
      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),
      eps    = minpos * 0.1,
      lx     = log2(x + eps),
      ly     = log2(y + eps),
      density = get_density(lx, ly, n = density_n)
    ) %>%
    arrange(density)
  
  p1 <- ggplot(df2, aes(x = lx, y = ly, color = density)) +
    geom_point() +
    scale_color_viridis() +
    scale_x_continuous(
      name   = paste0("log2(", quo_name(col_x_q), ")")
    ) +
    scale_y_continuous(
      name   = paste0("log2(", quo_name(col_y_q), ")")
    ) +
    coord_fixed() +
    geom_abline(slope = 1, intercept = 0,
                colour = "grey50", linetype = "dashed") +
    geom_hline(yintercept = 0, alpha = 0.5, colour = "grey") +
    geom_vline(xintercept = 0, alpha = 0.5, colour = "grey") +
    geom_abline(slope = 1, intercept = -(2**diffCutoff),
                colour = "grey", linetype = "dotted") +
    geom_abline(slope = 1, intercept = (2**diffCutoff),
                colour = "grey", linetype = "dotted") +
    theme_classic() +
    labs(x = quo_name(col_x_q),
         y = quo_name(col_y_q)) +
    ggtitle(title)
  
  fileName <- paste0("scatterplot_", name)
  svglite(here(figDir, paste0(fileName, ".svg")), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()
  
  png(here(figDir, paste0(fileName, ".png")), 
      width = 3.5, height = 3, units = "in", res = 600)
  print(p1)
  dev.off()
  
  # Pie chart
  df3 <- df %>%
    filter(Anno_simple %in% annoList) %>%
    select(id, x = !!col_x_q, y = !!col_y_q) %>%
    mutate(
      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),
      eps    = minpos * 0.1,
      lx     = log2(x + eps),
      ly     = log2(y + eps)
    ) %>%
    mutate(diff = ly - lx) %>%
    mutate(updown = ifelse(diff > diffCutoff, "UP",
                           ifelse(diff < -diffCutoff, "DOWN", "NO")))
  df3$updown <- factor(df3$updown, c("UP", "NO", "DOWN"))
  
  pie_df <- df3 %>%
    dplyr::count(updown) %>%
    mutate(pct   = n / sum(n) * 100,
           label = paste0(updown, "\n", n, "\n(", round(pct,1), "%)"))

  p2 <- ggplot(pie_df, aes(x = "", y = n, fill = updown)) +
    geom_col(color = "white") +
    coord_polar(theta = "y") +
    geom_text(aes(label = label),
              position = position_stack(vjust = 0.5),
              size     = fontSizeM/2) +
    theme_void() +   theme(legend.position = "none") +
    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))
  fileName <- here(figDir, paste0("piechart_", name))
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  svglite(paste0(fileName, ".svg"), width = width, height = height)
  print(p2)
  dev.off()
}


commonLoopDir <- here("../data/loop_analysis")
figDir <- here("../figure/loop_analysis")
dir.create(figDir, showWarnings = FALSE, recursive = TRUE)

data <- fread(here(commonLoopDir, "loopScore_chromosight.tsv"))

plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "chromosight_ooe_all_dTAGvDMSO",
                 title = "chromo_ooe_all_dTAGvDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("S-S"),
                 name = "chromosight_ooe_str_dTAGvDMSO",
                 title = "chromo_ooe_str_dTAGvDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("S-S", "S-X"),
                 name = "chromosight_ooe_str2_dTAGvDMSO",
                 title = "chromo_ooe_str2_dTAGvDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("P-P", "P-E", "E-E"),
                 name = "chromosight_ooe_reg_dTAGvDMSO",
                 title = "chromo_ooe_reg_dTAGvDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("P-S", "E-S"),
                 name = "chromosight_ooe_regStr_dTAGvDMSO",
                 title = "chromo_ooe_regStr_dTAGvDMSO", figDir)

plot_loop_scores(data, ooe_DMSO, ooe_A485, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "chromosight_ooe_all_A485vDMSO",
                 title = "chromo_ooe_all_A485vDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c("S-S"),
                 name = "chromosight_ooe_str_A485vDMSO",
                 title = "chromo_ooe_str_A485vDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c("S-S", "S-X"),
                 name = "chromosight_ooe_str2_A485vDMSO",
                 title = "chromo_ooe_str2_A485vDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c("P-P", "P-E", "E-E"),
                 name = "chromosight_ooe_reg_A485vDMSO",
                 title = "chromo_ooe_reg_A485vDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c("P-S", "E-S"),
                 name = "chromosight_ooe_regStr_A485vDMSO",
                 title = "chromo_ooe_regStr_A485vDMSO", figDir)


plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "chromosight_ooe_all_EpidTAGvEpiDMSO",
                 title = "chromo_ooe_all_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("S-S"),
                 name = "chromosight_ooe_str_EpidTAGvEpiDMSO",
                 title = "chromo_ooe_str_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("S-S", "S-X"),
                 name = "chromosight_ooe_str2_EpidTAGvEpiDMSO",
                 title = "chromo_ooe_str2_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("P-P", "P-E", "E-E"),
                 name = "chromosight_ooe_reg_EpidTAGvEpiDMSO",
                 title = "chromo_ooe_reg_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("P-S", "E-S"),
                 name = "chromosight_ooe_regStr_EpidTAGvEpiDMSO",
                 title = "chromo_ooe_regStr_EpidTAGvEpiDMSO", figDir)


plot_loop_scores(data, ooe_UT, ooe_AID, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "chromosight_ooe_all_AIDvUT",
                 title = "chromo_ooe_all_AIDvUT", figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c("S-S"),
                 name = "chromosight_ooe_str_AIDvUT",
                 title = "chromo_ooe_str_AIDvUT", figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c("S-S", "S-X"),
                 name = "chromosight_ooe_str2_AIDvUT",
                 title = "chromo_ooe_str2_AIDvUT", figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c("P-P", "P-E", "E-E"),
                 name = "chromosight_ooe_reg_AIDvUT",
                 title = "chromo_ooe_reg_AIDvUT", figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c("P-S", "E-S"),
                 name = "chromosight_ooe_regStr_AIDvUT",
                 title = "chromo_ooe_regStr_AIDvUT", figDir)


```

#### RNA-seq loopscore scatterplot
```{r}
loadLoopAnnoData <- function(fileName){
  data <- as_tibble(fread(fileName)) %>%
    dplyr::mutate(gene = strsplit(gene, '\\|'))
  return(data)
}
```

```{r}
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here("../data/loop_analysis")
diffDir <- here("../data/RNA_diff")
name <- "chromosight"
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_ensemblList.tsv"))) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, "_ooe_simpleAnno")) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("RNAvsLoop_", name, "_ooe_simpleAnno")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

```{r}
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here("../data/loop_analysis")
diffDir <- here("../data/RNA_diff")
name <- "chromosight"
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_ensemblList.tsv"))) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, "_ooe_complexAnno")) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("RNAvsLoop_", name, "_ooe_complexAnno")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

#### Scatterplot - HiCDC+
```{r}
commonLoopDir <- here("../data/loop_analysis")
figDir <- here("../figure/loop_analysis")
dir.create(figDir, showWarnings = FALSE, recursive = TRUE)

data <- fread(here(commonLoopDir, "loopScore_hicdcp.tsv"))

plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "hicdcp_ooe_all_dTAGvDMSO",
                 title = "hicdcp_ooe_all_dTAGvDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("S-S"),
                 name = "hicdcp_ooe_str_dTAGvDMSO",
                 title = "hicdcp_ooe_str_dTAGvDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("S-S", "S-X"),
                 name = "hicdcp_ooe_str2_dTAGvDMSO",
                 title = "hicdcp_ooe_str2_dTAGvDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("P-P", "P-E", "E-E"),
                 name = "hicdcp_ooe_reg_dTAGvDMSO",
                 title = "hicdcp_ooe_reg_dTAGvDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("P-S", "E-S"),
                 name = "hicdcp_ooe_regStr_dTAGvDMSO",
                 title = "hicdcp_ooe_regStr_dTAGvDMSO", figDir)

plot_loop_scores(data, ooe_DMSO, ooe_A485, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "hicdcp_ooe_all_A485vDMSO",
                 title = "hicdcp_ooe_all_A485vDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c("S-S"),
                 name = "hicdcp_ooe_str_A485vDMSO",
                 title = "hicdcp_ooe_str_A485vDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c("S-S", "S-X"),
                 name = "hicdcp_ooe_str2_A485vDMSO",
                 title = "hicdcp_ooe_str2_A485vDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c("P-P", "P-E", "E-E"),
                 name = "hicdcp_ooe_reg_A485vDMSO",
                 title = "hicdcp_ooe_reg_A485vDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c("P-S", "E-S"),
                 name = "hicdcp_ooe_regStr_A485vDMSO",
                 title = "hicdcp_ooe_regStr_A485vDMSO", figDir)


plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "hicdcp_ooe_all_EpidTAGvEpiDMSO",
                 title = "hicdcp_ooe_all_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("S-S"),
                 name = "hicdcp_ooe_str_EpidTAGvEpiDMSO",
                 title = "hicdcp_ooe_str_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("S-S", "S-X"),
                 name = "hicdcp_ooe_str2_EpidTAGvEpiDMSO",
                 title = "hicdcp_ooe_str2_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("P-P", "P-E", "E-E"),
                 name = "hicdcp_ooe_reg_EpidTAGvEpiDMSO",
                 title = "hicdcp_ooe_reg_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("P-S", "E-S"),
                 name = "hicdcp_ooe_regStr_EpidTAGvEpiDMSO",
                 title = "hicdcp_ooe_regStr_EpidTAGvEpiDMSO", figDir)


plot_loop_scores(data, ooe_UT, ooe_AID, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "hicdcp_ooe_all_AIDvUT",
                 title = "hicdcp_ooe_all_AIDvUT", figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c("S-S"),
                 name = "hicdcp_ooe_str_AIDvUT",
                 title = "hicdcp_ooe_str_AIDvUT", figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c("S-S", "S-X"),
                 name = "hicdcp_ooe_str2_AIDvUT",
                 title = "hicdcp_ooe_str2_AIDvUT", figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c("P-P", "P-E", "E-E"),
                 name = "hicdcp_ooe_reg_AIDvUT",
                 title = "hicdcp_ooe_reg_AIDvUT", figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c("P-S", "E-S"),
                 name = "hicdcp_ooe_regStr_AIDvUT",
                 title = "hicdcp_ooe_regStr_AIDvUT", figDir)

```
#### RNA-seq loopscore scatterplot
```{r}
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here("../data/loop_analysis")
diffDir <- here("../data/RNA_diff")
name <- "hicdcp"
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_ensemblList.tsv"))) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, "_ooe_simpleAnno")) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("RNAvsLoop_", name, "_ooe_simpleAnno")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

```{r}
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here("../data/loop_analysis")
diffDir <- here("../data/RNA_diff")
name <- "hicdcp"
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_ensemblList.tsv"))) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, "_ooe_complexAnno")) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("RNAvsLoop_", name, "_ooe_complexAnno")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

#### Scatterplot - Hansen
```{r}
plot_loop_scores <- function(df, col_x, col_y, annoList,
                             name, title, figDir,
                             diffCutoff = 0.5, density_n = 100,
                             xmin = -0.5, xmax = 1,
                             ymin = -0.5, ymax = 1) {
  col_x_q <- enquo(col_x)
  col_y_q <- enquo(col_y)
  
  # Scatterplot
  df2 <- df %>%
    filter(Anno_simple %in% annoList) %>%
    select(id, x = !!col_x_q, y = !!col_y_q) %>%
    mutate(
      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),
      eps    = minpos * 0.1,
      lx     = log2(x + eps),
      ly     = log2(y + eps)
    )
  
  p1 <- ggplot(df2, aes(x = lx, y = ly)) +
    geom_point() +
    scale_color_viridis() +
    scale_x_continuous(
      name   = paste0("log2(", quo_name(col_x_q), ")")
    ) +
    scale_y_continuous(
      name   = paste0("log2(", quo_name(col_y_q), ")")
    ) +
    coord_fixed() +
    geom_abline(slope = 1, intercept = 0,
                colour = "grey50", linetype = "dashed") +
    geom_hline(yintercept = 0, alpha = 0.5, colour = "grey") +
    geom_vline(xintercept = 0, alpha = 0.5, colour = "grey") +
    geom_abline(slope = 1, intercept = -(2**diffCutoff),
                colour = "grey", linetype = "dotted") +
    geom_abline(slope = 1, intercept = (2**diffCutoff),
                colour = "grey", linetype = "dotted") +
    theme_classic() +
    labs(x = quo_name(col_x_q),
         y = quo_name(col_y_q)) +
    ggtitle(title)
  
  fileName <- paste0("scatterplot_", name)
  svglite(here(figDir, paste0(fileName, ".svg")), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()
  
  png(here(figDir, paste0(fileName, ".png")), 
      width = 3.5, height = 3, units = "in", res = 600)
  print(p1)
  dev.off()
  
  # Pie chart
  df3 <- df %>%
    filter(Anno_simple %in% annoList) %>%
    select(id, x = !!col_x_q, y = !!col_y_q) %>%
    mutate(
      minpos = min(c(x, y)[c(x, y) > 0], na.rm = TRUE),
      eps    = minpos * 0.1,
      lx     = log2(x + eps),
      ly     = log2(y + eps)
    ) %>%
    mutate(diff = ly - lx) %>%
    mutate(updown = ifelse(diff > diffCutoff, "UP",
                           ifelse(diff < -diffCutoff, "DOWN", "NO")))
  df3$updown <- factor(df3$updown, c("UP", "NO", "DOWN"))
  
  pie_df <- df3 %>%
    dplyr::count(updown) %>%
    mutate(pct   = n / sum(n) * 100,
           label = paste0(updown, "\n", n, "\n(", round(pct,1), "%)"))

  p2 <- ggplot(pie_df, aes(x = "", y = n, fill = updown)) +
    geom_col(color = "white") +
    coord_polar(theta = "y") +
    geom_text(aes(label = label),
              position = position_stack(vjust = 0.5),
              size     = fontSizeM/2) +
    theme_void() +   theme(legend.position = "none") +
    scale_fill_manual(values = c(strong_red, no_grey, strong_blue))
  fileName <- here(figDir, paste0("piechart_", name))
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  svglite(paste0(fileName, ".svg"), width = width, height = height)
  print(p2)
  dev.off()
}

commonLoopDir <- here("../data/loop_analysis")
figDir <- here("../figure/loop_analysis")
dir.create(figDir, showWarnings = FALSE, recursive = TRUE)

data <- fread(here(commonLoopDir, "loopScore_Hansen.tsv"))
data <- data %>% 
  filter(
    !if_all(starts_with("ooe"), ~ .x == 0)   # drop rows where *every* ooe* value is 0
)

plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "Hansen_ooe_all_dTAGvDMSO",
                 title = "Hansen_ooe_all_dTAGvDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("S-S"),
                 name = "Hansen_ooe_str_dTAGvDMSO",
                 title = "Hansen_ooe_str_dTAGvDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("S-S", "S-X"),
                 name = "Hansen_ooe_str2_dTAGvDMSO",
                 title = "Hansen_ooe_str2_dTAGvDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("P-P", "P-E", "E-E"),
                 name = "Hansen_ooe_reg_dTAGvDMSO",
                 title = "Hansen_ooe_reg_dTAGvDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_dTAG, c("P-S", "E-S"),
                 name = "Hansen_ooe_regStr_dTAGvDMSO",
                 title = "Hansen_ooe_regStr_dTAGvDMSO", figDir)

plot_loop_scores(data, ooe_DMSO, ooe_A485, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "Hansen_ooe_all_A485vDMSO",
                 title = "Hansen_ooe_all_A485vDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c("S-S"),
                 name = "Hansen_ooe_str_A485vDMSO",
                 title = "Hansen_ooe_str_A485vDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c("S-S", "S-X"),
                 name = "Hansen_ooe_str2_A485vDMSO",
                 title = "Hansen_ooe_str2_A485vDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c("P-P", "P-E", "E-E"),
                 name = "Hansen_ooe_reg_A485vDMSO",
                 title = "Hansen_ooe_reg_A485vDMSO", figDir)
plot_loop_scores(data, ooe_DMSO, ooe_A485, c("P-S", "E-S"),
                 name = "Hansen_ooe_regStr_A485vDMSO",
                 title = "Hansen_ooe_regStr_A485vDMSO", figDir)


plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "Hansen_ooe_all_EpidTAGvEpiDMSO",
                 title = "Hansen_ooe_all_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("S-S"),
                 name = "Hansen_ooe_str_EpidTAGvEpiDMSO",
                 title = "Hansen_ooe_str_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("S-S", "S-X"),
                 name = "Hansen_ooe_str2_EpidTAGvEpiDMSO",
                 title = "Hansen_ooe_str2_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("P-P", "P-E", "E-E"),
                 name = "Hansen_ooe_reg_EpidTAGvEpiDMSO",
                 title = "Hansen_ooe_reg_EpidTAGvEpiDMSO", figDir)
plot_loop_scores(data, ooe_EpiDMSO, ooe_EpidTAG, c("P-S", "E-S"),
                 name = "Hansen_ooe_regStr_EpidTAGvEpiDMSO",
                 title = "Hansen_ooe_regStr_EpidTAGvEpiDMSO", figDir)


plot_loop_scores(data, ooe_UT, ooe_AID, c("P-P", "P-E", "P-S", "P-X",
                                                 "E-E", "E-S", "E-X",
                                                 "S-S", "S-X",
                                                 "X-X"),
                 name = "Hansen_ooe_all_AIDvUT",
                 title = "Hansen_ooe_all_AIDvUT", figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c("S-S"),
                 name = "Hansen_ooe_str_AIDvUT",
                 title = "Hansen_ooe_str_AIDvUT", figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c("S-S", "S-X"),
                 name = "Hansen_ooe_str2_AIDvUT",
                 title = "Hansen_ooe_str2_AIDvUT", figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c("P-P", "P-E", "E-E"),
                 name = "Hansen_ooe_reg_AIDvUT",
                 title = "Hansen_ooe_reg_AIDvUT", figDir)
plot_loop_scores(data, ooe_UT, ooe_AID, c("P-S", "E-S"),
                 name = "Hansen_ooe_regStr_AIDvUT",
                 title = "Hansen_ooe_regStr_AIDvUT", figDir)

```
#### RNA-seq loopscore scatterplot
```{r}
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here("../data/loop_analysis")
diffDir <- here("../data/RNA_diff")
name <- "Hansen"
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0("loopScore_", name, "_p-n_simple_ensemblList.tsv"))) %>%
  filter(
    !if_all(starts_with("ooe"), ~ .x == 0)   # drop rows where *every* ooe* value is 0
  ) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))


diff.RNA <- fread(here(diffDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, "_ooe_simpleAnno")) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("RNAvsLoop_", name, "_ooe_simpleAnno")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

```{r}
alpha <- 0.05
fcCutoff <- 0.5
diffCutoff <- 0.5
commonLoopDir <- here("../data/loop_analysis")
diffDir <- here("../data/RNA_diff")
name <- "Hansen"
geneAnnoData <- loadLoopAnnoData(here(commonLoopDir, paste0("loopScore_", name, "_p-n_complex_ensemblList.tsv"))) %>%
  filter(
    !if_all(starts_with("ooe"), ~ .x == 0)   # drop rows where *every* ooe* value is 0
  ) %>%
  rowwise() %>%                                # work one row at a time
  mutate(
    minpos = min(c(ooe_dTAG, ooe_DMSO)[c(ooe_dTAG, ooe_DMSO) > 0], na.rm = TRUE),
    eps    = ifelse(is.finite(minpos), minpos * 0.1, 0.01),      # fallback if both are 0
    diff   = log2((ooe_dTAG + eps) / (ooe_DMSO + eps))
  ) %>% 
  ungroup() %>% 
  select(-minpos, -eps) 
  #dplyr::mutate(diff = log2(ooe_dTAG) - log2(ooe_DMSO))

diff.RNA <- fread(here(diffDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC <= 0, padj < alpha))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA %>% dplyr::filter(shrinked_log2FC > 0, padj < alpha))$ensembl_gene_id


maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() +
  ggtitle(paste0(name, "_ooe_complexAnno")) +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") +
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("RNAvsLoop_", name, "_ooe_complexAnno")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```
--------------------------------------------------------------------------------
# ARCHIVE

```{r}
commonLoopDir <- here("../data/loop_analysis")

diffCutoff <- 0.2

data <- fread(here(commonLoopDir, "loopScore_chromosight.tsv"))

score.tb <- data %>% dplyr::filter(Anno_simple %in% c("S-S")) %>%
  dplyr::select(id, score_DMSO, score_dTAG)


### P1. UT vs AID
score.tb$density <- get_density(score.tb$score_DMSO, score.tb$score_dTAG, n = 200)
score.tb <- score.tb %>% dplyr::arrange(density)
p1 <- ggplot(score.tb, aes(x = score_DMSO, y = score_dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score"))


# Define the data
categories <- c("Up", "No", "Down")
values <- c(228, 9084, 57169)

# Calculate percentages
percentages <- round((values / sum(values)) * 100, 2)

# Combine values and percentages for labels
labels <- paste(categories, "\n", values, "\n(", percentages, "%)", sep = "")

fileName <- here(figDir, "piechart_unionLoops")
width <- panelSize(2)*mmToInch
height <- panelSize(2)*mmToInch
svglite(paste0(fileName, ".svg"), width = width, height =height)
pie(values, 
    labels = labels, 
    col = c(strong_red, no_grey, strong_blue), 
    cex = fontSizeM/12)
dev.off()

```

```{r}
commonLoopDir <- here("../data/loop_analysis")

diffCutoff <- 0.2

data <- fread(here(commonLoopDir, "loopScore_chromosight.tsv"))

score.tb <- data %>% dplyr::filter(Anno_simple %in% c("P-P", "P-E", "E-E")) %>%
  dplyr::select(id, ooe_DMSO, ooe_dTAG) %>%
  dplyr::filter(!is.na(ooe_DMSO), !is.na(ooe_dTAG))


### P1. UT vs AID
score.tb$density <- get_density(score.tb$ooe_DMSO, score.tb$ooe_dTAG, n = 200)
score.tb <- score.tb %>% dplyr::arrange(density)
p1 <- ggplot(score.tb, aes(x = ooe_DMSO, y = ooe_dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  coord_fixed() +
    xlim(-0.5, 5) + ylim(-0.5, 5) +

  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score"))
```

```{r}
library(dplyr)
library(ggplot2)
library(viridis)
library(purrr)

# your density fn
get_density <- function(x, y, n = 100) {
  # … whatever you already have …
}

# 1) make a general plotting function
plot_compare <- function(df, x_col, y_col, diffCutoff = 0.1, lim = c(-0.5, 1)) {
  df2 <- df %>%
    select(all_of(c(x_col, y_col))) %>%
    rename(x = !!sym(x_col), y = !!sym(y_col)) %>%
    mutate(density = get_density(x, y, n = 100)) %>%
    arrange(density)

  ggplot(df2, aes(x = x, y = y, color = density)) +
    geom_point() +
    scale_color_viridis() +
    xlim(lim) + ylim(lim) +
    coord_fixed() +
    geom_abline(slope = 1, intercept = 0, color = "grey50", linetype = "dashed") +
    geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
    geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
    geom_abline(slope = 1, intercept = -diffCutoff, color = "grey", linetype = "dotted") +
    geom_abline(slope = 1, intercept =  diffCutoff, color = "grey", linetype = "dotted") +
    theme_classic() +
    ggtitle(paste(x_col, "vs", y_col))
}

# 2) define the pairs you care about
pairs <- list(
  DMSO_vs_dTAG = c("score_DMSO", "score_dTAG"),
  UT_vs_AID     = c("score_UT",   "score_AID")
  # … add more …
)

# 3) build a named list of ggplots
plots <- map(pairs, ~ plot_compare(data, .x[1], .x[2], diffCutoff = diffCutoff))

# now you can print them all:
walk(plots, print)
# or arrange them with patchwork / gridExtra, etc.
```


```{r}
sample <- "G1.DMSO.Merged"
for(sample in c("G1.DMSO.Merged", "G1.dTAG.Merged", "G1.A485.Merged")){
  temp.25kb <- fread(here(consensusDir, paste0("loopScore_", sample, "_25kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, "O/E")
  colnames(temp.25kb) <- c("chrom1", "start1", "end1", "chrom2", "start2", "end2", "id", "obs", "obsexp")
  
  temp.10kb <- fread(here(consensusDir, paste0("loopScore_", sample, "_10kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, "O/E")
  colnames(temp.10kb) <- c("chrom1", "start1", "end1", "chrom2", "start2", "end2", "id", "obs", "obsexp")
  
  temp.5kb <-fread(here(consensusDir, paste0("loopScore_", sample, "_5kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, "O/E")
  colnames(temp.5kb) <- c("chrom1", "start1", "end1", "chrom2", "start2", "end2", "id", "obs", "obsexp")
  
  temp <- bind_rows(temp.25kb, temp.10kb, temp.5kb)
  fwrite(temp, here(consensusDir, paste0("loopScore_", sample, ".tsv")), sep = "\t")
}


temp.DMSO <- fread(here(consensusDir, "loopScore_G1.DMSO.Merged.tsv")) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.DMSO) <- c("id", "obs_DMSO", "obsexp_DMSO")
temp.dTAG <- fread(here(consensusDir, "loopScore_G1.dTAG.Merged.tsv")) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.dTAG) <- c("id", "obs_dTAG", "obsexp_dTAG")
temp.A485 <- fread(here(consensusDir, "loopScore_G1.A485.Merged.tsv")) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.A485) <- c("id", "obs_A485", "obsexp_A485")

loops_oe <- full_join(full_join(temp.DMSO, temp.dTAG, by = "id"),
          temp.A485, by = "id") %>%
  dplyr::mutate(oeFC_dTAG_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_dTAG/obsexp_DMSO),
                oeFC_A485_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_A485/obsexp_DMSO))

fwrite(loops_oe, here(consensusDir, paste0("loopScore_cons_obsexp.tsv")), sep = "\t")
```


#### Comparing G1 vs Async for consensus loops
##### All loops
```{r}
diffCutoff = 0.2
data <- fread(here(consensusDir, "chromo_cons_score.tsv"))

temp <- fread(here(consensusDir, "chromo_cons_score_async.tsv")) %>%
  dplyr::select(id, UT, AID)

score.tb <- data %>% dplyr::full_join(temp, by = c("id")) %>%
  dplyr::mutate(diff_G1 = dTAG - DMSO,
                  diff_async = AID - UT)


### P1. UT vs AID
score.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$UT, score.tb$AID)
p1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")

### P1. DMSO vs dTAG
score.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$dTAG)
p2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")


### P3. DMSO vs A485
score.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$A485)
p3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")

### P3. DMSO vs UT
score.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$UT)
p4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")


### P3. dTAG vs AID
score.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$dTAG, score.tb$AID)
p5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")

### P3. diff
score.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$diff_G1, score.tb$diff_async)
p6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-1, 0.5) + ylim(-1, 0.5) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = "grey") +
  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -1, y = 0.5, label = paste("r =", round(correlation, 2)), size = 5, color = "black")


png(here(figDir, paste0("consensus_score_scatterplot_pu100pz100_G1vsAsync.png")), res = 600, units = "in", width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = "h", ncol = 3))
dev.off()
svglite(here(figDir, paste0("consensus_score_scatterplot_pu100pz100_G1vsAsync.svg")), width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = "h", ncol = 3))
dev.off()


```
##### reg loops
```{r}
temp <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe")) %>%
  dplyr::mutate(res = V3 - V2,
                id = paste(V1, res, V2, V5, sep = "_"))
regID <- temp$id

diffCutoff = 0.2
data <- fread(here(consensusDir, "chromo_cons_score.tsv"))

temp <- fread(here(consensusDir, "chromo_cons_score_async.tsv")) %>%
  dplyr::select(id, UT, AID)

score.tb <- data %>% dplyr::full_join(temp, by = c("id")) %>%
  dplyr::mutate(diff_G1 = dTAG - DMSO,
                  diff_async = AID - UT) %>%
  dplyr::filter(id %in% regID)


### P1. UT vs AID
score.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$UT, score.tb$AID)
p1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")

### P1. DMSO vs dTAG
score.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$dTAG)
p2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")


### P3. DMSO vs A485
score.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$A485)
p3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")

### P3. DMSO vs UT
score.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$UT)
p4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")


### P3. dTAG vs AID
score.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$dTAG, score.tb$AID)
p5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")

### P3. diff
score.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$diff_G1, score.tb$diff_async)
p6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-1, 0.5) + ylim(-1, 0.5) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = "grey") +
  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = "grey") +
    theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -1, y = 0.5, label = paste("r =", round(correlation, 2)), size = 5, color = "black")


png(here(figDir, paste0("consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.png")), res = 600, units = "in", width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = "h", ncol = 3))
dev.off()
svglite(here(figDir, paste0("consensus_score_scatterplot_pu100pz100_G1vsAsync_reg.svg")), width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = "h", ncol = 3))
dev.off()


########## Saving Async and G1 specific regulatory loop
diffCutoff <- 0.2
temp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async >= -diffCutoff) %>%
  dplyr::select(seq(1, 7))
fwrite(temp, here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe"), sep = "\t", col.names = FALSE)

temp <- score.tb %>% dplyr::filter(diff_G1 >= -diffCutoff, diff_async < -diffCutoff) %>%
  dplyr::select(seq(1, 7))
fwrite(temp, here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe"), sep = "\t", col.names = FALSE)

temp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async >= -diffCutoff) %>%
  dplyr::select(seq(1, 7))
fwrite(temp, here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe"), sep = "\t", col.names = FALSE)

temp <- score.tb %>% dplyr::filter(diff_G1 < -diffCutoff, diff_async < -diffCutoff) %>%
  dplyr::select(seq(1, 7))
fwrite(temp, here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe"), sep = "\t", col.names = FALSE)
```

##### str loops
```{r}
temp <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure.bedpe")) %>%
  dplyr::mutate(res = V3 - V2,
                id = paste(V1, res, V2, V5, sep = "_"))
regID <- temp$id

diffCutoff = 0.2
data <- fread(here(consensusDir, "chromo_cons_score.tsv"))

temp <- fread(here(consensusDir, "chromo_cons_score_async.tsv")) %>%
  dplyr::select(id, UT, AID)

score.tb <- data %>% dplyr::full_join(temp, by = c("id")) %>%
  dplyr::mutate(diff_G1 = dTAG - DMSO,
                  diff_async = AID - UT) %>%
  dplyr::filter(id %in% regID)


### P1. UT vs AID
score.tb$density <- get_density(score.tb$UT, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$UT, score.tb$AID)
p1 <- ggplot(score.tb, aes(x = UT, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")

### P1. DMSO vs dTAG
score.tb$density <- get_density(score.tb$DMSO, score.tb$dTAG, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$dTAG)
p2 <- ggplot(score.tb, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")


### P3. DMSO vs A485
score.tb$density <- get_density(score.tb$DMSO, score.tb$A485, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$A485)
p3 <- ggplot(score.tb, aes(x = DMSO, y = A485, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")

### P3. DMSO vs UT
score.tb$density <- get_density(score.tb$DMSO, score.tb$UT, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$DMSO, score.tb$UT)
p4 <- ggplot(score.tb, aes(x = DMSO, y = UT, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")


### P3. dTAG vs AID
score.tb$density <- get_density(score.tb$dTAG, score.tb$AID, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$dTAG, score.tb$AID)
p5 <- ggplot(score.tb, aes(x = dTAG, y = AID, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black")

### P3. diff
score.tb$density <- get_density(score.tb$diff_G1, score.tb$diff_async, n = 100)
score.tb <- score.tb %>% dplyr::arrange(density)
correlation <- cor(score.tb$diff_G1, score.tb$diff_async)
p6 <- ggplot(score.tb, aes(x = diff_G1, y = diff_async, color = density)) +
  geom_point() + 
  scale_color_viridis() +
  xlim(-1, 0.5) + ylim(-1, 0.5) +
  coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  geom_hline(yintercept = diffCutoff, alpha = 0.5, color = "grey") +
  geom_hline(yintercept = -diffCutoff, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = diffCutoff, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = -diffCutoff, alpha = 0.5, color = "grey") +
  theme_classic() + ggtitle(paste0("Consensus loop score")) +
  annotate("text", x = -1, y = 0.5, label = paste("r =", round(correlation, 2)), size = 5, color = "black")


png(here(figDir, paste0("consensus_score_scatterplot_pu100pz100_G1vsAsync_str.png")), res = 600, units = "in", width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = "h", ncol = 3))
dev.off()
svglite(here(figDir, paste0("consensus_score_scatterplot_pu100pz100_G1vsAsync_str.svg")), width = 5*2.5, height = 2.5*2.5)
print(cowplot::plot_grid(p1, p2, p3, 
                         p4, p5, p6, align = "h", ncol = 3))
dev.off()


```
#### Comparing loops called from Async
```{r}
# Importing loops. For make comparison easier, 25 kb
binSize = 25*1000
temp <- fread(here(refDir, "Tjian_chromosight_loop.bedpe")) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp) <- c("V1", "V2", "V3", "V4", "V5", "V6")
loop.async <- importBedpe(temp)


binSize = 25*1000
temp <- fread(here(consensusDir, "chromo_cons.bedpe")) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp) <- c("V1", "V2", "V3", "V4", "V5", "V6")
loop.G1 <- importBedpe(temp)


# Check overlap
overlap <- findOverlaps(loop.async, loop.G1)


n.async <- nrow(as_tibble(loop.async))
n.G1 <- nrow(as_tibble(loop.G1))
n.async.overlap <- length(unique(queryHits(overlap)))
n.G1.overlap <- length(unique(subjectHits(overlap)))

plot(euler(c("Async" = n.async - n.async.overlap,
             "Async&G1" = n.async.overlap,
             "G1" = 1)), quantities = TRUE)


plot(euler(c("Async" =1,
             "Async&G1" = n.G1.overlap,
             "G1" = n.G1 - n.G1.overlap)), quantities = TRUE)




# Importing loops. For make comparison easier, 25 kb
binSize = 25*1000
temp.pp <- fread(here(refDir, "Tjian_chromosight_loop_P-P.bedpe")) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp.pp) <- c("V1", "V2", "V3", "V4", "V5", "V6")
binSize = 25*1000
temp.ep <- fread(here(refDir, "Tjian_chromosight_loop_E-P.bedpe")) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp.ep) <- c("V1", "V2", "V3", "V4", "V5", "V6")
temp <- bind_rows(temp.pp, temp.ep)
loop.async <- importBedpe(temp)


binSize = 25*1000
temp <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe")) %>%
  dplyr::mutate(center1 = 0.5*(V2 + V3),
                center2 = 0.5*(V5 + V6),
                start1 = center1 - 0.5*binSize,
                end1 = center1 + 0.5*binSize,
                start2 = center2 - 0.5*binSize,
                end2 = center2 + 0.5*binSize) %>%
  dplyr::select(V1, start1, end1, V4, start2, end2)
colnames(temp) <- c("V1", "V2", "V3", "V4", "V5", "V6")
loop.G1 <- importBedpe(temp)


# Check overlap
overlap <- findOverlaps(loop.async, loop.G1)


n.async <- nrow(as_tibble(loop.async))
n.G1 <- nrow(as_tibble(loop.G1))
n.async.overlap <- length(unique(queryHits(overlap)))
n.G1.overlap <- length(unique(subjectHits(overlap)))

plot(euler(c("Async" = n.async - n.async.overlap,
             "Async&G1" = n.async.overlap,
             "G1" = 1)), quantities = TRUE)


plot(euler(c("Async" =0.1,
             "Async&G1" = n.G1.overlap,
             "G1" = n.G1 - n.G1.overlap)), quantities = TRUE)

```


### [2.5] Consensus loop annotation
```{r}
#### Importing ChIP-exo peaks
refDir <- here("../..", "reference")
peak.H3K27ac <- importPeak(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed"))
peak.H3K4me3 <- importPeak(here(refDir, "33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed"))
peak.CTCF <- importPeak(here(refDir, "33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed"))
peak.RAD21 <- importPeak(here(refDir, "33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed"))
peak.Whyte.SE <- importPeak(here(refDir, "superEnhancer_Whyte_ESC_mm10.bed"))
peak.Dylan.SE <- importPeak(here(refDir, "superEnhancer_Dylan_ESC.bed"))
```
#### Functions
```{r}
createLoopAnnotation <- function(bedpe.loop.anno, name, figDir, outDir, colorList){
  temp = bedpe.loop.anno %>%
    dplyr::mutate(sample = name)
  
  num = nrow(temp)
  p7 = ggplot(temp, aes(x = sample, fill = Anno2)) +
    geom_bar(color = "black") +
    theme_bw() +
    labs(title = paste0(num, " loops"),
         x = "", y = "Counts") +
    scale_y_continuous(labels = comma_format()) +
    theme(plot.title = element_text(hjust = 0.5),
          aspect.ratio = 5,
          legend.position = "right",
          legend.direction  = "vertical") +
    scale_fill_manual(values = colorList)
  
  width = 3
  height = 5
  svglite(here(figDir,
               paste0("loopClassify_", name, ".svg")),
          width = width, height = height)
  plot(p7)
  invisible(dev.off())
  png(here(figDir,
           paste0("loopClassify_", name, ".png")),
      width = width, height = height, res = 600, units = "in")
  plot(p7)
  invisible(dev.off())
}


annotateLoopRelaxedTSS <- function(bedpe.anno){
  temp = bedpe.anno %>% dplyr::rowwise() %>%
    dplyr::mutate(
      A1 = if_else((A1_H3K4me3TSS), "P", 
                   if_else((A1_H3K27ac), "E",
                           if_else((A1_CTCF|A1_RAD21), "S", "X"))),
      A2 = if_else((A2_H3K4me3TSS), "P", 
                   if_else((A2_H3K27ac), "E",
                           if_else((A2_CTCF|A2_RAD21), "S", "X")))
    )
  temp = temp %>% dplyr::rowwise() %>%
    dplyr::mutate(Anno = paste0(A1, "-", A2),
                  Anno2 = if_else(Anno == "E-P", "P-E", 
                                  if_else(Anno == "S-P", "P-S",
                                          if_else(Anno == "X-P", "P-X",
                                                  if_else(Anno == "S-E", "E-S",
                                                          if_else(Anno == "X-E", "E-X",
                                                                  if_else(Anno == "X-S", "S-X",
                                                                          Anno)))))),
    )
  
  temp$Anno2 = factor(temp$Anno2, level = c("X-X",
                                            "S-X", "S-S",
                                            "E-X","E-S","E-E",
                                            "P-E","P-X", "P-S", "P-P"))
  
  # Checking the precense of super enhancer
  temp <- temp %>% dplyr::rowwise() %>%
    dplyr::mutate(AnnoSE = ifelse(A1_Whyte.SE | A2_Whyte.SE, "SE", "NO"))
  temp$AnnoSE <- factor(temp$AnnoSE, level = c("SE", "NO"))
  
  return(temp)
}

annotateLoopPromoterTSS <- function(bedpe.anno){
  temp = bedpe.anno %>% dplyr::rowwise() %>%
    dplyr::mutate(
      A1 = if_else((A1_H3K4me3TSS), "P", "N"),
      A2 = if_else((A2_H3K4me3TSS), "P", "N")
    )
  temp = temp %>% dplyr::rowwise() %>%
    dplyr::mutate(Anno = paste0(A1, "-", A2),
                  Anno2 = if_else(Anno == "N-P", "P-N", Anno))
  
  temp$Anno2 = factor(temp$Anno2, level = c("N-N", "P-N", "P-P"))
  
  return(temp)
}

annotateLoopEnhancer <- function(bedpe.anno){
  temp = bedpe.anno %>% dplyr::rowwise() %>%
    dplyr::mutate(
      A1 = if_else((A1_H3K27ac), "E", "N"),
      A2 = if_else((A2_H3K27ac), "E", "N")
    )
  temp = temp %>% dplyr::rowwise() %>%
    dplyr::mutate(Anno = paste0(A1, "-", A2),
                  Anno2 = if_else(Anno == "N-E", "E-N", Anno))
  temp$Anno2 = factor(temp$Anno2, level = c("N-N", "E-N", "E-E"))
  
  return(temp)
}

annotateLoopStructure <- function(bedpe.anno){
  temp = bedpe.anno %>% dplyr::rowwise() %>%
    dplyr::mutate(
      A1 = if_else((A1_CTCF|A1_RAD21), "S", "N"),
      A2 = if_else((A2_CTCF|A2_RAD21), "S", "N")
    )
  temp = temp %>% dplyr::rowwise() %>%
    dplyr::mutate(Anno = paste0(A1, "-", A2),
                  Anno2 = if_else(Anno == "N-S", "S-N", Anno))
  temp$Anno2 = factor(temp$Anno2, level = c("N-N", "S-N", "S-S"))
  return(temp)
}


annotateAnchorTSS <- function(bedpe){
  tb.loop = 
    setOverlapColumn("Whyte.SE",
                     setOverlapColumn("CTCF",
                                      setOverlapColumn("RAD21",
                                                       setOverlapColumn("H3K27ac",
                                                                        setOverlapColumn("H3K4me3TSS", bedpe)))))
  return(tb.loop)
}

setOverlapColumn <- function(peakName, loop){
  tb.loop = as_tibble(loop)
  overlap = returnOverlapIndexLixt(get(paste0("peak.", peakName)), tb.loop)
  tb.loop[[paste0("A1_", peakName)]] = FALSE
  tb.loop[[paste0("A1_", peakName)]][overlap[[1]]] = TRUE
  tb.loop[[paste0("A2_", peakName)]] = FALSE
  tb.loop[[paste0("A2_", peakName)]][overlap[[2]]] = TRUE
  return(tb.loop)
}

returnOverlapIndexLixt <- function(peak, loop){
  anchor1.tb = as_tibble(loop) %>% dplyr::select(chrom1, start1, end1)
  anchor1 = makeGRangesFromDataFrame(data.frame(
    chr = anchor1.tb$chrom1,
    start = anchor1.tb$start1,
    end = anchor1.tb$end1
  ))
  
  anchor2.tb = as_tibble(loop) %>% dplyr::select(chrom2, start2, end2)
  anchor2 = makeGRangesFromDataFrame(data.frame(
    chr = anchor2.tb$chrom2,
    start = anchor2.tb$start2,
    end = anchor2.tb$end2
  ))
  
  overlap = list(overlap1 = unique(queryHits(findOverlaps(anchor1, peak))),
                 overlap2 = unique(queryHits(findOverlaps(anchor2, peak))))
  return(overlap)
}

saveAnnoGroupBedpe <- function(temp, anno.list, name, annoName, ouDir){
  loop = temp %>% dplyr::filter(Anno2 %in% anno.list) %>%
    dplyr::select(c("chrom1", "start1", "end1", "chrom2", "start2", "end2"))
  fwrite(loop, here(outDir, paste0(name, "_", annoName, ".bedpe")), sep = "\t", col.names = FALSE)
}
```
#### Annotation
```{r}
consensus.loop.tb <- fread(here(consensusDir, "chromo_cons_score.tsv"))

################################################################################
# Filtering H3K4me3 peaks that has TSS nearby
# Since the finest resolution is 5kb, +-2.5kb will be used as a cutoff for checking TSS presence
flankSize <- 2500
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend)
colnames(gene.tb) <- c("chr", "start", "end")
TSS1kb.gr <- makeGRangesFromDataFrame(gene.tb)
temp <- peak.H3K4me3[unique(queryHits(findOverlaps(peak.H3K4me3, TSS1kb.gr)))]
fwrite(as_tibble(temp), here(refDir, 
                             paste0("33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.", 
                                    flankSize/1000, "kbTSS.bed")), sep = "\t", col.names = FALSE)
peak.H3K4me3TSS <- importPeak(here(refDir, paste0("33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.", 
                                    flankSize/1000, "kbTSS.bed")))
################################################################################
# Annotating with strict priority (P-TSS > E > S)
temp.anno.TSS <- annotateAnchorTSS(consensus.loop.tb) %>%
  dplyr::mutate(
    diff_dTAG_DMSO = (dTAG-DMSO),
    diff_A485_DMSO = (A485-DMSO))

name <- "chromo_cons_annoHierarchy"
consensus.loop.anno.tb <- annotateLoopRelaxedTSS(temp.anno.TSS)
fwrite(consensus.loop.anno.tb, here(consensusDir, paste0(name, ".tsv")), 
       sep = "\t", col.names = TRUE)
createLoopAnnotation(consensus.loop.anno.tb, name, figDir, outDir,  colorListLoop)
saveAnnoGroupBedpe(consensus.loop.anno.tb, unique(consensus.loop.anno.tb$Anno2) , name, "all", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c("P-P", "P-E", "P-S", "P-X", "E-E", "E-S", "E-X"), name, "regulatory", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c("S-S", "S-X"), name, "structure", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c("X-X"), name, "x-x", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c("P-P", "P-E", "P-S", "P-X"), name, "p-n", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c("P-P", "P-E", "E-E"), name, "pe-pe", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c("P-P", "P-E"), name, "p-pe", outDir)

saveAnnoGroupBedpe(consensus.loop.anno.tb, c("P-P"), name, "p-p", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c("P-E"), name, "p-e", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c("P-S"), name, "p-s", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.tb, c("P-X"), name, "p-x", outDir)

################################################################################
# Annotating with one marker (Promoter)
name <- "chromo_cons_annoPromoter"
consensus.loop.anno.promoter.tb <- annotateLoopPromoterTSS(temp.anno.TSS)
fwrite(consensus.loop.anno.promoter.tb, here(consensusDir, paste0(name, ".tsv")), 
       sep = "\t", col.names = TRUE)
createLoopAnnotation(consensus.loop.anno.promoter.tb, name, 
                     figDir, outDir,  colorListPromoter)
saveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, unique(consensus.loop.anno.promoter.tb$Anno2) , name, "all", outDir)  
saveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c("P-P"), name, "p-p", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c("P-N"), name, "p-n", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.promoter.tb, c("N-N"), name, "n-n", outDir)

################################################################################
# Annotating with one marker (Enhancer)
name <- "chromo_cons_annoEnhancer"
consensus.loop.anno.enhancer.tb <- annotateLoopEnhancer(temp.anno.TSS)
fwrite(consensus.loop.anno.enhancer.tb, here(consensusDir, paste0(name, ".tsv")), 
       sep = "\t", col.names = TRUE)
createLoopAnnotation(consensus.loop.anno.enhancer.tb, name, 
                     figDir, outDir,  colorListEnhancer)
saveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, unique(consensus.loop.anno.enhancer.tb$Anno2) , name, "all", outDir)  
saveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c("E-E"), name, "e-e", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c("E-N"), name, "e-n", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.enhancer.tb, c("N-N"), name, "n-n", outDir)
################################################################################
# Annotating with one marker (Structure)
name <- "chromo_cons_annoStructure"
consensus.loop.anno.structure.tb <- annotateLoopStructure(temp.anno.TSS)
fwrite(consensus.loop.anno.structure.tb, here(consensusDir, paste0(name, ".tsv")), 
       sep = "\t", col.names = TRUE)
createLoopAnnotation(consensus.loop.anno.structure.tb, name, 
                     figDir, outDir,  colorListStructure)
saveAnnoGroupBedpe(consensus.loop.anno.structure.tb, unique(consensus.loop.anno.structure.tb$Anno2) , name, "all", outDir)  
saveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c("S-S"), name, "s-s", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c("S-N"), name, "s-n", outDir)
saveAnnoGroupBedpe(consensus.loop.anno.structure.tb, c("N-N"), name, "n-n", outDir)
```

##### Pure-reg vs Str-reg
```{r}
################################################################################
# 2024.09.10 Splitting regulatory loop into pure regulatory and structure-related loops
name <- "chromo_cons_annoHierarchy"
consensus.loop.anno.tb <- fread(here(consensusDir, paste0(name, ".tsv")))
regulatory.loop.anno.tb <- consensus.loop.anno.tb %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E"))

regulatory.loop.anno.tb <- regulatory.loop.anno.tb %>% rowwise() %>%
  dplyr::mutate(
    Anno3 = ifelse(A1_RAD21 | A1_CTCF | A2_RAD21 | A2_RAD21, paste0("str"),
                   paste0("reg"))
  )


fwrite(regulatory.loop.anno.tb, here(consensusDir, paste0(name, "_Anno3.tsv")), 
       sep = "\t", col.names = TRUE)

regulatory.loop.anno.tb_reg <- regulatory.loop.anno.tb %>% dplyr::filter(Anno3 == "reg")
regulatory.loop.anno.tb_str <- regulatory.loop.anno.tb %>% dplyr::filter(Anno3 == "str")

saveAnnoGroupBedpe(regulatory.loop.anno.tb_reg, c("P-P", "P-E", "E-E"), name, "pe-pe_reg", outDir)
saveAnnoGroupBedpe(regulatory.loop.anno.tb_str, c("P-P", "P-E", "E-E"), name, "pe-pe_str", outDir)

```


### [2.6] Comparing across samples for conesnsus loop
#### Functions
```{r}
create_loop_dis_vs_score <- function(data, figDir, name, Anno2List){
  data = data %>% dplyr::filter(Anno2 %in% Anno2List)
  
  ### barplot
  temp <- data %>% dplyr::select(id, DMSO, dTAG, A485) %>%
    pivot_longer(!id, names_to = "treatment", values_to = "score")
  temp$treatment <- factor(temp$treatment, levels = c("DMSO", "dTAG", "A485"))
  
  p3 <- ggplot(temp, aes(x = treatment, y = score)) +
    geom_violin(aes(fill = treatment), show.legend = FALSE) +
    scale_fill_manual(values = c("DMSO" = "grey", "dTAG" = "pink", "A485" = "skyblue")) +
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    ylim(-0.5, 1) +
    geom_hline(yintercept = 0, linetype = "dashed", color = "grey") +
    theme_classic() +
    ggtitle(name) +
    theme(plot.title = element_text(size = 4))
  fileName <- paste0("score_barplot_", name)
  png(here(figDir, paste0(fileName, ".png")), 
      res = 600, units = "in", width = 2, height = 4)
  print(p3)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")), 
          width = 2, height = 4)
  print(p3)
  dev.off()
  
  ### Distance vs score
  
  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, dTAG, A485)

  avg_scores <- temp %>%
    group_by(distance) %>%
    summarise(across(starts_with("DMSO"):starts_with("A485"), mean, na.rm = TRUE))

  avg_scores_long <- avg_scores %>%
    pivot_longer(cols = DMSO:A485, names_to = "condition", values_to = "avg_score")
  avg_scores_long$condition <- factor(avg_scores_long$condition, levels = c("DMSO", "dTAG", "A485"))
  # Create the plot
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +
    geom_smooth(show.legend = TRUE) + ylim(0, 0.5) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = c("DMSO" = "grey", "dTAG" = "pink", "A485" = "skyblue")) +
    scale_fill_manual(values = c("DMSO" = "grey80", "dTAG" = "pink", "A485" = "skyblue")) +
    labs(title = paste0(name),
         x = "Distance",
         y = "Average Score") +
    theme(plot.title = element_text(size = 5))
  fileName <- paste0("dist_vs_score_linePlot_", name)
  png(here(figDir, paste0(fileName, ".png")),
      res = 600, units = "in", width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),
      width = 4, height = 3)
  print(p4)
  dev.off()
}

create_loop_dis_vs_diffscore <- function(data, figDir, name, Anno2List){
  data = data %>% dplyr::filter(Anno2 %in% Anno2List)
  
  
  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, diff_A485_DMSO)
  
  avg_scores <- temp %>%
    group_by(distance) %>%
    summarise(across(1:2, mean, na.rm = TRUE))
  
  avg_scores_long <- avg_scores %>%
    pivot_longer(cols = 2:3, names_to = "condition", values_to = "avg_score")
  avg_scores_long$condition <- factor(avg_scores_long$condition, 
                                      levels = c("diff_dTAG_DMSO", "diff_A485_DMSO"))
  # Create the plot
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +
    geom_smooth(show.legend = TRUE) + geom_hline(yintercept = 0) + ylim(-0.5, 0.1) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = c("diff_dTAG_DMSO" = "pink", "diff_A485_DMSO" = "skyblue")) +
    scale_fill_manual(values = c("diff_dTAG_DMSO" = "pink", "diff_A485_DMSO" = "skyblue")) +
    labs(title = paste0(name),
         x = "Distance",
         y = "Average Diff Score") +
    theme(plot.title = element_text(size = 5))
  fileName <- paste0("dist_vs_score_difflinePlot_", name)
  png(here(figDir, paste0(fileName, ".png")),
      res = 600, units = "in", width = 4.5, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),
          width = 4.5, height = 3)
  print(p4)
  dev.off()
}

create_loop_scatterplot <- function(data, figDir, name, Anno2List, diffCutoff){
  data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, "UP", 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, "NO", "DOWN")),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, "UP", 
                                            ifelse(diff_A485_DMSO > -diffCutoff, "NO", "DOWN"))) %>%
    dplyr::filter(Anno2 %in% Anno2List)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c("UP", "NO", "DOWN"))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c("UP", "NO", "DOWN"))
  
  num.up <- (summary(data$updown_dTAG_DMSO))["UP"]
  num.no <- (summary(data$updown_dTAG_DMSO))["NO"]
  num.down <- (summary(data$updown_dTAG_DMSO))["DOWN"]
  num.all <- num.up + num.no + num.down
  perc.up <- round(num.up / num.all * 100, 2)
  perc.no <- round(num.no / num.all * 100, 2)
  perc.down <- round(num.down / num.all * 100, 2)
  
  ### Scatterplot
  data$density <- get_density(data$DMSO, data$dTAG, n = 100)
  data <- data %>% dplyr::arrange(density)
  correlation <- cor(data$DMSO, data$dTAG)
  p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +
    geom_point(size = 1,
      alpha = 1,
      stroke = 0) + 
    scale_color_viridis(option = "D", guide = guide_colorbar(
                          barwidth = 1.5/5.08,  # Adjust width of the color bar
                          barheight = 15/5.08   # Adjust height of the color bar
                        )) +
    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
    geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    geom_hline(yintercept = 0, alpha = 0.5, color = "grey",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    geom_vline(xintercept = 0, alpha = 0.5, color = "grey",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    annotate("text", x = -0.5, y = 1, label = paste0("UP: ", num.up, " (", perc.up, "%)"), 
             color = "black", hjust = 0, , size = 1,
        family = fontType) +
    annotate("text", x = -0.5, y = 1-0.1, label = paste0("NO: ", num.no, " (", perc.no, "%)"), 
             color = "black", hjust = 0, , size = 1,
        family = fontType) +
    annotate("text", x = -0.5, y = 1-0.2, label = paste0("DOWN: ", num.down, " (", perc.down, "%)"), 
             color = "black", hjust = 0, , size = 1,
        family = fontType) +
    theme_classic() +
    #annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black") +
    theme(
      # legend.position = "none",
      plot.title = element_text(
        hjust = 0.5,
        size = fontSizeS,
        family = fontType
      ),
      axis.title = element_text(
        size = fontSizeS,
        family = fontType,
        color = "#000000"
      ),
      axis.text = element_text(
        size = fontSizeS,
        family = fontType,
        color = "#000000"
      ),
      axis.line = element_line(
        color = "#000000",
        size = lineThick*mmToLineUnit,
        lineend = "square"
      ),
      axis.ticks = element_line(
        color = "#000000",
        size = lineThick*mmToLineUnit,
        lineend = "square"
      ),
      panel.background = element_rect(fill = "transparent"),
    ) +
  xlab("Loop score\nG1.DMSO") +
    ylab("Loop score\nG1.dTAG")
  
  
  
  num.up <- (summary(data$updown_A485_DMSO))["UP"]
  num.no <- (summary(data$updown_A485_DMSO))["NO"]
  num.down <- (summary(data$updown_A485_DMSO))["DOWN"]
  num.all <- num.up + num.no + num.down
  perc.up <- round(num.up / num.all * 100, 2)
  perc.no <- round(num.no / num.all * 100, 2)
  perc.down <- round(num.down / num.all * 100, 2)
  
  data$density <- get_density(data$DMSO, data$A485, n = 100)
  data <- data %>% dplyr::arrange(density)
  correlation <- cor(data$DMSO, data$A485)
  p2 <- ggplot(data, aes(x = DMSO, y = A485, color = density)) +
    geom_point(size = 1,
      alpha = 1,
      stroke = 0) + 
    scale_color_viridis(option = "D", guide = guide_colorbar(
                          barwidth = 1.5/5.08,  # Adjust width of the color bar
                          barheight = 15/5.08   # Adjust height of the color bar
                        )) +
    xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
    geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    geom_hline(yintercept = 0, alpha = 0.5, color = "grey",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    geom_vline(xintercept = 0, alpha = 0.5, color = "grey",
      color = "black",
      size = lineThick*mmToLineUnit,
      lineend = "square") +
    annotate("text", x = -0.5, y = 1, label = paste0("UP: ", num.up, " (", perc.up, "%)"), 
             color = "black", hjust = 0, size = 1,
        family = fontType) +
    annotate("text", x = -0.5, y = 1-0.1, label = paste0("NO: ", num.no, " (", perc.no, "%)"), 
             color = "black", hjust = 0, size = 1,
        family = fontType) +
    annotate("text", x = -0.5, y = 1-0.2, label = paste0("DOWN: ", num.down, " (", perc.down, "%)"), 
             color = "black", hjust = 0, size = 1,
        family = fontType) +
    theme_classic() + 
    # annotate("text", x = -0.5, y = 1, label = paste("r =", round(correlation, 2)), size = 5, color = "black") +
    theme(
      # legend.position = "none",
      plot.title = element_text(
        hjust = 0.5,
        size = fontSizeS,
        family = fontType
      ),
      axis.title = element_text(
        size = fontSizeS,
        family = fontType,
        color = "#000000"
      ),
      axis.text = element_text(
        size = fontSizeS,
        family = fontType,
        color = "#000000"
      ),
      axis.line = element_line(
        color = "#000000",
        size = lineThick*mmToLineUnit,
        lineend = "square"
      ),
      axis.ticks = element_line(
        color = "#000000",
        size = lineThick*mmToLineUnit,
        lineend = "square"
      ),
      panel.background = element_rect(fill = "transparent"),
    ) +
    xlab("Loop score\nG1.DMSO") +
    ylab("Loop score\nG1.A485")

    width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.5)*mmToInch  
  
  fileName <- here(figDir,paste0("scatterplot_", name, "_dTAG_vs_DMSO_", diffCutoff))

  svglite(paste0(fileName, ".svg"), width = width, height =height)
  print(p1)
  dev.off()
  png(paste0(fileName, ".png"), width = width, height =height, res = 600, unit = "in")
  print(p1)
  dev.off()
  
    fileName <- here(figDir, paste0("scatterplot_", name, "_A485_vs_DMSO_", diffCutoff))

  svglite(paste0(fileName, ".svg"), width = width, height =height)
  print(p2)
  dev.off()
  png(paste0(fileName, ".png"), width = width, height =height, res = 600, unit = "in")
  print(p2)
  dev.off()
  
  # 
  # 
  # 
  # png(here(figDir, paste0(fileName, ".png")), res = 600, units = "in", width = 5*1.5, height = 2.5*1.5)
  # print(cowplot::plot_grid(p1, p2, align = "h"))
  # dev.off()
  # 
  # svglite(here(figDir, paste0(fileName, ".svg")), 
  #         width = 5*1.5, height = 2.5*1.5)
  # print(cowplot::plot_grid(p1, p2, align = "h"))
  # dev.off()
}

make_diff_bedpe <- function(data, name, Anno2List, outDir, diffCutoff){
  data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, "UP", 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, "NO", "DOWN")),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, "UP", 
                                            ifelse(diff_A485_DMSO > -diffCutoff, "NO", "DOWN"))) %>%
    dplyr::filter(Anno2 %in% Anno2List)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c("UP", "NO", "DOWN"))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c("UP", "NO", "DOWN"))
  
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == "UP") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, "_dTAGvsDMSO_UP_diff", diffCutoff, ".bedpe")), 
         sep = "\t", col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == "NO") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, "_dTAGvsDMSO_NO_diff", diffCutoff, ".bedpe")), 
         sep = "\t", col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == "DOWN") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, "_dTAGvsDMSO_DOWN_diff", diffCutoff, ".bedpe")), 
         sep = "\t", col.names = FALSE)
  
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == "UP") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, "_A485vsDMSO_UP_diff", diffCutoff, ".bedpe")), 
         sep = "\t", col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == "NO") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, "_A485vsDMSO_NO_diff", diffCutoff, ".bedpe")), 
         sep = "\t", col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == "DOWN") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, "_A485vsDMSO_DOWN_diff", diffCutoff, ".bedpe")), 
         sep = "\t", col.names = FALSE)
}

create_dist_vs_avgScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){
  avg_scores_long <- data %>%
    group_by(distance, Anno2) %>%
    summarise(avg_score = mean(score, na.rm = TRUE)) %>%
    ungroup() 
  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + 
    geom_smooth(show.legend = TRUE, se = se)  +
    ylim(0, 0.5) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = colorList) +
    scale_fill_manual(values = colorList) +
    labs(title = paste0(name),
         x = "Distance",
         y = "Average Score") +
    theme(plot.title = element_text(size = 8))
  
  fileName <- paste0("dist_vs_score_linePlot_", name)
  png(here(figDir, paste0(fileName, ".png")), 
      res = 600, units = "in", width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")), 
          width = 4, height = 3)
  print(p4)
  dev.off()
} 

create_dist_vs_avgDiffScore_perTreatment <- function(data, figDir, name, loopList, colorList, se = FALSE){
  avg_scores_long <- data %>%
    group_by(distance, Anno2) %>%
    summarise(avg_score = mean(score, na.rm = TRUE)) %>%
    ungroup() 
  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + 
    geom_hline(yintercept = 0) +
    geom_smooth(show.legend = TRUE, se = se)  +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = colorList) +
    scale_fill_manual(values = colorList) +
    labs(title = paste0(name),
         x = "Distance",
         y = "Average Diff Score") +
    theme(plot.title = element_text(size = 8)) 
  
  fileName <- paste0("dist_vs_score_difflinePlot_", name)
  png(here(figDir, paste0(fileName, ".png")), 
      res = 600, units = "in", width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")), 
          width = 4, height = 3)
  print(p4)
  dev.off()
} 

create_score_barplot_perTreatment <- function(data, figDir, name, loopList, colorList){
  data$Anno2 <- factor(data$Anno2, levels = loopList)
  
  p3 <- ggplot(data, aes(x = Anno2, y = score)) +
    geom_violin(aes(fill = Anno2), show.legend = FALSE) +
    scale_fill_manual(values = colorList) +
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    ylim(-0.5, 1) +
    geom_hline(yintercept = 0, linetype = "dashed", color = "grey") +
    theme_classic() +
    ggtitle(name) +
    theme(plot.title = element_text(size = 4))
  
  fileName <- paste0("score_barPlot_", name)
  
  png(here(figDir, paste0(fileName, ".png")), 
      res = 600, units = "in", width = 2, height = 4)
  print(p3)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")), 
          width = 2, height = 4)
  print(p3)
}


iterate_loop_functions <- function(data, figDir, groupName, annoList){
  # create_loop_dis_vs_score(data, figDir, groupName, annoList)
  # create_loop_dis_vs_diffscore(data, figDir, groupName, annoList)

  create_loop_scatterplot(data, figDir, groupName, annoList, 0.2)
  # create_loop_scatterplot(data, figDir, groupName, annoList, 0.1)
  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.2)
  # make_diff_bedpe(data, groupName, annoList, consensusDir, 0.1)
}
```

#### Relaxed annotation
```{r}

name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))

iterate_loop_functions(data, figDir, paste0(name, "_", "cl_all"), unique(data$Anno2))
iterate_loop_functions(data, figDir, paste0(name, "_", "cl_structure"), 
                       c("S-S", "S-X"))
iterate_loop_functions(data, figDir, paste0(name, "_", "s-s"), 
                       c("S-S"))
iterate_loop_functions(data, figDir, paste0(name, "_", "cl_regulatory"), 
                       c("P-P", "P-E", "P-S", "P-X", "E-E", "E-S", "E-X"))
iterate_loop_functions(data, figDir, paste0(name, "_", "cl_pe-pe"), 
                       c("P-P", "P-E", "E-E"))
iterate_loop_functions(data, figDir, paste0(name, "_", "p-pe"), 
                       c("P-P", "P-E"))
iterate_loop_functions(data, figDir, paste0(name, "_", "p-p"), 
                       c("P-P"))
iterate_loop_functions(data, figDir, paste0(name, "_", "p-e"), 
                       c("P-E"))
iterate_loop_functions(data, figDir, paste0(name, "_", "e-e"), 
                       c("E-E"))
iterate_loop_functions(data, figDir, paste0(name, "_", "x-x"), 
                       c("X-X"))
###########
# Creating differential scatterplot
View(data)



#######################
# Creating figures per each condition
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, "_DMSO"), c("X-X",
                                                                 "S-X", "S-S",
                                                                 "E-X","E-S","E-E",
                                                                 "P-E","P-X", "P-S", "P-P"), colorListLoop)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, "_dTAG"), c("X-X",
                                                                 "S-X", "S-S",
                                                                 "E-X","E-S","E-E",
                                                                 "P-E","P-X", "P-S", "P-P"), colorListLoop)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, "_A485"), c("X-X",
                                                                 "S-X", "S-S",
                                                                 "E-X","E-S","E-E",
                                                                 "P-E","P-X", "P-S", "P-P"), colorListLoop)

#######################
# Creating figures per each condition, differential
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, "_dTAG"), c("X-X",
                                                                 "S-X", "S-S",
                                                                 "E-X","E-S","E-E",
                                                                 "P-E","P-X", "P-S", "P-P"), colorListLoop)
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, "_dTAG_SE"), c("X-X",
                                                                 "S-X", "S-S",
                                                                 "E-X","E-S","E-E",
                                                                 "P-E","P-X", "P-S", "P-P"), colorListLoop, se = TRUE)
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, "_A485"), c("X-X",
                                                                 "S-X", "S-S",
                                                                 "E-X","E-S","E-E",
                                                                 "P-E","P-X", "P-S", "P-P"), colorListLoop)

create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, "_A485_SE"), c("X-X",
                                                                 "S-X", "S-S",
                                                                 "E-X","E-S","E-E",
                                                                 "P-E","P-X", "P-S", "P-P"), colorListLoop, se = TRUE)
```
##### Pure-reg vs str-reg
```{r}
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, "_Anno3.tsv")))
diffCutoff <- 0.2

# Splitting data
data.reg <- data %>% dplyr::filter(Anno3 == "reg")
data.str <- data %>% dplyr::filter(Anno3 == "str")

# Taking codes from previous function (str)
data <- data.str
data <- data %>%
  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, "UP", 
                                          ifelse(diff_dTAG_DMSO > -diffCutoff, "NO", "DOWN")),
                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, "UP", 
                                          ifelse(diff_A485_DMSO > -diffCutoff, "NO", "DOWN")))
data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c("UP", "NO", "DOWN"))
data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c("UP", "NO", "DOWN"))

num.up <- (summary(data$updown_dTAG_DMSO))["UP"]
num.no <- (summary(data$updown_dTAG_DMSO))["NO"]
num.down <- (summary(data$updown_dTAG_DMSO))["DOWN"]
num.all <- num.up + num.no + num.down
perc.up <- round(num.up / num.all * 100, 2)
perc.no <- round(num.no / num.all * 100, 2)
perc.down <- round(num.down / num.all * 100, 2)

data$density <- get_density(data$DMSO, data$dTAG, n = 100)
data <- data %>% dplyr::arrange(density)
p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  annotate("text", x = -0.5, y = 1, label = paste0("UP: ", num.up, " (", perc.up, "%)"), 
           color = "black", hjust = 0, size = 3) +
  annotate("text", x = -0.5, y = 1-0.1, label = paste0("NO: ", num.no, " (", perc.no, "%)"), 
           color = "black", hjust = 0, size = 3) +
  annotate("text", x = -0.5, y = 1-0.2, label = paste0("DOWN: ", num.down, " (", perc.down, "%)"), 
           color = "black", hjust = 0, size = 3) +
  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))

# Taking codes from previous function (reg)
data <- data.reg
data <- data %>%
  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, "UP", 
                                          ifelse(diff_dTAG_DMSO > -diffCutoff, "NO", "DOWN")),
                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, "UP", 
                                          ifelse(diff_A485_DMSO > -diffCutoff, "NO", "DOWN")))
data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c("UP", "NO", "DOWN"))
data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c("UP", "NO", "DOWN"))

num.up <- (summary(data$updown_dTAG_DMSO))["UP"]
num.no <- (summary(data$updown_dTAG_DMSO))["NO"]
num.down <- (summary(data$updown_dTAG_DMSO))["DOWN"]
num.all <- num.up + num.no + num.down
perc.up <- round(num.up / num.all * 100, 2)
perc.no <- round(num.no / num.all * 100, 2)
perc.down <- round(num.down / num.all * 100, 2)

data$density <- get_density(data$DMSO, data$dTAG, n = 100)
data <- data %>% dplyr::arrange(density)
p2 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  annotate("text", x = -0.5, y = 1, label = paste0("UP: ", num.up, " (", perc.up, "%)"), 
           color = "black", hjust = 0, size = 3) +
  annotate("text", x = -0.5, y = 1-0.1, label = paste0("NO: ", num.no, " (", perc.no, "%)"), 
           color = "black", hjust = 0, size = 3) +
  annotate("text", x = -0.5, y = 1-0.2, label = paste0("DOWN: ", num.down, " (", perc.down, "%)"), 
           color = "black", hjust = 0, size = 3) +
  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  
  

fileName <- paste0("scatterplot_", name, "_", diffCutoff, "_pure_str_reg")
png(here(figDir, paste0(fileName, ".png")), res = 600, units = "in", width = 5*1.5, height = 2.5*1.5)
print(cowplot::plot_grid(p1, p2, align = "h"))
dev.off()

svglite(here(figDir, paste0(fileName, ".svg")), 
        width = 5*1.5, height = 2.5*1.5)
print(cowplot::plot_grid(p1, p2, align = "h"))
dev.off()
```
##### 50kb vs 200 kb
```{r}
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, "_Anno3.tsv")))

data <- data %>% dplyr::mutate(size = start2 - start1)

data_under50kb <- data %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E"), size < 50*1000, Anno3 == "reg")
data_under200kb <- data %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E"), size >= 50*1000, size < 200*1000, Anno3 == "reg")
data_over200kb <- data %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E"), size >= 200*1000, Anno3 == "reg")

########

data <- data_under50kb

diffCutoff <- 0.2
data <- data %>%
  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, "UP", 
                                          ifelse(diff_dTAG_DMSO > -diffCutoff, "NO", "DOWN")),
                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, "UP", 
                                          ifelse(diff_A485_DMSO > -diffCutoff, "NO", "DOWN")))
data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c("UP", "NO", "DOWN"))
data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c("UP", "NO", "DOWN"))

####
num.up <- (summary(data$updown_dTAG_DMSO))["UP"]
num.no <- (summary(data$updown_dTAG_DMSO))["NO"]
num.down <- (summary(data$updown_dTAG_DMSO))["DOWN"]
num.all <- num.up + num.no + num.down
perc.up <- round(num.up / num.all * 100, 2)
perc.no <- round(num.no / num.all * 100, 2)
perc.down <- round(num.down / num.all * 100, 2)

data$density <- get_density(data$DMSO, data$dTAG, n = 100)
data <- data %>% dplyr::arrange(density)
p1 <- ggplot(data, aes(x = DMSO, y = dTAG, color = density)) +
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  annotate("text", x = -0.5, y = 1, label = paste0("UP: ", num.up, " (", perc.up, "%)"), 
           color = "black", hjust = 0, size = 3) +
  annotate("text", x = -0.5, y = 1-0.1, label = paste0("NO: ", num.no, " (", perc.no, "%)"), 
           color = "black", hjust = 0, size = 3) +
  annotate("text", x = -0.5, y = 1-0.2, label = paste0("DOWN: ", num.down, " (", perc.down, "%)"), 
           color = "black", hjust = 0, size = 3) +
  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  
  

####
num.up <- (summary(data$updown_A485_DMSO))["UP"]
num.no <- (summary(data$updown_A485_DMSO))["NO"]
num.down <- (summary(data$updown_A485_DMSO))["DOWN"]
num.all <- num.up + num.no + num.down
perc.up <- round(num.up / num.all * 100, 2)
perc.no <- round(num.no / num.all * 100, 2)
perc.down <- round(num.down / num.all * 100, 2)

data$density <- get_density(data$DMSO, data$A485, n = 100)
data <- data %>% dplyr::arrange(density)
p2 <- ggplot(data, aes(x = DMSO, y = A485, color = density)) +
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() +
  xlim(-0.5, 1) + ylim(-0.5, 1) + coord_fixed() +
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
  geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  annotate("text", x = -0.5, y = 1, label = paste0("UP: ", num.up, " (", perc.up, "%)"), 
           color = "black", hjust = 0, size = 3) +
  annotate("text", x = -0.5, y = 1-0.1, label = paste0("NO: ", num.no, " (", perc.no, "%)"), 
           color = "black", hjust = 0, size = 3) +
  annotate("text", x = -0.5, y = 1-0.2, label = paste0("DOWN: ", num.down, " (", perc.down, "%)"), 
           color = "black", hjust = 0, size = 3) +
  theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5))  
  

fileName <- paste0("scatterplot_", name, "_", diffCutoff, "_regunder50kb_pure")
png(here(figDir, paste0(fileName, ".png")), res = 600, units = "in", width = 5*1.5, height = 2.5*1.5)
print(cowplot::plot_grid(p1, p2, align = "h"))
dev.off()

svglite(here(figDir, paste0(fileName, ".svg")), 
        width = 5*1.5, height = 2.5*1.5)
print(cowplot::plot_grid(p1, p2, align = "h"))
dev.off()

```

#### One feature annotation - promoter
```{r}

name <- "chromo_cons_annoPromoter"
data <- fread(here(consensusDir, paste0(name, ".tsv")))
iterate_loop_functions(data, figDir, paste0(name, "_", "all"), unique(data$Anno2))
iterate_loop_functions(data, figDir, paste0(name, "_", "p-p"), c("P-P"))
iterate_loop_functions(data, figDir, paste0(name, "_", "p-n"), c("P-N"))
iterate_loop_functions(data, figDir, paste0(name, "_", "n-n"), c("N-N"))

colorList <- colorListPromoter
loopList <- c("N-N", "P-N", "P-P")

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, "_DMSO"), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, "_DMSO"), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, "_dTAG"), 
                                     loopList, colorList, se = TRUE)

create_score_barplot_perTreatment(temp, figDir, paste0(name, "_dTAG"), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, "_A485"), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, "_A485"), 
                                      loopList, colorList)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, "_dTAG"), 
                                     loopList, colorList, se = TRUE)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, "_A485"), 
                                     loopList, colorList, se = TRUE)
```

#### One feature annotation - enhancer
```{r}
name <- "chromo_cons_annoEnhancer"
data <- fread(here(consensusDir, paste0(name, ".tsv")))
iterate_loop_functions(data, figDir, paste0(name, "_", "all"), unique(data$Anno2))
iterate_loop_functions(data, figDir, paste0(name, "_", "e-e"), c("E-E"))
iterate_loop_functions(data, figDir, paste0(name, "_", "e-n"), c("E-N"))
iterate_loop_functions(data, figDir, paste0(name, "_", "n-n"), c("N-N"))

colorList <- colorListEnhancer
loopList <- c("N-N", "E-N", "E-E")

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, "_DMSO"), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, "_DMSO"), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, "_dTAG"), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, "_dTAG"), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, "_A485"), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, "_A485"), 
                                      loopList, colorList)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, "_dTAG"), 
                                     loopList, colorList, se = TRUE)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, "_A485"), 
                                     loopList, colorList, se = TRUE)
```
#### One feature annotation - structure

```{r}
name <- "chromo_cons_annoStructure"
data <- fread(here(consensusDir, paste0(name, ".tsv")))
iterate_loop_functions(data, figDir, paste0(name, "_", "all"), unique(data$Anno2))
iterate_loop_functions(data, figDir, paste0(name, "_", "s-s"), c("S-S"))
iterate_loop_functions(data, figDir, paste0(name, "_", "s-n"), c("S-N"))
iterate_loop_functions(data, figDir, paste0(name, "_", "n-n"), c("N-N"))

colorList <- colorListStructure
loopList <- c("N-N", "S-N", "S-S")

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, "_DMSO"), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, "_DMSO"), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, dTAG, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, "_dTAG"), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, "_dTAG"), 
                                      loopList, colorList)
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, A485, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment(temp, figDir, paste0(name, "_A485"), 
                                     loopList, colorList, se = TRUE)
create_score_barplot_perTreatment(temp, figDir, paste0(name, "_A485"), 
                                      loopList, colorList)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_dTAG_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, "_dTAG"), 
                                     loopList, colorList, se = TRUE)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, diff_A485_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgDiffScore_perTreatment(temp, figDir, paste0(name, "_A485"), 
                                     loopList, colorList, se = TRUE)

```

### [2.7] Distance vs loop # and score
```{r}
data <- fread(here(consensusDir, "chromo_cons_score.tsv")) %>%
  dplyr::mutate(distance = start2 - start1,
                res = end1 - start1)

p1 <- ggplot(data, aes(x = distance, fill = factor(res))) +
  geom_histogram(binwidth = 50000, alpha = 1) +
  labs(title = "Distribution of Distance by Resolution",
       x = "Distance",
       y = "Counts") + 
  facet_wrap(~ res, ncol = 1, scales = "free") + 
  scale_x_continuous(labels = label_kb_mb, limits = c(0, 5e6)) + 
  theme_classic() +
  theme(legend.position = "none",
        plot.title = element_text(size = 8))  # Removes the legend

png(here(figDir, paste0("consensus_dist_per_res.png")), 
    res = 600, units = "in", width = 3, height = 6)
print(p1)
dev.off()

p2 <- ggplot(data, aes(x = distance, fill = factor(res))) +
  geom_histogram(binwidth = 50000, alpha = 1) +
  labs(title = "Distribution of Distance by Resolution",
       x = "Distance",
       y = "Counts") + 
  facet_wrap(~ res, ncol = 1, scales = "free") + 
  scale_x_continuous(labels = label_kb_mb, limits = c(0, 2e6)) + 
  theme_classic() +
  theme(legend.position = "none",
        plot.title = element_text(size = 8))  # Removes the legend


png(here(figDir, paste0("consensus_dist_per_res_2mb.png")), 
    res = 600, units = "in", width = 3, height = 6)
print(p2)
dev.off()


```


```{r}
### Distance vs score
  
  temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, DMSO, dTAG, A485)
  
  avg_scores <- temp %>%
    group_by(distance) %>%
    summarise(across(starts_with("DMSO"):starts_with("A485"), mean, na.rm = TRUE))
  
  avg_scores_long <- avg_scores %>%
    pivot_longer(cols = DMSO:A485, names_to = "condition", values_to = "avg_score")
  avg_scores_long$condition <- factor(avg_scores_long$condition, levels = c("DMSO", "dTAG", "A485"))
  # Create the plot
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = condition, fill = condition)) +
    geom_smooth(show.legend = TRUE) + ylim(0, 0.5) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = c("DMSO" = "grey", "dTAG" = "pink", "A485" = "skyblue")) +
    scale_fill_manual(values = c("DMSO" = "grey80", "dTAG" = "pink", "A485" = "skyblue")) +
    labs(title = paste0("Distance vs. Average Score, ", note),
         x = "Distance",
         y = "Average Score") +
    theme(plot.title = element_text(size = 12))
  png(here(figDir, paste0("consensus_dist_vs_avgScore_allRes_pu100pz100_", note, ".png")), 
      res = 600, units = "in", width = 4, height = 3)
  print(p4)
  dev.off()

```

### [2.8] Annotating genes to P-P and P-E loops
#### Link gene to promoter anchor
Here, anchor was linked to a gene based on whether the anchor overlaps with TSS +- 2.5kb region
```{r}
# Annotating genes based on promoter anchor
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))
```


```{r}
flankSize <- 2500
gene.TSS.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)
colnames(gene.TSS.tb) <- c("chr", "start", "end", "strand", "gene", "ensembl")

fwrite(gene.TSS.tb, here(refDir, "mm10_GRCm38.p6_TSS2.5kb.bed"), sep = "\t", col.names = FALSE, row.names = FALSE)

findOverlapGene <- function(gene.TSS.tb, chrom1, start1, end1){
  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%
    dplyr::filter((start <= end1) & (end >= start1))
  return(temp$gene)
}
findOverlapEnsembl <- function(gene.TSS.tb, chrom1, start1, end1){
  temp <- gene.TSS.tb %>% dplyr::filter(chr == chrom1) %>%
    dplyr::filter((start <= end1) & (end >= start1))
  return(temp$ensembl)
}

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 == "P",
                                 list(findOverlapGene(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 == "P",
                                 list(findOverlapGene(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "P-S", "P-X")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(consensusDir, paste0(name, "_p-n_geneList.tsv")), sep = "\t")

temp_p_pe <- temp %>% dplyr::filter(Anno2 %in% c("P-P", "P-E")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_pe, here(consensusDir, paste0(name, "_p-pe_geneList.tsv")), sep = "\t")

temp <- data %>% rowwise() %>%
  dplyr::mutate(A1_gene = ifelse(A1 == "P",
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom1, start1, end1)),
                                 NA),
                A2_gene = ifelse(A2 == "P",
                                 list(findOverlapEnsembl(gene.TSS.tb, chrom2, start2, end2)),
                                 NA),
                gene = list(unique(c(A1_gene, A2_gene))))

temp_p_n <- temp %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "P-S", "P-X")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_n, here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")), sep = "\t")

temp_p_pe <- temp %>% dplyr::filter(Anno2 %in% c("P-P", "P-E")) %>% dplyr::select(-c("A1_gene", "A2_gene"))
fwrite(temp_p_pe, here(consensusDir, paste0(name, "_p-pe_ensemblList.tsv")), sep = "\t")

```
### [2.9] Size distribution of diff loops

```{r}
create_dist_barplot <- function(data, figDir, name, note, loopList, diffCutoff){
  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%
    dplyr::filter(Anno2 %in% loopList,
                  updown_dTAG_DMSO %in% c("UP", "NO", "DOWN"))
  p <- ggplot(temp, aes(x = updown_dTAG_DMSO, y = distance)) +
    geom_violin(aes(fill = updown_dTAG_DMSO)) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = updown_dTAG_DMSO), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + ggtitle(note) +
    scale_y_continuous(labels = label_kb_mb)
  fileName <- paste0("size_barplot_", name, "_dTAG_vs_DMSO_", note, "_", diffCutoff)
  height <- 3
  width <- 4
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
  
  
  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%
    dplyr::filter(Anno2 %in% loopList,
                  updown_A485_DMSO %in% c("UP", "NO",  "DOWN"))
  p <- ggplot(temp, aes(x = updown_A485_DMSO, y = distance)) +
    geom_violin(aes(fill = updown_A485_DMSO)) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = updown_A485_DMSO), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + ggtitle(note) +
    scale_y_continuous(labels = label_kb_mb)
  fileName <- paste0("size_barplot_", name, "_A485_vs_DMSO_", note, "_", diffCutoff)
  height <- 3
  width <- 4
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}


name
diffCutoff <- 0.2
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))
data <- data %>%
  dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, "UP", 
                                          ifelse(diff_dTAG_DMSO > -diffCutoff, "NO", "DOWN")),
                updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, "UP", 
                                          ifelse(diff_A485_DMSO > -diffCutoff, "NO", "DOWN")),
                distance = start2 - start1)
data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c("UP", "NO", "DOWN"))
data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c("UP", "NO", "DOWN"))
create_dist_barplot(data, figDir, name, "p-n", c("P-P", "P-E", "P-S", "P-X"), 0.2)
create_dist_barplot(data, figDir, name, "p-pe", c("P-P", "P-E"), 0.2)
create_dist_barplot(data, figDir, name, "pe-pe", c("P-P", "P-E", "E-E"), 0.2)
create_dist_barplot(data, figDir, name, "str", c("S-S", "S-X"), 0.2)

```
### [2.10] Linking with RNA-seq/PRO-seq
#### Function & parameter
```{r}
GOdir <- here("../..", "result", "loop", "GO")
dir.create(GOdir, showWarnings = FALSE, recursive = TRUE)

getGO <- function(name, figDir, geneList, categoryNum = 15, height = 10, width = 7){
  GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
  GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
  fwrite(as.data.frame(GO), here(GOdir, paste0("GO_", name, "_ensembl.tsv")), sep = "\t")
  fwrite(as.data.frame(GO.readable), here(GOdir, paste0("GO_", name, "_readable.tsv")), sep = "\t")
  
  if(nrow(as.data.frame(GO)) != 0){
    #####
    fileName <- paste0("GO_", name)
    svglite(here(figDir, paste0(fileName, ".svg")), height = height, width = width)
    print(dotplot(GO, showCategory = categoryNum, title = name) + 
            scale_color_continuous(limits = c(0, 0.05), low = "red", high = "black"))
    dev.off()
    png(here(figDir, paste0(fileName, ".png")), height = height, width = width, res = 600, unit = "in")
    print(dotplot(GO, showCategory = categoryNum, title = name) + 
            scale_color_continuous(limits = c(0, 0.05), low = "red", high = "black"))
    dev.off()
  } 
}

convPvalue <- function(pvalue){
  out <- ifelse(pvalue < 0.0001, "****",
                ifelse(pvalue < 0.001, "***",
                       ifelse(pvalue < 0.01, "**",
                              ifelse(pvalue < 0.05, "*", "ns"))))
  return(out)
}

loadLoopAnnoData <- function(fileName, diffCutoff = 0.2, annoList = c("P-P", "P-E", "P-S", "P-X")){
  data <- fread(fileName) %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, "UP", 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, "NO", "DOWN")),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, "UP", 
                                            ifelse(diff_A485_DMSO > -diffCutoff, "NO", "DOWN")),
                  gene = strsplit(gene, '\\|')) %>%
    dplyr::filter(Anno2 %in%  annoList)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c("UP", "NO", "DOWN"))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c("UP", "NO", "DOWN"))
  
  return(data)
}
```

#### dTAG Scatterplot
```{r}
loopType <- "p-n"

# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- "chromo_cons_annoHierarchy"

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>%
  dplyr::mutate(distance = start2 - start1)
# geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
#                                       diffCutoff = diffCutoff,
#                                       annoList = c("P-P"))%>% 
#   dplyr::mutate(distance = start2 - start1)
# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% c(), "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, "gene_avgScore_fc_dTAG_p-n.tsv"), sep = "\t")

#
# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag,
#                       label = ifelse(flag != "0NO", external_gene_name, NA),
#                       shape = as.factor(maxFlag))) +
#   geom_point() + geom_text_repel() + theme_classic() +
#   ggtitle("dTAG") +
#   geom_hline(yintercept = 0) +
#   geom_hline(yintercept = diffCutoff, linetype = "dashed") +
#   geom_hline(yintercept = - diffCutoff, linetype = "dashed") +
#   geom_vline(xintercept = 0) +
#   geom_vline(xintercept = fcCutoff, linetype = "dashed") +
#   geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
#   scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
#   scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))
#
# fileName <- paste0("log2FC_vs_avgScore_dTAG_", loopType, "_diffCutoff_", diffCutoff)
# height <- 4
# width <- 7
# png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
# print(p)
# dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, "2DOWN",
                              ifelse(gene %in% c(), "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

# fwrite(temp, here(consensusDir, paste0("gene_avgScore_fc_dTAG_", loopType, "_noFCcutoff.tsv")), sep = "\t")

p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point(size = 1, alpha = 1,
      stroke = 0) + geom_text_repel() + theme_classic() + 
  guides(color = "none", shape = "none") + 
  geom_hline(yintercept = 0, alpha = 1,
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square") +
  geom_hline(yintercept = c(diffCutoff, -diffCutoff), linetype = "dashed", alpha = 1,
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square") +
  geom_vline(xintercept = 0, alpha = 1,
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square") +
  geom_vline(xintercept = c(fcCutoff, -fcCutoff), linetype = "dashed", alpha = 1,
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square") +
  theme(
    axis.title.x = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),    
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) + labs(y = "Avg. Δ loop score", x = "log2(shrunken FC)") +
  scale_color_manual(values = c("0NO" = "#A9A8A9", "1UP" = "#CB333A", "2DOWN" = "#4852A0")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_dTAG_", loopType, "_diffCutoff_", diffCutoff, "_noFCcutoff")
height <- 42*mmToInch
width <- 50*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - up and down
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.updown.RNA.noFCcutoff, "2DOWN",
                              ifelse(gene %in% c(), "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("dTAG") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_dTAG_", loopType, "_diffCutoff_", diffCutoff, "_noFCcutoffupdown")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

# 
# ## RNA + PRO-seq
# temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, gene) %>% 
#   unnest(gene) %>% group_by(gene) %>%
#   summarize(mean_diff_score = mean(diff_dTAG_DMSO), .groups = 'drop')
# 
# temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
#   dplyr::mutate(flag = ifelse(gene %in% geneList.down, "2DOWN",
#                               ifelse(gene %in% geneList.up, "1UP", "0NO")),
#                 maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
#                 shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
#   dplyr::arrange(flag)
# 
# fwrite(temp, here(consensusDir, "gene_avgScore_fc_dTAG_", loopType, ".tsv"), sep = "\t")
# 
# p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
#                       label = ifelse(flag != "0NO", external_gene_name, NA),
#                       shape = as.factor(maxFlag))) +
#   geom_point() + geom_text_repel() + theme_classic() + 
#   ggtitle("dTAG") +
#   geom_hline(yintercept = 0) +
#   geom_hline(yintercept = diffCutoff, linetype = "dashed") +
#   geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
#   geom_vline(xintercept = 0) +
#   geom_vline(xintercept = fcCutoff, linetype = "dashed") +
#   geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
#   scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
#   scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))
# 
# fileName <- paste0("log2FC_vs_avgScore_dTAG_", loopType, "_diffCutoff_", diffCutoff, "_RNA-PRO")
# height <- 4
# width <- 7
# png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
# print(p)
# dev.off()
```


#### dTAG Scatterplot OE
##### Avg
```{r}

loopType <- "p-pe"

# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- "chromo_cons_annoHierarchy"

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c("id"))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% c(), "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, "gene_avgScore_fc_dTAG_p-n.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("dTAG") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_dTAG_OE_", loopType, "_avgLogOE")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, "2DOWN",
                              ifelse(gene %in% c(), "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("dTAG") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_dTAG_OE_", loopType, "_avgLogOE_noFCcutoff")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```
##### Sum
```{r}
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- "chromo_cons_annoHierarchy"

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c("id"))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% c(), "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, "gene_avgScore_fc_dTAG_p-n.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("dTAG") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = sum(log_obsexp_diff_dTAG_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, "2DOWN",
                              ifelse(gene %in% c(), "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("dTAG") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_dTAG_OE_p-n_sumLogOE_noFCcutoff")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### abs max
```{r}
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- "chromo_cons_annoHierarchy"

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c("id"))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')


temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% c(), "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, "gene_avgScore_fc_dTAG_p-n.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("dTAG") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO[which.max(abs(log_obsexp_diff_dTAG_DMSO))], .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, "2DOWN",
                              ifelse(gene %in% c(), "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("dTAG") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_dTAG_OE_p-n_absLogOE_noFCcutoff")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```
##### Closest P-N loop
```{r}
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- "chromo_cons_annoHierarchy"

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c("id"))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% 
  unnest(gene) %>% group_by(gene) %>% 
  slice_min(distance, with_ties = FALSE) %>% 
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% c(), "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, "gene_avgScore_fc_dTAG_p-n.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("dTAG") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% 
  unnest(gene) %>% group_by(gene) %>%
  slice_min(distance, with_ties = FALSE) %>% 
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, "2DOWN",
                              ifelse(gene %in% c(), "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("dTAG") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_dTAG_OE_p-n_closestLogOE_noFCcutoff")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### Farthest P-N loop
```{r}
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha)
# Importing loop gene annotation
name <- "chromo_cons_annoHierarchy"

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>% 
  dplyr::mutate(distance = start2 - start1)


# Loading OE loop score
minValue <- -4
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c("id"))

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id,
                          (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id))
geneList.down.RNA <- (diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.down.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff %>% dplyr::filter(shrinked_log2FC < 0))$ensembl_gene_id
geneList.updown.RNA.noFCcutoff <- (diff.RNA.G1.dTAG.noFCcutoff)$ensembl_gene_id

geneList.up <- unique(c((diff.RNA.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G1.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id,
                        (diff.PRO.G2.dTAG %>% dplyr::filter(shrinked_log2FC > 0))$ensembl_gene_id))


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 2

temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% 
  unnest(gene) %>% group_by(gene) %>% 
  slice_max(distance, with_ties = FALSE) %>% 
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% c(), "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

#fwrite(temp, here(consensusDir, "gene_avgScore_fc_dTAG_p-n.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("dTAG") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

# No FC cutoff option - down only
temp <- geneAnnoData %>% dplyr::select(log_obsexp_diff_dTAG_DMSO, gene, distance) %>% 
  unnest(gene) %>% group_by(gene) %>%
  slice_max(distance, with_ties = FALSE) %>% 
  summarize(mean_diff_score = log_obsexp_diff_dTAG_DMSO, .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA.noFCcutoff, "2DOWN",
                              ifelse(gene %in% c(), "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)


p <- ggplot(temp, aes(x = shrinked_log2FC, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("dTAG") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "grey", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_dTAG_OE_p-n_farthestLogOE_noFCcutoff")
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

#### A485 Scatterplot
##### P-N
```{r}
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.G1.A485 <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)

# Importing loop gene annotation
name <- "chromo_cons_annoHierarchy"

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>% 
  dplyr::mutate(distance = start2 - start1)

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, "gene_avgScore_fc_dTAG_p-n.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("A485") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "black", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_A485_p-n_diffCutoff_", diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

# [2] Sum of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, "gene_sumScore_fc_dTAG_p-n.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("A485") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "black", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_sumScore_A485_p-n_diffCutoff_", diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()


# [3] Max of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, "gene_maxAbsScore_fc_dTAG_p-n.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("A485") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "black", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_maxAbsScore_A485_p-n_diffCutoff_", diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

```
##### P-PE
```{r}
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.G1.A485 <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)

# Importing loop gene annotation
name <- "chromo_cons_annoHierarchy"

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff,
                                      annoList = c("P-P", "P-E"))%>% 
  dplyr::mutate(distance = start2 - start1)

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, "gene_avgScore_fc_dTAG_p-pe.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("A485") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "black", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_A485_p-pe_diffCutoff_", diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

# [2] Sum of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, "gene_sumScore_fc_dTAG_p-pe.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("A485") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "black", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_sumScore_A485_p-pe_diffCutoff_", diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()


# [3] Max of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, "gene_maxAbsScore_fc_dTAG_p-pe.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("A485") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "black", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_maxAbsScore_A485_p-pe_diffCutoff_", diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### P-S
```{r}
# getting list of genes of interest from RNA-seq and PRO-seq
alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.G1.A485 <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)

# Importing loop gene annotation
name <- "chromo_cons_annoHierarchy"

diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff,
                                      annoList = c("P-S"))%>% 
  dplyr::mutate(distance = start2 - start1)

# Testing different ways to calculate representative feature of loops for each gene
diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
geneList.down.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC < -fcCutoff))$ensembl_gene_id
geneList.up.RNA <- (diff.RNA.G1.A485 %>% dplyr::filter(shrinked_log2FC > fcCutoff))$ensembl_gene_id


# [1] Average of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, "gene_avgScore_fc_dTAG_p-s.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = mean_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("A485") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "black", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_avgScore_A485_p-s_diffCutoff_", diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

# [2] Sum of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(sum_diff_score = sum(diff_A485_DMSO), .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, "gene_sumScore_fc_dTAG_p-s.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = sum_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("A485") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "black", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_sumScore_A485_p-s_diffCutoff_", diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()


# [3] Max of differential loop scores for each gene
## RNA only
fcCutoff <- 0.5
alpha <- 0.05
maxLog2FC <- 4

temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(max_abs_diff_score = diff_A485_DMSO[which.max(abs(diff_A485_DMSO))], .groups = 'drop')

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% geneList.down.RNA, "2DOWN",
                              ifelse(gene %in% geneList.up.RNA, "1UP", "0NO")),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                shrlog2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag)

fwrite(temp, here(consensusDir, "gene_maxAbsScore_fc_dTAG_p-s.tsv"), sep = "\t")

p <- ggplot(temp, aes(x = shrlog2fcMax, y = max_abs_diff_score, color = flag, 
                      label = ifelse(flag != "0NO", external_gene_name, NA),
                      shape = as.factor(maxFlag))) +
  geom_point() + geom_text_repel() + theme_classic() + 
  ggtitle("A485") +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = diffCutoff, linetype = "dashed") +
  geom_hline(yintercept = - diffCutoff, linetype = "dashed") + 
  geom_vline(xintercept = 0) +
  geom_vline(xintercept = fcCutoff, linetype = "dashed") +
  geom_vline(xintercept = -fcCutoff, linetype = "dashed") +
  scale_color_manual(values = c("0NO" = "black", "1UP" = "red", "2DOWN" = "blue")) +  # Corrected color mapping
  scale_shape_manual(values = c("TRUE" = 2, "FALSE" = 19))

fileName <- paste0("log2FC_vs_maxAbsScore_A485_p-s_diffCutoff_", diffCutoff)
height <- 4
width <- 7
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```


## [2.11] How many loops per gene?
```{r}
# IMPORTING GENE ANNO DATA FOR P-N LOOPS
name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = 0.2,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = "_"))


# Counting number of loop per genes
tempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(
    peak = list(peakID),
    anno2 = list(Anno2),
    count = n())

ggplot(tempSum, aes(x = count)) + geom_histogram(binwidth = 1) + theme_classic() + 
  ggtitle("# of P-N loops for each gene") + scale_y_log10()

###################################################################################
```

## [2.11.2] SuperEnhancer?
```{r}
# IMPORTING GENE ANNO DATA FOR P-N LOOPS
name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = 0.2,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))

tempSE <- geneAnnoData %>% unnest(gene) %>% group_by(gene) %>% summarize(SE = ifelse(any(AnnoSE == "SE"), 1, 0))


group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv"))$gene
group5 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv"))$gene
group8 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv"))$gene


tempSE <- tempSE %>% rowwise() %>% dplyr::mutate(
  group = ifelse(gene %in% group1, "group1",
                 ifelse(gene %in% group2, "group2",
                        ifelse(gene %in% group5, "group5",
                               ifelse(gene %in% group8, "group8", NA))))) %>% 
  dplyr::filter(!is.na(group))

perc.group1 <- nrow(tempSE %>% dplyr::filter(group == "group1", SE == 1))/
  nrow(tempSE %>% dplyr::filter(group == "group1"))

perc.group2 <- nrow(tempSE %>% dplyr::filter(group == "group2", SE == 1))/
  nrow(tempSE %>% dplyr::filter(group == "group2"))

perc.group5 <- nrow(tempSE %>% dplyr::filter(group == "group5", SE == 1))/
  nrow(tempSE %>% dplyr::filter(group == "group5"))

perc.group8 <- nrow(tempSE %>% dplyr::filter(group == "group8", SE == 1))/
  nrow(tempSE %>% dplyr::filter(group == "group8"))

tempPlot <- tibble(group = c("group1", "group2", "group5", "group8"),
                   perc = c(perc.group1, perc.group2, perc.group5, perc.group8))

ggplot(tempPlot, aes(x = group, y = perc)) + geom_point() + theme_classic() + ylim(0, 0.2)
```


```{r}
plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  p15 <- round(getPvalWilcox(temp.tb, "group1", "group5"), 5)
  p18 <- round(getPvalWilcox(temp.tb, "group1", "group8"), 5)
  p25 <- round(getPvalWilcox(temp.tb, "group2", "group5"), 5)
  p28 <- round(getPvalWilcox(temp.tb, "group2", "group8"), 5)
  p58 <- round(getPvalWilcox(temp.tb, "group5", "group8"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate("text", x = 1, y = ymin + 1, label = paste0("p12: ", convPvalue(p12), "\n",
                                                         "p15: ", convPvalue(p15), "\n",
                                                         "p18: ", convPvalue(p18), "\n",
                                                         "p25: ", convPvalue(p25), "\n",
                                                         "p28: ", convPvalue(p28), "\n",
                                                         "p58: ",convPvalue( p58), "\n"),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("insulation_score_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_DMSO")



```


## [2.12] How many loops/distance per gene in each quadrant?
#### dTAG with binary grouping
##### Splitting genes to group
```{r}
name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = 0.2,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = "_"))


## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  drop_na(shrinked_log2FC)


temp <- temp %>%
  dplyr::mutate(group = ifelse(padj < 0.05 & shrinked_log2FC < 0, 1, 
                               ifelse(mean_diff_score < 0, 2, 3)))



fcCutoff <- 0.5
diffCutoff <- 0.2

gene.group1 <- (temp %>% dplyr::filter(group == 1))$gene
gene.group2 <- (temp %>% dplyr::filter(group == 2))$gene
fwrite((temp %>% dplyr::filter(group == 1)), here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 2)), here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"), sep = "\t")


# Adding group information to geneAnno
geneAnnoData <- geneAnnoData %>% unnest(gene) %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, "group1",
                 ifelse(gene %in% gene.group2, "group2", NA))
)


```
##### - GO for each group

```{r}

gene.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
gene.group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

GO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE)
GO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE)
GO1.df <- as.data.frame(GO1)
GO2.df <- as.data.frame(GO2)
# fwrite(GO1.df, here("GO_binary_group1.tsv"), sep = "\t")
# fwrite(GO2.df, here("GO_binary_group2.tsv"), sep = "\t")
GO1.df <- fread(here("GO_binary_group1.tsv"))
GO2.df <- fread(here("GO_binary_group2.tsv"))

subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 1") %>%
  dplyr::arrange(p.adjust)
subset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))

subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 2") %>%
  dplyr::arrange(p.adjust)
subset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))


GOlist <- factor(c("GO:0001824", "GO:0030879", "GO:0021953", "GO:0019827", 
                 "GO:0022613", "GO:0050767", "GO:0034470", "GO:0016055", 
                 "GO:0006397", "GO:0030900", "GO:0008380"))

data <- bind_rows(subset1, subset2) %>%
  dplyr::filter(ID %in% GOlist)

descOrder <- sort(unique(data$Description))[c(4, 10, 2, 1, 3, 11, 7, 8, 6, 5, 9)]
pValueLogMax <- 10
data <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))
p <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + 
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM) + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = "white", high = "#CB333A",
                      # limits = c(0, 1),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL) +
  theme_bw() +  # Apply theme_bw first, so custom theme settings come after
  theme(
    panel.background = element_rect(fill = "transparent"),  # Override theme_bw panel
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      size = fontSizeS,         # Ensure size is set for x-axis text
      family = fontType,
      color = "#000000",
    ),
    axis.text.y = element_text(
      size = fontSizeS,         # Ensure size is set for y-axis text
      family = fontType,
      color = "#000000",
      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick * mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick * mmToLineUnit,
      lineend = "square"
    ),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )
  


fileName <- here(figDir, "..", "GO", "GO_groups_binaryGrouping")
width <- panelSize(2.5)*mmToInch
height <- panelSize(1.2)*mmToInch
svglite(paste0(fileName, ".svg"), height = height, width = width)
print(p)
dev.off()
```


##### - Average loop size
```{r}
# Checking average distance of loops per gene
# temp is a tibble where delta loop and log2fc are merged
temp$group <- factor(temp$group)

temp <- temp %>% dplyr::filter(group %in% c(1, 2))


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$mean_distance
  distance2 <- (data %>% dplyr::filter(group ==group2) )$mean_distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv12 <- round(getPvalWilcox(temp, 1, 2), 5)



p <- ggplot(temp, aes(x = group, y = mean_distance)) + geom_violin(aes(fill = group), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")+
  annotate("text", x = 1, y = 1000000, label = paste0("pv12: ", pv12),
           color = "black", hjust = 0, size = 3)
  
  
fileName <- paste0("size_barplot_diffGroup_dTAG_vs_DMSO_binaryGroup")
height <- 3
width <- 2
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Loop number per gene: P-N
```{r}
# Counting number of loop per genes
tempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(
    peak = list(peakID),
    anno2 = list(Anno2),
    count = n())

tempSum <- tempSum %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, "group1",
                 ifelse(gene %in% gene.group2, "group2", NA))
) %>% dplyr::filter(!is.na(group)) %>% dplyr::filter(group %in% c("group1", "group2"))

# 
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$count
  distance2 <- (data %>% dplyr::filter(group ==group2) )$count
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


pv12 <- round(getPvalWilcox(tempSum,"group1", "group2"), 5)
# pv15 <- round(getPvalWilcox(tempSum,"group1", "group5"), 5)
# pv18 <- round(getPvalWilcox(tempSum,"group1", "group8"), 5)
# pv25 <- round(getPvalWilcox(tempSum,"group2", "group5"), 5)
# pv28 <- round(getPvalWilcox(tempSum,"group2", "group8"), 5)
# pv58 <- round(getPvalWilcox(tempSum,"group5", "group8"), 5)


p <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA, color = "black", alpha = 0.6,
                 linewidth = lineThick * mmToLineUnit, lineend = "square", show.legend = FALSE) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  labs(x = NULL, y = "# of P-N loops per gene") +
  coord_cartesian(ylim = c(0, 8)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black"
  )+
  annotate("text", x = 1, y = 3, label = paste0("pv12: ", convPvalue(pv12)),
           color = "black", hjust = 0, size = 1) +
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )


fileName <- paste0("count_barplot_diffGroup_dTAG_vs_DMSO_binaryGroup")
width <- panelSize(0.8)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Counting loop types
```{r}
#######
temp2 <- tempSum %>% rowwise() %>% mutate(total = length(anno2),
                                 num_pp = sum(anno2 == "P-P"),
                                 num_pe = sum(anno2 == "P-E"),
                                 num_ps = sum(anno2 == "P-S"),
                                 num_px = sum(anno2 == "P-X"),
                                 ratio_reg = (num_pp + num_pe)/total,
                                 ratio_str = num_ps/total)

#saveRDS(temp2, here(resultDir, "gene_loop_link_A485.rds"))


loopType <- temp2 %>% group_by(group) %>% summarise(num_pp = sum(num_pp),
                                        num_pe = sum(num_pe),
                                        num_ps = sum(num_ps),
                                        num_px = sum(num_px))


loopTypeLong <- loopType %>% pivot_longer(-group, names_to = "type", values_to = "count")

loopTypeLong$type <- factor(loopTypeLong$type, levels = c("num_pp", "num_pe", "num_ps", "num_px"))

# Plotting
ggplot(loopTypeLong, aes(fill=type, y=count, x=group)) + 
    geom_bar(position="fill", stat="identity") + theme_classic()

```

##### - Loop number per gene: P-P
```{r}
########
#P-P
data <- temp2 %>% dplyr::select(group, num_pp)
colnames(data) <- c("group", "count")
pv12 <- round(getPvalWilcox(data,"group1", "group2"), 5)
# pv15 <- round(getPvalWilcox(data,"group1", "group5"), 5)
# pv18 <- round(getPvalWilcox(data,"group1", "group8"), 5)
# pv25 <- round(getPvalWilcox(data,"group2", "group5"), 5)
# pv28 <- round(getPvalWilcox(data,"group2", "group8"), 5)
# pv58 <- round(getPvalWilcox(data,"group5", "group8"), 5)


p <- ggplot(data, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA, color = "black", alpha = 0.6,
                 linewidth = lineThick * mmToLineUnit, lineend = "square", show.legend = FALSE) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  labs(x = NULL, y = "# of P-P loops per gene") +
  coord_cartesian(ylim = c(0, 4)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black"
  )+
  annotate("text", x = 1, y = 3, label = paste0("pv12: ", convPvalue(pv12)),
           color = "black", hjust = 0, size = 1) +
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )

fileName <- paste0("count_barplot_diffGroup_dTAG_vs_DMSO_pp_binaryGroup")
width <- panelSize(0.8)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Loop number per gene: P-E
```{r}
########
#P-E
data <- temp2 %>% dplyr::select(group, num_pe)
colnames(data) <- c("group", "count")
pv12 <- round(getPvalWilcox(data,"group1", "group2"), 5)


p <- ggplot(data, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA, color = "black", alpha = 0.6,
                 linewidth = lineThick * mmToLineUnit, lineend = "square", show.legend = FALSE) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  labs(x = NULL, y = "# of P-E loops per gene") +
  coord_cartesian(ylim = c(0, 4)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black"
  )+
  annotate("text", x = 1, y = 3, label = paste0("pv12: ", convPvalue(pv12)),
           color = "black", hjust = 0, size = 1) +
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )



fileName <- paste0("count_barplot_diffGroup_dTAG_vs_DMSO_pe_binaryGroup")
width <- panelSize(0.8)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Loop number per gene: P-S
```{r}
########
#P-S
data <- temp2 %>% dplyr::select(group, num_ps)
colnames(data) <- c("group", "count")
pv12 <- round(getPvalWilcox(data,"group1", "group2"), 5)


p <- ggplot(data, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA, color = "black", alpha = 0.6,
                 linewidth = lineThick * mmToLineUnit, lineend = "square", show.legend = FALSE) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  labs(x = NULL, y = "# of P-S loops per gene") +
  coord_cartesian(ylim = c(0, 4)) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black"
  )+
  annotate("text", x = 1, y = 3, label = paste0("pv12: ", convPvalue(pv12)),
           color = "black", hjust = 0, size = 1) +
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )



fileName <- paste0("count_barplot_diffGroup_dTAG_vs_DMSO_ps_binaryGroup")
width <- panelSize(0.8)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

#### dTAG
##### - Splitting genes to groups
```{r}
name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = 0.2,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = "_"))



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  drop_na(shrinked_log2FC)


fcCutoff <- 0.5
diffCutoff <- 0.2
# 
temp <- temp %>%
  dplyr::mutate(group = ifelse(mean_diff_score < -diffCutoff,
                               ifelse(shrinked_log2FC < -fcCutoff, 1,
                                      ifelse(shrinked_log2FC <fcCutoff, 2, 3)),
                               ifelse(mean_diff_score < diffCutoff,
                                      ifelse(shrinked_log2FC < -fcCutoff, 4,
                                             ifelse(shrinked_log2FC < fcCutoff, 5, 6)),
                                      ifelse(shrinked_log2FC < -fcCutoff, 7,
                                             ifelse(shrinked_log2FC < fcCutoff, 8, 9)))))


gene.group1 <- (temp %>% dplyr::filter(group == 1))$gene
gene.group2 <- (temp %>% dplyr::filter(group == 2))$gene
gene.group3 <- (temp %>% dplyr::filter(group == 3))$gene
gene.group4 <- (temp %>% dplyr::filter(group == 4))$gene
gene.group5 <- (temp %>% dplyr::filter(group == 5))$gene
gene.group6 <- (temp %>% dplyr::filter(group == 6))$gene
gene.group7 <- (temp %>% dplyr::filter(group == 7))$gene
gene.group8 <- (temp %>% dplyr::filter(group == 8))$gene
gene.group9 <- (temp %>% dplyr::filter(group == 9))$gene

fwrite((temp %>% dplyr::filter(group == 1)), here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 2)), here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 3)), here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group3.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 4)), here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group4.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 5)), here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 6)), here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group6.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 7)), here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group7.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 8)), here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 9)), here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group9.tsv"), sep = "\t")


# Adding group information to geneAnno
geneAnnoData <- geneAnnoData %>% unnest(gene) %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, "group1",
                 ifelse(gene %in% gene.group2, "group2",
                        ifelse(gene %in% gene.group3, "group3",
                               ifelse(gene %in% gene.group4, "group4",
                                      ifelse(gene %in% gene.group5, "group5",
                                             ifelse(gene %in% gene.group6, "group6",
                                                    ifelse(gene %in% gene.group7, "group7",
                                                           ifelse(gene %in% gene.group8, "group8",
                                                                  ifelse(gene %in% gene.group9, "group9", NA)))))))))
)


```
##### - GO for each group

```{r}
GO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO5 <- enrichGO(gene = gene.group5, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO8 <- enrichGO(gene = gene.group8, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")

GO1.df <- as.data.frame(GO1)
GO2.df <- as.data.frame(GO2)
GO3.df <- as.data.frame(GO5)
GO4.df <- as.data.frame(GO8)

subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "group1") %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by "/"
      parts <- unlist(strsplit(x, "/"))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset2 <- GO2.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = "group2") %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by "/"
      parts <- unlist(strsplit(x, "/"))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset3 <- GO3.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = "group3") %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by "/"
      parts <- unlist(strsplit(x, "/"))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

GOlist <- factor(c("GO:0033002", "GO:0070373", "GO:0048730", "GO:0031103",
                 "GO:0022613", "GO:0050767", "GO:0034470", "GO:0016055", 
                 "GO:0006397", "GO:0030900", "GO:0008380"))

data <- bind_rows(bind_rows(subset1, subset2), subset3) %>%
  dplyr::filter(ID %in% GOlist)

descOrder <- sort(unique(data$Description))[c(1, 2, 5, 7,
                                 3, 4, 6, 8, 9, 10, 11)]

p <- ggplot(data, aes(x = group, y = factor(Description, level = descOrder), color = p.adjust, size = gr)) + 
  geom_point() + theme_bw() +
  scale_color_gradient(low = "red", high = "blue", limits = c(0, 0.05)) +
  scale_size_continuous(range = c(0, 3)) +
  labs(x = NULL, y = NULL) +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- here(figDir, "..", "GO", "GO_groups")
height = 2
width = 3.5
svglite(paste0(fileName, ".svg"), height = height, width = width)
print(p)
dev.off()
```



##### - Average loop size
```{r}
# Checking average distance of loops per gene
# temp is a tibble where delta loop and log2fc are merged
temp$group <- factor(temp$group)

#
temp <- temp %>% dplyr::filter(group %in% c(1, 2, 5, 8))


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$mean_distance
  distance2 <- (data %>% dplyr::filter(group ==group2) )$mean_distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv12 <- round(getPvalWilcox(temp, 1, 2), 5)
pv15 <- round(getPvalWilcox(temp, 1, 5), 5)
pv18 <- round(getPvalWilcox(temp, 1, 8), 5)
pv25 <- round(getPvalWilcox(temp, 2, 5), 5)
pv28 <- round(getPvalWilcox(temp, 2, 8), 5)
pv58 <- round(getPvalWilcox(temp, 5, 8), 5)


p <- ggplot(temp, aes(x = group, y = mean_distance)) + geom_violin(aes(fill = group), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  annotate("text", x = 1, y = 1000000, label = paste0("pv12: ", pv12, "\n",
                                                      "pv15: ", pv15, "\n",
                                                      "pv18: ", pv18, "\n",
                                                      "pv25: ", pv25, "\n",
                                                      "pv28: ", pv28, "\n",
                                                      "pv58: ", pv58, "\n"), 
           color = "black", hjust = 0, size = 3)
  
  
fileName <- paste0("size_barplot_diffGroup_dTAG_vs_DMSO")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Loop number per gene: P-N
```{r}
# Counting number of loop per genes
tempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(
    peak = list(peakID),
    anno2 = list(Anno2),
    count = n())

tempSum <- tempSum %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, "group1",
                 ifelse(gene %in% gene.group2, "group2",
                        ifelse(gene %in% gene.group3, "group3",
                               ifelse(gene %in% gene.group4, "group4",
                                      ifelse(gene %in% gene.group5, "group5",
                                             ifelse(gene %in% gene.group6, "group6",
                                                    ifelse(gene %in% gene.group7, "group7",
                                                           ifelse(gene %in% gene.group8, "group8",
                                                                  ifelse(gene %in% gene.group9, "group9", NA)))))))))
) %>%
  dplyr::filter(group %in% c("group1", "group2", "group5", "group8"))


# TEMP START
#geneList.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv"))
#geneList.group1.temp <- geneList.group1 %>% dplyr::left_join(tempSum, by = c("gene"))
# TEMP END

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$count
  distance2 <- (data %>% dplyr::filter(group ==group2) )$count
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


pv12 <- round(getPvalWilcox(tempSum,"group1", "group2"), 5)
pv15 <- round(getPvalWilcox(tempSum,"group1", "group5"), 5)
pv18 <- round(getPvalWilcox(tempSum,"group1", "group8"), 5)
pv25 <- round(getPvalWilcox(tempSum,"group2", "group5"), 5)
pv28 <- round(getPvalWilcox(tempSum,"group2", "group8"), 5)
pv58 <- round(getPvalWilcox(tempSum,"group5", "group8"), 5)


p <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2), limits = c(0, 10)) + 
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")  +
  annotate("text", x = 1, y = 3, label = paste0("pv12: ", pv12, "\n",
                                                "pv15: ", pv15, "\n",
                                                "pv18: ", pv18, "\n",
                                                "pv25: ", pv25, "\n",
                                                "pv28: ", pv28, "\n",
                                                "pv58: ", pv58, "\n"), 
           color = "black", hjust = 0, size = 1) +  theme(legend.position = "none")


fileName <- paste0("count_barplot_diffGroup_dTAG_vs_DMSO")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Counting loop types
```{r}
#######
temp2 <- tempSum %>% rowwise() %>% mutate(total = length(anno2),
                                 num_pp = sum(anno2 == "P-P"),
                                 num_pe = sum(anno2 == "P-E"),
                                 num_ps = sum(anno2 == "P-S"),
                                 num_px = sum(anno2 == "P-X"),
                                 ratio_reg = (num_pp + num_pe)/total,
                                 ratio_str = num_ps/total)

saveRDS(temp2, here(resultDir, "gene_loop_link.rds"))


loopType <- temp2 %>% group_by(group) %>% summarise(num_pp = sum(num_pp),
                                        num_pe = sum(num_pe),
                                        num_ps = sum(num_ps),
                                        num_px = sum(num_px))


loopTypeLong <- loopType %>% pivot_longer(-group, names_to = "type", values_to = "count")

loopTypeLong$type <- factor(loopTypeLong$type, levels = c("num_pp", "num_pe", "num_ps", "num_px"))

# Plotting
ggplot(loopTypeLong, aes(fill=type, y=count, x=group)) + 
    geom_bar(position="fill", stat="identity") + theme_classic()

```

##### - Loop number per gene: P-P
```{r}
########
#P-P
data <- temp2 %>% dplyr::select(group, num_pp)
colnames(data) <- c("group", "count")
pv12 <- round(getPvalWilcox(data,"group1", "group2"), 5)
pv15 <- round(getPvalWilcox(data,"group1", "group5"), 5)
pv18 <- round(getPvalWilcox(data,"group1", "group8"), 5)
pv25 <- round(getPvalWilcox(data,"group2", "group5"), 5)
pv28 <- round(getPvalWilcox(data,"group2", "group8"), 5)
pv58 <- round(getPvalWilcox(data,"group5", "group8"), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")  +
  annotate("text", x = 1, y = 3, label = paste0("pv12: ", pv12, "\n",
                                                "pv15: ", pv15, "\n",
                                                "pv18: ", pv18, "\n",
                                                "pv25: ", pv25, "\n",
                                                "pv28: ", pv28, "\n",
                                                "pv58: ", pv58, "\n"), 
           color = "black", hjust = 0, size = 1)+  theme(legend.position = "none")


fileName <- paste0("count_barplot_diffGroup_dTAG_vs_DMSO_pp")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Loop number per gene: P-E
```{r}
########
#P-E
data <- temp2 %>% dplyr::select(group, num_pe)
colnames(data) <- c("group", "count")
pv12 <- round(getPvalWilcox(data,"group1", "group2"), 5)
pv15 <- round(getPvalWilcox(data,"group1", "group5"), 5)
pv18 <- round(getPvalWilcox(data,"group1", "group8"), 5)
pv25 <- round(getPvalWilcox(data,"group2", "group5"), 5)
pv28 <- round(getPvalWilcox(data,"group2", "group8"), 5)
pv58 <- round(getPvalWilcox(data,"group5", "group8"), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")  +
  annotate("text", x = 1, y = 3, label = paste0("pv12: ", pv12, "\n",
                                                "pv15: ", pv15, "\n",
                                                "pv18: ", pv18, "\n",
                                                "pv25: ", pv25, "\n",
                                                "pv28: ", pv28, "\n",
                                                "pv58: ", pv58, "\n"), 
           color = "black", hjust = 0, size = 1)+  theme(legend.position = "none")


fileName <- paste0("count_barplot_diffGroup_dTAG_vs_DMSO_pe")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Loop number per gene: P-S
```{r}
########
#P-S
data <- temp2 %>% dplyr::select(group, num_ps)
colnames(data) <- c("group", "count")
pv12 <- round(getPvalWilcox(data,"group1", "group2"), 5)
pv15 <- round(getPvalWilcox(data,"group1", "group5"), 5)
pv18 <- round(getPvalWilcox(data,"group1", "group8"), 5)
pv25 <- round(getPvalWilcox(data,"group2", "group5"), 5)
pv28 <- round(getPvalWilcox(data,"group2", "group8"), 5)
pv58 <- round(getPvalWilcox(data,"group5", "group8"), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")  +
  annotate("text", x = 1, y = 3, label = paste0("pv12: ", pv12, "\n",
                                                "pv15: ", pv15, "\n",
                                                "pv18: ", pv18, "\n",
                                                "pv25: ", pv25, "\n",
                                                "pv28: ", pv28, "\n",
                                                "pv58: ", pv58, "\n"), 
           color = "black", hjust = 0, size = 1)+  theme(legend.position = "none")


fileName <- paste0("count_barplot_diffGroup_dTAG_vs_DMSO_ps")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Loop number per gene: P-X
```{r}
########
#P-X
data <- temp2 %>% dplyr::select(group, num_px)
colnames(data) <- c("group", "count")
pv12 <- round(getPvalWilcox(data,"group1", "group2"), 5)
pv15 <- round(getPvalWilcox(data,"group1", "group5"), 5)
pv18 <- round(getPvalWilcox(data,"group1", "group8"), 5)
pv25 <- round(getPvalWilcox(data,"group2", "group5"), 5)
pv28 <- round(getPvalWilcox(data,"group2", "group8"), 5)
pv58 <- round(getPvalWilcox(data,"group5", "group8"), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")  +
  annotate("text", x = 1, y = 3, label = paste0("pv12: ", pv12, "\n",
                                                "pv15: ", pv15, "\n",
                                                "pv18: ", pv18, "\n",
                                                "pv25: ", pv25, "\n",
                                                "pv28: ", pv28, "\n",
                                                "pv58: ", pv58, "\n"), 
           color = "black", hjust = 0, size = 1)+  theme(legend.position = "none")


fileName <- paste0("count_barplot_diffGroup_dTAG_vs_DMSO_px")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

#### A485
##### - Splitting genes to groups
```{r}
name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = 0.2,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = "_"))



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)


temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  drop_na(shrinked_log2FC)


fcCutoff <- 0.5
diffCutoff <- 0.2
# 
temp <- temp %>%
  dplyr::mutate(group = ifelse(mean_diff_score < -diffCutoff,
                               ifelse(shrinked_log2FC < -fcCutoff, 1,
                                      ifelse(shrinked_log2FC <fcCutoff, 2, 3)),
                               ifelse(mean_diff_score < diffCutoff,
                                      ifelse(shrinked_log2FC < -fcCutoff, 4,
                                             ifelse(shrinked_log2FC < fcCutoff, 5, 6)),
                                      ifelse(shrinked_log2FC < -fcCutoff, 7,
                                             ifelse(shrinked_log2FC < fcCutoff, 8, 9)))))


gene.group1 <- (temp %>% dplyr::filter(group == 1))$gene
gene.group2 <- (temp %>% dplyr::filter(group == 2))$gene
gene.group3 <- (temp %>% dplyr::filter(group == 3))$gene
gene.group4 <- (temp %>% dplyr::filter(group == 4))$gene
gene.group5 <- (temp %>% dplyr::filter(group == 5))$gene
gene.group6 <- (temp %>% dplyr::filter(group == 6))$gene
gene.group7 <- (temp %>% dplyr::filter(group == 7))$gene
gene.group8 <- (temp %>% dplyr::filter(group == 8))$gene
gene.group9 <- (temp %>% dplyr::filter(group == 9))$gene

fwrite((temp %>% dplyr::filter(group == 1)), here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group1.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 2)), here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group2.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 3)), here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group3.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 4)), here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group4.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 5)), here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group5.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 6)), here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group6.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 7)), here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group7.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 8)), here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group8.tsv"), sep = "\t")
fwrite((temp %>% dplyr::filter(group == 9)), here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group9.tsv"), sep = "\t")


# Adding group information to geneAnno
geneAnnoData <- geneAnnoData %>% unnest(gene) %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, "group1",
                 ifelse(gene %in% gene.group2, "group2",
                        ifelse(gene %in% gene.group3, "group3",
                               ifelse(gene %in% gene.group4, "group4",
                                      ifelse(gene %in% gene.group5, "group5",
                                             ifelse(gene %in% gene.group6, "group6",
                                                    ifelse(gene %in% gene.group7, "group7",
                                                           ifelse(gene %in% gene.group8, "group8",
                                                                  ifelse(gene %in% gene.group9, "group9", NA)))))))))
)


```
##### - GO for each group

```{r}
GO1 <- enrichGO(gene = gene.group1, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO2 <- enrichGO(gene = gene.group2, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO3 <- enrichGO(gene = gene.group3, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO4 <- enrichGO(gene = gene.group4, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO5 <- enrichGO(gene = gene.group5, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO6 <- enrichGO(gene = gene.group6, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO7 <- enrichGO(gene = gene.group7, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO8 <- enrichGO(gene = gene.group8, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO9 <- enrichGO(gene = gene.group9, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")

dotplot(GO1, showCategory = 10)

# 
# GO1.df <- as.data.frame(GO1)
# GO2.df <- as.data.frame(GO2)
# GO3.df <- as.data.frame(GO5)
# GO4.df <- as.data.frame(GO8)
# 
# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "group1") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = "group2") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset3 <- GO3.df %>% dplyr::select(ID, Description,GeneRatio, p.adjust) %>% dplyr::mutate(group = "group3") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# GOlist <- factor(c("GO:0033002", "GO:0070373", "GO:0048730", "GO:0031103",
#                  "GO:0022613", "GO:0050767", "GO:0034470", "GO:0016055", 
#                  "GO:0006397", "GO:0030900", "GO:0008380"))
# 
# data <- bind_rows(bind_rows(subset1, subset2), subset3) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# descOrder <- sort(unique(data$Description))[c(1, 2, 5, 7,
#                                  3, 4, 6, 8, 9, 10, 11)]
# 
# p <- ggplot(data, aes(x = group, y = factor(Description, level = descOrder), color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = "red", high = "blue", limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, "..", "GO", "GO_groups")
# height = 2
# width = 3.5
# svglite(paste0(fileName, ".svg"), height = height, width = width)
# print(p)
# dev.off()
```



##### - Average loop size
```{r}
# Checking average distance of loops per gene
# temp is a tibble where delta loop and log2fc are merged
temp$group <- factor(temp$group)


# 
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group ==group1) )$mean_distance
#   distance2 <- (data %>% dplyr::filter(group ==group2) )$mean_distance
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# pv12 <- round(getPvalWilcox(temp, 1, 2), 5)
# pv15 <- round(getPvalWilcox(temp, 1, 5), 5)
# pv18 <- round(getPvalWilcox(temp, 1, 8), 5)
# pv25 <- round(getPvalWilcox(temp, 2, 5), 5)
# pv28 <- round(getPvalWilcox(temp, 2, 8), 5)
# pv58 <- round(getPvalWilcox(temp, 5, 8), 5)


p <- ggplot(temp, aes(x = group, y = mean_distance)) + geom_violin(aes(fill = group), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")
  # annotate("text", x = 1, y = 1000000, label = paste0("pv12: ", pv12, "\n",
  #                                                     "pv15: ", pv15, "\n",
  #                                                     "pv18: ", pv18, "\n",
  #                                                     "pv25: ", pv25, "\n",
  #                                                     "pv28: ", pv28, "\n",
  #                                                     "pv58: ", pv58, "\n"), 
  #          color = "black", hjust = 0, size = 3)
  # 
  
fileName <- paste0("size_barplot_diffGroup_A485_vs_DMSO")
height <- 3
width <- 4
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Loop number per gene: P-N
```{r}
# Counting number of loop per genes
tempSum <- geneAnnoData %>% dplyr::select(peakID, gene, Anno2) %>% unnest(gene) %>% group_by(gene) %>%  summarize(
    peak = list(peakID),
    anno2 = list(Anno2),
    count = n())

tempSum <- tempSum %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, "group1",
                 ifelse(gene %in% gene.group2, "group2",
                        ifelse(gene %in% gene.group3, "group3",
                               ifelse(gene %in% gene.group4, "group4",
                                      ifelse(gene %in% gene.group5, "group5",
                                             ifelse(gene %in% gene.group6, "group6",
                                                    ifelse(gene %in% gene.group7, "group7",
                                                           ifelse(gene %in% gene.group8, "group8",
                                                                  ifelse(gene %in% gene.group9, "group9", NA)))))))))
) %>% dplyr::filter(!is.na(group))

# 
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group ==group1) )$count
#   distance2 <- (data %>% dplyr::filter(group ==group2) )$count
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# 
# pv12 <- round(getPvalWilcox(tempSum,"group1", "group2"), 5)
# pv15 <- round(getPvalWilcox(tempSum,"group1", "group5"), 5)
# pv18 <- round(getPvalWilcox(tempSum,"group1", "group8"), 5)
# pv25 <- round(getPvalWilcox(tempSum,"group2", "group5"), 5)
# pv28 <- round(getPvalWilcox(tempSum,"group2", "group8"), 5)
# pv58 <- round(getPvalWilcox(tempSum,"group5", "group8"), 5)


p <- ggplot(tempSum, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 10, by = 2)) + 
  coord_cartesian(ylim = c(0, 10)) +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  theme(legend.position = "none")
  # annotate("text", x = 1, y = 3, label = paste0("pv12: ", pv12, "\n",
  #                                               "pv15: ", pv15, "\n",
  #                                               "pv18: ", pv18, "\n",
  #                                               "pv25: ", pv25, "\n",
  #                                               "pv28: ", pv28, "\n",
  #                                               "pv58: ", pv58, "\n"), 
  #          color = "black", hjust = 0, size = 1) +  


fileName <- paste0("count_barplot_diffGroup_A485_vs_DMSO")
height <- 3
width <- 4
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Counting loop types
```{r}
#######
temp2 <- tempSum %>% rowwise() %>% mutate(total = length(anno2),
                                 num_pp = sum(anno2 == "P-P"),
                                 num_pe = sum(anno2 == "P-E"),
                                 num_ps = sum(anno2 == "P-S"),
                                 num_px = sum(anno2 == "P-X"),
                                 ratio_reg = (num_pp + num_pe)/total,
                                 ratio_str = num_ps/total)

saveRDS(temp2, here(resultDir, "gene_loop_link_A485.rds"))


loopType <- temp2 %>% group_by(group) %>% summarise(num_pp = sum(num_pp),
                                        num_pe = sum(num_pe),
                                        num_ps = sum(num_ps),
                                        num_px = sum(num_px))


loopTypeLong <- loopType %>% pivot_longer(-group, names_to = "type", values_to = "count")

loopTypeLong$type <- factor(loopTypeLong$type, levels = c("num_pp", "num_pe", "num_ps", "num_px"))

# Plotting
ggplot(loopTypeLong, aes(fill=type, y=count, x=group)) + 
    geom_bar(position="fill", stat="identity") + theme_classic()

```

##### - Loop number per gene: P-P
```{r}
########
#P-P
data <- temp2 %>% dplyr::select(group, num_pp)
colnames(data) <- c("group", "count")
# pv12 <- round(getPvalWilcox(data,"group1", "group2"), 5)
# pv15 <- round(getPvalWilcox(data,"group1", "group5"), 5)
# pv18 <- round(getPvalWilcox(data,"group1", "group8"), 5)
# pv25 <- round(getPvalWilcox(data,"group2", "group5"), 5)
# pv28 <- round(getPvalWilcox(data,"group2", "group8"), 5)
# pv58 <- round(getPvalWilcox(data,"group5", "group8"), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")  +
  theme(legend.position = "none")
  # annotate("text", x = 1, y = 3, label = paste0("pv12: ", pv12, "\n",
  #                                               "pv15: ", pv15, "\n",
  #                                               "pv18: ", pv18, "\n",
  #                                               "pv25: ", pv25, "\n",
  #                                               "pv28: ", pv28, "\n",
  #                                               "pv58: ", pv58, "\n"), 
  #          color = "black", hjust = 0, size = 1)


fileName <- paste0("count_barplot_diffGroup_A485_vs_DMSO_pp")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Loop number per gene: P-E
```{r}
########
#P-E
data <- temp2 %>% dplyr::select(group, num_pe)
colnames(data) <- c("group", "count")
# pv12 <- round(getPvalWilcox(data,"group1", "group2"), 5)
# pv15 <- round(getPvalWilcox(data,"group1", "group5"), 5)
# pv18 <- round(getPvalWilcox(data,"group1", "group8"), 5)
# pv25 <- round(getPvalWilcox(data,"group2", "group5"), 5)
# pv28 <- round(getPvalWilcox(data,"group2", "group8"), 5)
# pv58 <- round(getPvalWilcox(data,"group5", "group8"), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")  +
  theme(legend.position = "none")
  # annotate("text", x = 1, y = 3, label = paste0("pv12: ", pv12, "\n",
  #                                               "pv15: ", pv15, "\n",
  #                                               "pv18: ", pv18, "\n",
  #                                               "pv25: ", pv25, "\n",
  #                                               "pv28: ", pv28, "\n",
  #                                               "pv58: ", pv58, "\n"), 
  #          color = "black", hjust = 0, size = 1)


fileName <- paste0("count_barplot_diffGroup_A485_vs_DMSO_pe")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Loop number per gene: P-S
```{r}
########
#P-S
data <- temp2 %>% dplyr::select(group, num_ps)
colnames(data) <- c("group", "count")
# pv12 <- round(getPvalWilcox(data,"group1", "group2"), 5)
# pv15 <- round(getPvalWilcox(data,"group1", "group5"), 5)
# pv18 <- round(getPvalWilcox(data,"group1", "group8"), 5)
# pv25 <- round(getPvalWilcox(data,"group2", "group5"), 5)
# pv28 <- round(getPvalWilcox(data,"group2", "group8"), 5)
# pv58 <- round(getPvalWilcox(data,"group5", "group8"), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")  +
  theme(legend.position = "none")
  # annotate("text", x = 1, y = 3, label = paste0("pv12: ", pv12, "\n",
  #                                               "pv15: ", pv15, "\n",
  #                                               "pv18: ", pv18, "\n",
  #                                               "pv25: ", pv25, "\n",
  #                                               "pv28: ", pv28, "\n",
  #                                               "pv58: ", pv58, "\n"), 
  #          color = "black", hjust = 0, size = 1)+  


fileName <- paste0("count_barplot_diffGroup_A485_vs_DMSO_ps")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Loop number per gene: P-X
```{r}
########
#P-X
data <- temp2 %>% dplyr::select(group, num_px)
colnames(data) <- c("group", "count")
# pv12 <- round(getPvalWilcox(data,"group1", "group2"), 5)
# pv15 <- round(getPvalWilcox(data,"group1", "group5"), 5)
# pv18 <- round(getPvalWilcox(data,"group1", "group8"), 5)
# pv25 <- round(getPvalWilcox(data,"group2", "group5"), 5)
# pv28 <- round(getPvalWilcox(data,"group2", "group8"), 5)
# pv58 <- round(getPvalWilcox(data,"group5", "group8"), 5)

p <- ggplot(data, aes(x = group, y = count, fill = group)) +
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() +       
  scale_y_continuous(breaks = seq(0, 5, by = 2), limits = c(0, 5)) + 
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")  +
  theme(legend.position = "none")
  # annotate("text", x = 1, y = 3, label = paste0("pv12: ", pv12, "\n",
  #                                               "pv15: ", pv15, "\n",
  #                                               "pv18: ", pv18, "\n",
  #                                               "pv25: ", pv25, "\n",
  #                                               "pv28: ", pv28, "\n",
  #                                               "pv58: ", pv58, "\n"), 
  #          color = "black", hjust = 0, size = 1)+  


fileName <- paste0("count_barplot_diffGroup_A485_vs_DMSO_px")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```


### dTAG
#### Grouping with P-N number
##### Grouping
```{r}
name <- "chromo_cons_annoHierarchy"

alpha <- 0.05
fcCutoff <- 0.5
diff.PRO.G1.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G1.dTAG_vs_G1.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.PRO.G2.dTAG <- fread(here(refDir, "diff_G1G2.dTAG_G2.dTAG_vs_G2.DMSO_PROseq.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha)
############
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = 0.2,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = "_"))



# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers
resultDir <- here("../../result")

temp2 <- readRDS(here(resultDir, "gene_loop_link.rds"))


pnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene
pnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene
pnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene
pnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene
pnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, "2DOWN", "0NO"),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  pnOver = ifelse(gene %in% pnOver8, "pnOver8",
                  ifelse(gene %in% pnOver6, "pnOver6",
                         ifelse(gene %in% pnOver4, "pnOver4",
                                ifelse(gene %in% pnOver2, "pnOver2",
                                       ifelse(gene %in% pnOver0, "pnOver0", NA)))))) %>%
  drop_na(pnOver)
```

##### GO for each group
```{r}
GOfigDir <- here(figDir, "../GO")
getGO("pnOver8", GOfigDir, pnOver8)
getGO("pnOver6", GOfigDir, pnOver6)
getGO("pnOver4", GOfigDir, pnOver4)
getGO("pnOver2", GOfigDir, pnOver2)
getGO("pnOver0", GOfigDir, pnOver0)

#####################
GO0.df <- as.data.frame(enrichGO(gene = pnOver0, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
GO2.df <- as.data.frame(enrichGO(gene = pnOver2, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
GO4.df <- as.data.frame(enrichGO(gene = pnOver4, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
GO6.df <- as.data.frame(enrichGO(gene = pnOver6, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
GO8.df <- as.data.frame(enrichGO(gene = pnOver8, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))


subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "pnOver0") %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by "/"
      parts <- unlist(strsplit(x, "/"))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "pnOver2") %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by "/"
      parts <- unlist(strsplit(x, "/"))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "pnOver4") %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by "/"
      parts <- unlist(strsplit(x, "/"))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset6 <- GO6.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "pnOver6") %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by "/"
      parts <- unlist(strsplit(x, "/"))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))
subset8 <- GO8.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "pnOver8") %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by "/"
      parts <- unlist(strsplit(x, "/"))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))


GOlist <- factor(c("GO:0006397", "GO:0008380", "GO:0022613", "GO:0034470",
                   "GO:0016055", "GO:0007389", "GO:0048562", "GO:0045165", 
                   "GO:0072001", "GO:0007517", "GO:0048705"))

data <- bind_rows(bind_rows(bind_rows(subset0, subset2), subset4), subset8) %>%
  dplyr::filter(ID %in% GOlist)

p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
  geom_point() + theme_bw() +
  scale_color_gradient(low = "red", high = "blue", limits = c(0, 0.05)) +
  scale_size_continuous(range = c(0, 3)) +
  labs(x = NULL, y = NULL) +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- here(figDir, "..", "GO", "GO_groups_pn")
height = 2
width = 3.3
svglite(paste0(fileName, ".svg"), height = height, width = width)
print(p)
dev.off()
```


##### loop score
```{r}
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv02 <- round(getPvalWilcox(temp, "pnOver0", "pnOver2"), 5)
pv24 <- round(getPvalWilcox(temp, "pnOver2", "pnOver4"), 5)
pv46 <- round(getPvalWilcox(temp, "pnOver4", "pnOver6"), 5)
pv08 <- round(getPvalWilcox(temp, "pnOver0", "pnOver8"), 5)
pv28 <- round(getPvalWilcox(temp, "pnOver2", "pnOver8"), 5)
pv48 <- round(getPvalWilcox(temp, "pnOver4", "pnOver8"), 5)
pv68 <- round(getPvalWilcox(temp, "pnOver6", "pnOver8"), 5)


p <- ggplot(temp, aes(x = pnOver, y = mean_diff_score)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0.2)+
  annotate("text", x = 1, y = 0, label = paste0("pv02: ", convPvalue(pv02), "\n",
                                                "pv24: ", convPvalue(pv24), "\n",
                                                "pv46: ", convPvalue(pv46), "\n",
                                                "pv68: ", convPvalue(pv68), "\n",
                                                "pv48: ", convPvalue(pv48), "\n",
                                                "pv28: ", convPvalue(pv28), "\n",
                                                "pv08: ", convPvalue(pv08), "\n"), 
           color = "black", hjust = 0, size = 3)

  
fileName <- paste0("diffScore_barplot_pnGroup_dTAG_vs_DMSO")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### log2FC
```{r}
#
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$log2FoldChange
  distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$log2FoldChange
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
 
pv02 <- round(getPvalWilcox(tempDown, "pnOver0", "pnOver2"), 5)
pv04 <- round(getPvalWilcox(tempDown, "pnOver0", "pnOver4"), 5)
pv06 <- round(getPvalWilcox(tempDown, "pnOver0", "pnOver6"), 5)
pv08 <- round(getPvalWilcox(tempDown, "pnOver0", "pnOver8"), 5)
pv24 <- round(getPvalWilcox(tempDown, "pnOver2", "pnOver4"), 5)
pv26 <- round(getPvalWilcox(tempDown, "pnOver2", "pnOver6"), 5)
pv28 <- round(getPvalWilcox(tempDown, "pnOver2", "pnOver8"), 5)
pv46 <- round(getPvalWilcox(tempDown, "pnOver4", "pnOver6"), 5)
pv48 <- round(getPvalWilcox(tempDown, "pnOver4", "pnOver8"), 5)
pv68 <- round(getPvalWilcox(tempDown, "pnOver6", "pnOver8"), 5)




p <- ggplot(tempDown, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)+
  annotate("text", x = 1, y = -0.5, label = paste0("pv02: ", convPvalue(pv02), "\n",
                                                   "pv04: ", convPvalue(pv04), "\n",
                                                   "pv06: ", convPvalue(pv06), "\n",
                                                   "pv08: ", convPvalue(pv08), "\n",
                                                   "pv24: ", convPvalue(pv24), "\n",
                                                   "pv26: ", convPvalue(pv26), "\n",
                                                   "pv28: ", convPvalue(pv28), "\n",
                                                   "pv46: ", convPvalue(pv46), "\n",
                                                   "pv48: ", convPvalue(pv48), "\n",
                                                   "pv68: ", convPvalue(pv68), "\n"), 
           color = "black", hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0("log2FC_barplot_pnGroup_dTAG_vs_DMSO_down")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
pv02 <- round(getPvalWilcox(tempUp, "pnOver0", "pnOver2"), 5)
pv04 <- round(getPvalWilcox(tempUp, "pnOver0", "pnOver4"), 5)
pv06 <- round(getPvalWilcox(tempUp, "pnOver0", "pnOver6"), 5)
pv08 <- round(getPvalWilcox(tempUp, "pnOver0", "pnOver8"), 5)
pv24 <- round(getPvalWilcox(tempUp, "pnOver2", "pnOver4"), 5)
pv26 <- round(getPvalWilcox(tempUp, "pnOver2", "pnOver6"), 5)
pv28 <- round(getPvalWilcox(tempUp, "pnOver2", "pnOver8"), 5)
pv46 <- round(getPvalWilcox(tempUp, "pnOver4", "pnOver6"), 5)
pv48 <- round(getPvalWilcox(tempUp, "pnOver4", "pnOver8"), 5)
pv68 <- round(getPvalWilcox(tempUp, "pnOver6", "pnOver8"), 5)




p <- ggplot(tempUp, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)+
  annotate("text", x = 1, y = 0.5, label = paste0("pv02: ", convPvalue(pv02), "\n",
                                                   "pv04: ", convPvalue(pv04), "\n",
                                                   "pv06: ", convPvalue(pv06), "\n",
                                                   "pv08: ", convPvalue(pv08), "\n",
                                                   "pv24: ", convPvalue(pv24), "\n",
                                                   "pv26: ", convPvalue(pv26), "\n",
                                                   "pv28: ", convPvalue(pv28), "\n",
                                                   "pv46: ", convPvalue(pv46), "\n",
                                                   "pv48: ", convPvalue(pv48), "\n",
                                                   "pv68: ", convPvalue(pv68), "\n"), 
           color = "black", hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0("log2FC_barplot_pnGroup_dTAG_vs_DMSO_up")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

#### Grouping with P-S number
##### Grouping
```{r}
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, "2DOWN", "0NO"),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  psOver = ifelse(gene %in% psOver4, "psOver4",
                  ifelse(gene %in% psOver3, "psOver3",
                         ifelse(gene %in% psOver2, "psOver2",
                                ifelse(gene %in% psOver1, "psOver1",
                                       ifelse(gene %in% psOver0, "psOver0", NA)))))) %>%
  drop_na(psOver)

```

##### GO for each group
```{r}
GOfigDir <- here(figDir, "../GO")

#####################
GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))
GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))
GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))
GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))
GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))

fwrite(GO0.df, here("GO_PS_group0.tsv"), sep = "\t")
fwrite(GO1.df, here("GO_PS_group1.tsv"), sep = "\t")
fwrite(GO2.df, here("GO_PS_group2.tsv"), sep = "\t")
fwrite(GO3.df, here("GO_PS_group3.tsv"), sep = "\t")
fwrite(GO4.df, here("GO_PS_group4.tsv"), sep = "\t")

GO0.df <- fread(here("GO_PS_group0.tsv"))
GO1.df <- fread(here("GO_PS_group1.tsv"))
GO2.df <- fread(here("GO_PS_group2.tsv"))
GO3.df <- fread(here("GO_PS_group3.tsv"))
GO4.df <- fread(here("GO_PS_group4.tsv"))

subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 0") %>%
  dplyr::arrange(p.adjust)
subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 1") %>%
  dplyr::arrange(p.adjust)
subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 2") %>%
  dplyr::arrange(p.adjust)
subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 3") %>%
  dplyr::arrange(p.adjust)
subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 4") %>%
  dplyr::arrange(p.adjust)

subset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))


GOlist <- factor(c("GO:0008380", "GO:0006397", "GO:0034470", "GO:0022613", "GO:0016055",
                   "GO:0061138", "GO:0060562", "GO:0007389", "GO:0060485", "GO:0048638", "GO:0045664"))

data <- bind_rows(bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset3), subset4) %>%
  dplyr::filter(ID %in% GOlist)

descOrder <- sort(unique(data$Description))[rev(c(10, 4, 5, 9, 11,
                                                  2, 6,
                                                  3, 1, 8, 7))]

data <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))
p <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + 
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM) + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = "white", high = "#CB333A",
                      # limits = c(0, 1),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL) +
  theme_bw() +  # Apply theme_bw first, so custom theme settings come after
  theme(
    panel.background = element_rect(fill = "transparent"),  # Override theme_bw panel
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      size = fontSizeS,         # Ensure size is set for x-axis text
      family = fontType,
      color = "#000000",
    ),
    axis.text.y = element_text(
      size = fontSizeS,         # Ensure size is set for y-axis text
      family = fontType,
      color = "#000000",
      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick * mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick * mmToLineUnit,
      lineend = "square"
    ),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, "..", "GO", "GO_groups_ps")
width <- panelSize(2.7)*mmToInch
height <- panelSize(1.2)*mmToInch
svglite(paste0(fileName, ".svg"), height = height, width = width)
print(p)
dev.off()
```

##### loop score
```{r}
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

ps01 <- round(getPvalWilcox(temp, "psOver0", "psOver1"), 5)
ps12 <- round(getPvalWilcox(temp, "psOver1", "psOver2"), 5)
ps23 <- round(getPvalWilcox(temp, "psOver2", "psOver3"), 5)
ps34 <- round(getPvalWilcox(temp, "psOver3", "psOver4"), 5)
ps24 <- round(getPvalWilcox(temp, "psOver2", "psOver4"), 5)
ps14 <- round(getPvalWilcox(temp, "psOver1", "psOver4"), 5)
ps04 <- round(getPvalWilcox(temp, "psOver0", "psOver4"), 5)


p <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + 
  geom_violin(aes(fill = psOver), 
              color = "black",
              linewidth = lineMedium * mmToLineUnit, lineend = "square",
              show.legend = FALSE) +
  geom_boxplot(width = 0.3, color = "black",
               linewidth = lineMedium * mmToLineUnit, lineend = "square",
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = "Average Δ loop score") +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black"
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate("text", x = 1, y = 0, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n",
                                                "ps24: ", convPvalue(ps24), "\n", 
                                                "ps14: ", convPvalue(ps14), "\n",
                                                "ps04: ", convPvalue(ps04), "\n"), 
           color = "black", hjust = 0, size = 2) +
    scale_fill_manual(values = c("#777777", "#8B7E65", "#A28452", "#C2884D", "#F28E2C")) +
  coord_cartesian(ylim = c(-0.5, 0.1))



fileName <- paste0("diffScore_barplot_psGroup_dTAG_vs_DMSO_2")
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### log2FC
```{r}
temp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))

ks_result1 <- ks.test(
  temp %>% dplyr::filter(psOver == "psOver4") %>% pull(absLog2FC),
  temp %>% dplyr::filter(psOver == "psOver3") %>% pull(absLog2FC)
)
ks_result2 <- ks.test(
  temp %>% dplyr::filter(psOver == "psOver4") %>% pull(absLog2FC),
  temp %>% dplyr::filter(psOver == "psOver2") %>% pull(absLog2FC)
)
ks_result3 <- ks.test(
  temp %>% dplyr::filter(psOver == "psOver4") %>% pull(absLog2FC),
  temp %>% dplyr::filter(psOver == "psOver1") %>% pull(absLog2FC)
)
ks_result4 <- ks.test(
  temp %>% dplyr::filter(psOver == "psOver4") %>% pull(absLog2FC),
  temp %>% dplyr::filter(psOver == "psOver0") %>% pull(absLog2FC)
)

p <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +
scale_color_manual(values = (c("#777777", "#8B7E65", "#A28452", "#C2884D", "#F28E2C"))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = "square" ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = "Abs. log2(fold change)",
    y = "Cumulative Probability"
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.position = "none",
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))
fileName <- paste0("log2FC_cdf_psGroup_dTAG_vs_DMSO")
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()




#
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
 
ps01 <- round(getPvalWilcox(tempDown, "psOver0", "psOver1"), 5)
ps12 <- round(getPvalWilcox(tempDown, "psOver1", "psOver2"), 5)
ps23 <- round(getPvalWilcox(tempDown, "psOver2", "psOver3"), 5)
ps34 <- round(getPvalWilcox(tempDown, "psOver3", "psOver4"), 5)
ps24 <- round(getPvalWilcox(tempDown, "psOver2", "psOver4"), 5)
ps14 <- round(getPvalWilcox(tempDown, "psOver1", "psOver4"), 5)

ps04 <- round(getPvalWilcox(tempDown, "psOver0", "psOver4"), 5)


p <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c("#D9D9D9", "#BFBFBF", "#A6A6A6", "#8C8C8C", "#737373")) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = "black",
              linewidth = lineThick * mmToLineUnit, lineend = "square",
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = "log2(fold change)") +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = "point", shape = 21, size = 1,
    fill = "red", color = "black"
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate("text", x = 1, y = -0.5, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n",
                                                "ps24: ", convPvalue(ps24), "\n", 
                                                "ps14: ", convPvalue(ps14), "\n",
                                                "ps04: ", convPvalue(ps04), "\n"), 
           color = "black", hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))
  
fileName <- paste0("log2FC_barplot_psGroup_dTAG_vs_DMSO_down")
width <- panelSize(1.2)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
ps01 <- round(getPvalWilcox(tempUp, "psOver0", "psOver1"), 5)
ps12 <- round(getPvalWilcox(tempUp, "psOver1", "psOver2"), 5)
ps23 <- round(getPvalWilcox(tempUp, "psOver2", "psOver3"), 5)
ps34 <- round(getPvalWilcox(tempUp, "psOver3", "psOver4"), 5)
ps24 <- round(getPvalWilcox(tempUp, "psOver2", "psOver4"), 5)
ps14 <- round(getPvalWilcox(tempUp, "psOver1", "psOver4"), 5)
ps04 <- round(getPvalWilcox(tempUp, "psOver0", "psOver4"), 5)




p <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c("#D9D9D9", "#BFBFBF", "#A6A6A6", "#8C8C8C", "#737373")) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = "black",
              linewidth = lineThick * mmToLineUnit, lineend = "square",
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = "log2(fold change)") +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = "point", shape = 21, size = 1,
    fill = "red", color = "black"
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate("text", x = 1, y = 0.5, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n",
                                                "ps24: ", convPvalue(ps24), "\n", 
                                                "ps14: ", convPvalue(ps14), "\n",
                                                "ps04: ", convPvalue(ps04), "\n"), 
           color = "black", hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0("log2FC_barplot_psGroup_dTAG_vs_DMSO_up")
width <- panelSize(1.18)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```


#### Grouping with P-E number
##### Grouping
```{r}
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

psOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, "2DOWN", "0NO"),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  psOver = ifelse(gene %in% psOver4, "psOver4",
                  ifelse(gene %in% psOver3, "psOver3",
                         ifelse(gene %in% psOver2, "psOver2",
                                ifelse(gene %in% psOver1, "psOver1",
                                       ifelse(gene %in% psOver0, "psOver0", NA)))))) %>%
  drop_na(psOver)

```

##### GO for each group
```{r}
GOfigDir <- here(figDir, "../GO")
#####################
GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))
GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))
GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))
GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))
GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))

# fwrite(GO0.df, here("GO_PE_group0.tsv"), sep = "\t")
# fwrite(GO1.df, here("GO_PE_group1.tsv"), sep = "\t")
# fwrite(GO2.df, here("GO_PE_group2.tsv"), sep = "\t")
# fwrite(GO3.df, here("GO_PE_group3.tsv"), sep = "\t")
# fwrite(GO4.df, here("GO_PE_group4.tsv"), sep = "\t")


subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 0") %>%
  dplyr::arrange(p.adjust)
subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 1") %>%
  dplyr::arrange(p.adjust)
subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 2") %>%
  dplyr::arrange(p.adjust)
subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 3") %>%
  dplyr::arrange(p.adjust)
subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 4") %>%
  dplyr::arrange(p.adjust)

subset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))

GOlist <- factor(c("GO:0008380", "GO:0006397", "GO:0034470", "GO:0022613", "GO:0016055",
                   "GO:0061138", "GO:0060562", "GO:0007389", "GO:0060485", "GO:0048638", "GO:0045664",
                   "GO:0040029"))

data <- bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset4) %>%
  dplyr::filter(ID %in% GOlist)

descOrder <- sort(unique(data$Description))[rev(c(11, 5, 6, 10, 12,
                                                  1,
                                                  3, 7, 4, 2, 9, 8))]

empty_row3 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = "Group 3"                   # Group to add as empty column
)

empty_row4 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = "Group 4"                   # Group to add as empty column
)

# Append the empty row to your dataset
data <- rbind(data, empty_row3, empty_row4)


data <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))
p <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + 
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM) + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = "white", high = "#CB333A",
                      # limits = c(0, 1),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL) +
  theme_bw() +  # Apply theme_bw first, so custom theme settings come after
  theme(
    panel.background = element_rect(fill = "transparent"),  # Override theme_bw panel
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      size = fontSizeS,         # Ensure size is set for x-axis text
      family = fontType,
      color = "#000000",
    ),
    axis.text.y = element_text(
      size = fontSizeS,         # Ensure size is set for y-axis text
      family = fontType,
      color = "#000000",
      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick * mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick * mmToLineUnit,
      lineend = "square"
    ),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, "..", "GO", "GO_groups_pe")
width <- panelSize(2.65)*mmToInch
height <- panelSize(1.3)*mmToInch
svglite(paste0(fileName, ".svg"), height = height, width = width)
print(p)
dev.off()
```
##### loop score
```{r}
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

ps01 <- round(getPvalWilcox(temp, "psOver0", "psOver1"), 5)
ps12 <- round(getPvalWilcox(temp, "psOver1", "psOver2"), 5)
ps23 <- round(getPvalWilcox(temp, "psOver2", "psOver3"), 5)
ps34 <- round(getPvalWilcox(temp, "psOver3", "psOver4"), 5)
ps24 <- round(getPvalWilcox(temp, "psOver2", "psOver4"), 5)
ps14 <- round(getPvalWilcox(temp, "psOver1", "psOver4"), 5)
ps04 <- round(getPvalWilcox(temp, "psOver0", "psOver4"), 5)


p <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + 
    scale_fill_manual(values = c("#777777", "#8B7E65", "#A28452", "#C2884D", "#F28E2C")) +
  geom_violin(aes(fill = psOver), 
              color = "black",
              linewidth = lineMedium * mmToLineUnit, lineend = "square",
              show.legend = FALSE) +
  geom_boxplot(width = 0.3, color = "black",
               linewidth = lineMedium * mmToLineUnit, lineend = "square",
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = "Average Δ loop score") +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black"
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate("text", x = 1, y = 0, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n",
                                                "ps24: ", convPvalue(ps24), "\n", 
                                                "ps14: ", convPvalue(ps14), "\n",
                                                "ps04: ", convPvalue(ps04), "\n"), 
           color = "black", hjust = 0, size = 2) +
  coord_cartesian(ylim = c(-0.5, 0.1))


fileName <- paste0("diffScore_barplot_peGroup_dTAG_vs_DMSO")
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### log2FC
```{r}
temp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))
p <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +
scale_color_manual(values = (c("#777777", "#8B7E65", "#A28452", "#C2884D", "#F28E2C"))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = "square" ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = "Abs. log2(fold change)",
    y = "Cumulative Probability"
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.position = "none",
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))
fileName <- paste0("log2FC_cdf_peGroup_dTAG_vs_DMSO")
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()


#
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
 
ps01 <- round(getPvalWilcox(tempDown, "psOver0", "psOver1"), 5)
ps12 <- round(getPvalWilcox(tempDown, "psOver1", "psOver2"), 5)
ps23 <- round(getPvalWilcox(tempDown, "psOver2", "psOver3"), 5)
ps34 <- round(getPvalWilcox(tempDown, "psOver3", "psOver4"), 5)
ps24 <- round(getPvalWilcox(tempDown, "psOver2", "psOver4"), 5)
ps14 <- round(getPvalWilcox(tempDown, "psOver1", "psOver4"), 5)

ps04 <- round(getPvalWilcox(tempDown, "psOver0", "psOver4"), 5)


p <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c("#D9D9D9", "#BFBFBF", "#A6A6A6", "#8C8C8C", "#737373")) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = "black",
              linewidth = lineThick * mmToLineUnit, lineend = "square",
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = "log2(fold change)") +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = "point", shape = 21, size = 1,
    fill = "red", color = "black"
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate("text", x = 1, y = -0.5, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n",
                                                "ps24: ", convPvalue(ps24), "\n", 
                                                "ps14: ", convPvalue(ps14), "\n",
                                                "ps04: ", convPvalue(ps04), "\n"), 
           color = "black", hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))
  
fileName <- paste0("log2FC_barplot_peGroup_dTAG_vs_DMSO_down")
width <- panelSize(1.2)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
ps01 <- round(getPvalWilcox(tempUp, "psOver0", "psOver1"), 5)
ps12 <- round(getPvalWilcox(tempUp, "psOver1", "psOver2"), 5)
ps23 <- round(getPvalWilcox(tempUp, "psOver2", "psOver3"), 5)
ps34 <- round(getPvalWilcox(tempUp, "psOver3", "psOver4"), 5)
ps24 <- round(getPvalWilcox(tempUp, "psOver2", "psOver4"), 5)
ps14 <- round(getPvalWilcox(tempUp, "psOver1", "psOver4"), 5)
ps04 <- round(getPvalWilcox(tempUp, "psOver0", "psOver4"), 5)




p <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c("#D9D9D9", "#BFBFBF", "#A6A6A6", "#8C8C8C", "#737373")) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = "black",
              linewidth = lineThick * mmToLineUnit, lineend = "square",
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = "log2(fold change)") +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = "point", shape = 21, size = 1,
    fill = "red", color = "black"
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate("text", x = 1, y = 0.5, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n",
                                                "ps24: ", convPvalue(ps24), "\n", 
                                                "ps14: ", convPvalue(ps14), "\n",
                                                "ps04: ", convPvalue(ps04), "\n"), 
           color = "black", hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0("log2FC_barplot_peGroup_dTAG_vs_DMSO_up")
width <- panelSize(1.18)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```


#### Grouping with P-P number
##### Grouping
```{r}
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

psOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, "2DOWN", "0NO"),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  psOver = ifelse(gene %in% psOver4, "psOver4",
                  ifelse(gene %in% psOver3, "psOver3",
                         ifelse(gene %in% psOver2, "psOver2",
                                ifelse(gene %in% psOver1, "psOver1",
                                       ifelse(gene %in% psOver0, "psOver0", NA)))))) %>%
  drop_na(psOver)


```
##### GO for each group
```{r}
GOfigDir <- here(figDir, "../GO")

#####################
GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))
GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))
GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))
GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))
GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP", readable = TRUE))
# 
# fwrite(GO0.df, here("GO_PP_group0.tsv"), sep = "\t")
# fwrite(GO1.df, here("GO_PP_group1.tsv"), sep = "\t")
# fwrite(GO2.df, here("GO_PP_group2.tsv"), sep = "\t")
# fwrite(GO3.df, here("GO_PP_group3.tsv"), sep = "\t")
# fwrite(GO4.df, here("GO_PP_group4.tsv"), sep = "\t")

subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 0") %>%
  dplyr::arrange(p.adjust)
subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 1") %>%
  dplyr::arrange(p.adjust)
subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 2") %>%
  dplyr::arrange(p.adjust)
subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 3") %>%
  dplyr::arrange(p.adjust)
subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "Group 4") %>%
  dplyr::arrange(p.adjust)

subset0$GeneRatio <- sapply(strsplit(subset0$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset1$GeneRatio <- sapply(strsplit(subset1$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset2$GeneRatio <- sapply(strsplit(subset2$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset3$GeneRatio <- sapply(strsplit(subset3$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))
subset4$GeneRatio <- sapply(strsplit(subset4$GeneRatio, "/"), function(x) as.numeric(x[1]) / as.numeric(x[2]))

GOlist <- factor(c("GO:0008380", "GO:0006397", "GO:0034470", "GO:0022613", "GO:0016055",
                   "GO:0061138", "GO:0060562", "GO:0007389", "GO:0060485", "GO:0048638", "GO:0045664"))

data <- bind_rows(subset0, subset1) %>%
  dplyr::filter(ID %in% GOlist)



empty_row2 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = "Group 2"                   # Group to add as empty column
)

empty_row3 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = "Group 3"                   # Group to add as empty column
)

empty_row4 <- data.frame(
  ID = NA,                             # No specific ID
  Description = NA,                    # No description
  GeneRatio = NA,                      # No gene ratio
  p.adjust = NA,                       # No p.adjust value
  group = "Group 4"                   # Group to add as empty column
)

# Append the empty row to your dataset
data <- rbind(data, empty_row2, empty_row3, empty_row4)
descOrder <- sort(unique(data$Description))[rev(c(12,
                                                  4, 5, 9, 11, 10, 
                                                  2, 6, 3, 1, 8, 7))]
data <- data %>% dplyr::filter(Description %in% descOrder)


data <- data %>% dplyr::rowwise() %>% dplyr::mutate(pValueLog = min(-log10(p.adjust), pValueLogMax))
p <- ggplot(data, aes(x = group, y = factor(Description, levels = descOrder), size = pValueLog, fill = GeneRatio)) + 
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM) + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = "white", high = "#CB333A",
                      # limits = c(0, 1),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL) +
  theme_bw() +  # Apply theme_bw first, so custom theme settings come after
  theme(
    panel.background = element_rect(fill = "transparent"),  # Override theme_bw panel
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      size = fontSizeS,         # Ensure size is set for x-axis text
      family = fontType,
      color = "#000000",
    ),
    axis.text.y = element_text(
      size = fontSizeS,         # Ensure size is set for y-axis text
      family = fontType,
      color = "#000000",
      lineheight = 0.9          # Allows wrapping for y-axis labels to fit into 2 lines
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick * mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick * mmToLineUnit,
      lineend = "square"
    ),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, "..", "GO", "GO_groups_pp")
width <- panelSize(2.65)*mmToInch
height <- panelSize(1.2)*mmToInch
svglite(paste0(fileName, ".svg"), height = height, width = width)
print(p)
dev.off()
```

##### loop score
```{r}
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

ps01 <- round(getPvalWilcox(temp, "psOver0", "psOver1"), 5)
ps12 <- round(getPvalWilcox(temp, "psOver1", "psOver2"), 5)
ps23 <- round(getPvalWilcox(temp, "psOver2", "psOver3"), 5)
ps34 <- round(getPvalWilcox(temp, "psOver3", "psOver4"), 5)
ps24 <- round(getPvalWilcox(temp, "psOver2", "psOver4"), 5)
ps14 <- round(getPvalWilcox(temp, "psOver1", "psOver4"), 5)
ps04 <- round(getPvalWilcox(temp, "psOver0", "psOver4"), 5)

p <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + 
    scale_fill_manual(values = rev(c("#777777", "#8B7E65", "#A28452", "#C2884D", "#F28E2C"))) +
  geom_violin(aes(fill = psOver), 
              color = "black",
              linewidth = lineMedium * mmToLineUnit, lineend = "square",
              show.legend = FALSE) +
  geom_boxplot(width = 0.3, color = "black",
               linewidth = lineMedium * mmToLineUnit, lineend = "square",
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = "Average Δ loop score") +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black"
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate("text", x = 1, y = 0, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n",
                                                "ps24: ", convPvalue(ps24), "\n", 
                                                "ps14: ", convPvalue(ps14), "\n",
                                                "ps04: ", convPvalue(ps04), "\n"), 
           color = "black", hjust = 0, size = 2) +
  coord_cartesian(ylim = c(-0.5, 0.1))


fileName <- paste0("diffScore_barplot_ppGroup_dTAG_vs_DMSO")
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

```
##### log2FC
```{r}
temp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))
p <- ggplot(temp, aes(x = absLog2FC, color = psOver)) +
scale_color_manual(values = (rev(c("#777777", "#8B7E65", "#A28452", "#C2884D", "#F28E2C")))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = "square" ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = "Abs. log2(fold change)",
    y = "Cumulative Probability"
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.position = "none",
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))
fileName <- paste0("log2FC_cdf_ppGroup_dTAG_vs_DMSO")
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()



#
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
  distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
 
ps01 <- round(getPvalWilcox(tempDown, "psOver0", "psOver1"), 5)
ps12 <- round(getPvalWilcox(tempDown, "psOver1", "psOver2"), 5)
ps23 <- round(getPvalWilcox(tempDown, "psOver2", "psOver3"), 5)
ps34 <- round(getPvalWilcox(tempDown, "psOver3", "psOver4"), 5)
ps24 <- round(getPvalWilcox(tempDown, "psOver2", "psOver4"), 5)
ps14 <- round(getPvalWilcox(tempDown, "psOver1", "psOver4"), 5)

ps04 <- round(getPvalWilcox(tempDown, "psOver0", "psOver4"), 5)


p <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c("#D9D9D9", "#BFBFBF", "#A6A6A6", "#8C8C8C", "#737373")) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = "black",
              linewidth = lineThick * mmToLineUnit, lineend = "square",
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = "log2(fold change)") +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = "point", shape = 21, size = 1,
    fill = "red", color = "black"
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate("text", x = 1, y = -0.5, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n",
                                                "ps24: ", convPvalue(ps24), "\n", 
                                                "ps14: ", convPvalue(ps14), "\n",
                                                "ps04: ", convPvalue(ps04), "\n"), 
           color = "black", hjust = 0, size = 2) + coord_cartesian(ylim = c(-1, 0))
  
fileName <- paste0("log2FC_barplot_ppGroup_dTAG_vs_DMSO_down")
width <- panelSize(1.2)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
ps01 <- round(getPvalWilcox(tempUp, "psOver0", "psOver1"), 5)
ps12 <- round(getPvalWilcox(tempUp, "psOver1", "psOver2"), 5)
ps23 <- round(getPvalWilcox(tempUp, "psOver2", "psOver3"), 5)
ps34 <- round(getPvalWilcox(tempUp, "psOver3", "psOver4"), 5)
ps24 <- round(getPvalWilcox(tempUp, "psOver2", "psOver4"), 5)
ps14 <- round(getPvalWilcox(tempUp, "psOver1", "psOver4"), 5)
ps04 <- round(getPvalWilcox(tempUp, "psOver0", "psOver4"), 5)




p <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + 
  scale_fill_manual(values = c("#D9D9D9", "#BFBFBF", "#A6A6A6", "#8C8C8C", "#737373")) + # Five shades of grey
  geom_violin(aes(fill = psOver), 
              color = "black",
              linewidth = lineThick * mmToLineUnit, lineend = "square",
              show.legend = FALSE) +
  geom_boxplot(width = 0.1, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = "log2(fold change)") +
  stat_summary(
    aes(group = psOver), fun = mean,
    geom = "point", shape = 21, size = 1,
    fill = "red", color = "black"
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate("text", x = 1, y = 0.5, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n",
                                                "ps24: ", convPvalue(ps24), "\n", 
                                                "ps14: ", convPvalue(ps14), "\n",
                                                "ps04: ", convPvalue(ps04), "\n"), 
           color = "black", hjust = 0, size = 2) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0("log2FC_barplot_ppGroup_dTAG_vs_DMSO_up")
width <- panelSize(1.18)*mmToInch
height <- panelSize(1)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

### A485
#### Grouping with P-N number
##### Grouping
```{r}
############
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = 0.2,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = "_"))


# temp2
#calculating diff score and log2fc distribution based on p-n numbers
temp2 <- readRDS(here(resultDir, "gene_loop_link_A485.rds"))

pnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene
pnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene
pnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene
pnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene
pnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  pnOver = ifelse(gene %in% pnOver8, "pnOver8",
                  ifelse(gene %in% pnOver6, "pnOver6",
                         ifelse(gene %in% pnOver4, "pnOver4",
                                ifelse(gene %in% pnOver2, "pnOver2",
                                       ifelse(gene %in% pnOver0, "pnOver0", NA)))))) %>%
  drop_na(pnOver)
```

##### (SKIP) GO for each group
```{r}
# GOfigDir <- here(figDir, "../GO")
# getGO("pnOver8", GOfigDir, pnOver8)
# getGO("pnOver6", GOfigDir, pnOver6)
# getGO("pnOver4", GOfigDir, pnOver4)
# getGO("pnOver2", GOfigDir, pnOver2)
# getGO("pnOver0", GOfigDir, pnOver0)
# 
# #####################
# GO0.df <- as.data.frame(enrichGO(gene = pnOver0, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO2.df <- as.data.frame(enrichGO(gene = pnOver2, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO4.df <- as.data.frame(enrichGO(gene = pnOver4, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO6.df <- as.data.frame(enrichGO(gene = pnOver6, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO8.df <- as.data.frame(enrichGO(gene = pnOver8, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# 
# 
# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "pnOver0") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "pnOver2") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "pnOver4") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset6 <- GO6.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "pnOver6") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset8 <- GO8.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "pnOver8") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# 
# GOlist <- factor(c("GO:0006397", "GO:0008380", "GO:0022613", "GO:0034470",
#                    "GO:0016055", "GO:0007389", "GO:0048562", "GO:0045165", 
#                    "GO:0072001", "GO:0007517", "GO:0048705"))
# 
# data <- bind_rows(bind_rows(bind_rows(subset0, subset2), subset4), subset8) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = "red", high = "blue", limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, "..", "GO", "GO_groups_pn")
# height = 2
# width = 3.3
# svglite(paste0(fileName, ".svg"), height = height, width = width)
# print(p)
# dev.off()
```


##### loop score
```{r}
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$mean_diff_score
#   distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$mean_diff_score
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# pv02 <- round(getPvalWilcox(temp, "pnOver0", "pnOver2"), 5)
# pv24 <- round(getPvalWilcox(temp, "pnOver2", "pnOver4"), 5)
# pv46 <- round(getPvalWilcox(temp, "pnOver4", "pnOver6"), 5)
# pv08 <- round(getPvalWilcox(temp, "pnOver0", "pnOver8"), 5)
# pv28 <- round(getPvalWilcox(temp, "pnOver2", "pnOver8"), 5)
# pv48 <- round(getPvalWilcox(temp, "pnOver4", "pnOver8"), 5)
# pv68 <- round(getPvalWilcox(temp, "pnOver6", "pnOver8"), 5)


p <- ggplot(temp, aes(x = pnOver, y = mean_diff_score)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)
  # annotate("text", x = 1, y = 0, label = paste0("pv02: ", convPvalue(pv02), "\n",
  #                                               "pv24: ", convPvalue(pv24), "\n",
  #                                               "pv46: ", convPvalue(pv46), "\n",
  #                                               "pv68: ", convPvalue(pv68), "\n",
  #                                               "pv48: ", convPvalue(pv48), "\n",
  #                                               "pv28: ", convPvalue(pv28), "\n",
  #                                               "pv08: ", convPvalue(pv08), "\n"), 
  #          color = "black", hjust = 0, size = 3)

   
fileName <- paste0("diffScore_barplot_pnGroup_A485_vs_DMSO")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### log2FC
```{r}
#
#  getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$log2FoldChange
#   distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$log2FoldChange
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
#  
# pv02 <- round(getPvalWilcox(tempDown, "pnOver0", "pnOver2"), 5)
# pv04 <- round(getPvalWilcox(tempDown, "pnOver0", "pnOver4"), 5)
# pv06 <- round(getPvalWilcox(tempDown, "pnOver0", "pnOver6"), 5)
# pv08 <- round(getPvalWilcox(tempDown, "pnOver0", "pnOver8"), 5)
# pv24 <- round(getPvalWilcox(tempDown, "pnOver2", "pnOver4"), 5)
# pv26 <- round(getPvalWilcox(tempDown, "pnOver2", "pnOver6"), 5)
# pv28 <- round(getPvalWilcox(tempDown, "pnOver2", "pnOver8"), 5)
# pv46 <- round(getPvalWilcox(tempDown, "pnOver4", "pnOver6"), 5)
# pv48 <- round(getPvalWilcox(tempDown, "pnOver4", "pnOver8"), 5)
# pv68 <- round(getPvalWilcox(tempDown, "pnOver6", "pnOver8"), 5)




p <- ggplot(tempDown, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)
  # annotate("text", x = 1, y = -0.5, label = paste0("pv02: ", convPvalue(pv02), "\n",
  #                                                  "pv04: ", convPvalue(pv04), "\n",
  #                                                  "pv06: ", convPvalue(pv06), "\n",
  #                                                  "pv08: ", convPvalue(pv08), "\n",
  #                                                  "pv24: ", convPvalue(pv24), "\n",
  #                                                  "pv26: ", convPvalue(pv26), "\n",
  #                                                  "pv28: ", convPvalue(pv28), "\n",
  #                                                  "pv46: ", convPvalue(pv46), "\n",
  #                                                  "pv48: ", convPvalue(pv48), "\n",
  #                                                  "pv68: ", convPvalue(pv68), "\n"), 
  #          color = "black", hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0("log2FC_barplot_pnGroup_A485_vs_DMSO_down")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
#  
# pv02 <- round(getPvalWilcox(tempUp, "pnOver0", "pnOver2"), 5)
# pv04 <- round(getPvalWilcox(tempUp, "pnOver0", "pnOver4"), 5)
# pv06 <- round(getPvalWilcox(tempUp, "pnOver0", "pnOver6"), 5)
# pv08 <- round(getPvalWilcox(tempUp, "pnOver0", "pnOver8"), 5)
# pv24 <- round(getPvalWilcox(tempUp, "pnOver2", "pnOver4"), 5)
# pv26 <- round(getPvalWilcox(tempUp, "pnOver2", "pnOver6"), 5)
# pv28 <- round(getPvalWilcox(tempUp, "pnOver2", "pnOver8"), 5)
# pv46 <- round(getPvalWilcox(tempUp, "pnOver4", "pnOver6"), 5)
# pv48 <- round(getPvalWilcox(tempUp, "pnOver4", "pnOver8"), 5)
# pv68 <- round(getPvalWilcox(tempUp, "pnOver6", "pnOver8"), 5)
# 



p <- ggplot(tempUp, aes(x = pnOver, y = log2FoldChange)) + geom_violin(aes(fill = pnOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = pnOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)
  # annotate("text", x = 1, y = 0.5, label = paste0("pv02: ", convPvalue(pv02), "\n",
  #                                                  "pv04: ", convPvalue(pv04), "\n",
  #                                                  "pv06: ", convPvalue(pv06), "\n",
  #                                                  "pv08: ", convPvalue(pv08), "\n",
  #                                                  "pv24: ", convPvalue(pv24), "\n",
  #                                                  "pv26: ", convPvalue(pv26), "\n",
  #                                                  "pv28: ", convPvalue(pv28), "\n",
  #                                                  "pv46: ", convPvalue(pv46), "\n",
  #                                                  "pv48: ", convPvalue(pv48), "\n",
  #                                                  "pv68: ", convPvalue(pv68), "\n"), 
  #          color = "black", hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0("log2FC_barplot_pnGroup_A485_vs_DMSO_up")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

#### Grouping with P-S number
##### Grouping
```{r}
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene




## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  drop_na(shrinked_log2FC)


temp <- temp %>% dplyr::mutate(
  psOver = ifelse(gene %in% psOver4, "psOver4",
                  ifelse(gene %in% psOver3, "psOver3",
                         ifelse(gene %in% psOver2, "psOver2",
                                ifelse(gene %in% psOver1, "psOver1",
                                       ifelse(gene %in% psOver0, "psOver0", NA)))))) %>%
  drop_na(psOver)

```

##### (SKIP) GO for each group
```{r}
# GOfigDir <- here(figDir, "../GO")
# getGO("psOver4", GOfigDir, psOver4)
# getGO("psOver3", GOfigDir, psOver3)
# getGO("psOver2", GOfigDir, psOver2)
# getGO("psOver1", GOfigDir, psOver1)
# getGO("psOver0", GOfigDir, psOver0)
# 
# #####################
# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# 
# 
# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver0") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver1") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver2") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver3") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver4") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# 
# GOlist <- factor(c("GO:0006397", "GO:0008380", "GO:0022613", "GO:0034470",
#                    "GO:0016055", "GO:0007389", "GO:0048562", "GO:0045165", 
#                    "GO:0072001", "GO:0007517", "GO:0048705", "GO:0003002"))
# 
# data <- bind_rows(bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset3), subset4) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = "red", high = "blue", limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, "..", "GO", "GO_groups_ps")
# height = 2
# width = 3.4
# svglite(paste0(fileName, ".svg"), height = height, width = width)
# print(p)
# dev.off()
```

##### loop score
```{r}
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# ps01 <- round(getPvalWilcox(temp, "psOver0", "psOver1"), 5)
# ps12 <- round(getPvalWilcox(temp, "psOver1", "psOver2"), 5)
# ps23 <- round(getPvalWilcox(temp, "psOver2", "psOver3"), 5)
# ps34 <- round(getPvalWilcox(temp, "psOver3", "psOver4"), 5)
# ps24 <- round(getPvalWilcox(temp, "psOver2", "psOver4"), 5)
# ps14 <- round(getPvalWilcox(temp, "psOver1", "psOver4"), 5)
# ps04 <- round(getPvalWilcox(temp, "psOver0", "psOver4"), 5)
# 

p <- ggplot(temp, aes(x = psOver, y = mean_diff_score)) + geom_violin(aes(fill = psOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = psOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)
  # annotate("text", x = 1, y = 0, label = paste0("ps01: ", convPvalue(ps01), "\n",
  #                                               "ps12: ", convPvalue(ps12), "\n",
  #                                               "ps23: ", convPvalue(ps23), "\n",
  #                                               "ps34: ", convPvalue(ps34), "\n",
  #                                               "ps24: ", convPvalue(ps24), "\n", 
  #                                               "ps14: ", convPvalue(ps14), "\n",
  #                                               "ps04: ", convPvalue(ps04), "\n"), 
  #          color = "black", hjust = 0, size = 3)

  
fileName <- paste0("diffScore_barplot_psGroup_A485_vs_DMSO")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### log2FC
```{r}
#
#  getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
#  
# ps01 <- round(getPvalWilcox(tempDown, "psOver0", "psOver1"), 5)
# ps12 <- round(getPvalWilcox(tempDown, "psOver1", "psOver2"), 5)
# ps23 <- round(getPvalWilcox(tempDown, "psOver2", "psOver3"), 5)
# ps34 <- round(getPvalWilcox(tempDown, "psOver3", "psOver4"), 5)
# ps24 <- round(getPvalWilcox(tempDown, "psOver2", "psOver4"), 5)
# ps14 <- round(getPvalWilcox(tempDown, "psOver1", "psOver4"), 5)
# 
# ps04 <- round(getPvalWilcox(tempDown, "psOver0", "psOver4"), 5)


p <- ggplot(tempDown, aes(x = psOver, y = log2FoldChange)) + geom_violin(aes(fill = psOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = psOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)
  # annotate("text", x = 1, y = -0.5, label = paste0("ps01: ", convPvalue(ps01), "\n",
  #                                               "ps12: ", convPvalue(ps12), "\n",
  #                                               "ps23: ", convPvalue(ps23), "\n",
  #                                               "ps34: ", convPvalue(ps34), "\n",
  #                                               "ps24: ", convPvalue(ps24), "\n",
  #                                               "ps14: ", convPvalue(ps14), "\n",
  #                                               "ps04: ", convPvalue(ps04), "\n"), 
  #          color = "black", hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0("log2FC_barplot_psGroup_A485_vs_DMSO_down")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
#  
# ps01 <- round(getPvalWilcox(tempUp, "psOver0", "psOver1"), 5)
# ps12 <- round(getPvalWilcox(tempUp, "psOver1", "psOver2"), 5)
# ps23 <- round(getPvalWilcox(tempUp, "psOver2", "psOver3"), 5)
# ps34 <- round(getPvalWilcox(tempUp, "psOver3", "psOver4"), 5)
# ps24 <- round(getPvalWilcox(tempUp, "psOver2", "psOver4"), 5)
# ps14 <- round(getPvalWilcox(tempUp, "psOver1", "psOver4"), 5)
# ps04 <- round(getPvalWilcox(tempUp, "psOver0", "psOver4"), 5)
# 



p <- ggplot(tempUp, aes(x = psOver, y = log2FoldChange)) + geom_violin(aes(fill = psOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = psOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)
  # annotate("text", x = 1, y = 0.5, label = paste0("ps01: ", convPvalue(ps01), "\n",
  #                                               "ps12: ", convPvalue(ps12), "\n",
  #                                               "ps23: ", convPvalue(ps23), "\n",
  #                                               "ps34: ", convPvalue(ps34), "\n",
  #                                               "ps24: ", convPvalue(ps24), "\n",
  #                                               "ps14: ", convPvalue(ps14), "\n",
  #                                               "ps04: ", convPvalue(ps04), "\n"), 
  #          color = "black", hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0("log2FC_barplot_psGroup_A485_vs_DMSO_up")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```


#### Grouping with P-E number
##### Grouping
```{r}
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers

peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  drop_na(shrinked_log2FC)


temp <- temp %>% dplyr::mutate(
  peOver = ifelse(gene %in% peOver4, "peOver4",
                  ifelse(gene %in% peOver3, "peOver3",
                         ifelse(gene %in% peOver2, "peOver2",
                                ifelse(gene %in% peOver1, "peOver1",
                                       ifelse(gene %in% peOver0, "peOver0", NA)))))) %>%
  drop_na(peOver)

```

##### (SKIP) GO for each group
```{r}
# GOfigDir <- here(figDir, "../GO")
# getGO("peOver4", GOfigDir, psOver4)
# getGO("peOver3", GOfigDir, psOver3)
# getGO("peOver2", GOfigDir, psOver2)
# getGO("peOver1", GOfigDir, psOver1)
# getGO("peOver0", GOfigDir, psOver0)
# 
# #####################
# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# 
# 
# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver0") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver1") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver2") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver3") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver4") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# 
# GOlist <- factor(c("GO:0006397", "GO:0008380", "GO:0022613", "GO:0034470",
#                    "GO:0016055", "GO:0007389", "GO:0048562", "GO:0045165", 
#                    "GO:0072001", "GO:0007517", "GO:0048705", 
#                    "GO:0040029", "GO:0010165"))
# 
# data <- bind_rows(bind_rows(bind_rows(subset0, subset1), subset2), subset4) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = "red", high = "blue", limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, "..", "GO", "GO_groups_pe")
# height = 2
# width = 3.4
# svglite(paste0(fileName, ".svg"), height = height, width = width)
# print(p)
# dev.off()
```
##### loop score
```{r}
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# ps01 <- round(getPvalWilcox(temp, "psOver0", "psOver1"), 5)
# ps12 <- round(getPvalWilcox(temp, "psOver1", "psOver2"), 5)
# ps23 <- round(getPvalWilcox(temp, "psOver2", "psOver3"), 5)
# ps34 <- round(getPvalWilcox(temp, "psOver3", "psOver4"), 5)
# ps24 <- round(getPvalWilcox(temp, "psOver2", "psOver4"), 5)
# ps14 <- round(getPvalWilcox(temp, "psOver1", "psOver4"), 5)
# ps04 <- round(getPvalWilcox(temp, "psOver0", "psOver4"), 5)


p <- ggplot(temp, aes(x = peOver, y = mean_diff_score)) + geom_violin(aes(fill = peOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = peOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)
  # annotate("text", x = 1, y = 0, label = paste0("ps01: ", convPvalue(ps01), "\n",
  #                                               "ps12: ", convPvalue(ps12), "\n",
  #                                               "ps23: ", convPvalue(ps23), "\n",
  #                                               "ps34: ", convPvalue(ps34), "\n",
  #                                               "ps24: ", convPvalue(ps24), "\n",
  #                                               "ps14: ",convPvalue( ps14), "\n",
  #                                               "ps04: ",convPvalue( ps04), "\n"), 
  #          color = "black", hjust = 0, size = 3)

  
fileName <- paste0("diffScore_barplot_peGroup_A485_vs_DMSO")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### log2FC
```{r}
#
#  getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
#  
# ps01 <- round(getPvalWilcox(tempDown, "psOver0", "psOver1"), 5)
# ps12 <- round(getPvalWilcox(tempDown, "psOver1", "psOver2"), 5)
# ps23 <- round(getPvalWilcox(tempDown, "psOver2", "psOver3"), 5)
# ps34 <- round(getPvalWilcox(tempDown, "psOver3", "psOver4"), 5)
# ps24 <- round(getPvalWilcox(tempDown, "psOver2", "psOver4"), 5)
# ps14 <- round(getPvalWilcox(tempDown, "psOver1", "psOver4"), 5)
# ps04 <- round(getPvalWilcox(tempDown, "psOver0", "psOver4"), 5)


p <- ggplot(tempDown, aes(x = peOver, y = log2FoldChange)) + geom_violin(aes(fill = peOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = peOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)
  # annotate("text", x = 1, y = -0.5, label = paste0("ps01: ", convPvalue(ps01), "\n",
  #                                               "ps12: ", convPvalue(ps12), "\n",
  #                                               "ps23: ", convPvalue(ps23), "\n",
  #                                               "ps34: ", convPvalue(ps34), "\n",
  #                                               "ps24: ", convPvalue(ps24), "\n",
  #                                               "ps14: ", convPvalue(ps14), "\n",
  #                                               "ps04: ", convPvalue(ps04), "\n"), 
  #          color = "black", hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0("log2FC_barplot_peGroup_A485_vs_DMSO_down")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
 
# ps01 <- round(getPvalWilcox(tempUp, "psOver0", "psOver1"), 5)
# ps12 <- round(getPvalWilcox(tempUp, "psOver1", "psOver2"), 5)
# ps23 <- round(getPvalWilcox(tempUp, "psOver2", "psOver3"), 5)
# ps34 <- round(getPvalWilcox(tempUp, "psOver3", "psOver4"), 5)
# ps24 <- round(getPvalWilcox(tempUp, "psOver2", "psOver4"), 5)
# ps14 <- round(getPvalWilcox(tempUp, "psOver1", "psOver4"), 5)
# ps04 <- round(getPvalWilcox(tempUp, "psOver0", "psOver4"), 5)
# 




p <- ggplot(tempUp, aes(x = peOver, y = log2FoldChange)) + geom_violin(aes(fill = peOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = peOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)
  # annotate("text", x = 1, y = 0.5, label = paste0("ps01: ", convPvalue(ps01), "\n",
  #                                               "ps12: ", convPvalue(ps12), "\n",
  #                                               "ps23: ", convPvalue(ps23), "\n",
  #                                               "ps34: ", convPvalue(ps34), "\n",
  #                                               "ps24: ", convPvalue(ps24), "\n",
  #                                               "ps14: ", convPvalue(ps14), "\n",
  #                                               "ps04: ", convPvalue(ps04), "\n"), 
  #          color = "black", hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0("log2FC_barplot_peGroup_A485_vs_DMSO_up")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```


#### Grouping with P-P number
##### Grouping
```{r}
# temp2 contains genes from group 1, 2, 5, 8 and loop counts
#calculating diff score and log2fc distribution based on p-n numbers
ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene



## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_A485_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_A485_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  drop_na(shrinked_log2FC)


temp <- temp %>% dplyr::mutate(
  ppOver = ifelse(gene %in% ppOver4, "ppOver4",
                  ifelse(gene %in% ppOver3, "ppOver3",
                         ifelse(gene %in% ppOver2, "ppOver2",
                                ifelse(gene %in% ppOver1, "ppOver1",
                                       ifelse(gene %in% ppOver0, "ppOver0", NA)))))) %>%
  drop_na(ppOver)
```
##### (SKIP) GO for each group
```{r}
# GOfigDir <- here(figDir, "../GO")
# getGO("ppOver4", GOfigDir, psOver4)
# getGO("ppOver3", GOfigDir, psOver3)
# getGO("ppOver2", GOfigDir, psOver2)
# getGO("ppOver1", GOfigDir, psOver1)
# getGO("ppOver0", GOfigDir, psOver0)
# 
# #####################
# GO0.df <- as.data.frame(enrichGO(gene = psOver0, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO1.df <- as.data.frame(enrichGO(gene = psOver1, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO2.df <- as.data.frame(enrichGO(gene = psOver2, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO3.df <- as.data.frame(enrichGO(gene = psOver3, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# GO4.df <- as.data.frame(enrichGO(gene = psOver4, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
# 
# 
# subset0 <- GO0.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver0") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset1 <- GO1.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver1") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset2 <- GO2.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver2") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset3 <- GO3.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver3") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# subset4 <- GO4.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "psOver4") %>%
#   dplyr::mutate(
#     gr = sapply(GeneRatio, function(x) {
#       # Split the string by "/"
#       parts <- unlist(strsplit(x, "/"))
#       # Convert to numeric and perform the division
#       as.numeric(parts[1]) / as.numeric(parts[2])
#     })
#   ) %>% dplyr::arrange(desc(gr))
# 
# 
# GOlist <- factor(c("GO:0006397", "GO:0008380", "GO:0022613", "GO:0034470",
#                    "GO:0016055", "GO:0007389", "GO:0048562", "GO:0045165", 
#                    "GO:0072001", "GO:0007517", "GO:0048705", "GO:0003002", "GO:0009411"))
# 
# data <- bind_rows(bind_rows(subset0, subset1), subset3) %>%
#   dplyr::filter(ID %in% GOlist)
# 
# p <- ggplot(data, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
#   geom_point() + theme_bw() +
#   scale_color_gradient(low = "red", high = "blue", limits = c(0, 0.05)) +
#   scale_size_continuous(range = c(0, 3)) +
#   labs(x = NULL, y = NULL) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- here(figDir, "..", "GO", "GO_groups_pp")
# height = 2
# width = 3.4
# svglite(paste0(fileName, ".svg"), height = height, width = width)
# print(p)
# dev.off()
```

##### loop score
```{r}
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$mean_diff_score
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$mean_diff_score
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 
# ps01 <- round(getPvalWilcox(temp, "psOver0", "psOver1"), 5)
# ps12 <- round(getPvalWilcox(temp, "psOver1", "psOver2"), 5)
# ps23 <- round(getPvalWilcox(temp, "psOver2", "psOver3"), 5)
# ps34 <- round(getPvalWilcox(temp, "psOver3", "psOver4"), 5)
# ps24 <- round(getPvalWilcox(temp, "psOver2", "psOver4"), 5)
# ps14 <- round(getPvalWilcox(temp, "psOver1", "psOver4"), 5)
# ps04 <- round(getPvalWilcox(temp, "psOver0", "psOver4"), 5)


p <- ggplot(temp, aes(x = ppOver, y = mean_diff_score)) + geom_violin(aes(fill = ppOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = ppOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)
  # annotate("text", x = 1, y = 0, label = paste0("ps01: ", convPvalue(ps01), "\n",
  #                                               "ps12: ", convPvalue(ps12), "\n",
  #                                               "ps23: ", convPvalue(ps23), "\n",
  #                                               "ps34: ", convPvalue(ps34), "\n",
  #                                               "ps24: ", convPvalue(ps24), "\n",
  #                                               "ps14: ", convPvalue(ps14), "\n",
  #                                               "ps04: ", convPvalue(ps04), "\n"), 
  #          color = "black", hjust = 0, size = 3)

  
fileName <- paste0("diffScore_barplot_ppGroup_A485_vs_DMSO")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```
##### log2FC
```{r}
#
#  getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(psOver ==group1) )$log2FoldChange
#   distance2 <- (data %>% dplyr::filter(psOver ==group2) )$log2FoldChange
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }

tempDown <- temp %>% dplyr::filter(log2FoldChange < 0)
#  
# ps01 <- round(getPvalWilcox(tempDown, "psOver0", "psOver1"), 5)
# ps12 <- round(getPvalWilcox(tempDown, "psOver1", "psOver2"), 5)
# ps23 <- round(getPvalWilcox(tempDown, "psOver2", "psOver3"), 5)
# ps34 <- round(getPvalWilcox(tempDown, "psOver3", "psOver4"), 5)
# ps24 <- round(getPvalWilcox(tempDown, "psOver2", "psOver4"), 5)
# ps14 <- round(getPvalWilcox(tempDown, "psOver1", "psOver4"), 5)
# ps04 <- round(getPvalWilcox(tempDown, "psOver0", "psOver4"), 5)



p <- ggplot(tempDown, aes(x = ppOver, y = log2FoldChange)) + geom_violin(aes(fill = ppOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = ppOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)
  # annotate("text", x = 1, y = -0.5, label = paste0("ps01: ", convPvalue(ps01), "\n",
  #                                               "ps12: ", convPvalue(ps12), "\n",
  #                                               "ps23: ", convPvalue(ps23), "\n",
  #                                               "ps34: ", convPvalue(ps34), "\n",
  #                                               "ps24: ", convPvalue(ps24), "\n",
  #                                               "ps14: ", convPvalue(ps14), "\n",
  #                                               "ps04: ", convPvalue(ps04), "\n"), 
  #          color = "black", hjust = 0, size = 3) + coord_cartesian(ylim = c(-1, 0))

  
fileName <- paste0("log2FC_barplot_ppGroup_A485_vs_DMSO_down")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()



tempUp <- temp %>% dplyr::filter(log2FoldChange > 0)
#  
# ps01 <- round(getPvalWilcox(tempUp, "psOver0", "psOver1"), 5)
# ps12 <- round(getPvalWilcox(tempUp, "psOver1", "psOver2"), 5)
# ps23 <- round(getPvalWilcox(tempUp, "psOver2", "psOver3"), 5)
# ps34 <- round(getPvalWilcox(tempUp, "psOver3", "psOver4"), 5)
# ps24 <- round(getPvalWilcox(tempUp, "psOver2", "psOver4"), 5)
# ps14 <- round(getPvalWilcox(tempUp, "psOver1", "psOver4"), 5)
# ps04 <- round(getPvalWilcox(tempUp, "psOver0", "psOver4"), 5)
# 
# 



p <- ggplot(tempUp, aes(x = ppOver, y = log2FoldChange)) + geom_violin(aes(fill = ppOver), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + theme_classic() + 
  stat_summary(aes(group = ppOver), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  geom_hline(yintercept = 0)
  # annotate("text", x = 1, y = 0.5, label = paste0("ps01: ", convPvalue(ps01), "\n",
  #                                               "ps12: ", convPvalue(ps12), "\n",
  #                                               "ps23: ", convPvalue(ps23), "\n",
  #                                               "ps34: ", convPvalue(ps34), "\n",
  #                                               "ps24: ", convPvalue(ps24), "\n",
  #                                               "ps14: ", convPvalue(ps14), "\n",
  #                                               "ps04: ", convPvalue(ps04), "\n"), 
  #          color = "black", hjust = 0, size = 3) + coord_cartesian(ylim = c(0, 1))

  
fileName <- paste0("log2FC_barplot_ppGroup_A485_vs_DMSO_up")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

## [2.13] How to define multiconnected hub using regulatory loops?
```{r}
# IMPORTING GENE ANNO DATA FOR P-N LOOPS
name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                 diffCutoff = 0.2,
                                 annoList = c("P-P", "P-E", "P-S", "P-X")) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27, 28))

data <- fread(here(consensusDir, paste0(name, ".tsv"))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>%
  dplyr::mutate(binSize = end1 - start1,
                adj_start1 = ifelse(binSize == 5000, start1,
                                    ifelse(binSize == 10000, start1,
                                           start1 + 10000)),
                adj_end1 = adj_start1 + 5000,
                adj_start2 = ifelse(binSize == 5000, start2,
                                    ifelse(binSize == 10000, start2,
                                           start2 + 10000)),
                adj_end2 = adj_start2 + 5000,
                anchor1 = paste(chrom1, adj_start1, adj_end1, sep = "_"),
                anchor2 = paste(chrom2, adj_start2, adj_end2, sep = "_"))

# data <- fread(here(consensusDir, paste0(name, ".tsv"))) %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 13, 22, 23, 24, 25, 27)) %>% 
#   dplyr::mutate(binSize = end1 - start1,
#                 adj_start1 = ifelse(binSize == 5000, start1,
#                                     ifelse(binSize == 10000, start1+5000,
#                                            start1 + 10000)),
#                 adj_end1 = adj_start1 + 5000,
#                 adj_start2 = ifelse(binSize == 5000, start2,
#                                     ifelse(binSize == 10000, start2 + 5000,
#                                            start2 + 10000)),
#                 adj_end2 = adj_start2 + 5000,
#                 anchor1 = paste(chrom1, adj_start1, adj_end1, sep = "_"),
#                 anchor2 = paste(chrom2, adj_start2, adj_end2, sep = "_"))

data.reg <- data %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "P-S", "P-X", "E-E", "E-S", "E-X"))

## Graph
#install.packages("igraph")
library(igraph)

# To be able to construct a graph, each anchor need to have same resolution.
# Shink the size to 10 kb
# If the anchor is 25kb, choose the middle 5kb bin
# If the anchor is 10kb, choose the left 5kb bin

graph <- graph_from_data_frame(data.reg %>% dplyr::select(anchor1, anchor2))
components <- components(graph)
data.reg$hub <- components$membership[data.reg$anchor1]

temp.bedpe <- data.reg %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)
fwrite(temp.bedpe, here(consensusDir, paste0(name, "_regulatory_5kbAdj.bedpe")), 
       col.names = FALSE,row.names = FALSE, sep = "\t")  

hubNum <- data.reg %>% group_by(hub) %>% summarise(count = n())

# Hub size distribution
p <- ggplot(hubNum, aes(x = count)) + geom_histogram(binwidth  = 1) + theme_classic() + 
  scale_y_log10()

svglite(here(figDir, "hub_size_distribution.svg"), height = 2, width = 2)
print(p)
dev.off()

data.reg <- data.reg %>% dplyr::left_join(hubNum, by = "hub") 
data.reg <- data.reg %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = "_"))

# Exporting regulatory loops with specific hub size
temp.bedpe <- data.reg %>% dplyr::filter(count >= 3) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)
fwrite(temp.bedpe, here(consensusDir, paste0(name, "_regulatory_5kbAdj_hub3.bedpe")), 
       col.names = FALSE,row.names = FALSE, sep = "\t")  

temp.bedpe <- data.reg %>% dplyr::filter(count >= 5) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)
fwrite(temp.bedpe, here(consensusDir, paste0(name, "_regulatory_5kbAdj_hub5.bedpe")), 
       col.names = FALSE,row.names = FALSE, sep = "\t")

temp.bedpe <- data.reg %>% dplyr::filter(count >= 10) %>% dplyr::select(chrom1, adj_start1, adj_end1, chrom2, adj_start2, adj_end2)
fwrite(temp.bedpe, here(consensusDir, paste0(name, "_regulatory_5kbAdj_hub10.bedpe")), 
       col.names = FALSE,row.names = FALSE, sep = "\t")


# Adding gene annotation to hubs
genePeakPair <- geneAnnoData %>% dplyr::mutate(peakID = paste(chrom1, start1, start2, sep = "_")) %>% dplyr::select(peakID, gene)
data.reg <- data.reg %>% dplyr::left_join(genePeakPair, by = "peakID")

# During unnesting, E-N loops without gene annotated are removed
data.reg <- data.reg %>% unnest(gene) %>% dplyr::mutate(
  group = ifelse(gene %in% gene.group1, "group1",
                 ifelse(gene %in% gene.group2, "group2",
                        ifelse(gene %in% gene.group3, "group3",
                               ifelse(gene %in% gene.group4, "group4",
                                      ifelse(gene %in% gene.group5, "group5",
                                             ifelse(gene %in% gene.group6, "group6",
                                                    ifelse(gene %in% gene.group7, "group7",
                                                           ifelse(gene %in% gene.group8, "group8",
                                                                  ifelse(gene %in% gene.group9, "group9", NA)))))))))
)


temp <- data.reg %>% dplyr::select(gene, hub, count, group) %>%
  group_by(gene) %>% slice_max(count, with_ties = FALSE) %>%
  dplyr::filter(group %in% c("group1", "group2", "group5", "group8"))


# TEMP START
# TEMP START
geneList.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv"))
geneList.group1.temp <- geneList.group1 %>% dplyr::left_join(temp, by = c("gene"))
# TEMP END

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$count
  distance2 <- (data %>% dplyr::filter(group ==group2) )$count
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


pv12 <- round(getPvalWilcox(tempSum,"group1", "group2"), 5)
pv15 <- round(getPvalWilcox(tempSum,"group1", "group5"), 5)
pv18 <- round(getPvalWilcox(tempSum,"group1", "group8"), 5)
pv25 <- round(getPvalWilcox(tempSum,"group2", "group5"), 5)
pv28 <- round(getPvalWilcox(tempSum,"group2", "group8"), 5)
pv58 <- round(getPvalWilcox(tempSum,"group5", "group8"), 5)


p <- ggplot(temp, aes(x = group, y = count, fill = group)) + 
  geom_boxplot(width = 0.5, outlier.shape = NA) + theme_classic() + 
    scale_y_continuous(breaks = seq(0, 30, by = 5), limits = c(0, 30)) + 

  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")  +
  annotate("text", x = 1, y = 3, label = paste0("pv12: ", pv12, "\n",
                                                "pv15: ", pv15, "\n",
                                                "pv18: ", pv18, "\n",
                                                "pv25: ", pv25, "\n",
                                                "pv28: ", pv28, "\n",
                                                "pv58: ", pv58, "\n"), 
           color = "black", hjust = 0, size = 1) +  theme(legend.position = "none")


fileName <- paste0("countHub_barplot_diffGroup_dTAG_vs_DMSO")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()



```


## [2.14] Looking deeper into TAD and insulation
### Insulation score of TSS?
#### Importing insulation score
```{r}
# Import insulation score calculated with python
resultDir <- here("../../result")
insScore.DMSO <- fread(here(resultDir, "TAD", "insulationScore_25kb_G1DMSO.tsv")) %>% 
  dplyr::select(c("chrom", "start", "end", "log2_insulation_score_125000")) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = "_"))
colnames(insScore.DMSO) <- c("chrom", "start", "end", "insulationScore", "binID")
insScore.dTAG <- fread(here(resultDir, "TAD", "insulationScore_25kb_G1dTAG.tsv")) %>% 
  dplyr::select(c("chrom", "start", "end", "log2_insulation_score_125000")) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = "_"))
colnames(insScore.dTAG) <- c("chrom", "start", "end", "insulationScore", "binID")

#insScore <- full_join(insScore.DMSO, insScore.dTAG, by = c("binID")) %>%
#  dplyr::select(binID, chrom.x, start.x, end.x, insulationScore.x, insulationScore.y) 

#colnames(insScore) <- c("binID", "chr", "start", "end", "insulation_score_DMSO", "insulation_scoare_dTAG")

#View(insScore)

```

#### Linking to gene
```{r}
gene.TSS.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3)) %>%
  dplyr::select(V6, V5, V1, TSS)
colnames(gene.TSS.tb) <- c("ensembl", "gene", "chr", "TSS")

getInsulationScore <- function(chr, TSS, insScore.tb){
  temp.tb <- insScore.tb %>% dplyr::filter(chrom == chr, start < TSS, end > TSS)
  out <- temp.tb$insulationScore
  if(length(out) < 1){
    return(NA)
  }else{
    return(temp.tb$insulationScore)
  }
}

gene.insScore.all <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  log2_insScore_DMSO = getInsulationScore(chr, TSS, insScore.DMSO),
  insScore_DMSO = 2^log2_insScore_DMSO,
  log2_insScore_dTAG = getInsulationScore(chr, TSS, insScore.dTAG),
  insScore_dTAG = 2^log2_insScore_dTAG,
  diff_insScore = insScore_dTAG - insScore_DMSO)


```

#### Checking insulation score of the nearest TAD
```{r}
# Importing TAD boundaries
tad_boundary <- fread(here("../../result/TAD", "TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed"))
colnames(tad_boundary) <- c("chr", "start", "end")
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = "_"),
                                               center = (start + end)/2)

findClosestTADBoundary <- function(chrom, TSS, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom) %>%
    dplyr::mutate(distance = abs(center - TSS)) %>%
    slice_min(distance)
  if(nrow(temp) == 1){
      return(temp$center)
  }else{
    return(NA)
  }
}


gene.insScore.all <- gene.insScore.all %>% rowwise() %>%
  dplyr::mutate(closestBoundary = findClosestTADBoundary(chr, TSS, tad_boundary),
                log2_boundaryInsScore_DMSO = getInsulationScore(chr, closestBoundary, insScore.DMSO),
                boundaryInsScore_DMSO = 2^log2_boundaryInsScore_DMSO,
                log2_boundaryInsScore_dTAG = getInsulationScore(chr, closestBoundary, insScore.dTAG),
                boundaryInsScore_dTAG = 2^log2_boundaryInsScore_dTAG,
                diff_boundaryInsScore = boundaryInsScore_dTAG - boundaryInsScore_DMSO)

saveRDS(gene.insScore.all, here(resultDir, "gene.insScore.all.rds"))
gene.insScore.all <- readRDS(here(resultDir, "gene.insScore.all.rds"))
```
##### Plotting for binary groups
```{r}
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, "group1",
                 ifelse(ensembl %in% group2, "group2", NA))) %>% 
  dplyr::filter(!is.na(group))


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_insScore <- function(temp.tb, note, ymin = -1.5, ymax = 0){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  
  p <- ggplot(temp.tb, aes(x = ".", fill = group, y = -score)) + 
    labs(x = NULL, y = "- Insulation score") +  # Remove x-axis title
    scale_fill_manual(values = rev((c("#777777", "#F28E2C")))) +

    introdataviz::geom_split_violin(linewidth = lineMedium * mmToLineUnit, lineend = "square",
                                    alpha = .4) +
    geom_boxplot(width = 0.3, color = "black",
                 linewidth = lineMedium * mmToLineUnit, lineend = "square",
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + theme_classic() +
    stat_summary(
      aes(group = group), fun = mean,
      geom = "point", shape = 21, size = 0.5,
      fill = "black", color = "black", position = position_dodge(.3)
    ) +
    
    # 
    # geom_violin(aes(fill = group), color = "black", linewidth = lineThick*mmToLineUnit, lineend = "square", show.legend = FALSE) + 
    # geom_boxplot(width = 0.1,  color = "black", linewidth = lineThick*mmToLineUnit, lineend = "square",
    #              outlier.size = 1, outlier.stroke = NA) +
    # stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 1, fill = "red", color = "black") + 
    geom_hline(yintercept = 0, linewidth = lineThick*mmToLineUnit) +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate("text", x = 1, y = ymin + 1, label = paste0("p12: ", convPvalue(p12)),
             color = "black", hjust = 0, size = 3) +
    theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )+   guides(
      fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
      ))
      
      
  fileName <- paste0("insulation_score_binaryGroup_", note)
  width <- panelSize(1.55)*mmToInch
height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_DMSO_binaryGroup", ymin = -1.1, ymax = -0.5)

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_dTAG_binaryGroup", ymin =  -1.1, ymax = -0.5)

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_diff_binaryGroup", ymin = -0.3, ymax = 0.1)
```

##### Plotting for groups
```{r}
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv"))$gene
group5 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv"))$gene
group8 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv"))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, "group1",
                 ifelse(ensembl %in% group2, "group2",
                        ifelse(ensembl %in% group5, "group5",
                               ifelse(ensembl %in% group8, "group8", NA))))) %>% 
  dplyr::filter(!is.na(group))


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  p15 <- round(getPvalWilcox(temp.tb, "group1", "group5"), 5)
  p18 <- round(getPvalWilcox(temp.tb, "group1", "group8"), 5)
  p25 <- round(getPvalWilcox(temp.tb, "group2", "group5"), 5)
  p28 <- round(getPvalWilcox(temp.tb, "group2", "group8"), 5)
  p58 <- round(getPvalWilcox(temp.tb, "group5", "group8"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate("text", x = 1, y = ymin + 1, label = paste0("p12: ", convPvalue(p12), "\n",
                                                         "p15: ", convPvalue(p15), "\n",
                                                         "p18: ", convPvalue(p18), "\n",
                                                         "p25: ", convPvalue(p25), "\n",
                                                         "p28: ", convPvalue(p28), "\n",
                                                         "p58: ",convPvalue( p58), "\n"),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("insulation_score_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_DMSO")

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_dTAG")

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_diff", ymin = -0.5, ymax = 1)
```

##### Plotting for P-N
```{r}
temp2 <- readRDS(here(resultDir, "gene_loop_link.rds"))

pnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene
pnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene
pnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene
pnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene
pnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% pnOver8, "p8",
                 ifelse(ensembl %in% pnOver6, "p6",
                        ifelse(ensembl %in% pnOver4, "p4",
                               ifelse(ensembl %in% pnOver2, "p2", 
                                      ifelse(ensembl %in% pnOver0, "p0", NA))))))  %>% 
  dplyr::filter(!is.na(group))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p02 <- round(getPvalWilcox(temp.tb, "p0", "p2"), 5)
  p24 <- round(getPvalWilcox(temp.tb, "p2", "p4"), 5)
  p46 <- round(getPvalWilcox(temp.tb, "p4", "p6"), 5)
  p68 <- round(getPvalWilcox(temp.tb, "p6", "p8"), 5)
  p48 <- round(getPvalWilcox(temp.tb, "p4", "p8"), 5)
  p28 <- round(getPvalWilcox(temp.tb, "p2", "p8"), 5)
  p08 <- round(getPvalWilcox(temp.tb, "p0", "p8"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate("text", x = 1, y = ymin + 1, label = paste0("p02: ", convPvalue(p02), "\n",
                                                         "p24: ", convPvalue(p24), "\n",
                                                         "p46: ", convPvalue(p46), "\n",
                                                         "p68: ", convPvalue(p68), "\n",
                                                         "p48: ", convPvalue(p48), "\n",
                                                         "p28: ",convPvalue( p28), "\n",
                                                         "p08: ",convPvalue( p08), "\n"),
             color = "black", hjust = 0, size = 3)  +
    scale_fill_manual(values = c("#d9d9d9", "#bdbdbd", "#969696", "#737373", "#525252"))
  
  
  fileName <- paste0("insulation_score_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_DMSO_P-N")

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_dTAG_P-N")

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_diff_P-N", ymin = -0.5, ymax = 1)

```
##### Plotting for P-S
```{r}
temp2 <- readRDS(here(resultDir, "gene_loop_link.rds"))

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% psOver4, "p4",
                 ifelse(ensembl %in% psOver3, "p3",
                        ifelse(ensembl %in% psOver2, "p2",
                               ifelse(ensembl %in% psOver1, "p1", 
                                      ifelse(ensembl %in% psOver0, "p0", NA))))))  %>% 
  dplyr::filter(!is.na(group))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p01 <- round(getPvalWilcox(temp.tb, "p0", "p1"), 5)
  p12 <- round(getPvalWilcox(temp.tb, "p1", "p2"), 5)
  p23 <- round(getPvalWilcox(temp.tb, "p2", "p3"), 5)
  p34 <- round(getPvalWilcox(temp.tb, "p3", "p4"), 5)
  p24 <- round(getPvalWilcox(temp.tb, "p2", "p4"), 5)
  p14 <- round(getPvalWilcox(temp.tb, "p1", "p4"), 5)
  p04 <- round(getPvalWilcox(temp.tb, "p0", "p4"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate("text", x = 1, y = ymin + 1, label = paste0("p01: ", convPvalue(p01), "\n",
                                                         "p12: ", convPvalue(p12), "\n",
                                                         "p23: ", convPvalue(p23), "\n",
                                                         "p34: ", convPvalue(p34), "\n",
                                                         "p24: ", convPvalue(p24), "\n",
                                                         "p14: ",convPvalue( p14), "\n",
                                                         "p04: ",convPvalue( p04), "\n"), 
             color = "black", hjust = 0, size = 3) +
    scale_fill_manual(values = c("#d9d9d9", "#bdbdbd", "#969696", "#737373", "#525252"))
  
  
  fileName <- paste0("insulation_score_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_DMSO_P-S")

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_dTAG_P-S")

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_diff_P-S", ymin = -0.5, ymax = 1)
```
##### Plotting for P-E
```{r}
temp2 <- readRDS(here(resultDir, "gene_loop_link.rds"))

peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% peOver4, "p4",
                 ifelse(ensembl %in% peOver3, "p3",
                        ifelse(ensembl %in% peOver2, "p2",
                               ifelse(ensembl %in% peOver1, "p1", 
                                      ifelse(ensembl %in% peOver0, "p0", NA))))))  %>% 
  dplyr::filter(!is.na(group))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p01 <- round(getPvalWilcox(temp.tb, "p0", "p1"), 5)
  p12 <- round(getPvalWilcox(temp.tb, "p1", "p2"), 5)
  p23 <- round(getPvalWilcox(temp.tb, "p2", "p3"), 5)
  p34 <- round(getPvalWilcox(temp.tb, "p3", "p4"), 5)
  p24 <- round(getPvalWilcox(temp.tb, "p2", "p4"), 5)
  p14 <- round(getPvalWilcox(temp.tb, "p1", "p4"), 5)
  p04 <- round(getPvalWilcox(temp.tb, "p0", "p4"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate("text", x = 1, y = ymin + 1, label = paste0("p01: ", convPvalue(p01), "\n",
                                                         "p12: ", convPvalue(p12), "\n",
                                                         "p23: ", convPvalue(p23), "\n",
                                                         "p34: ", convPvalue(p34), "\n",
                                                         "p24: ", convPvalue(p24), "\n",
                                                         "p14: ",convPvalue( p14), "\n",
                                                         "p04: ",convPvalue( p04), "\n"), 
             color = "black", hjust = 0, size = 3) +
    scale_fill_manual(values = c("#d9d9d9", "#bdbdbd", "#969696", "#737373", "#525252"))
  
  
  fileName <- paste0("insulation_score_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_DMSO_P-E")

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_dTAG_P-E")

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_diff_P-E", ymin = -0.5, ymax = 1)
```
##### Plotting for P-P
```{r}
temp2 <- readRDS(here(resultDir, "gene_loop_link.rds"))

ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene


gene.insScore <- gene.insScore.all %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% ppOver4, "p4",
                 ifelse(ensembl %in% ppOver3, "p3",
                        ifelse(ensembl %in% ppOver2, "p2",
                               ifelse(ensembl %in% ppOver1, "p1", 
                                      ifelse(ensembl %in% ppOver0, "p0", NA))))))  %>% 
  dplyr::filter(!is.na(group))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$score
  distance2 <- (data %>% dplyr::filter(group ==group2) )$score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

plot_insScore <- function(temp.tb, note, ymin = 0, ymax = 1.5){
  p01 <- round(getPvalWilcox(temp.tb, "p0", "p1"), 5)
  p12 <- round(getPvalWilcox(temp.tb, "p1", "p2"), 5)
  p23 <- round(getPvalWilcox(temp.tb, "p2", "p3"), 5)
  p34 <- round(getPvalWilcox(temp.tb, "p3", "p4"), 5)
  p24 <- round(getPvalWilcox(temp.tb, "p2", "p4"), 5)
  p14 <- round(getPvalWilcox(temp.tb, "p1", "p4"), 5)
  p04 <- round(getPvalWilcox(temp.tb, "p0", "p4"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate("text", x = 1, y = ymin + 1, label = paste0("p01: ", convPvalue(p01), "\n",
                                                         "p12: ", convPvalue(p12), "\n",
                                                         "p23: ", convPvalue(p23), "\n",
                                                         "p34: ", convPvalue(p34), "\n",
                                                         "p24: ", convPvalue(p24), "\n",
                                                         "p14: ",convPvalue( p14), "\n",
                                                         "p04: ",convPvalue( p04), "\n"), 
             color = "black", hjust = 0, size = 3) +
    scale_fill_manual(values = c("#d9d9d9", "#bdbdbd", "#969696", "#737373", "#525252"))
  
  
  fileName <- paste0("insulation_score_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

# DMSO
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_DMSO)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_DMSO_P-P")

# dTAG
temp.tb <- gene.insScore %>% dplyr::select(group, boundaryInsScore_dTAG)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_dTAG_P-P")

# diff
temp.tb <- gene.insScore %>% dplyr::select(group, diff_boundaryInsScore)
colnames(temp.tb) <- c("group", "score")
plot_insScore(temp.tb, "nearestBoundary_diff_P-P", ymin = -0.5, ymax = 1)
```


## [2.15] TAD distance/size
#### Link TAD
```{r}
refDir <- here("../..", "reference")

# Importing TAD boundary
tad_boundary <- fread(here("../../result/TAD", "TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed"))
colnames(tad_boundary) <- c("chr", "start", "end")
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = "_"),
                                               center = (start + end)/2)

# Importing TAD
tad <- fread(here("../../result/TAD", "TAD_25kb_125kb_otsu_G1DMSO.bedpe"))
colnames(tad) <- c("chr1", "start1", "end1", "chr2", "start2", "end2")
tad <- tad %>% dplyr::mutate(tadID = paste(chr1, start1, end1, sep = "_"),
                             tadSize = end1 - start1)

# Importing gene
gene.TSS.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3)) %>%
  dplyr::select(V6, V5, V1, TSS)
colnames(gene.TSS.tb) <- c("ensembl", "gene", "chr", "TSS")

# Functions
findDistanceToTAD <- function(chrom, TSS, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom) %>%
    dplyr::mutate(distance = abs(center - TSS)) %>% slice_min(distance)
  if(nrow(temp) == 1){
    return(temp$distance)
  }else{
    return(NA)
  }
}

findItsTAD <- function(chrom, TSS, tad){
  temp <- tad %>% dplyr::filter(chr1 == chrom,
                                start1 < TSS,
                                end1 > TSS)
  if(nrow(temp) == 1){
    return(temp$tadID)
  }else{
    return(NA)
  }
}

findTADSize <-function(chrom, TSS, tad){
  temp <- tad %>% dplyr::filter(chr1 == chrom,
                                start1 < TSS,
                                end1 > TSS)
  if(nrow(temp) == 1){
    return(temp$tadSize)
  }else{
    return(NA)
  }
}

gene.TSS.tb <- gene.TSS.tb %>% rowwise() %>%
  dplyr::mutate(distance = findDistanceToTAD(chr, TSS, tad_boundary),
                TAD = findItsTAD(chr, TSS, tad),
                TADsize = findTADSize(chr, TSS, tad))
```

##### dTAG - binaryGroup
```{r}
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, "group1",
                 ifelse(ensembl %in% group2, "group2", NA))) %>% 
  dplyr::filter(!is.na(group))


## Plot distance
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$distance
  distance2 <- (data %>% dplyr::filter(group == group2) )$distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  
  p <- ggplot(temp.tb, aes(x = ".", fill = group, y = distance)) +
    # Set axis labels (no x-axis title)
    scale_fill_manual(values = ((c("#777777", "#F28E2C")))) +
    labs(x = NULL, y = "Distance from TAD boundary") +
    # Violin plot with black outline, customized line width and end
    introdataviz::geom_split_violin(
     color = "black", alpha = 0.4,
      linewidth = lineMedium * mmToLineUnit, lineend = "square"
    ) +
    # Box plot with customized line width, square end, and outlier size
    geom_boxplot(
      width = 0.3, color = "black", alpha = 0.6,
      linewidth = lineMedium * mmToLineUnit, lineend = "square",
      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE
    ) +
    
    # Mean point in each group
    stat_summary(
      aes(group = group), fun = mean,
      geom = "point", shape = 21, size = 0.5,
      fill = "black", color = "black", position = position_dodge(.3)
    ) +
    
    # Horizontal line at y = 0
    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
    
    # Coordinate limits and custom y-axis labels
    coord_cartesian(ylim = c(ymin, ymax)) +
    scale_y_continuous(labels = label_kb_mb) +
    
    # Annotate p-value text
    annotate(
      "text", x = 1, y = ymin + 1,
      label = paste0("p12: ", convPvalue(p12)),
      color = "black", hjust = 0, size = 3
    ) +
    
    # Theme customization
    theme_classic() +
    theme(
      axis.title = element_text(
        size = fontSizeM, family = fontType, color = "#000000"
      ),
      axis.text = element_text(
        size = fontSizeS, family = fontType, color = "#000000"
      ),
      axis.text.x = element_text(
        angle = 45, hjust = 1, vjust = 1
      ),
      axis.line = element_line(
        color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
      ),
      axis.ticks = element_line(
        color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
      ),
      panel.background = element_rect(fill = "transparent"),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)) +
    guides(
      fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
      )
    )
  
  
  fileName <- paste0("distance_to_boundary_", note)
  width <- panelSize(1.55)*mmToInch
  height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

plot_TADdistance(gene.TSS.tb.plot, "group_binayGroup", ymax = 1000000)


## Plot TAD size
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize
  distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  
  p <- ggplot(temp.tb, aes(x = ".", fill = group, y = TADsize)) +
    # Set axis labels (no x-axis title)
    labs(x = NULL, y = "Size of TAD") +
        scale_fill_manual(values = ((c("#777777", "#F28E2C")))) +

    # Violin plot with black outline, customized line width and end
    introdataviz::geom_split_violin(
      color = "black",
      linewidth = lineMedium* mmToLineUnit, lineend = "square", alpha = .4
    ) +
    
    # Box plot with customized line width, square end, and outlier size
    geom_boxplot(
      width = 0.3, color = "black",
      linewidth = lineMedium* mmToLineUnit, lineend = "square",
      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE
    ) +
    
    # Mean point in each group
    stat_summary(
      aes(group = group), fun = mean,
      geom = "point", shape = 21, size = 0.5,
      fill = "black", color = "black", position = position_dodge(.3)
    ) +
    
    # Horizontal line at y = 0
    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
    
    # Coordinate limits and custom y-axis labels
    coord_cartesian(ylim = c(ymin, ymax)) +
    scale_y_continuous(labels = label_kb_mb) +
    
    # Annotate p-value text
    annotate(
      "text", x = 1, y = ymin + 1,
      label = paste0("p12: ", convPvalue(p12)),
      color = "black", hjust = 0, size = 3
    ) +
    
    # Theme customization
  theme_classic() +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) + guides(
      fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
      ))
  
  
  
  fileName <- paste0("size_of_boundary_", note)
  width <- panelSize(1.55)*mmToInch
  height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}
plot_TADsize(gene.TSS.tb.plot, "group_binaryGroup", ymax = 3e6)
```

##### dTAG - Plotting for groups
```{r}
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv"))$gene
group5 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv"))$gene
group8 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv"))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, "group1",
                 ifelse(ensembl %in% group2, "group2",
                        ifelse(ensembl %in% group5, "group5",
                               ifelse(ensembl %in% group8, "group8", NA))))) %>% 
  dplyr::filter(!is.na(group))


## Plot distance
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$distance
  distance2 <- (data %>% dplyr::filter(group == group2) )$distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  p15 <- round(getPvalWilcox(temp.tb, "group1", "group5"), 5)
  p18 <- round(getPvalWilcox(temp.tb, "group1", "group8"), 5)
  p25 <- round(getPvalWilcox(temp.tb, "group2", "group5"), 5)
  p28 <- round(getPvalWilcox(temp.tb, "group2", "group8"), 5)
  p58 <- round(getPvalWilcox(temp.tb, "group5", "group8"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = distance)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + scale_y_continuous(labels = label_kb_mb) +
    annotate("text", x = 1, y = (ymin + ymax)/2 + 1, label = paste0("p12: ", convPvalue(p12), "\n",
                                                         "p15: ", convPvalue(p15), "\n",
                                                         "p18: ", convPvalue(p18), "\n",
                                                         "p25: ", convPvalue(p25), "\n",
                                                         "p28: ", convPvalue(p28), "\n",
                                                         "p58: ",convPvalue( p58), "\n"),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("distance_to_boundary_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

plot_TADdistance(gene.TSS.tb.plot, "group")


## Plot TAD size
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize
  distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  p15 <- round(getPvalWilcox(temp.tb, "group1", "group5"), 5)
  p18 <- round(getPvalWilcox(temp.tb, "group1", "group8"), 5)
  p25 <- round(getPvalWilcox(temp.tb, "group2", "group5"), 5)
  p28 <- round(getPvalWilcox(temp.tb, "group2", "group8"), 5)
  p58 <- round(getPvalWilcox(temp.tb, "group5", "group8"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = TADsize)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + scale_y_continuous(labels = label_kb_mb) +
    annotate("text", x = 1, y = (ymin + ymax)/2 + 1, label = paste0("p12: ", convPvalue(p12), "\n",
                                                         "p15: ", convPvalue(p15), "\n",
                                                         "p18: ", convPvalue(p18), "\n",
                                                         "p25: ", convPvalue(p25), "\n",
                                                         "p28: ", convPvalue(p28), "\n",
                                                         "p58: ",convPvalue( p58), "\n"),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("size_of_boundary_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}
plot_TADsize(gene.TSS.tb.plot, "group", ymax = 6e6)
```

##### A485 - Plotting for groups
```{r}
group1 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group2.tsv"))$gene
group3 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group3.tsv"))$gene
group4 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group4.tsv"))$gene
group5 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group5.tsv"))$gene
group6 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group6.tsv"))$gene
group7 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group7.tsv"))$gene
group8 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group8.tsv"))$gene
group9 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group9.tsv"))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>%
  rowwise() %>%
  dplyr::mutate(
    group = dplyr::case_when(
      ensembl %in% group1 ~ "group1",
      ensembl %in% group2 ~ "group2",
      ensembl %in% group3 ~ "group3",
      ensembl %in% group4 ~ "group4",
      ensembl %in% group5 ~ "group5",
      ensembl %in% group6 ~ "group6",
      ensembl %in% group7 ~ "group7",
      ensembl %in% group8 ~ "group8",
      ensembl %in% group9 ~ "group9",
      TRUE ~ NA_character_
    )
  ) %>%
  dplyr::filter(!is.na(group))

## Plot distance
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group == group1) )$distance
#   distance2 <- (data %>% dplyr::filter(group == group2) )$distance
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }


plot_TADdistance <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  # p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  # p15 <- round(getPvalWilcox(temp.tb, "group1", "group5"), 5)
  # p18 <- round(getPvalWilcox(temp.tb, "group1", "group8"), 5)
  # p25 <- round(getPvalWilcox(temp.tb, "group2", "group5"), 5)
  # p28 <- round(getPvalWilcox(temp.tb, "group2", "group8"), 5)
  # p58 <- round(getPvalWilcox(temp.tb, "group5", "group8"), 5)
  # 
  p <- ggplot(temp.tb, aes(x = group, y = distance)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + scale_y_continuous(labels = label_kb_mb)
    # annotate("text", x = 1, y = (ymin + ymax)/2 + 1, label = paste0("p12: ", convPvalue(p12), "\n",
    #                                                      "p15: ", convPvalue(p15), "\n",
    #                                                      "p18: ", convPvalue(p18), "\n",
    #                                                      "p25: ", convPvalue(p25), "\n",
    #                                                      "p28: ", convPvalue(p28), "\n",
    #                                                      "p58: ",convPvalue( p58), "\n"),
    #          color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("distance_to_boundary_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

plot_TADdistance(gene.TSS.tb.plot, "group_A485")


## Plot TAD size
# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group == group1) )$TADsize
#   distance2 <- (data %>% dplyr::filter(group == group2) )$TADsize
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# 

plot_TADsize <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  # p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  # p15 <- round(getPvalWilcox(temp.tb, "group1", "group5"), 5)
  # p18 <- round(getPvalWilcox(temp.tb, "group1", "group8"), 5)
  # p25 <- round(getPvalWilcox(temp.tb, "group2", "group5"), 5)
  # p28 <- round(getPvalWilcox(temp.tb, "group2", "group8"), 5)
  # p58 <- round(getPvalWilcox(temp.tb, "group5", "group8"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = TADsize)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + scale_y_continuous(labels = label_kb_mb) 
    # annotate("text", x = 1, y = (ymin + ymax)/2 + 1, label = paste0("p12: ", convPvalue(p12), "\n",
    #                                                      "p15: ", convPvalue(p15), "\n",
    #                                                      "p18: ", convPvalue(p18), "\n",
    #                                                      "p25: ", convPvalue(p25), "\n",
    #                                                      "p28: ", convPvalue(p28), "\n",
    #                                                      "p58: ",convPvalue( p58), "\n"),
    #          color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("size_of_boundary_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}
plot_TADsize(gene.TSS.tb.plot, "group_A485", ymax = 6e6)
```

## [2.16] Checking the intensity of RAD21 at TAD boundary
#### Calculating RAD21 intensity of the nearest TAD boundary
```{r}
refDir <- here("../..", "reference")

# Importing TAD boundary
tad_boundary <- fread(here("../../result/TAD", "TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed"))
colnames(tad_boundary) <- c("chr", "start", "end")
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = "_"),
                                               start = start -175000/2,
                                               end = end + 175000/2,
                                               center = (start + end)/2)

# Importing RAD21 bigwig track
bw.RAD21 <- import(here(refDir, "33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm_bin50bp.bw"))

# Create GRanges object for TAD boundaries
tad_ranges <- makeGRangesFromDataFrame(tad_boundary, keep.extra.columns = TRUE)

# Find overlaps between all TAD boundaries and RAD21 bigwig data
overlaps <- findOverlaps(tad_ranges, bw.RAD21)

# Extract overlapping regions and scores from the BigWig
overlapping_bw <- bw.RAD21[subjectHits(overlaps)]
overlapping_tads <- tad_ranges[queryHits(overlaps)]

# Aggregate scores by TAD boundary regions


scores <- as_tibble(overlapping_bw) %>%
  dplyr::mutate(tad_id = tad_ranges[queryHits(overlaps)]$tad_id) %>%
  group_by(tad_id) %>%
  summarise(rad21Score = sum(score))

tad_boundary <- tad_boundary %>%
  left_join(scores, by = "tad_id")





# Importing gene
gene.TSS.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3)) %>%
  dplyr::select(V6, V5, V1, TSS)
colnames(gene.TSS.tb) <- c("ensembl", "gene", "chr", "TSS")


# Find nearest TAD boundary
findClosestTADBoundaryID <- function(chrom, TSS, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom) %>%
    dplyr::mutate(distance = abs(center - TSS)) %>%
    slice_min(distance)
  if(nrow(temp) == 1){
      return(temp$tad_id)
  }else{
    return(NA)
  }
}
gene.TSS.tb <- gene.TSS.tb %>% rowwise() %>%
  dplyr::mutate(closestBoundary = findClosestTADBoundaryID(chr, TSS, tad_boundary))

temp <- tad_boundary %>% dplyr::select(tad_id, rad21Score)

gene.TSS.tb <- gene.TSS.tb %>% left_join(temp, by = c("closestBoundary" = "tad_id") )

```


##### Plotting for groups
```{r}
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv"))$gene
group5 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv"))$gene
group8 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv"))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, "group1",
                 ifelse(ensembl %in% group2, "group2",
                        ifelse(ensembl %in% group5, "group5",
                               ifelse(ensembl %in% group8, "group8", NA))))) %>% 
  dplyr::filter(!is.na(group))


## Plot distance
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$rad21Score
  distance2 <- (data %>% dplyr::filter(group == group2) )$rad21Score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_rad21ScoreAtBoundary <- function(temp.tb, note){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  p15 <- round(getPvalWilcox(temp.tb, "group1", "group5"), 5)
  p18 <- round(getPvalWilcox(temp.tb, "group1", "group8"), 5)
  p25 <- round(getPvalWilcox(temp.tb, "group2", "group5"), 5)
  p28 <- round(getPvalWilcox(temp.tb, "group2", "group8"), 5)
  p58 <- round(getPvalWilcox(temp.tb, "group5", "group8"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = rad21Score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + 
    annotate("text", x = 1, y = 20 + 1, label = paste0("p12: ", convPvalue(p12), "\n",
                                                         "p15: ", convPvalue(p15), "\n",
                                                         "p18: ", convPvalue(p18), "\n",
                                                         "p25: ", convPvalue(p25), "\n",
                                                         "p28: ", convPvalue(p28), "\n",
                                                         "p58: ",convPvalue( p58), "\n"),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("rad21Score_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

plot_rad21ScoreAtBoundary(gene.TSS.tb.plot, "group")


```


## [2.17] Checking the density of gene / enhancer within designated TAD
#### Making TAD gene count
```{r}
### IMPORTING REQUIRED DATA
# Importing TAD
tad <- fread(here("../../result/TAD", "TAD_25kb_125kb_otsu_G1DMSO.bedpe"))
colnames(tad) <- c("chr1", "start1", "end1", "chr2", "start2", "end2")
tad <- tad %>% dplyr::mutate(tadID = paste(chr1, start1, end1, sep = "_"))


# Importing gene
gene.TSS.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3)) %>%
  dplyr::select(V6, V5, V1, TSS)
colnames(gene.TSS.tb) <- c("ensembl", "gene", "chr", "TSS")

# Importing enhancer
peak.H3K27ac <- as_tibble(importPeak(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed"))) %>%
  dplyr::mutate(center = (start + end)/2)


### FUNCTION FOR COUNTING
findItsTAD <- function(chrom, coordinate, tad){
  temp <- tad %>% dplyr::filter(chr1 == chrom,
                                         start1 < coordinate,
                                         end1 > coordinate)
  if(nrow(temp) == 1){
    return(temp$tadID)
  }else{
    return(NA)
  }
}

### Counting each features for TAD
### Counting gene
geneCountPerTAD <- gene.TSS.tb %>% rowwise() %>%
  dplyr::mutate(TAD = findItsTAD(chr, TSS, tad)) %>%
  drop_na() %>%
  group_by(TAD) %>%
  summarize(count = n())

### Counting enhancer

enhCountPerTAD <- peak.H3K27ac %>% rowwise() %>%
  dplyr::mutate(TAD = findItsTAD(seqnames, center, tad)) %>%
  drop_na() %>%
  group_by(TAD) %>%
  summarize(count = n())

### Get TAD sizez
tad.db <- tad %>% left_join(geneCountPerTAD, by = c("tadID" = "TAD"), ) %>%
  left_join(enhCountPerTAD, by = c("tadID" = "TAD")) %>%
  dplyr::select(c(1, 2, 3, 7, 8, 9)) %>%
  mutate_all(~replace(., is.na(.), 0))

colnames(tad.db) <- c("chr", "start", "end", "tadID", "geneCount", "enhCount")

tad.db <- tad.db %>% dplyr::mutate(
  tadSize = end - start,
  geneDensity = geneCount/tadSize * 100e3,
  enhDensity = enhCount/tadSize* 100e3,
  regDensity = (geneCount + enhCount)/tadSize* 100e3
)



### Assign TAD and information to gene
gene.TSS.tb <- gene.TSS.tb %>% rowwise() %>%
  dplyr::mutate(TAD = findItsTAD(chr, TSS, tad))
#gene.TSS.tb <- gene.TSS.tb %>% dplyr::filter(!is.na(TAD))
temp <- tad.db %>% dplyr::select(-c(1, 2, 3))

gene.TSS.tb <- gene.TSS.tb %>% dplyr::left_join(temp, by = c("TAD" = "tadID"))
```

#### Plotting for groups
##### geneCount
###### Binary group
```{r}
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, "group1",
                 ifelse(ensembl %in% group2, "group2", NA))) %>% 
  dplyr::filter(!is.na(group))


## geneCount
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$geneCount
  distance2 <- (data %>% dplyr::filter(group == group2) )$geneCount
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_geneCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = geneCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() +
    annotate("text", x = 1, y = (ymin + ymax)/2 + 1, label = paste0("p12: ", convPvalue(p12)),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("geneCount_", note)
  height <- 3
  width <- 1.5
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}
plot_geneCount(gene.TSS.tb.plot, "group_binaryGroup", ymax = 200)

```
###### Group
```{r}
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv"))$gene
group5 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv"))$gene
group8 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv"))$gene


gene.TSS.tb.plot <- gene.TSS.tb %>% rowwise() %>% dplyr::mutate(
  group = ifelse(ensembl %in% group1, "group1",
                 ifelse(ensembl %in% group2, "group2",
                        ifelse(ensembl %in% group5, "group5",
                               ifelse(ensembl %in% group8, "group8", NA))))) %>% 
  dplyr::filter(!is.na(group))


## geneCount
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$geneCount
  distance2 <- (data %>% dplyr::filter(group == group2) )$geneCount
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_geneCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  p15 <- round(getPvalWilcox(temp.tb, "group1", "group5"), 5)
  p18 <- round(getPvalWilcox(temp.tb, "group1", "group8"), 5)
  p25 <- round(getPvalWilcox(temp.tb, "group2", "group5"), 5)
  p28 <- round(getPvalWilcox(temp.tb, "group2", "group8"), 5)
  p58 <- round(getPvalWilcox(temp.tb, "group5", "group8"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = geneCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() +
    annotate("text", x = 1, y = (ymin + ymax)/2 + 1, label = paste0("p12: ", convPvalue(p12), "\n",
                                                         "p15: ", convPvalue(p15), "\n",
                                                         "p18: ", convPvalue(p18), "\n",
                                                         "p25: ", convPvalue(p25), "\n",
                                                         "p28: ", convPvalue(p28), "\n",
                                                         "p58: ",convPvalue( p58), "\n"),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("geneCount_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}
plot_geneCount(gene.TSS.tb.plot, "group", ymax = 200)

```
##### enhCount
###### Binary Group
```{r}
## enhCount
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$enhCount
  distance2 <- (data %>% dplyr::filter(group == group2) )$enhCount
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_enhCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = enhCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() +
    annotate("text", x = 1, y = (ymin + ymax)/2 + 1, label = paste0("p12: ", convPvalue(p12)),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("enhCount_", note)
  height <- 3
  width <- 1.5
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}
plot_enhCount(gene.TSS.tb.plot, "group_binaryGroup", ymax = 200)

```
###### Group
```{r}
## enhCount
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$enhCount
  distance2 <- (data %>% dplyr::filter(group == group2) )$enhCount
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_enhCount <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  p15 <- round(getPvalWilcox(temp.tb, "group1", "group5"), 5)
  p18 <- round(getPvalWilcox(temp.tb, "group1", "group8"), 5)
  p25 <- round(getPvalWilcox(temp.tb, "group2", "group5"), 5)
  p28 <- round(getPvalWilcox(temp.tb, "group2", "group8"), 5)
  p58 <- round(getPvalWilcox(temp.tb, "group5", "group8"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = enhCount)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() +
    annotate("text", x = 1, y = (ymin + ymax)/2 + 1, label = paste0("p12: ", convPvalue(p12), "\n",
                                                         "p15: ", convPvalue(p15), "\n",
                                                         "p18: ", convPvalue(p18), "\n",
                                                         "p25: ", convPvalue(p25), "\n",
                                                         "p28: ", convPvalue(p28), "\n",
                                                         "p58: ",convPvalue( p58), "\n"),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("enhCount_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}
plot_enhCount(gene.TSS.tb.plot, "group", ymax = 200)

```
##### geneDensity
###### binaryGroup
```{r}
## geneDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$geneDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$geneDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_geneDensity <- function(temp.tb, note, ymin = 0, ymax = 10){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  
  p <- ggplot(temp.tb, aes(x = ".", fill = group, y = geneDensity)) +
    # Set axis labels (no x-axis title)
    labs(x = NULL, y = "Gene density within TAD") +
    scale_fill_manual(values = (rev(c("#777777","#F28E2C")))) +
    # Violin plot with black outline, customized line width and end
    introdataviz::geom_split_violin(linewidth = lineMedium * mmToLineUnit, lineend = "square",
                                    alpha = .4
    ) +
    
    # Box plot with customized line width, square end, and outlier size
    geom_boxplot(
      width = 0.3, color = "black",
      linewidth = lineMedium * mmToLineUnit, lineend = "square",
      outlier.shape = NA,  alpha = 0.6, show.legend = FALSE
    ) +
    
    # Mean point in each group
    stat_summary(
      aes(group = group), fun = mean,
      geom = "point", shape = 21, size = 0.5,
      fill = "black", color = "black", position = position_dodge(.3)
    ) +
    
    # Horizontal line at y = 0
    geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
    
    # Coordinate limits and custom y-axis labels
    coord_cartesian(ylim = c(ymin, ymax)) +
    
    # Annotate p-value text
    annotate(
      "text", x = 1, y = ymin + 1,
      label = paste0("p12: ", convPvalue(p12)),
      color = "black", hjust = 0, size = 3
    ) +
    
    # Theme customization
    theme_classic() +
    theme(
      axis.title = element_text(
        size = fontSizeM, family = fontType, color = "#000000"
      ),
      axis.text = element_text(
        size = fontSizeS, family = fontType, color = "#000000"
      ),
      axis.text.x = element_text(
        angle = 45, hjust = 1, vjust = 1
      ),
      axis.line = element_line(
        color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
      ),
      axis.ticks = element_line(
        color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
      ),
      panel.background = element_rect(fill = "transparent"),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    )+   
    guides(
      fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
      ))
  
  
  
  
  
  fileName <- paste0("geneDensity_", note)
  width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}
plot_geneDensity(gene.TSS.tb.plot, "group_binaryGroup", ymax = 8)

```
###### Group
```{r}
## geneDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$geneDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$geneDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_geneDensity <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  p15 <- round(getPvalWilcox(temp.tb, "group1", "group5"), 5)
  p18 <- round(getPvalWilcox(temp.tb, "group1", "group8"), 5)
  p25 <- round(getPvalWilcox(temp.tb, "group2", "group5"), 5)
  p28 <- round(getPvalWilcox(temp.tb, "group2", "group8"), 5)
  p58 <- round(getPvalWilcox(temp.tb, "group5", "group8"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = geneDensity)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() +
    annotate("text", x = 1, y = (ymin + ymax)/2 + 1, label = paste0("p12: ", convPvalue(p12), "\n",
                                                         "p15: ", convPvalue(p15), "\n",
                                                         "p18: ", convPvalue(p18), "\n",
                                                         "p25: ", convPvalue(p25), "\n",
                                                         "p28: ", convPvalue(p28), "\n",
                                                         "p58: ",convPvalue( p58), "\n"),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("geneDensity_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}
plot_geneDensity(gene.TSS.tb.plot, "group", ymax = 10)

```
##### enhDensity
###### Binary group
```{r}
## enhDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$enhDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$enhDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_enhDensity <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = enhDensity)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() +
    annotate("text", x = 1, y = (ymin + ymax)/2 + 1, label = paste0("p12: ", convPvalue(p12)),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("enhDensity_", note)
  height <- 3
  width <- 1.5
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}
plot_enhDensity(gene.TSS.tb.plot, "group_binaryGroup", ymax = 10)

```
###### Group
```{r}
## enhDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$enhDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$enhDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_enhDensity <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  p15 <- round(getPvalWilcox(temp.tb, "group1", "group5"), 5)
  p18 <- round(getPvalWilcox(temp.tb, "group1", "group8"), 5)
  p25 <- round(getPvalWilcox(temp.tb, "group2", "group5"), 5)
  p28 <- round(getPvalWilcox(temp.tb, "group2", "group8"), 5)
  p58 <- round(getPvalWilcox(temp.tb, "group5", "group8"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = enhDensity)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() +
    annotate("text", x = 1, y = (ymin + ymax)/2 + 1, label = paste0("p12: ", convPvalue(p12), "\n",
                                                         "p15: ", convPvalue(p15), "\n",
                                                         "p18: ", convPvalue(p18), "\n",
                                                         "p25: ", convPvalue(p25), "\n",
                                                         "p28: ", convPvalue(p28), "\n",
                                                         "p58: ",convPvalue( p58), "\n"),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("enhDensity_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}
plot_enhDensity(gene.TSS.tb.plot, "group", ymax = 10)

```
##### regdensity
```{r}
## regDensity
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$regDensity
  distance2 <- (data %>% dplyr::filter(group == group2) )$regDensity
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


plot_regDensity <- function(temp.tb, note, ymin = 0, ymax = 2000000){
  p12 <- round(getPvalWilcox(temp.tb, "group1", "group2"), 5)
  p15 <- round(getPvalWilcox(temp.tb, "group1", "group5"), 5)
  p18 <- round(getPvalWilcox(temp.tb, "group1", "group8"), 5)
  p25 <- round(getPvalWilcox(temp.tb, "group2", "group5"), 5)
  p28 <- round(getPvalWilcox(temp.tb, "group2", "group8"), 5)
  p58 <- round(getPvalWilcox(temp.tb, "group5", "group8"), 5)
  
  p <- ggplot(temp.tb, aes(x = group, y = regDensity)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() +
    annotate("text", x = 1, y = (ymin + ymax)/2 + 1, label = paste0("p12: ", convPvalue(p12), "\n",
                                                         "p15: ", convPvalue(p15), "\n",
                                                         "p18: ", convPvalue(p18), "\n",
                                                         "p25: ", convPvalue(p25), "\n",
                                                         "p28: ", convPvalue(p28), "\n",
                                                         "p58: ",convPvalue( p58), "\n"),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("regDensity_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}
plot_regDensity(gene.TSS.tb.plot, "group", ymax = 10)

```
#### Checking TAD average log2FC
```{r}
diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj)

temp <- left_join(gene.TSS.tb, diff.RNA, by = c("ensembl" = "ensembl_gene_id")) %>% dplyr::filter(!is.na(log2FoldChange),
                                                                                                  !is.na(TAD))


data <- temp %>% group_by(TAD) %>%
  dplyr::summarise(absAvgLog2FC = abs(mean(log2FoldChange)),
                   avgLog2FC = mean(log2FoldChange),
                   geneDensity = mean(geneDensity),
                   enhDensity = mean(enhDensity),
                   regDensity = mean(regDensity))

data$geneDensityGroup <- cut(
  data$geneDensity,
  breaks = quantile(data$geneDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),
  include.lowest = TRUE,
  labels = paste0(seq(0, 80, 20), "-", seq(20, 100, 20), "%")
)

data$enhDensityGroup <- cut(
  data$enhDensity,
  breaks = quantile(data$enhDensity, probs = seq(0, 1, 0.2), na.rm = TRUE),
  include.lowest = TRUE,
  labels = paste0(seq(0, 80, 20), "-", seq(20, 100, 20), "%")
)


### Ploting  grouping

p <- ggplot(data, aes(x = enhDensityGroup, y = enhDensity, fill = enhDensityGroup)) + 
  geom_boxplot(color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA) + theme_classic() +
  coord_cartesian(ylim = c(0, quantile(data$enhDensity, 0.99))) +
  labs(x = "Enhancer Density Group" , y = "TAD enhancer density") +
  scale_fill_manual(values = c("#D9D9D9", "#BFBFBF", "#A6A6A6", "#8C8C8C", "#737373")) +
  theme(
    legend.position = "none",
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- paste0("tadGroup_enhDensity")
width <- panelSize(1.2)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()




p <- ggplot(data, aes(x = geneDensityGroup, y = geneDensity, fill = geneDensityGroup)) + 
  geom_boxplot(color = "black",
               linewidth = lineMedium * mmToLineUnit, lineend = "square",
               outlier.shape = NA) + theme_classic() +
  coord_cartesian(ylim = c(0, quantile(data$geneDensity, 0.99))) +
  labs(x = "Gene Density Group" , y = "Gene density") +
  scale_fill_manual(values = c("#777777", "#8B7E65", "#A28452", "#C2884D", "#F28E2C")) +
  theme(
    legend.position = "none",
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )
fileName <- paste0("tadGroup_geneDensity")
width <- 31*mmToInch
height <- 38*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()


### Plotting distribution - enh
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(enhDensityGroup ==group1) )$avgLog2FC
  distance2 <- (data %>% dplyr::filter(enhDensityGroup ==group2) )$avgLog2FC
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


#### ALL
# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))
# p <- ggplot(data, aes(x = enhDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = enhDensityGroup))+ 
#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +
#   coord_cartesian(ylim = c(-ylim, ylim)) +
#   geom_hline(yintercept = 0) +   theme(legend.position = "none") +
#   scale_fill_manual(values = c("#d9d9d9", "#bdbdbd", "#969696", "#737373", "#525252"))
# 
# fileName <- paste0("tadGroup_enhDensity_avgLog2FC")
# height <- 3
# width <- 3
# png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
# print(p)
# dev.off()
#### UP
data.plus <- data %>% dplyr::filter(avgLog2FC > 0)
ps01 <- round(getPvalWilcox(data.plus, "0-20%", "20-40%"), 5)
ps12 <- round(getPvalWilcox(data.plus, "20-40%", "40-60%"), 5)
ps23 <- round(getPvalWilcox(data.plus, "40-60%", "60-80%"), 5)
ps34 <- round(getPvalWilcox(data.plus, "60-80%", "80-100%"), 5)



p <- ggplot(data.plus, aes(x = enhDensityGroup, y = avgLog2FC)) + 
  geom_violin(aes(fill = enhDensityGroup),
              color = "black",
              linewidth = lineThick * mmToLineUnit, lineend = "square",
              show.legend = FALSE)+ 
  geom_boxplot(width = 0.1, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  labs(x = "Enhancer density group" , y = "avg log2(fold change)") +
  stat_summary(
    aes(group = enhDensityGroup), fun = mean,
    geom = "point", shape = 21, size = 1,
    fill = "red", color = "black"
  ) +
  scale_fill_manual(values = c("#D9D9D9", "#BFBFBF", "#A6A6A6", "#8C8C8C", "#737373")) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+ coord_cartesian(ylim = c(0, 1.5)) +
  annotate("text", x = 1, y = 1, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n"), 
           color = "black", hjust = 0, size = 2)


fileName <- paste0("tadGroup_enhDensity_avgLog2FC_up")
width <- panelSize(1.15)*mmToInch
height <- panelSize(1.07)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()


#### DOWN
data.minus <- data %>% dplyr::filter(avgLog2FC < 0)
ps01 <- round(getPvalWilcox(data.minus, "0-20%", "20-40%"), 5)
ps12 <- round(getPvalWilcox(data.minus, "20-40%", "40-60%"), 5)
ps23 <- round(getPvalWilcox(data.minus, "40-60%", "60-80%"), 5)
ps34 <- round(getPvalWilcox(data.minus, "60-80%", "80-100%"), 5)


p <- ggplot(data.minus, aes(x = enhDensityGroup, y = avgLog2FC)) + 
  geom_violin(aes(fill = enhDensityGroup),
              color = "black",
              linewidth = lineThick * mmToLineUnit, lineend = "square",
              show.legend = FALSE)+ 
  geom_boxplot(width = 0.1, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  labs(x = "Enhancer density group" , y = "avg log2(fold change)") +
  stat_summary(
    aes(group = enhDensityGroup), fun = mean,
    geom = "point", shape = 21, size = 1,
    fill = "red", color = "black"
  ) +
  scale_fill_manual(values = c("#D9D9D9", "#BFBFBF", "#A6A6A6", "#8C8C8C", "#737373")) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+ coord_cartesian(ylim = c(-1.5, 0))+
  annotate("text", x = 1, y = -1, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n"), 
           color = "black", hjust = 0, size = 2)

fileName <- paste0("tadGroup_enhDensity_avgLog2FC_down")
width <- panelSize(1.175)*mmToInch
height <- panelSize(1.07)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()



### Plotting distribution - gene
#### ALL
# ylim <- max(abs(quantile(data$avgLog2FC, 0.01)), abs(quantile(data$avgLog2FC, 0.99)))
# p <- ggplot(data, aes(x = geneDensityGroup, y = avgLog2FC)) + geom_violin(aes(fill = geneDensityGroup))+ 
#   geom_boxplot(outlier.shape = NA, width = 0.1) + theme_classic() +
#   coord_cartesian(ylim = c(-ylim, ylim)) +
#   geom_hline(yintercept = 0) +   theme(legend.position = "none") +
#   scale_fill_manual(values = c("#d9d9d9", "#bdbdbd", "#969696", "#737373", "#525252"))
# 
# fileName <- paste0("tadGroup_geneDensity_avgLog2FC")
# height <- 3
# width <- 3
# png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
# print(p)
# dev.off()
 getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(geneDensityGroup ==group1) )$avgLog2FC
  distance2 <- (data %>% dplyr::filter(geneDensityGroup ==group2) )$avgLog2FC
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


data.plus <- data %>% dplyr::filter(avgLog2FC > 0)
ps01 <- round(getPvalWilcox(data.plus, "0-20%", "20-40%"), 5)
ps12 <- round(getPvalWilcox(data.plus, "20-40%", "40-60%"), 5)
ps23 <- round(getPvalWilcox(data.plus, "40-60%", "60-80%"), 5)
ps34 <- round(getPvalWilcox(data.plus, "60-80%", "80-100%"), 5)



p <- ggplot(data.plus, aes(x = geneDensityGroup, y = avgLog2FC)) + 
  geom_violin(aes(fill = geneDensityGroup),
              color = "black",
              linewidth = lineThick * mmToLineUnit, lineend = "square",
              show.legend = FALSE)+ 
  geom_boxplot(width = 0.1, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  labs(x = "Gene density group" , y = "avg log2(fold change)") +
  stat_summary(
    aes(group = geneDensityGroup), fun = mean,
    geom = "point", shape = 21, size = 1,
    fill = "red", color = "black"
  ) +
  scale_fill_manual(values = c("#D9D9D9", "#BFBFBF", "#A6A6A6", "#8C8C8C", "#737373")) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+ coord_cartesian(ylim = c(0, 1.5)) +
  annotate("text", x = 1, y = 1, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n"), 
           color = "black", hjust = 0, size = 2)


fileName <- paste0("tadGroup_geneDensity_avgLog2FC_up")
width <- panelSize(1.15)*mmToInch
height <- panelSize(1.07)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()


#### DOWN
data.minus <- data %>% dplyr::filter(avgLog2FC < 0)
ps01 <- round(getPvalWilcox(data.minus, "0-20%", "20-40%"), 5)
ps12 <- round(getPvalWilcox(data.minus, "20-40%", "40-60%"), 5)
ps23 <- round(getPvalWilcox(data.minus, "40-60%", "60-80%"), 5)
ps34 <- round(getPvalWilcox(data.minus, "60-80%", "80-100%"), 5)


p <- ggplot(data.minus, aes(x = geneDensityGroup, y = avgLog2FC)) + 
  geom_violin(aes(fill = geneDensityGroup),
              color = "black",
              linewidth = lineThick * mmToLineUnit, lineend = "square",
              show.legend = FALSE)+ 
  geom_boxplot(width = 0.1, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  labs(x = "Gene density group" , y = "avg log2(fold change)") +
  stat_summary(
    aes(group = geneDensityGroup), fun = mean,
    geom = "point", shape = 21, size = 1,
    fill = "red", color = "black"
  ) +
  scale_fill_manual(values = c("#D9D9D9", "#BFBFBF", "#A6A6A6", "#8C8C8C", "#737373")) +
  theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+ coord_cartesian(ylim = c(-1.5, 0))+
  annotate("text", x = 1, y = -1, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n"), 
           color = "black", hjust = 0, size = 2)

fileName <- paste0("tadGroup_geneDensity_avgLog2FC_down")
width <- panelSize(1.175)*mmToInch
height <- panelSize(1.07)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()


### CDF plot

ks_result <- ks.test(
  data %>% dplyr::filter(geneDensityGroup == "0-20%") %>% pull(absAvgLog2FC),
  data %>% dplyr::filter(geneDensityGroup == "20-40%") %>% pull(absAvgLog2FC)
)


p <- ggplot(data, aes(x = absAvgLog2FC, color = geneDensityGroup)) +
  scale_color_manual(values = rev(c("#777777", "#8B7E65", "#A28452", "#C2884D", "#F28E2C"))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = "square" ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = "Abs. log2(fold change)",
    y = "Cumulative Probability"
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.position = "none",
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS),
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))


fileName <- paste0("tadGroup_geneDensity_avgLog2FC_cdf")
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

data <- data.minus

group1_data <- data$absAvgLog2FC[data$geneDensityGroup == "0-20%"]
group2_data <- data$absAvgLog2FC[data$geneDensityGroup == "20-40%"]
ks.test(group1_data, group2_data)

group1_data <- data$absAvgLog2FC[data$geneDensityGroup == "20-40%"]
group2_data <- data$absAvgLog2FC[data$geneDensityGroup == "40-60%"]
ks.test(group1_data, group2_data)

group1_data <- data$absAvgLog2FC[data$geneDensityGroup == "40-60%"]
group2_data <- data$absAvgLog2FC[data$geneDensityGroup == "60-80%"]
ks.test(group1_data, group2_data)

group1_data <- data$absAvgLog2FC[data$geneDensityGroup == "60-80%"]
group2_data <- data$absAvgLog2FC[data$geneDensityGroup == "80-100%"]
ks.test(group1_data, group2_data)


```


## [2.18] Comparing TAD insulation score across samples
Checking how insulation score changes by treatment at DMSO TAD boundaries
```{r}
name <- "chromo_cons_annoHierarchy"
consensus.loop.anno.tb <- fread(here(consensusDir, paste0(name, ".tsv")))

# Import insulation score calculated with python
resultDir <- here("../../result")
insScore.DMSO <- fread(here(resultDir, "TAD", "insulationScore_25kb_G1DMSO.tsv")) %>% 
  dplyr::select(c("chrom", "start", "end", "log2_insulation_score_125000")) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = "_"))
colnames(insScore.DMSO) <- c("chrom", "start", "end", "insulationScore", "binID")
insScore.dTAG <- fread(here(resultDir, "TAD", "insulationScore_25kb_G1dTAG.tsv")) %>% 
  dplyr::select(c("chrom", "start", "end", "log2_insulation_score_125000")) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = "_"))
colnames(insScore.dTAG) <- c("chrom", "start", "end", "insulationScore", "binID")
insScore.A485 <- fread(here(resultDir, "TAD", "insulationScore_25kb_G1A485.tsv")) %>% 
  dplyr::select(c("chrom", "start", "end", "log2_insulation_score_125000")) %>%
  dplyr::mutate(binID = paste(chrom, start, end, sep = "_"))
colnames(insScore.A485) <- c("chrom", "start", "end", "insulationScore", "binID")

getInsulationScore <- function(chr, coordinate, insScore.tb){
  temp.tb <- insScore.tb %>% dplyr::filter(chrom == chr, start < coordinate, end > coordinate)
  out <- temp.tb$insulationScore
  if(length(out) < 1){
    return(NA)
  }else{
    return(temp.tb$insulationScore)
  }
}

# Importing TAD boundaries
tad_boundary <- fread(here("../../result/TAD", "TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed"))
colnames(tad_boundary) <- c("chr", "start", "end")
tad_boundary <- tad_boundary %>% rowwise() %>%
  dplyr::mutate(tad_id = paste(chr, start, end, sep = "_"),
                center = (start + end)/2,
                insScore_DMSO = getInsulationScore(chr, center, insScore.DMSO),
                insScore_dTAG = getInsulationScore(chr, center, insScore.dTAG),
                insScore_A485 = getInsulationScore(chr, center, insScore.A485))

tad_boundary <- tad_boundary %>% filter(!if_any(everything(), is.na))

tad_boundary$density <- get_density(tad_boundary$insScore_DMSO, tad_boundary$insScore_dTAG, n = 100)
tad_boundary <- tad_boundary %>% dplyr::arrange(density)
ggplot(tad_boundary, aes(x = insScore_DMSO, y = insScore_dTAG, color = density)) + 
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() + coord_fixed() +
  geom_abline(slope = 1, intercept = 0) + theme_bw()



tad_boundary$density <- get_density(tad_boundary$insScore_DMSO, tad_boundary$insScore_A485, n = 100)
tad_boundary <- tad_boundary %>% dplyr::arrange(density)
ggplot(tad_boundary, aes(x = insScore_DMSO, y = insScore_A485, color = density)) + 
  geom_point(show.legend = FALSE) + 
  scale_color_viridis() + coord_fixed() +
  geom_abline(slope = 1, intercept = 0) + theme_bw()




```


## [2.20] Checking how many loops cross the boundary?
Previously, I tried to check the percentage of loops crossing the boundary per group which wasn't fruitful.
This time, try to do this on the differential loops.
#### dTAG
```{r}
### Importing differential regulatory loops

loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe")) %>%
  dplyr::mutate(group = "UP/NO")
colnames(loop.up) <- c("chr1", "start1", "end1", "chr2", "start2", "end2", "group")
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe")) %>%
  dplyr::mutate(group = "UP/NO")
colnames(loop.no) <- c("chr1", "start1", "end1", "chr2", "start2", "end2", "group")
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe")) %>%
  dplyr::mutate(group = "DOWN")
colnames(loop.down) <- c("chr1", "start1", "end1", "chr2", "start2", "end2", "group")

loops <- bind_rows(bind_rows(loop.up, loop.no), loop.down)

### Importing TAD boundary
tad_boundary <- fread(here("../../result/TAD", "TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed"))
colnames(tad_boundary) <- c("chr", "start", "end")
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = "_"),
                                               start = start -175000/2,
                                               end = end + 175000/2,
                                               center = (start + end)/2)
### Functions
checkBoundaryCross <- function(chrom1, start1, end2, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom1,
                                 center > start1,
                                 center < end2)
  return(length(temp$center))
}

### Check overlap
loops <- loops %>% rowwise() %>%
  dplyr::mutate(boundaryCross = checkBoundaryCross(chr1, start1, end2, tad_boundary))

### Plotting
summary_data <- loops %>%
  group_by(group) %>%
  summarise(percentage = mean(boundaryCross > 0) * 100)

summary_data$group <- factor(summary_data$group, levels = c("UP/NO", "DOWN"))

p <- ggplot(summary_data, aes(x = group, y = percentage)) +
  geom_bar(stat = "identity", fill = darken(strong_green, amount = 0.2)) +
  labs(y = "% of loops crossing TAD boundary", x = NULL) +
  theme_classic() + ylim(0, 100) +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
  )

fileName <- paste0("boundaryCrossRatio")
width <- panelSize(1)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

#### A485
```{r}
### Importing differential regulatory loops
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe")) %>%
  dplyr::mutate(group = "up")
colnames(loop.up) <- c("chr1", "start1", "end1", "chr2", "start2", "end2", "group")
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe")) %>%
  dplyr::mutate(group = "no")
colnames(loop.no) <- c("chr1", "start1", "end1", "chr2", "start2", "end2", "group")
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe")) %>%
  dplyr::mutate(group = "down")
colnames(loop.down) <- c("chr1", "start1", "end1", "chr2", "start2", "end2", "group")

loops <- bind_rows(bind_rows(loop.up, loop.no), loop.down)

### Importing TAD boundary
tad_boundary <- fread(here("../../result/TAD", "TAD_25kb_125kb_otsu_boundaries_G1DMSO.bed"))
colnames(tad_boundary) <- c("chr", "start", "end")
tad_boundary <- tad_boundary %>% dplyr::mutate(tad_id = paste(chr, start, end, sep = "_"),
                                               start = start -175000/2,
                                               end = end + 175000/2,
                                               center = (start + end)/2)
### Functions
checkBoundaryCross <- function(chrom1, start1, end2, tad_boundary){
  temp <- tad_boundary %>% dplyr::filter(chr == chrom1,
                                 center > start1,
                                 center < end2)
  return(length(temp$center))
}

### Check overlap
loops <- loops %>% rowwise() %>%
  dplyr::mutate(boundaryCross = checkBoundaryCross(chr1, start1, end2, tad_boundary))

### Plotting
summary_data <- loops %>%
  group_by(group) %>%
  summarise(percentage = mean(boundaryCross > 0) * 100)


p <- ggplot(summary_data, aes(x = group, y = percentage)) +
  geom_bar(stat = "identity", fill = "skyblue") +
  labs(title = "Percentage of Rows with boundaryCross > 0 per Group",
       x = "Group",
       y = "Percentage") +
  theme_classic() + ylim(0, 100)

fileName <- paste0("boundaryCrossRatio_A485")
height <- 3
width <- 3
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```


## [2.21] LOLA on differential loop anchors
##### LOADING LOLA
```{r}
# LOADING LOLA DB
library("simpleCache")
library("LOLA")
lolaDB = loadRegionDB("/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/reference/LOLACore_cached/mm10")

# FUNCTIONS
extractAnchor <- function(loop){
  anchor1 <- loop %>% dplyr::select(c(1, 2, 3))
  colnames(anchor1) <- c("chr", "start", "end")
  anchor2 <- loop %>% dplyr::select(c(4, 5, 6))
  colnames(anchor2) <- c("chr", "start", "end")
  anchors <- reduce(makeGRangesFromDataFrame(bind_rows(anchor1, anchor2)))
    return(anchors)
}

```
#### dTAG, Comparing to Async
##### - Limited to ATAC-seq signal, reg loop backgroupd
```{r}
atac <- fread(here(refDir, "GSM3106257_ATAC_ESC_1.bed")) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c("chr", "start", "end")
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, "chromo_cons_annoHierarchy.tsv")) %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E"))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



loop.1 <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe"))
anchor.1 <- (extractAnchor(loop.1))
overlaps <- findOverlaps(anchor.1, atac.gr)
anchor.1 <- pintersect(anchor.1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.2 <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe"))
anchor.2 <- (extractAnchor(loop.2))
overlaps <- findOverlaps(anchor.2, atac.gr)
anchor.2 <- pintersect(anchor.2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.3 <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe"))
anchor.3 <- (extractAnchor(loop.3))
overlaps <- findOverlaps(anchor.3, atac.gr)
anchor.3 <- pintersect(anchor.3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.4 <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe"))
anchor.4 <- (extractAnchor(loop.4))
overlaps <- findOverlaps(anchor.4, atac.gr)
anchor.4 <- pintersect(anchor.4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


anchors <- list(anchor.1, anchor.2, anchor.3, anchor.4)
tbs <- list()
temps <- list()

# Process clusters c1 to c8
for (i in 1:4) {
  
  anchor <- anchors[[i]]
  # Run LOLA
  result <- runLOLA(anchor, anchor.all, lolaDB)
  tb <- as_tibble(result)
  
  # Filter and summarize
  tb <- tb %>%
    dplyr::mutate(target = toupper(antibody)) %>%
    filter(str_to_lower(cellType) == "embryonic stem cell") %>%
    dplyr::filter(qValue < alpha) %>%
    dplyr::group_by(target) %>%
    slice_min(meanRnk, with_ties = FALSE)
  
  # Store tb
  tbs[[i]] <- tb
  
  # Select and rename oddsRatio
  temp <- tb %>% dplyr::select(target, oddsRatio)
  colnames(temp) <- c("target", paste0("OR_c", i))
  
  # Store temp
  temps[[i]] <- temp
}

# Merge all temp tables into one
temp <- Reduce(function(x, y) full_join(x, y, by = "target"), temps) %>%
  mutate_all(~replace_na(., 1))
colnames(temp) <- c("target", "bothRetained", "AsyncSpecificPerturb", "G1SpecificPerturb", "bothPerturb")
data <- temp %>% column_to_rownames("target") %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c("white", "red"))


#fviz_nbclust(data, kmeans, method = "wss")

p <- Heatmap(
  data,
  name = "Odds Ratio",                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)



```

#### dTAG
##### - Limiting to ATAC-seq signal, reg loop background
```{r}
atac <- fread(here(refDir, "GSM3106257_ATAC_ESC_1.bed")) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c("chr", "start", "end")
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, "chromo_cons_annoHierarchy.tsv")) %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E"))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe"))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe"))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.upno <- bind_rows(loop.up, loop.no)
anchor.upno <- (extractAnchor(loop.upno))
overlaps <- findOverlaps(anchor.upno, atac.gr)
anchor.upno <- pintersect(anchor.upno[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



```


```{r}
# RUNNING LOLA
lolaDir <- here("../../result/lola")
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv"), sep = "\t")

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv"), sep = "\t")

# UPNO
result = runLOLA(anchor.upno, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv"), sep = "\t")

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv"), sep = "\t")


### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c("target", "OR_up")
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c("target", "OR_no")
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c("target", "OR_down")


temp <- full_join(full_join(temp.up, temp.no, by = c("target")), temp.down, by = c("target")) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c("white", "red"))


#fviz_nbclust(data, kmeans, method = "wss")

# p <- Heatmap(
#   data,
#   name = "Odds Ratio",                   # Name of the heatmap legend
#   cluster_columns = FALSE,            # Remove column dendrogram
#   row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)
#   show_row_dend = FALSE,
#   col = col_fun                       # Use the red gradient color scale
# )
# 
# fileName <- paste0("anchorLOLA_dTAG_vs_DMSO_diff0.2_regAnchorBackground_atac")
# height <- 7
# width <- 3.5
# png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
# print(p)
# dev.off()
# 


### Visualizing p-value and OR
alpha <- 0.05
# tb.up <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv")) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = "UP") %>%
#   filter(str_to_lower(cellType) == "embryonic stem cell") %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# tb.no <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv")) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = "NO") %>%
#   filter(str_to_lower(cellType) == "embryonic stem cell") %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)

tb.upno <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_upno_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = "UP/NO") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.upno %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_upno_atac_pub.tsv"), sep = "\t")

tb.down <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = "DOWN") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.down %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_down_atac_pub.tsv"), sep = "\t")


temp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.upno, temp.down)

# order <- c((temp %>% dplyr::filter(group == "UP/NO") %>% arrange(desc(oddsRatio)))$target, 
#            (temp %>% dplyr::filter(group == "DOWN") %>% arrange(desc(oddsRatio)))$target)

# temp$target <- factor(temp$target, levels = rev(order))
temp$group <- factor(temp$group, levels = c("UP/NO", "DOWN"))

targetList <- c("POLR2A", "CTR9",
                "AFF4", "ELL2",
                "MED1", "MED12",
                "TBP", "TAF1", "TAF3",
                "E2F1", "YY1", "NIPBL", 
                "EP300", "DPY30", "SETDB1",
                "RAD21", "SMC1A", "SMC3", "CTCF",
                "SUZ12", "PHF19"
)
temp <- temp %>% dplyr::filter(target %in% targetList)
temp$target <- factor(temp$target, levels = rev(targetList))


qValueLogMax <- 50
temp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))

p <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = "white", high = "#CB333A",
                      limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )
# p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
#   geom_point() + theme_bw() + 
#   scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
#   scale_color_gradient(low = "blue", high = "red",
#                        guide = guide_colorbar(
#                          barwidth = 1.5/5.08,  # Adjust width of the color bar
#                          barheight = 15/5.08    # Adjust height of the color bar
#                        )) +
#   labs(x = NULL, y = NULL)  +
#   theme(
#     axis.title = element_text(
#       size = fontSizeS,
#       family = fontType,
#       color = "#000000"
#     ),
#     axis.text = element_text(
#       size = fontSizeS,
#       family = fontType,
#       color = "#000000"
#     ),
#     axis.text.x = element_text(
#       angle = 45,      # Rotate x-axis labels 45 degrees
#       hjust = 1,       # Adjust horizontal justification
#       vjust = 1        # Adjust vertical justification
#     ),
#     axis.line = element_line(
#       color = "#000000",
#       size = lineThick*mmToLineUnit,
#       lineend = "square"
#     ),
#     axis.ticks = element_line(
#       color = "#000000",
#       size = lineThick*mmToLineUnit,
#       lineend = "square"
#     ),
#     panel.background = element_rect(fill = "transparent"),
#     legend.text = element_text(family = fontType, size = fontSizeS),
#     legend.title = element_text(family = fontType, size = fontSizeS)
#   )

fileName <- paste0("anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac_upno")
width <- panelSize(1.5)*mmToInch
height <- panelSize(1.9)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```


```{r}
### 241015 Testing on subset of loops
anchor.c1 <- extractAnchor(loop.cluster1)
overlaps <- findOverlaps(anchor.c1, atac.gr)
anchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c2 <- extractAnchor(loop.cluster2)
overlaps <- findOverlaps(anchor.c2, atac.gr)
anchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c3 <- extractAnchor(loop.cluster3)
overlaps <- findOverlaps(anchor.c3, atac.gr)
anchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c4 <- extractAnchor(loop.cluster4)
overlaps <- findOverlaps(anchor.c4, atac.gr)
anchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c5 <- extractAnchor(loop.cluster5)
overlaps <- findOverlaps(anchor.c5, atac.gr)
anchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c6 <- extractAnchor(loop.cluster6)
overlaps <- findOverlaps(anchor.c6, atac.gr)
anchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c7 <- extractAnchor(loop.cluster7)
overlaps <- findOverlaps(anchor.c7, atac.gr)
anchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c8 <- extractAnchor(loop.cluster8)
overlaps <- findOverlaps(anchor.c8, atac.gr)
anchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

result = runLOLA(anchor.c1, anchor.all, lolaDB)
tb.c1 = as_tibble(result)

result = runLOLA(anchor.c2, anchor.all, lolaDB)
tb.c2 = as_tibble(result)

result = runLOLA(anchor.c3, anchor.all, lolaDB)
tb.c3 = as_tibble(result)

result = runLOLA(anchor.c4, anchor.all, lolaDB)
tb.c4 = as_tibble(result)
result = runLOLA(anchor.c5, anchor.all, lolaDB)
tb.c5 = as_tibble(result)

result = runLOLA(anchor.c6, anchor.all, lolaDB)
tb.c6 = as_tibble(result)

result = runLOLA(anchor.c7, anchor.all, lolaDB)
tb.c7 = as_tibble(result)

result = runLOLA(anchor.c8, anchor.all, lolaDB)
tb.c8 = as_tibble(result)

### HEATMAP
alpha <- 0.05
tb.c1 <- tb.c1 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c2 <- tb.c2 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c3 <- tb.c3 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c4 <- tb.c4 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c5 <- tb.c5 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c6 <- tb.c6 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c7 <- tb.c7 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c8 <- tb.c8 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)
colnames(temp.c1) <- c("target", "OR_c1")
temp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)
colnames(temp.c2) <- c("target", "OR_c2")
temp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)
colnames(temp.c3) <- c("target", "OR_c3")
temp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)
colnames(temp.c4) <- c("target", "OR_c4")
temp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)
colnames(temp.c5) <- c("target", "OR_c5")
temp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)
colnames(temp.c6) <- c("target", "OR_c6")
temp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)
colnames(temp.c7) <- c("target", "OR_c7")
temp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)
colnames(temp.c8) <- c("target", "OR_c8")

temp <- full_join(temp.c1, temp.c2, by = "target") %>%
  full_join(temp.c3, by = "target") %>%
  full_join(temp.c4, by = "target") %>%
  full_join(temp.c5, by = "target") %>%
  full_join(temp.c6, by = "target") %>%
  full_join(temp.c7, by = "target") %>%
  full_join(temp.c8, by = "target") %>%
  mutate_all(~replace_na(., 1))

data <- temp %>% column_to_rownames("target") %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c("white", "red"))


#fviz_nbclust(data, kmeans, method = "wss")

p <- Heatmap(
  data,
  name = "Odds Ratio",                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)


# Initialize lists to store results
anchors <- list()
tbs <- list()
temps <- list()

# Process clusters c1 to c8
for (i in 1:4) {
  # Extract anchor
  loop_cluster <- get(paste0("loop.cluster", i))
  anchor <- extractAnchor(loop_cluster)
  
  # Find overlaps and intersect
  overlaps <- findOverlaps(anchor, atac.gr)
  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
  
  # Store anchor
  anchors[[i]] <- anchor
  
  # Run LOLA
  result <- runLOLA(anchor, anchor.all, lolaDB)
  tb <- as_tibble(result)
  
  # Filter and summarize
  tb <- tb %>%
    dplyr::mutate(target = toupper(antibody)) %>%
    filter(str_to_lower(cellType) == "embryonic stem cell") %>%
    dplyr::filter(qValue < alpha) %>%
    dplyr::group_by(target) %>%
    slice_min(meanRnk, with_ties = FALSE)
  
  # Store tb
  tbs[[i]] <- tb
  
  # Select and rename oddsRatio
  temp <- tb %>% dplyr::select(target, oddsRatio)
  colnames(temp) <- c("target", paste0("OR_c", i))
  
  # Store temp
  temps[[i]] <- temp
}

# Merge all temp tables into one
temp <- Reduce(function(x, y) full_join(x, y, by = "target"), temps) %>%
  mutate_all(~replace_na(., 1))
data <- temp %>% column_to_rownames("target") %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c("white", "red"))


#fviz_nbclust(data, kmeans, method = "wss")

p <- Heatmap(
  data,
  name = "Odds Ratio",                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)
```



##### - Limited to ATAC-seq signal, all loop backgroup
```{r}
atac <- fread(here(refDir, "GSM3106257_ATAC_ESC_1.bed")) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c("chr", "start", "end")
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, "chromo_cons_annoHierarchy.tsv"))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe"))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe"))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.upno <- bind_rows(loop.up, loop.no)
anchor.upno <- (extractAnchor(loop.upno))
overlaps <- findOverlaps(anchor.upno, atac.gr)
anchor.upno <- pintersect(anchor.upno[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loopNum <- nrow(loop.upno)

# Selecting same number of extreme down loops
loop.down <- loop.all %>% dplyr::filter(diff_dTAG_DMSO < -0.2) %>% dplyr::arrange(diff_dTAG_DMSO) %>% slice_head(n = loopNum)
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

```


```{r}
# RUNNING LOLA
lolaDir <- here("../../result/lola")
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
#fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv"), sep = "\t")

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
#fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv"), sep = "\t")

# UPNO
result = runLOLA(anchor.upno, anchor.all, lolaDB)
tb = as_tibble(result)
#fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv"), sep = "\t")


# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
#fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv"), sep = "\t")



### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c("target", "OR_up")
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c("target", "OR_no")
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c("target", "OR_down")


temp <- full_join(full_join(temp.up, temp.no, by = c("target")), temp.down, by = c("target")) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c("white", "red"))


#fviz_nbclust(data, kmeans, method = "wss")

# p <- Heatmap(
#   data,
#   name = "Odds Ratio",                   # Name of the heatmap legend
#   cluster_columns = FALSE,            # Remove column dendrogram
#   row_km = 10,                         # Define the number of k-means clusters for rows (adjust as needed)
#   show_row_dend = FALSE,
#   col = col_fun,
#   border = TRUE
# )
# 
# fileName <- paste0("anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_allAnchorBackground_atac")
# height <- 7
# width <- 3.5
# png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
# print(p)
# dev.off()




### Visualizing p-value and OR
alpha <- 0.05
# tb.up <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv")) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = "UP") %>%
#   filter(str_to_lower(cellType) == "embryonic stem cell") %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# tb.no <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv")) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = "NO") %>%
#   filter(str_to_lower(cellType) == "embryonic stem cell") %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
tb.upno <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = "UP/NO") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.upno %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_upno_allLoops_extreme_atac_pub.tsv"), sep = "\t")
tb.down <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log10(qValue),
                group = "DOWN") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
fwrite(tb.down %>% dplyr::select(c(24, 16, 20,
                                   4, 25, 5,
                                   7, 8, 9, 10, 11,
                                   12, 13, 14)), here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_down_allLoops_extreme_atac_pub.tsv"), sep = "\t")

# temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
# temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.upno <- tb.upno %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.upno, temp.down)
# 
# order <- c((temp %>% dplyr::filter(group == "UP/NO") %>% arrange(desc(oddsRatio)))$target, 
#            (temp %>% dplyr::filter(group == "DOWN") %>% arrange(desc(oddsRatio)))$target)
# temp$target <- factor(temp$target, levels = rev(order))
temp$group <- factor(temp$group, levels = c("UP/NO", "DOWN"))


targetList <- c("POLR2A", "CTR9",
                "AFF4", "ELL2",
                "MED1", "MED12",
                "TBP", "TAF1", "TAF3",
                "ESRRB", "KLF4", "NANOG", "POU5F1", "SOX2", "STAT3", "E2F1", "YY1",
                "EP300", "DPY30", "EZH2", "KDM2B", "KDB4B", "KDM4C", "KDM6B", "RBBP5",
                "RAD21", "SMC1A", "SMC3", "CTCF",
                "JARID2", "SUZ12"
)
temp <- temp %>% dplyr::filter(target %in% targetList)

temp$target <- factor(temp$target, levels = rev(targetList))
# MAX qValueLog to 50
qValueLogMax <- 50
temp2 <- temp %>% dplyr::mutate(qValueLog = min(qValueLog, qValueLogMax))
p <- ggplot(temp2, aes(x = group, y = target, fill = oddsRatio, size = qValueLog)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 0.5*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(0.5, 2)) +  # Set min and max point sizes here
  scale_fill_gradient(low = "white", high = "#CB333A",
                      limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + 
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- paste0("anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_OR_qValue_allAnchorBackground_atac_ordered")
width <- panelSize(1.5)*mmToInch
height <- panelSize(2.5)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()




```

### dTAG, obsexp

##### - Limited to ATAC-seq signal, all loop backgroup
```{r}
atac <- fread(here(refDir, "GSM3106257_ATAC_ESC_1.bed")) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c("chr", "start", "end")
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, "chromo_cons_annoHierarchy.tsv"))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_logOE_all_dTAGvsDMSO_UP_diff0.5.bedpe"))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_logOE_all_dTAGvsDMSO_NO_diff0.5.bedpe"))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_logOE_all_dTAGvsDMSO_DOWN_diff0.5.bedpe"))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


```


```{r}
# RUNNING LOLA
lolaDir <- here("../../result/lola")
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv"), sep = "\t")

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv"), sep = "\t")

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv"), sep = "\t")



### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c("target", "OR_up")
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c("target", "OR_no")
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c("target", "OR_down")


temp <- full_join(full_join(temp.up, temp.no, by = c("target")), temp.down, by = c("target")) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c("white", "red"))


#fviz_nbclust(data, kmeans, method = "wss")

p <- Heatmap(
  data,
  name = "Odds Ratio",                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 4,                        # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)

fileName <- paste0("anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_allLoops_allAnchorBackground_atac")
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()


############
# 
# ### Visualizing p-value and OR
# alpha <- 0.05
# tb.up <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_allLoops_atac.tsv")) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = "UP") %>%
#   filter(str_to_lower(cellType) == "embryonic stem cell") %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# tb.no <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_allLoops_atac.tsv")) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = "NO") %>%
#   filter(str_to_lower(cellType) == "embryonic stem cell") %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# tb.down <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_allLoops_atac.tsv")) %>%
#   dplyr::mutate(target = toupper(antibody),
#                 qValueLog = -log2(qValue),
#                 group = "DOWN") %>%
#   filter(str_to_lower(cellType) == "embryonic stem cell") %>%
#   dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
#   slice_min(meanRnk, with_ties = FALSE)
# 
# temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
# temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
# temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)
# 
# temp <- bind_rows(temp.up, temp.down)
# 
# order <- c((temp %>% dplyr::filter(group == "UP") %>% arrange(desc(oddsRatio)))$target, 
#            (temp %>% dplyr::filter(group == "DOWN") %>% arrange(desc(oddsRatio)))$target)
# temp$target <- factor(temp$target, levels = rev(order))
# p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
#   geom_point() + theme_bw() + scale_color_gradient(low = "blue", high = "red") +
#   labs(x = NULL, y = NULL)  +   scale_size_continuous(range = c(1, 3)) +
#   theme(axis.text = element_text(size = 6),  # Set axis text size
#         axis.title = element_text(size = 6), # Set axis title size (if not removed)
#         legend.text = element_text(size = 6), # Set legend text size
#         legend.title = element_text(size = 6)) 
# 
# fileName <- paste0("anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_allLoops_OR_allAnchorBackground_atac")
# height <-3
# width <- 2
# png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
# print(p)
# dev.off()
# svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
# print(p)
# dev.off()


```

##### - Limiting to ATAC-seq signal, reg loop background
```{r}
atac <- fread(here(refDir, "GSM3106257_ATAC_ESC_1.bed")) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c("chr", "start", "end")
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, "chromo_cons_annoHierarchy.tsv")) %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E"))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_logOE_pe-pe_dTAGvsDMSO_UP_diff0.5.bedpe"))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_logOE_pe-pe_dTAGvsDMSO_NO_diff0.5.bedpe"))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_logOE_pe-pe_dTAGvsDMSO_DOWN_diff0.5.bedpe"))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



```


```{r}
# RUNNING LOLA
lolaDir <- here("../../result/lola")
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv"), sep = "\t")

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv"), sep = "\t")

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv"), sep = "\t")


### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_up_pe-peLoops_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_no_pe-peLoops_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_logOE_diff0.5_down_pe-peLoops_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c("target", "OR_up")
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c("target", "OR_no")
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c("target", "OR_down")


temp <- full_join(full_join(temp.up, temp.no, by = c("target")), temp.down, by = c("target")) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c("white", "red"))


#fviz_nbclust(data, kmeans, method = "wss")

p <- Heatmap(
  data,
  name = "Odds Ratio",                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun                       # Use the red gradient color scale
)

fileName <- paste0("anchorLOLA_dTAG_vs_DMSO_logOE_diff0.5_pe-peLoops_regAnchorBackground_atac")
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()



### Visualizing p-value and OR
alpha <- 0.05
tb.up <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_up_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "UP") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_no_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "NO") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, "LOLA_dTAG_vs_DMSO_diff0.2_down_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "DOWN") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.up, temp.down)

order <- c((temp %>% dplyr::filter(group == "UP") %>% arrange(desc(oddsRatio)))$target, 
           (temp %>% dplyr::filter(group == "DOWN") %>% arrange(desc(oddsRatio)))$target)
temp$target <- factor(temp$target, levels = rev(order))
p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
  geom_point() + theme_bw() + scale_color_gradient(low = "blue", high = "red") +
  labs(x = NULL, y = NULL)  +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- paste0("anchorLOLA_dTAG_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac")
height <-3
width <- 2
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()





### 241015 Testing on subset of loops
anchor.c1 <- extractAnchor(loop.cluster1)
overlaps <- findOverlaps(anchor.c1, atac.gr)
anchor.c1 <- pintersect(anchor.c1[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c2 <- extractAnchor(loop.cluster2)
overlaps <- findOverlaps(anchor.c2, atac.gr)
anchor.c2 <- pintersect(anchor.c2[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c3 <- extractAnchor(loop.cluster3)
overlaps <- findOverlaps(anchor.c3, atac.gr)
anchor.c3 <- pintersect(anchor.c3[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c4 <- extractAnchor(loop.cluster4)
overlaps <- findOverlaps(anchor.c4, atac.gr)
anchor.c4 <- pintersect(anchor.c4[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c5 <- extractAnchor(loop.cluster5)
overlaps <- findOverlaps(anchor.c5, atac.gr)
anchor.c5 <- pintersect(anchor.c5[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c6 <- extractAnchor(loop.cluster6)
overlaps <- findOverlaps(anchor.c6, atac.gr)
anchor.c6 <- pintersect(anchor.c6[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c7 <- extractAnchor(loop.cluster7)
overlaps <- findOverlaps(anchor.c7, atac.gr)
anchor.c7 <- pintersect(anchor.c7[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

anchor.c8 <- extractAnchor(loop.cluster8)
overlaps <- findOverlaps(anchor.c8, atac.gr)
anchor.c8 <- pintersect(anchor.c8[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

result = runLOLA(anchor.c1, anchor.all, lolaDB)
tb.c1 = as_tibble(result)

result = runLOLA(anchor.c2, anchor.all, lolaDB)
tb.c2 = as_tibble(result)

result = runLOLA(anchor.c3, anchor.all, lolaDB)
tb.c3 = as_tibble(result)

result = runLOLA(anchor.c4, anchor.all, lolaDB)
tb.c4 = as_tibble(result)
result = runLOLA(anchor.c5, anchor.all, lolaDB)
tb.c5 = as_tibble(result)

result = runLOLA(anchor.c6, anchor.all, lolaDB)
tb.c6 = as_tibble(result)

result = runLOLA(anchor.c7, anchor.all, lolaDB)
tb.c7 = as_tibble(result)

result = runLOLA(anchor.c8, anchor.all, lolaDB)
tb.c8 = as_tibble(result)

### HEATMAP
alpha <- 0.05
tb.c1 <- tb.c1 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c2 <- tb.c2 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c3 <- tb.c3 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c4 <- tb.c4 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.c5 <- tb.c5 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c6 <- tb.c6 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c7 <- tb.c7 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

tb.c8 <- tb.c8 %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>%
  dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.c1 <- tb.c1 %>% dplyr::select(target, oddsRatio)
colnames(temp.c1) <- c("target", "OR_c1")
temp.c2 <- tb.c2 %>% dplyr::select(target, oddsRatio)
colnames(temp.c2) <- c("target", "OR_c2")
temp.c3 <- tb.c3 %>% dplyr::select(target, oddsRatio)
colnames(temp.c3) <- c("target", "OR_c3")
temp.c4 <- tb.c4 %>% dplyr::select(target, oddsRatio)
colnames(temp.c4) <- c("target", "OR_c4")
temp.c5 <- tb.c5 %>% dplyr::select(target, oddsRatio)
colnames(temp.c5) <- c("target", "OR_c5")
temp.c6 <- tb.c6 %>% dplyr::select(target, oddsRatio)
colnames(temp.c6) <- c("target", "OR_c6")
temp.c7 <- tb.c7 %>% dplyr::select(target, oddsRatio)
colnames(temp.c7) <- c("target", "OR_c7")
temp.c8 <- tb.c8 %>% dplyr::select(target, oddsRatio)
colnames(temp.c8) <- c("target", "OR_c8")

temp <- full_join(temp.c1, temp.c2, by = "target") %>%
  full_join(temp.c3, by = "target") %>%
  full_join(temp.c4, by = "target") %>%
  full_join(temp.c5, by = "target") %>%
  full_join(temp.c6, by = "target") %>%
  full_join(temp.c7, by = "target") %>%
  full_join(temp.c8, by = "target") %>%
  mutate_all(~replace_na(., 1))

data <- temp %>% column_to_rownames("target") %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c("white", "red"))


#fviz_nbclust(data, kmeans, method = "wss")

p <- Heatmap(
  data,
  name = "Odds Ratio",                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)


# Initialize lists to store results
anchors <- list()
tbs <- list()
temps <- list()

# Process clusters c1 to c8
for (i in 1:4) {
  # Extract anchor
  loop_cluster <- get(paste0("loop.cluster", i))
  anchor <- extractAnchor(loop_cluster)
  
  # Find overlaps and intersect
  overlaps <- findOverlaps(anchor, atac.gr)
  anchor <- pintersect(anchor[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
  
  # Store anchor
  anchors[[i]] <- anchor
  
  # Run LOLA
  result <- runLOLA(anchor, anchor.all, lolaDB)
  tb <- as_tibble(result)
  
  # Filter and summarize
  tb <- tb %>%
    dplyr::mutate(target = toupper(antibody)) %>%
    filter(str_to_lower(cellType) == "embryonic stem cell") %>%
    dplyr::filter(qValue < alpha) %>%
    dplyr::group_by(target) %>%
    slice_min(meanRnk, with_ties = FALSE)
  
  # Store tb
  tbs[[i]] <- tb
  
  # Select and rename oddsRatio
  temp <- tb %>% dplyr::select(target, oddsRatio)
  colnames(temp) <- c("target", paste0("OR_c", i))
  
  # Store temp
  temps[[i]] <- temp
}

# Merge all temp tables into one
temp <- Reduce(function(x, y) full_join(x, y, by = "target"), temps) %>%
  mutate_all(~replace_na(., 1))
data <- temp %>% column_to_rownames("target") %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c("white", "red"))


#fviz_nbclust(data, kmeans, method = "wss")

p <- Heatmap(
  data,
  name = "Odds Ratio",                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)
```


### A485
##### - Limited to ATAC-seq signal, all loop backgroupd
```{r}
atac <- fread(here(refDir, "GSM3106257_ATAC_ESC_1.bed")) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c("chr", "start", "end")
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, "chromo_cons_annoHierarchy.tsv"))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe"))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loopNum <- nrow(loop.down)

# Selecting same number of extreme no loops
loop.no <- loop.all %>% 
  dplyr::mutate(absDiff = abs(diff_A485_DMSO)) %>%
  dplyr::filter(absDiff < 0.2) %>%
  dplyr::arrange(absDiff) %>% slice_head(n = loopNum)
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
```

```{r}
# RUNNING LOLA
lolaDir <- here("../../result/lola")
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv"), sep = "\t")

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv"), sep = "\t")

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv"), sep = "\t")



### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c("target", "OR_up")
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c("target", "OR_no")
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c("target", "OR_down")


temp <- full_join(full_join(temp.up, temp.no, by = c("target")), temp.down, by = c("target")) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c("white", "red"))


#fviz_nbclust(data, kmeans, method = "wss")

p <- Heatmap(
  data,
  name = "Odds Ratio",                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 5,                         # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)

fileName <- paste0("anchorLOLA_A485_vs_DMSO_diff0.2_allLoops_extreme_regAnchorBackground_atac")
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()




### Visualizing p-value and OR
alpha <- 0.05
tb.up <- fread(here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_up_allLoops_extreme_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "UP") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_no_allLoops_extreme_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "NO") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_down_allLoops_extreme_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "DOWN") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.up, temp.down)

order <- unique(c((temp %>% dplyr::filter(group == "UP") %>% arrange(desc(oddsRatio)))$target, 
           (temp %>% dplyr::filter(group == "DOWN") %>% arrange(desc(oddsRatio)))$target))
temp$target <- factor(temp$target, levels = rev(order))
p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
  geom_point() + theme_bw() + scale_color_gradient(low = "blue", high = "red") +
  labs(x = NULL, y = NULL)  +   scale_size_continuous(range = c(1, 3)) +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- paste0("anchorLOLA_A485_vs_DMSO_diff0.2_allLoops_extreme_OR_qValue_regAnchorBackground_atac")
height <-3
width <- 2
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### - Limited to ATAC-seq signal, reg loop backgrouund 
```{r}
atac <- fread(here(refDir, "GSM3106257_ATAC_ESC_1.bed")) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c("chr", "start", "end")
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
### Importing differential regulatory loops & extract anchor
loop.all <- fread(here(consensusDir, "chromo_cons_annoHierarchy.tsv")) %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E"))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe"))
anchor.up <- (extractAnchor(loop.up))
overlaps <- findOverlaps(anchor.up, atac.gr)
anchor.up <- pintersect(anchor.up[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe"))
anchor.no <- (extractAnchor(loop.no))
overlaps <- findOverlaps(anchor.no, atac.gr)
anchor.no <- pintersect(anchor.no[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- (extractAnchor(loop.down))
overlaps <- findOverlaps(anchor.down, atac.gr)
anchor.down <- pintersect(anchor.down[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])


```

```{r}
# RUNNING LOLA
lolaDir <- here("../../result/lola")
dir.create(lolaDir, showWarnings = FALSE, recursive = TRUE)

# UP
result = runLOLA(anchor.up, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv"), sep = "\t")

# NO
result = runLOLA(anchor.no, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv"), sep = "\t")

# DOWN
result = runLOLA(anchor.down, anchor.all, lolaDB)
tb = as_tibble(result)
fwrite(tb, here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv"), sep = "\t")



### HEATMAP
alpha <- 0.05
tb.up <- fread(here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody)) %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio)
colnames(temp.up) <- c("target", "OR_up")
temp.no <- tb.no %>% dplyr::select(target, oddsRatio)
colnames(temp.no) <- c("target", "OR_no")
temp.down <- tb.down %>% dplyr::select(target, oddsRatio)
colnames(temp.down) <- c("target", "OR_down")


temp <- full_join(full_join(temp.up, temp.no, by = c("target")), temp.down, by = c("target")) %>% mutate_all(~replace_na(., 1))

data <- as.matrix(temp[2:4])
rownames(data) <- temp$target

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c("white", "red"))


p <- Heatmap(
  data,
  name = "Odds Ratio",                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 4,                         # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun                       # Use the red gradient color scale
)

fileName <- paste0("anchorLOLA_A485_vs_DMSO_diff0.2_regAnchorBackground_atac")
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()


### Visualizing p-value and OR
alpha <- 0.05
tb.up <- fread(here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_up_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "UP") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.no <- fread(here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_no_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "NO") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)
tb.down <- fread(here(lolaDir, "LOLA_A485_vs_DMSO_diff0.2_down_atac.tsv")) %>%
  dplyr::mutate(target = toupper(antibody),
                qValueLog = -log2(qValue),
                group = "DOWN") %>%
  filter(str_to_lower(cellType) == "embryonic stem cell") %>%
  dplyr::filter(qValue < alpha) %>% dplyr::group_by(target) %>%
  slice_min(meanRnk, with_ties = FALSE)

temp.up <- tb.up %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.no <- tb.no %>% dplyr::select(target, oddsRatio, qValueLog, group)
temp.down <- tb.down %>% dplyr::select(target, oddsRatio, qValueLog, group)

temp <- bind_rows(temp.up, temp.down)

order <- c((temp %>% dplyr::filter(group == "UP") %>% arrange(desc(oddsRatio)))$target, 
           (temp %>% dplyr::filter(group == "DOWN") %>% arrange(desc(oddsRatio)))$target)
temp$target <- factor(temp$target, levels = rev(order))
p <- ggplot(temp, aes(x = group, y = target, color = qValueLog, size = oddsRatio)) +
  geom_point() + theme_bw() + scale_color_gradient(low = "blue", high = "red") +
  labs(x = NULL, y = NULL)  +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

fileName <- paste0("anchorLOLA_A485_vs_DMSO_diff0.2_OR_qValue_regAnchorBackground_atac")
height <-3
width <- 2
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```


## [2.22] Comparing absolute RNA expression level across group
The aim is to see if there is a trend in RNA expression level among group 1, 2, 3, 4.
It would be making comparison among genes. For this, TPM should be used.
```{r}
## Importing groups
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv"))$gene
group5 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv"))$gene
group8 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv"))$gene

## Importing RNA-seq TPM for DMSO
tpm.selected <- fread(here(refDir, "readCount.filtered.TPM.all.tsv")) %>% dplyr::select(1, 3, 4, 5)
colnames(tpm.selected) <- c("ensembl", "rep1", "rep2", "rep3")

tpm.selected <- tpm.selected %>% dplyr::rowwise() %>%
  dplyr::mutate(
  group = ifelse(ensembl %in% group1, "group1",
                 ifelse(ensembl %in% group2, "group2",
                        ifelse(ensembl %in% group5, "group5",
                               ifelse(ensembl %in% group8, "group8", NA))))) %>% 
  dplyr::filter(!is.na(group)) %>%
  dplyr::mutate(avgTPM = mean(rep1, rep2, rep3))


ggplot(tpm.selected, aes(x = group, y = avgTPM)) +
  geom_violin(aes(fill = group), show.legend = FALSE) +
  geom_boxplot(width = 0.1, outlier.shape = NA) + 
  scale_y_log10() +
  theme_classic()



  p <- ggplot(temp.tb, aes(x = group, y = score)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + coord_cartesian(ylim = c(ymin, ymax)) +
    annotate("text", x = 1, y = ymin + 1, label = paste0("p12: ", convPvalue(p12), "\n",
                                                         "p15: ", convPvalue(p15), "\n",
                                                         "p18: ", convPvalue(p18), "\n",
                                                         "p25: ", convPvalue(p25), "\n",
                                                         "p28: ", convPvalue(p28), "\n",
                                                         "p58: ",convPvalue( p58), "\n"),
             color = "black", hjust = 0, size = 3)
  
  
  fileName <- paste0("insulation_score_", note)
  height <- 3
  width <- 3
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
```

## [2.23] Checking Early gene from Bobbie
#### dTAG
```{r}
## Importing groups
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group2.tsv"))$gene
group5 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group5.tsv"))$gene
group8 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_group8.tsv"))$gene


## Importing Bobbie gene classification
geneCluster <- fread(here(refDir, "bobbie_gene_classification.csv")) %>%
  dplyr::select(gene, enst, Cluster)
colnames(geneCluster) <- c("gene", "ensembl_transcript_id", "cluster")


## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c("ensembl_transcript_id", "ensembl_gene_id"),
                 filters = "ensembl_transcript_id",
                 values = geneCluster$ensembl_transcript,
                 mart = ensembl.v102)
geneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c("ensembl_transcript_id"))

# Making data for stacked barplot
countGene <- function(geneCluster, groupName, clusterName){
  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,
                                            cluster %in% clusterName))
  return(num)
}
countGeneList <- function(geneCluster, groupName){
  n1 <- countGene(geneCluster, groupName, "Early")
  n2 <- countGene(geneCluster, groupName, "Middle")
  n3 <-countGene(geneCluster, groupName, "Late")
  n4 <- countGene(geneCluster, groupName, "Transient")
  return(c(n1, n2, n3, n4))
}

group <- c(rep("group1", 4), rep("group2", 4), rep("group3", 4), rep("group4", 4))
cluster <- rep(c("Early", "Middle", "Late", "Transient"), 4)
cluster <- factor(cluster, levels = c("Early", "Middle", "Late", "Transient"))
value <- c(countGeneList(geneCluster, group1),
           countGeneList(geneCluster, group2),
           countGeneList(geneCluster, group5),
           countGeneList(geneCluster, group8))

data <- data.frame(group, cluster, value)


# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="fill", stat="identity") + theme_classic()


# Statistical analysis 
# Similar to the Chi-Square test, Fisher’s Exact Test is used when you have smaller sample sizes or when the expected frequency in any cell of the contingency table is below 5.
temp <- data %>% dplyr::filter(group %in% c("group1", "group2"))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

temp <- data %>% dplyr::filter(group %in% c("group1", "group3"))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

temp <- data %>% dplyr::filter(group %in% c("group1", "group4"))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result


### P-N
resultDir <- here("../../result")
temp2 <- readRDS(here(resultDir, "gene_loop_link.rds"))

pnOver8 <- (temp2 %>% dplyr::filter(total >= 8))$gene
pnOver6 <- (temp2 %>% dplyr::filter(total >= 6, total < 8))$gene
pnOver4 <- (temp2 %>% dplyr::filter(total >= 4, total < 6))$gene
pnOver2 <- (temp2 %>% dplyr::filter(total >= 2, total < 4))$gene
pnOver0 <- (temp2 %>% dplyr::filter(total < 2))$gene

group <- c(rep("pnOver8", 4), rep("pnOver6", 4), rep("pnOver4", 4), rep("pnOver2", 4), rep("pnOver0", 4))
cluster <- rep(c("Early", "Middle", "Late", "Transient"), 5)
cluster <- factor(cluster, levels = c("Early", "Middle", "Late", "Transient"))
value <- c(countGeneList(geneCluster, pnOver8),
           countGeneList(geneCluster, pnOver6),
           countGeneList(geneCluster, pnOver4),
           countGeneList(geneCluster, pnOver2),
           countGeneList(geneCluster, pnOver0))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="fill", stat="identity") + theme_classic()

temp <- data %>% dplyr::filter(group %in% c("pnOver2", "pnOver8"))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

### P-S
psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene

group <- c(rep("psOver4", 4), rep("psOver3", 4), rep("psOver2", 4), rep("psOver1", 4), rep("psOver0", 4))
cluster <- rep(c("Early", "Middle", "Late", "Transient"), 5)
cluster <- factor(cluster, levels = c("Early", "Middle", "Late", "Transient"))
value <- c(countGeneList(geneCluster, psOver4),
           countGeneList(geneCluster, psOver3),
           countGeneList(geneCluster, psOver2),
           countGeneList(geneCluster, psOver1),
           countGeneList(geneCluster, psOver0))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="fill", stat="identity") + theme_classic()
temp <- data %>% dplyr::filter(group %in% c("psOver2", "psOver4"))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

### P-E
peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene

group <- c(rep("peOver4", 4), rep("peOver3", 4), rep("peOver2", 4), rep("peOver1", 4), rep("peOver0", 4))
cluster <- rep(c("Early", "Middle", "Late", "Transient"), 5)
cluster <- factor(cluster, levels = c("Early", "Middle", "Late", "Transient"))
value <- c(countGeneList(geneCluster, peOver4),
           countGeneList(geneCluster, peOver3),
           countGeneList(geneCluster, peOver2),
           countGeneList(geneCluster, peOver1),
           countGeneList(geneCluster, peOver0))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="fill", stat="identity") + theme_classic()

### P-P
ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene

group <- c(rep("ppOver4", 4), rep("ppOver3", 4), rep("ppOver2", 4), rep("ppOver1", 4), rep("ppOver0", 4))
cluster <- rep(c("Early", "Middle", "Late", "Transient"), 5)
cluster <- factor(cluster, levels = c("Early", "Middle", "Late", "Transient"))
value <- c(countGeneList(geneCluster, ppOver4),
           countGeneList(geneCluster, ppOver3),
           countGeneList(geneCluster, ppOver2),
           countGeneList(geneCluster, ppOver1),
           countGeneList(geneCluster, ppOver0))
data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="fill", stat="identity") + theme_classic()

```
#### A485
```{r}
## Importing groups
group1 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group2.tsv"))$gene
group3 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group3.tsv"))$gene
group4 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group4.tsv"))$gene
group5 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group5.tsv"))$gene
group6 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group6.tsv"))$gene
group7 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group7.tsv"))$gene
group8 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group8.tsv"))$gene
group9 <- fread(here(refDir, "geneList_A485_vs_DMSO_RNA_loop_group9.tsv"))$gene


## Importing Bobbie gene classification
geneCluster <- fread(here(refDir, "bobbie_gene_classification.csv")) %>%
  dplyr::select(gene, enst, Cluster)
colnames(geneCluster) <- c("gene", "ensembl_transcript_id", "cluster")


## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c("ensembl_transcript_id", "ensembl_gene_id"),
                 filters = "ensembl_transcript_id",
                 values = geneCluster$ensembl_transcript,
                 mart = ensembl.v102)
geneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c("ensembl_transcript_id"))

# Making data for stacked barplot
countGene <- function(geneCluster, groupName, clusterName){
  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,
                                            cluster %in% clusterName))
  return(num)
}
countGeneList <- function(geneCluster, groupName){
  n1 <- countGene(geneCluster, groupName, "Early")
  n2 <- countGene(geneCluster, groupName, "Middle")
  n3 <-countGene(geneCluster, groupName, "Late")
  n4 <- countGene(geneCluster, groupName, "Transient")
  return(c(n1, n2, n3, n4))
}

group <- c(rep("group1", 4), rep("group2", 4), rep("group3", 4),
           rep("group4", 4), rep("group5", 4), rep("group6", 4),
           rep("group7", 4), rep("group8", 4), rep("group9", 4))
cluster <- rep(c("Early", "Middle", "Late", "Transient"), 9)
cluster <- factor(cluster, levels = c("Early", "Middle", "Late", "Transient"))
value <- c(countGeneList(geneCluster, group1),
           countGeneList(geneCluster, group2),
           countGeneList(geneCluster, group3),
           countGeneList(geneCluster, group4),
           countGeneList(geneCluster, group5),
           countGeneList(geneCluster, group6),
           countGeneList(geneCluster, group7),
           countGeneList(geneCluster, group8),
           countGeneList(geneCluster, group9))

data <- data.frame(group, cluster, value)


# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="fill", stat="identity") + theme_classic()


# Statistical analysis 
# Similar to the Chi-Square test, Fisher’s Exact Test is used when you have smaller sample sizes or when the expected frequency in any cell of the contingency table is below 5.
temp <- data %>% dplyr::filter(group %in% c("group1", "group2"))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

temp <- data %>% dplyr::filter(group %in% c("group1", "group3"))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result

temp <- data %>% dplyr::filter(group %in% c("group1", "group4"))
contingency_table <- xtabs(value ~ group + cluster, data = temp)
fisher_result <- fisher.test(contingency_table, simulate.p.value = TRUE, B = 100000)
fisher_result


```

## [2.24] Checking bookmarking
(1) Checking whether subset of regulatory loop have bookmarking
(2) Checking whether loops related to genes have bookmarking
H3K27ac_effie
ATAC_effie
TBP
Oct4_effie, Oct4_dsg
Sox2_effie, Sox2_dsg
Esrrb_dsg
Klf4_effie
CTCF
##### Functions
```{r}
extractAnchor <- function(loop){
  anchor1 <- loop %>% dplyr::select(c(1, 2, 3))
  colnames(anchor1) <- c("chr", "start", "end")
  anchor2 <- loop %>% dplyr::select(c(4, 5, 6))
  colnames(anchor2) <- c("chr", "start", "end")
  anchors <- reduce(makeGRangesFromDataFrame(bind_rows(anchor1, anchor2)))
    return(anchors)
}

runFisherExact <- function(interest.gr, background.gr, query.gr){
  overlaps_interest <- countOverlaps(interest.gr, query.gr)
  a <- sum(overlaps_interest > 0)
  total_interest <- length(interest.gr)
  c <- total_interest - a
  
  overlaps_background <- countOverlaps(background.gr, query.gr)
  b <- sum(overlaps_background > 0)
  total_background <- length(background.gr)
  d <- total_background - b
  
  # Construct contingency table
  contingency_table <- matrix(c(a, c, b, d), nrow=2, byrow=TRUE,
                              dimnames=list("Region" = c("interest.gr", "background.gr"),
                                            "Overlap" = c("Yes", "No")))
  
  # Perform Fisher's exact test
  fisher_result <- fisher.test(contingency_table)
  
  return(fisher_result)
}

runFisherExactCombination <- function(interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr, lost.gr){
  # SEEDING
  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)
  result.tb <- tibble(interest = paste0(interestName, "_UP"),
                      target = paste0(targetName, "_retained"),
                      pvalue = temp$p.value,
                      oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, "_NO"),
            target = paste0(targetName, "_retained"),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, "_DOWN"),
            target = paste0(targetName, "_retained"),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.up.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, "_UP"),
            target = paste0(targetName, "_lost"),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.no.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, "_NO"),
            target = paste0(targetName, "_lost"),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, "_DOWN"),
            target = paste0(targetName, "_lost"),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  return(result.tb)
}

runFisherExactCombinationBinary <- function(interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr, lost.gr){
  # SEEDING
  temp <- runFisherExact(loop.upno.gr, background.gr, retained.gr)
  result.tb <- tibble(interest = paste0(interestName, "_UP/NO"),
                      target = paste0(targetName, "_retained"),
                      pvalue = temp$p.value,
                      oddsRatio = temp$estimate)
  

  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, "_DOWN"),
            target = paste0(targetName, "_retained"),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.upno.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, "_UP/NO"),
            target = paste0(targetName, "_lost"),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)

  
  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, "_DOWN"),
            target = paste0(targetName, "_lost"),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  return(result.tb)
}

runFisherExactCombinationRetained <- function(interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr){
  # SEEDING
  temp <- runFisherExact(loop.up.gr, background.gr, retained.gr)
  result.tb <- tibble(interest = paste0(interestName, "_UP"),
                      target = paste0(targetName, "_retained"),
                      pvalue = temp$p.value,
                      oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.no.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, "_NO"),
            target = paste0(targetName, "_retained"),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  # ADDING ROWS
  temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)
  result.tb <- result.tb %>% 
    add_row(interest = paste0(interestName, "_DOWN"),
            target = paste0(targetName, "_retained"),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  

  return(result.tb)
}

runFisherExactCombinationTarget <- function(targetName, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr){
  # RETAINED loop
  retained <- fread(here(refDir, "TF_bookmarking", targetName, "am_a.bed")) %>% dplyr::select(c(1, 2, 3))
  colnames(retained) <- c("chr", "start", "end")
  retained.gr <- makeGRangesFromDataFrame(retained)
  # LOST loop
  lost <- fread(here(refDir, "TF_bookmarking", targetName, "oa.bed")) %>% dplyr::select(c(1, 2, 3))
  colnames(lost) <- c("chr", "start", "end")
  lost.gr <- makeGRangesFromDataFrame(lost)
  
  result <- runFisherExactCombination(interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr, lost.gr)
  
  return(result)
}

runFisherExactCombinationTargetBinary <- function(targetName, interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr){
  # RETAINED loop
  retained <- fread(here(refDir, "TF_bookmarking", targetName, "am_a.bed")) %>% dplyr::select(c(1, 2, 3))
  colnames(retained) <- c("chr", "start", "end")
  retained.gr <- makeGRangesFromDataFrame(retained)
  # LOST loop
  lost <- fread(here(refDir, "TF_bookmarking", targetName, "oa.bed")) %>% dplyr::select(c(1, 2, 3))
  colnames(lost) <- c("chr", "start", "end")
  lost.gr <- makeGRangesFromDataFrame(lost)
  
  result <- runFisherExactCombinationBinary(interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr, lost.gr)
  
  return(result)
}

runFisherExactCombinationTargetRetained <- function(targetName, interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr){
  # RETAINED loop
  retained <- fread(here(refDir, "TF_bookmarking", targetName, "am_a.bed")) %>% dplyr::select(c(1, 2, 3))
  colnames(retained) <- c("chr", "start", "end")
  retained.gr <- makeGRangesFromDataFrame(retained)
  # LOST loop
  result <- runFisherExactCombinationRetained(interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr,
                                      targetName,
                                      retained.gr)
  
  return(result)
}
```

##### All loops
```{r}
#### Importing loops of interest
interestName <- "allLoop"
# BACKGROUND loop
background <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all.bedpe"))
background.gr <- (extractAnchor(background))
# UP loop
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe"))
loop.up.gr <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe"))
loop.no.gr <- (extractAnchor(loop.no))
# DOWN loop
loopNum <- nrow(loop.no)
loop.all <- fread(here(consensusDir, "chromo_cons_annoHierarchy.tsv"))
loop.down <- loop.all %>% dplyr::filter(diff_dTAG_DMSO < -0.2) %>% dplyr::arrange(diff_dTAG_DMSO) %>% slice_head(n = loopNum)
loop.down.gr <- (extractAnchor(loop.down))

#### Importing loops of target
temp1 <- runFisherExactCombinationTarget("ATAC_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget("CTCF", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget("ESRRB_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget("ESRRB_NCB", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget("ESRRB_pfa", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget("H3K27ac_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget("KLF4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget("NANOG_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget("NANOG_pfa", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget("OCT4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp11 <- runFisherExactCombinationTarget("OCT4_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp12 <- runFisherExactCombinationTarget("OCT4_pfa", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp13 <- runFisherExactCombinationTarget("SMC1", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp14 <- runFisherExactCombinationTarget("SOX2_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp15 <- runFisherExactCombinationTarget("SOX2_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp16 <- runFisherExactCombinationTarget("SOX2_pfa", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp17 <- runFisherExactCombinationTarget("TBP", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10,
         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = "target")

col_fun <- colorRamp2(c(0, 1, 5), 
                      c("blue", "white", "red"))

Heatmap(as.matrix(heatmap_data),
        name = "Odds Ratio",
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, "n.s.", sprintf("%.2e", pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = FALSE,
        cluster_columns = FALSE,
        column_title = "Interest",
        row_title = "Target",
        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), 
                                    labels = c("0", "1", "2", "3", "4", "5")))
```
##### All loops refined
```{r}


#### Importing loops of target
temp1 <- runFisherExactCombinationTarget("ATAC_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget("CTCF", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget("ESRRB_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget("H3K27ac_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget("KLF4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget("NANOG_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget("OCT4_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget("SMC1", interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget("SOX2_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget("TBP", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = "target")

col_fun <- colorRamp2(c(0, 1, 3), 
                      c("blue", "white", "red"))

Heatmap(as.matrix(heatmap_data),
        name = "Odds Ratio",
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, "n.s.", sprintf("%.2e", pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = "Interest",
        row_title = "Target",
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c("0", "1", "2", "3")))

```


##### Reg loops
```{r}
#### Importing loops of interest
interestName <- "regLoop"
# BACKGROUND loop
background <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe"))
background.gr <- (extractAnchor(background))
# UP loop
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe"))
loop.up.gr <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe"))
loop.no.gr <- (extractAnchor(loop.no))
# UPNO loop
loop.upno <- bind_rows(loop.up, loop.no)
loop.upno.gr <- extractAnchor(loop.upno)
# DOWN loop
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe"))
loop.down.gr <- (extractAnchor(loop.down))
```
###### Figure - H3K27ac only
```{r}
targetName <- "H3K27ac_effie"
# RETAINED loop
retained <- fread(here(refDir, "TF_bookmarking", targetName, "am_a.bed")) %>% dplyr::select(c(1, 2, 3))
colnames(retained) <- c("chr", "start", "end")
retained.gr <- makeGRangesFromDataFrame(retained)
# LOST loop
lost <- fread(here(refDir, "TF_bookmarking", targetName, "oa.bed")) %>% dplyr::select(c(1, 2, 3))
colnames(lost) <- c("chr", "start", "end")
lost.gr <- makeGRangesFromDataFrame(lost)


# SEEDING
temp <- runFisherExact(loop.upno.gr, background.gr, retained.gr)
result.tb <- tibble(interest = paste0(interestName, "_UP/NO"),
                    target = paste0(targetName, "_retained"),
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)

# ADDING ROWS
temp <- runFisherExact(loop.down.gr, background.gr, retained.gr)
result.tb <- result.tb %>% 
  add_row(interest = paste0(interestName, "_DOWN"),
          target = paste0(targetName, "_retained"),
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

# ADDING ROWS
temp <- runFisherExact(loop.upno.gr, background.gr, lost.gr)
result.tb <- result.tb %>% 
  add_row(interest = paste0(interestName, "_UP/NO"),
          target = paste0(targetName, "_lost"),
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

# ADDING ROWS
temp <- runFisherExact(loop.down.gr, background.gr, lost.gr)
result.tb <- result.tb %>% 
  add_row(interest = paste0(interestName, "_DOWN"),
          target = paste0(targetName, "_lost"),
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)


result.tb <- result.tb %>%
  mutate(interest = recode(interest, 
                           "regLoop_UP/NO" = "UP/NO",
                           "regLoop_DOWN" = "DOWN"),
         target = recode(target,
                         "H3K27ac_effie_retained" = "Retained",
                         "H3K27ac_effie_lost" = "Lost"))

result.tb$interest <- factor(result.tb$interest, levels = c("UP/NO", "DOWN"))

p <- ggplot(result.tb, aes(x = interest, y = target, size = -log10(pvalue), fill = oddsRatio)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 0.5*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
  scale_fill_gradientn(colors = c("#4852A0", "white", "#CB333A"),  # Define gradient colors
                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), 
                      #low = "white", high = "#CB333A",
                      #                  limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) +
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, "heatmap_H3K27ac_bookmarking_reg_dotplot")
width <- panelSize(1.7)*mmToInch
height <- panelSize(1.1)*mmToInch
# png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
# print(p)
# dev.off()
svglite(paste0(fileName, ".svg"),  height = height, width = width)
print(p)
dev.off()

  
```
###### Figure - all targets
```{r}
#### Importing loops of target

temp1 <- runFisherExactCombinationTargetBinary("ESRRB_dsg", interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTargetBinary("H3K27ac_effie", interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTargetBinary("KLF4_effie", interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTargetBinary("OCT4_effie", interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTargetBinary("SOX2_effie", interestName,
                                      loop.upno.gr, loop.down.gr,
                                      background.gr)


data <- bind_rows(temp1, temp2, temp3, temp4, temp5)



result.tb <- data %>%
  mutate(interest = recode(interest, 
                           "regLoop_UP/NO" = "UP/NO",
                           "regLoop_DOWN" = "DOWN"),
         target = recode(target,
                         "H3K27ac_effie_retained" = "H3K27ac_retained",
                         "H3K27ac_effie_lost" = "H3K27ac_lost",
                         "ESRRB_dsg_retained" = "ESRRB_retained",
                         "ESRRB_dsg_lost" = "ESRRB_lost",
                         "KLF4_effie_retained" = "KLF4_retained",
                         "KLF4_effie_lost" = "KLF4_lost",
                         "OCT4_effie_retained" = "OCT4_retained",
                         "OCT4_effie_lost" = "OCT4_lost",
                         "SOX2_effie_retained" = "SOX2_retained",
                         "SOX2_effie_lost" = "SOX2_lost"))

result.tb$interest <- factor(result.tb$interest, levels = c("UP/NO", "DOWN"))
result.tb$target <- factor(result.tb$target, levels = rev(c("H3K27ac_retained", "H3K27ac_lost",
                                                        "ESRRB_retained", "ESRRB_lost",
                                                        "KLF4_retained", "KLF4_lost",
                                                        "OCT4_retained", "OCT4_lost",
                                                        "SOX2_retained","SOX2_lost")))

p <- ggplot(result.tb, aes(x = interest, y = target, size = -log10(pvalue), fill = oddsRatio)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
  scale_fill_gradientn(colors = c("#4852A0", "white", "#CB333A"),  # Define gradient colors
                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), 
                      #low = "white", high = "#CB333A",
                      #                  limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) +
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, "heatmap_alltarget_bookmarking_reg_dotplot")
width <- panelSize(2.2)*mmToInch
height <- panelSize(2)*mmToInch
# png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
# print(p)
# dev.off()
svglite(paste0(fileName, ".svg"),  height = height, width = width)
print(p)
dev.off()








```
###### Retained & Lost
```{r}
#### Importing loops of target
temp1 <- runFisherExactCombinationTarget("ATAC_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget("CTCF", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget("ESRRB_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget("ESRRB_NCB", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget("ESRRB_pfa", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget("H3K27ac_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget("KLF4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget("NANOG_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget("NANOG_pfa", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget("OCT4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp11 <- runFisherExactCombinationTarget("OCT4_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp12 <- runFisherExactCombinationTarget("OCT4_pfa", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp13 <- runFisherExactCombinationTarget("SMC1", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp14 <- runFisherExactCombinationTarget("SOX2_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp15 <- runFisherExactCombinationTarget("SOX2_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp16 <- runFisherExactCombinationTarget("SOX2_pfa", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp17 <- runFisherExactCombinationTarget("TBP", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10,
         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = "target")

col_fun <- colorRamp2(c(0, 1, 5), 
                      c("blue", "white", "red"))

Heatmap(as.matrix(heatmap_data),
        name = "Odds Ratio",
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, "n.s.", sprintf("%.2e", pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = "Interest",
        row_title = "Target",
        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), 
                                    labels = c("0", "1", "2", "3", "4", "5")))

```
######  Retained
```{r}

#### Importing loops of target
temp1 <- runFisherExactCombinationTargetRetained("ATAC_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTargetRetained("CTCF", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTargetRetained("ESRRB_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTargetRetained("ESRRB_NCB", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTargetRetained("ESRRB_pfa", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTargetRetained("H3K27ac_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTargetRetained("KLF4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTargetRetained("NANOG_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTargetRetained("NANOG_pfa", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTargetRetained("OCT4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp11 <- runFisherExactCombinationTargetRetained("OCT4_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp12 <- runFisherExactCombinationTargetRetained("OCT4_pfa", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp13 <- runFisherExactCombinationTargetRetained("SMC1", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp14 <- runFisherExactCombinationTargetRetained("SOX2_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp15 <- runFisherExactCombinationTargetRetained("SOX2_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp16 <- runFisherExactCombinationTargetRetained("SOX2_pfa", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp17 <- runFisherExactCombinationTargetRetained("TBP", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10,
         temp11, temp12, temp13, temp14, temp15, temp16 ,temp17)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = "target")

col_fun <- colorRamp2(c(0, 1, 3), 
                      c("blue", "white", "red"))

Heatmap(as.matrix(heatmap_data),
        name = "Odds Ratio",
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, "n.s.", sprintf("%.2e", pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = "Interest",
        row_title = "Target",
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c("0", "1", "2", "3")))

```

#### Reg refined
###### Retained & Lost
```{r}


#### Importing loops of target
temp1 <- runFisherExactCombinationTarget("ATAC_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget("CTCF", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget("ESRRB_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget("H3K27ac_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget("KLF4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget("NANOG_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget("OCT4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget("SMC1", interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget("SOX2_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget("TBP", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = "target")

col_fun <- colorRamp2(c(0, 1, 3), 
                      c("blue", "white", "red"))

Heatmap(as.matrix(heatmap_data),
        name = "Odds Ratio",
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, "n.s.", sprintf("%.2e", pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = "Interest",
        row_title = "Target",
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c("0", "1", "2", "3")))



```
###### Retained
```{r}


#### Importing loops of target
temp1 <- runFisherExactCombinationTargetRetained("ATAC_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTargetRetained("CTCF", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTargetRetained("ESRRB_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTargetRetained("H3K27ac_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTargetRetained("KLF4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTargetRetained("NANOG_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTargetRetained("OCT4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTargetRetained("SMC1", interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTargetRetained("SOX2_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTargetRetained("TBP", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = "target")

col_fun <- colorRamp2(c(0, 1, 3), 
                      c("blue", "white", "red"))

Heatmap(as.matrix(heatmap_data),
        name = "Odds Ratio",
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, "n.s.", sprintf("%.2e", pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = "Interest",
        row_title = "Target",
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c("0", "1", "2", "3")))



```
## [2.24.2] Checking bookmarking - A485
#### All loops
```{r}
#### Importing loops of interest
interestName <- "allLoop"
# BACKGROUND loop
background <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all.bedpe"))
background.gr <- (extractAnchor(background))
# UP loop
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe"))
loop.up.gr <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_NO_diff0.2.bedpe"))
loop.no.gr <- (extractAnchor(loop.no))
# DOWN loop
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe"))
loop.down.gr <- (extractAnchor(loop.down))
```
##### All loops refined
```{r}


#### Importing loops of target
temp1 <- runFisherExactCombinationTarget("ATAC_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget("CTCF", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget("ESRRB_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget("H3K27ac_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget("KLF4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget("NANOG_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget("OCT4_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget("SMC1", interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget("SOX2_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget("TBP", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = "target")

col_fun <- colorRamp2(c(0, 1, 3), 
                      c("blue", "white", "red"))

Heatmap(as.matrix(heatmap_data),
        name = "Odds Ratio",
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, "n.s.", sprintf("%.2e", pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = "Interest",
        row_title = "Target",
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c("0", "1", "2", "3")))

```
#### Reg loops
```{r}
#### Importing loops of interest
interestName <- "regLoop"
# BACKGROUND loop
background <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe"))
background.gr <- (extractAnchor(background))
# UP loop
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe"))
loop.up.gr <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe"))
loop.no.gr <- (extractAnchor(loop.no))
# DOWN loop
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe"))
loop.down.gr <- (extractAnchor(loop.down))

fwrite(as_tibble(loop.up.gr) %>% dplyr::select(seqnames, start, end), here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.anchor.bed"), col.names = FALSE, sep = "\t")
fwrite(as_tibble(loop.no.gr) %>% dplyr::select(seqnames, start, end), here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.anchor.bed"), col.names = FALSE, sep = "\t")
fwrite(as_tibble(loop.down.gr) %>% dplyr::select(seqnames, start, end), here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.anchor.bed"), col.names = FALSE, sep = "\t")
```
##### Retained & Lost
```{r}


#### Importing loops of target
temp1 <- runFisherExactCombinationTarget("ATAC_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp2 <- runFisherExactCombinationTarget("CTCF", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp3 <- runFisherExactCombinationTarget("ESRRB_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp4 <- runFisherExactCombinationTarget("H3K27ac_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp5 <- runFisherExactCombinationTarget("KLF4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp6 <- runFisherExactCombinationTarget("NANOG_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp7 <- runFisherExactCombinationTarget("OCT4_effie", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp8 <- runFisherExactCombinationTarget("SMC1", interestName,
                                     loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp9 <- runFisherExactCombinationTarget("SOX2_dsg", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)
temp10 <- runFisherExactCombinationTarget("TBP", interestName,
                                      loop.up.gr, loop.no.gr, loop.down.gr,
                                      background.gr)




data <- bind_rows(temp1, temp2, temp3, temp4, temp5,
         temp6, temp7, temp8, temp9, temp10)

# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = "target")

col_fun <- colorRamp2(c(0, 1, 3), 
                      c("blue", "white", "red"))

Heatmap(as.matrix(heatmap_data),
        name = "Odds Ratio",
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, "n.s.", sprintf("%.2e", pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = "Interest",
        row_title = "Target",
        heatmap_legend_param = list(at = c(0, 1, 2, 3), 
                                    labels = c("0", "1", "2", "3")))



```
### DEGs from RNA-seq
2.5kb from TSS, at least 1 bp overlap
#### 2i
```{r}
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3)) %>%
  dplyr::select(V1, TSS, V6)
colnames(gene.tb) <- c("chr", "TSS", "ensembl")

diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c("ensembl_gene_id" = "ensembl")) %>%
  dplyr::filter(!is.na(TSS))
alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ "UP",
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ "DOWN",
                                                        TRUE ~ "NO"))


temp <- diff.RNA %>% dplyr::mutate(start = TSS - 2500,
                           end = TSS + 2500) %>%
  dplyr::select(chr, start, end, ensembl_gene_id, diff)


down.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == "DOWN"))
up.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == "UP"))
no.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == "NO"))
all.gr <- makeGRangesFromDataFrame(temp)

data <- runFisherExactCombinationTarget("H3K27ac_effie", "TSS",
                                      up.gr, no.gr, down.gr,
                                      all.gr)


# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = "target")

col_fun <- colorRamp2(c(0, 1, 2), 
                      c("blue", "white", "red"))

Heatmap(as.matrix(heatmap_data),
        name = "Odds Ratio",
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, "n.s.", sprintf("%.2e", pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = "Interest",
        row_title = "Target",
        heatmap_legend_param = list(at = c(0, 1, 2), 
                                    labels = c("0", "1", "2")))


## GO TEST
diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c("ensembl_gene_id" = "ensembl")) %>%
  dplyr::filter(!is.na(TSS))
alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ "UP",
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ "DOWN",
                                                        TRUE ~ "NO"))
geneList <- (diff.RNA %>% dplyr::filter(diff == "DOWN"))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)

downStemGene <- unique(unlist((as.data.frame(GO) %>% dplyr::slice(c(4, 5, 14, 66)) %>% dplyr::mutate(geneID = strsplit(geneID, "/")))$geneID))
downStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(ensembl_gene_id %in% downStemGene))

print(dotplot(GO, showCategory = 15, title = "") + 
        scale_color_continuous(limits = c(0, 0.05), low = "red", high = "black"))
geneList <- (diff.RNA %>% dplyr::filter(diff == "UP"))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
print(dotplot(GO, showCategory = 15, title = "") + 
        scale_color_continuous(limits = c(0, 0.05), low = "red", high = "black"))


downNONStem.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == "DOWN",
                                                               !(ensembl_gene_id %in% downStemGene)))

print(dotplot(GO, showCategory = 15, title = "") + 
        scale_color_continuous(limits = c(0, 0.05), low = "red", high = "black"))
geneList <- (diff.RNA %>% dplyr::filter(diff == "UP"))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
print(dotplot(GO, showCategory = 15, title = "") + 
        scale_color_continuous(limits = c(0, 0.05), low = "red", high = "black"))



### Checking bookmarking only in stem gene

data <- runFisherExactCombinationTarget("H3K27ac_effie", "TSS",
                                      down.gr, downNONStem.gr, downStem.gr,
                                      all.gr)


# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = "target")

col_fun <- colorRamp2(c(0, 1, 2), 
                      c("blue", "white", "red"))

Heatmap(as.matrix(heatmap_data),
        name = "Odds Ratio",
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, "n.s.", sprintf("%.2e", pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = "Interest",
        row_title = "Target",
        heatmap_legend_param = list(at = c(0, 1, 2), 
                                    labels = c("0", "1", "2")))
```
#### Epi
```{r}
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3)) %>%
  dplyr::select(V1, TSS, V6)
colnames(gene.tb) <- c("chr", "TSS", "ensembl")

diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.Epi.A485_vs_G1.Epi.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c("ensembl_gene_id" = "ensembl")) %>%
  dplyr::filter(!is.na(TSS))
alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ "UP",
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ "DOWN",
                                                        TRUE ~ "NO"))


temp <- diff.RNA %>% dplyr::mutate(start = TSS - 2500,
                           end = TSS + 2500) %>%
  dplyr::select(chr, start, end, ensembl_gene_id, diff)


down.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == "DOWN"))
up.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == "UP"))
no.gr <- makeGRangesFromDataFrame(temp %>% dplyr::filter(diff == "NO"))
all.gr <- makeGRangesFromDataFrame(temp)

data <- runFisherExactCombinationTarget("H3K27ac_effie", "TSS",
                                      up.gr, no.gr, down.gr,
                                      all.gr)


# Visualization
library(circlize)

heatmap_data <- data %>% dplyr::select(target, interest, oddsRatio) %>%
pivot_wider(names_from = interest, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, interest, pvalue) %>%
  pivot_wider(names_from = interest, values_from = pvalue) %>%
  column_to_rownames(var = "target")

col_fun <- colorRamp2(c(0, 1, 2), 
                      c("blue", "white", "red"))

Heatmap(as.matrix(heatmap_data),
        name = "Odds Ratio",
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, "n.s.", sprintf("%.2e", pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = "Interest",
        row_title = "Target",
        heatmap_legend_param = list(at = c(0, 1, 2), 
                                    labels = c("0", "1", "2")))


## GO
diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.Epi.A485_vs_G1.Epi.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c("ensembl_gene_id" = "ensembl")) %>%
  dplyr::filter(!is.na(TSS))
alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ "UP",
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ "DOWN",
                                                        TRUE ~ "NO"))

geneList <- (diff.RNA %>% dplyr::filter(diff == "DOWN"))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
print(dotplot(GO, showCategory = 15, title = "") + 
        scale_color_continuous(limits = c(0, 0.05), low = "red", high = "black"))
geneList <- (diff.RNA %>% dplyr::filter(diff == "UP"))$ensembl_gene_id
GO <- enrichGO(gene = geneList, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
GO.readable <- setReadable(GO, OrgDb = org.Mm.eg.db)
print(dotplot(GO, showCategory = 15, title = "") + 
        scale_color_continuous(limits = c(0, 0.05), low = "red", high = "black"))

```


## [2.25] Checking genes related to regulatory loops
### dTAG, Comparing to Async
#### P-P, P-E
```{r}
name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-pe_ensemblList.tsv")),
                                      diffCutoff = 0.2)

id.G1SpecificPert <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_G1vsAsync_G1SpecificPert.bedpe"))$V7
id.AsyncSpecificPert <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_G1vsAsync_AsyncSpecificPert.bedpe"))$V7
id.bothPert <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothPert.bedpe"))$V7
id.bothRetained <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_G1vsAsync_bothRetained.bedpe"))$V7


geneList.G1SpecificPert <- (geneAnnoData %>% dplyr::filter(id %in% id.G1SpecificPert) %>% unnest(gene))$gene
geneList.AsyncSpecificPert <- (geneAnnoData %>% dplyr::filter(id %in% id.AsyncSpecificPert) %>% unnest(gene))$gene
geneList.bothPert <- (geneAnnoData %>% dplyr::filter(id %in% id.bothPert) %>% unnest(gene))$gene
geneList.bothRetained <- (geneAnnoData %>% dplyr::filter(id %in% id.bothRetained) %>% unnest(gene))$gene

GO.G1SpecificPert.df <- as.data.frame(enrichGO(gene = geneList.G1SpecificPert, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
GO.AsyncSpecificPer.df <- as.data.frame(enrichGO(gene = geneList.AsyncSpecificPert, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
GO.bothPert.df <- as.data.frame(enrichGO(gene = geneList.bothPert, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))
GO.bothRetained.df <- as.data.frame(enrichGO(gene = geneList.bothRetained, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP"))

subset.G1SpecificPert <- GO.G1SpecificPert.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "G1SpecificPert") %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by "/"
      parts <- unlist(strsplit(x, "/"))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

subset.AsyncSpecificPert <- GO.AsyncSpecificPer.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "AsyncSpecificPert") %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by "/"
      parts <- unlist(strsplit(x, "/"))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

subset.bothPert <- GO.bothPert.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "bothPert") %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by "/"
      parts <- unlist(strsplit(x, "/"))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

subset.bothRetained <- GO.bothRetained.df %>% dplyr::select(ID, Description, GeneRatio, p.adjust) %>% dplyr::mutate(group = "bothRetained") %>%
  dplyr::mutate(
    gr = sapply(GeneRatio, function(x) {
      # Split the string by "/"
      parts <- unlist(strsplit(x, "/"))
      # Convert to numeric and perform the division
      as.numeric(parts[1]) / as.numeric(parts[2])
    })
  ) %>% dplyr::arrange(desc(gr))

data <- bind_rows(bind_rows(subset.G1SpecificPert, subset.bothPert), subset.bothRetained)

p <- ggplot(subset.G1SpecificPert, aes(x = group, y = Description, color = p.adjust, size = gr)) + 
  geom_point() + theme_bw() +
  scale_color_gradient(low = "red", high = "blue", limits = c(0, 0.05)) +
  scale_size_continuous(range = c(0, 3)) +
  labs(x = NULL, y = NULL) +
  theme(axis.text = element_text(size = 6),  # Set axis text size
        axis.title = element_text(size = 6), # Set axis title size (if not removed)
        legend.text = element_text(size = 6), # Set legend text size
        legend.title = element_text(size = 6)) 

```

### dTAG
#### P-P, P-E
```{r}
name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-pe_ensemblList.tsv")),
                                      diffCutoff = 0.2)

geneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == "UP") %>% unnest(gene))$gene)
geneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == "NO") %>% unnest(gene))$gene)
geneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == "DOWN") %>% unnest(gene))$gene)



# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN
sets_list <- list(up = geneList.upLoop,
                  no = geneList.noLoop,
                  down = geneList.downLoop)

# Create the Euler plot
euler_fit <- euler(sets_list)
plot(euler_fit,
     labels = TRUE,  # Display set labels
     fills = TRUE,   # Color fill the regions
     quantities = TRUE)


# GO
GO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.down)

# GO to only specific subset
geneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))
geneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))
geneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))
GO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.down)


## Checking percentage of bobbie early gene

## Importing Bobbie gene classification
geneCluster <- fread(here(refDir, "bobbie_gene_classification.csv")) %>%
  dplyr::select(gene, enst, Cluster)
colnames(geneCluster) <- c("gene", "ensembl_transcript_id", "cluster")


## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c("ensembl_transcript_id", "ensembl_gene_id"),
                 filters = "ensembl_transcript_id",
                 values = geneCluster$ensembl_transcript,
                 mart = ensembl.v102)
geneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c("ensembl_transcript_id"))

# Making data for stacked barplot
countGene <- function(geneCluster, groupName, clusterName){
  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,
                                            cluster %in% clusterName))
  return(num)
}
countGeneList <- function(geneCluster, groupName){
  n1 <- countGene(geneCluster, groupName, "Early")
  n2 <- countGene(geneCluster, groupName, "Middle")
  n3 <-countGene(geneCluster, groupName, "Late")
  n4 <- countGene(geneCluster, groupName, "Transient")
  return(c(n1, n2, n3, n4))
}

group <- c(rep("up", 4), rep("no", 4), rep("down", 4))
cluster <- rep(c("Early", "Middle", "Late", "Transient"), 3)
cluster <- factor(cluster, levels = c("Early", "Middle", "Late", "Transient"))
value <- c(countGeneList(geneCluster, geneList.upLoop),
           countGeneList(geneCluster, geneList.noLoop),
           countGeneList(geneCluster, geneList.downLoop))

data <- data.frame(group, cluster, value)
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="stack", stat = "identity") + theme_classic()
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="fill", stat = "identity") + theme_classic()

value <- c(countGeneList(geneCluster, geneList.upLoop.specific),
           countGeneList(geneCluster, geneList.noLoop.specific),
           countGeneList(geneCluster, geneList.downLoop.specific))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="stack", stat = "identity") + theme_classic()
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="fill", stat = "identity") + theme_classic()

```


#### P-N
```{r}
name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = 0.2)

geneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == "UP") %>% unnest(gene))$gene)
geneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == "NO") %>% unnest(gene))$gene)
geneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_dTAG_DMSO == "DOWN") %>% unnest(gene))$gene)



# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN
sets_list <- list(up = geneList.upLoop,
                  no = geneList.noLoop,
                  down = geneList.downLoop)

# Create the Euler plot
euler_fit <- euler(sets_list)
plot(euler_fit,
     labels = TRUE,  # Display set labels
     fills = TRUE,   # Color fill the regions
     quantities = TRUE)


# GO
GO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.down)

# GO to only specific subset
geneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))
geneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))
geneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))
GO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.down)


## Checking percentage of bobbie early gene

## Importing Bobbie gene classification
geneCluster <- fread(here(refDir, "bobbie_gene_classification.csv")) %>%
  dplyr::select(gene, enst, Cluster)
colnames(geneCluster) <- c("gene", "ensembl_transcript_id", "cluster")


## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c("ensembl_transcript_id", "ensembl_gene_id"),
                 filters = "ensembl_transcript_id",
                 values = geneCluster$ensembl_transcript,
                 mart = ensembl.v102)
geneCluster <- geneCluster %>% dplyr::left_join(idPair_tg, by = c("ensembl_transcript_id"))

# Making data for stacked barplot
countGene <- function(geneCluster, groupName, clusterName){
  num <- nrow(geneCluster %>% dplyr::filter(ensembl_gene_id %in% groupName,
                                            cluster %in% clusterName))
  return(num)
}
countGeneList <- function(geneCluster, groupName){
  n1 <- countGene(geneCluster, groupName, "Early")
  n2 <- countGene(geneCluster, groupName, "Middle")
  n3 <-countGene(geneCluster, groupName, "Late")
  n4 <- countGene(geneCluster, groupName, "Transient")
  return(c(n1, n2, n3, n4))
}

group <- c(rep("up", 4), rep("no", 4), rep("down", 4))
cluster <- rep(c("Early", "Middle", "Late", "Transient"), 3)
cluster <- factor(cluster, levels = c("Early", "Middle", "Late", "Transient"))
value <- c(countGeneList(geneCluster, geneList.upLoop),
           countGeneList(geneCluster, geneList.noLoop),
           countGeneList(geneCluster, geneList.downLoop))

data <- data.frame(group, cluster, value)
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="stack", stat = "identity") + theme_classic()
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="fill", stat = "identity") + theme_classic()

value <- c(countGeneList(geneCluster, geneList.upLoop.specific),
           countGeneList(geneCluster, geneList.noLoop.specific),
           countGeneList(geneCluster, geneList.downLoop.specific))

data <- data.frame(group, cluster, value)
# Plotting
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="stack", stat = "identity") + theme_classic()
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="fill", stat = "identity") + theme_classic()



################## Checking how those genes behave in A485
diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ "UP",
                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ "DOWN",
                                            TRUE ~ "NO"),
                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoop ~ "cohesin-upLoop",
                                                 ensembl_gene_id %in% geneList.noLoop ~ "cohesin-noLoop",
                                                 ensembl_gene_id %in% geneList.downLoop ~ "cohesin-downLoop",
                                                 TRUE ~ "NA"))


ggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +
  geom_bar(position="fill") + theme_bw()


upLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-upLoop", diff == "DOWN"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-upLoop"))
upLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-upLoop", diff == "UP"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-upLoop"))

noLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-noLoop", diff == "DOWN"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-noLoop"))
noLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-noLoop", diff == "UP"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-noLoop"))

downLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-downLoop", diff == "DOWN"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-downLoop"))
downLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-downLoop", diff == "UP"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-downLoop"))


data <- tibble(geneGroup = c("cohesin-upLoop", "cohesin-upLoop", 
                     "cohesin-noLoop", "cohesin-noLoop", 
                     "cohesin-downLoop", "cohesin-downLoop"),
       diff = rep(c("DOWN", "UP"), 3),
       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)

ggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +
  geom_bar(stat = "identity", position = "dodge") + theme_bw()




geneList.noLoopUnique <- geneList.noLoop[!geneList.noLoop %in% unique(c(geneList.downLoop, geneList.upLoop))]
geneList.downLoopUnique <- geneList.downLoop[!geneList.downLoop %in% unique(c(geneList.noLoop, geneList.upLoop))]
geneList.upLoopUnique <- geneList.upLoop[!geneList.upLoop %in% unique(c(geneList.noLoop, geneList.downLoop))]

diff.RNA.out <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ "UP",
                                            padj < alpha & shrinked_log2FC < -fcCutoff ~ "DOWN",
                                            TRUE ~ "NO"),
                           geneGroup = case_when(ensembl_gene_id %in% geneList.upLoopUnique  ~ "cohesin-upLoop",
                                                 ensembl_gene_id %in% geneList.noLoopUnique ~ "cohesin-noLoop",
                                                 ensembl_gene_id %in% geneList.downLoopUnique ~ "cohesin-downLoop",
                                                 TRUE ~ "NA"))


ggplot(diff.RNA.out, aes(x = geneGroup, fill = diff)) +
  geom_bar(position="fill") + theme_bw()


upLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-upLoop", diff == "DOWN"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-upLoop"))
upLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-upLoop", diff == "UP"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-upLoop"))

noLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-noLoop", diff == "DOWN"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-noLoop"))
noLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-noLoop", diff == "UP"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-noLoop"))

downLoop.downPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-downLoop", diff == "DOWN"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-downLoop"))
downLoop.upPerc <- nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-downLoop", diff == "UP"))/nrow(diff.RNA.out %>% dplyr::filter(geneGroup == "cohesin-downLoop"))


data <- tibble(geneGroup = c("cohesin-upLoop", "cohesin-upLoop", 
                     "cohesin-noLoop", "cohesin-noLoop", 
                     "cohesin-downLoop", "cohesin-downLoop"),
       diff = rep(c("DOWN", "UP"), 3),
       perc = c(upLoop.downPerc, upLoop.upPerc, noLoop.downPerc, noLoop.upPerc, downLoop.downPerc, downLoop.upPerc)*100)

ggplot(data, aes(x = geneGroup, y = perc, fill = diff )) +
  geom_bar(stat = "identity", position = "dodge") + theme_bw()

```
### A485
#### P-P, P-E
```{r}
name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-pe_ensemblList.tsv")),
                                      diffCutoff = 0.2)

geneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == "UP") %>% unnest(gene))$gene)
geneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == "NO") %>% unnest(gene))$gene)
geneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == "DOWN") %>% unnest(gene))$gene)



# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN
sets_list <- list(up = geneList.upLoop,
                  no = geneList.noLoop,
                  down = geneList.downLoop)

# Create the Euler plot
euler_fit <- euler(sets_list)
plot(euler_fit,
     labels = TRUE,  # Display set labels
     fills = TRUE,   # Color fill the regions
     quantities = TRUE)


# GO
GO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.up, showCategory = 15)
GO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.no, showCategory = 15)
GO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.down, showCategory = 20)

# GO to only specific subset
geneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))
geneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))
geneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))
GO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.down, showCategory = 20)


```

#### P-N
```{r}
name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = 0.2)

geneList.upLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == "UP") %>% unnest(gene))$gene)
geneList.noLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == "NO") %>% unnest(gene))$gene)
geneList.downLoop <- unique((geneAnnoData %>% dplyr::filter(updown_A485_DMSO == "DOWN") %>% unnest(gene))$gene)



# CHECKING HOW MANY GENES OVERLAP AMONG UP/NO/DOWN
sets_list <- list(up = geneList.upLoop,
                  no = geneList.noLoop,
                  down = geneList.downLoop)

# Create the Euler plot
euler_fit <- euler(sets_list)
plot(euler_fit,
     labels = TRUE,  # Display set labels
     fills = TRUE,   # Color fill the regions
     quantities = TRUE)


# GO
GO.up <- enrichGO(gene = geneList.upLoop, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.down, showCategory = 20)

# GO to only specific subset
geneList.upLoop.specific <- setdiff(geneList.upLoop, union(geneList.noLoop, geneList.downLoop))
geneList.noLoop.specific <- setdiff(geneList.noLoop, union(geneList.upLoop, geneList.downLoop))
geneList.downLoop.specific <- setdiff(geneList.downLoop, union(geneList.noLoop, geneList.upLoop))
GO.up <- enrichGO(gene = geneList.upLoop.specific, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.up)
GO.no <- enrichGO(gene = geneList.noLoop.specific, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.no)
GO.down <- enrichGO(gene = geneList.downLoop.specific, OrgDb = org.Mm.eg.db, keyType = "ENSEMBL", ont = "BP")
dotplot(GO.down)


```
## [2.26] Checking the ChIP intensity at anchors
This doesn't have to be restricted to P-N loops. Let's check all loops first.
Also instead of density (mean), median could be better choice. Sum is not appropriate here since
the size of anchors are not same.
#### Limited to peaks to reduce noise
##### dTAG
```{r}
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore
  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

name <- "chromo_cons_annoHierarchy"

# UP loop
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe"))
anchor.up <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe"))
anchor.no <- (extractAnchor(loop.no))
# UP NO
loop.upno <- bind_rows(loop.up, loop.no)
anchor.upno <- (extractAnchor(loop.upno))
# DOWN loop
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- (extractAnchor(loop.down))

getSumScores <- function(track, anchor) {
  # Find overlaps between all anchors and track regions at once
  overlaps <- findOverlaps(anchor, track)
  
  # Extract the scores and corresponding anchor indices
  anchor_indices <- queryHits(overlaps)
  track_scores <- score(track)[subjectHits(overlaps)]
  
  # Use tapply to calculate the median scores for each anchor
  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)
  
  # Initialize a numeric vector to store the median scores for each anchor
  all_median_scores <- rep(NA, length(anchor))
  
  # Populate the median scores for the anchors that have overlaps
  all_median_scores[as.numeric(names(median_scores))] <- median_scores
  
  return(all_median_scores)
}

plotSumScores <- function(track, peak, name){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  a <- getSumScores(peakTrack, anchor.up)
  b <- getSumScores(peakTrack, anchor.no)
  c <- getSumScores(peakTrack, anchor.down)
  a.tb <- tibble(loop = "UP",
                 sumScore = a)
  b.tb <- tibble(loop = "NO",
                 sumScore = b)
  c.tb <- tibble(loop = "DOWN",
                 sumScore = c)
  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()
  ggplot(data, aes(x = loop, y = sumScore)) + 
    labs(x = NULL, y = paste0(name, " average peak score per anchor")) +
    geom_violin(aes(fill = group), color = "black",
                linewidth = lineThick * mmToLineUnit, lineend = "square",
                show.legend = FALSE) +
    geom_boxplot(width = 0.1, color = "black",
                 linewidth = lineThick * mmToLineUnit, lineend = "square",
                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +
    stat_summary(
      aes(group = loop), fun = mean,
      geom = "point", shape = 21, size = 1,
      fill = "red", color = "black"
    ) +
    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.95))) + theme(
    axis.title = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )
}

plotSumScoresBinary <- function(track, peak, name, anchor.upno, anchor.down){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  b <- getSumScores(peakTrack, anchor.upno)
  c <- getSumScores(peakTrack, anchor.down)
  b.tb <- tibble(loop = "UP/NO",
                 sumScore = b)
  c.tb <- tibble(loop = "DOWN",
                 sumScore = c)
  data <- bind_rows(b.tb, c.tb) %>% drop_na()
  data$loop <- factor(data$loop, levels = c("UP/NO", "DOWN"))
  
  p12 <- getPvalWilcox(data, "UP/NO", "DOWN")
  p <-  ggplot(data, aes(x = name, fill = loop, y = sumScore)) + 
    labs(x = NULL, y = paste0("Average ChIP peak score at anchor)")) +
    introdataviz::geom_split_violin(linewidth = lineThick * mmToLineUnit, lineend = "square",
                                    alpha = .4) +
    geom_boxplot(width = 0.3, color = "black",
                 linewidth = lineThick * mmToLineUnit, lineend = "square",
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + theme_classic() +
    stat_summary(
      aes(group = loop), fun = mean,
      geom = "point", shape = 21, size = 0.5,
      fill = "black", color = "black", position = position_dodge(.3)
    ) + theme(
      axis.title = element_text(
        size = fontSizeM, family = fontType, color = "#000000"
      ),
      axis.text = element_text(
        size = fontSizeM, family = fontType, color = "#000000"
      ),
      axis.text.x = element_text(
        angle = 0,
      ),
      axis.text.y = element_text(
        size = fontSizeS,
      ),
      axis.line = element_line(
        color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
      ),
      axis.ticks = element_line(
        color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
      ),
      panel.background = element_rect(fill = "transparent"),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    ) + 
    coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.9))) + 
    annotate(
     "text", x = 1, y = quantile(data$sumScore, 0.5),
     label = paste0("p12: ", convPvalue(p12)),
     color = "black", hjust = 0, size = 3
   ) +   guides(
    fill = guide_legend(
        keywidth = 0.2,  # Adjust the width of the legend keys
        keyheight = 0.2  # Adjust the height of the legend keys
    )
  )
  
   fileName <- paste0("ChIP_peak_avgPeakScore_", name)
  width <- panelSize(1.5)*mmToInch
  height <- panelSize(1.2)*mmToInch
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

# Sum peak score
####
track <- import(here(refDir, "33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed"))
#plotSumScores(track, peak, "H3K4me3")
plotSumScoresBinary(track, peak, "H3K4me3", anchor.upno, anchor.down)

track <- import(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed"))
#plotSumScores(track, peak, "H3K27ac")
plotSumScoresBinary(track, peak, "H3K27ac", anchor.upno, anchor.down)

track <- import(here(refDir, "GSM2683440_J1_H3K14ac_mm10Lifted.black.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "GSM2683440_J1_H3K14ac_mm10Lifted.bed"))
#plotSumScores(track, peak, "H3K14ac")
plotSumScoresBinary(track, peak, "H3K14ac", anchor.upno, anchor.down)

track <- import(here(refDir, "33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed"))
#plotSumScores(track, peak, "CTCF")
plotSumScoresBinary(track, peak, "CTCF", anchor.upno, anchor.down)

track <- import(here(refDir, "33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed"))
#plotSumScores(track, peak, "RAD21")
plotSumScoresBinary(track, peak, "RAD21", anchor.upno, anchor.down)


```
##### A485
```{r}
name <- "chromo_cons_annoHierarchy"

# UP loop
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe"))
anchor.up <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe"))
anchor.no <- (extractAnchor(loop.no))
# DOWN loop
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- (extractAnchor(loop.down))

getSumScores <- function(track, anchor) {
  # Find overlaps between all anchors and track regions at once
  overlaps <- findOverlaps(anchor, track)
  
  # Extract the scores and corresponding anchor indices
  anchor_indices <- queryHits(overlaps)
  track_scores <- score(track)[subjectHits(overlaps)]
  
  # Use tapply to calculate the median scores for each anchor
  median_scores <- tapply(track_scores, anchor_indices, sum, na.rm = TRUE)
  
  # Initialize a numeric vector to store the median scores for each anchor
  all_median_scores <- rep(NA, length(anchor))
  
  # Populate the median scores for the anchors that have overlaps
  all_median_scores[as.numeric(names(median_scores))] <- median_scores
  
  return(all_median_scores)
}

plotSumScores <- function(track, peak, name){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  a <- getSumScores(peakTrack, anchor.up)
  b <- getSumScores(peakTrack, anchor.no)
  c <- getSumScores(peakTrack, anchor.down)
  a.tb <- tibble(loop = "UP",
                 sumScore = a)
  b.tb <- tibble(loop = "NO",
                 sumScore = b)
  c.tb <- tibble(loop = "DOWN",
                 sumScore = c)
  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()
  ggplot(data, aes(x = loop, y = sumScore)) + geom_boxplot(outlier.shape = NA) + theme_classic() + ggtitle(paste0(name, " sum peak")) +
    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.9)))
}

# Sum peak score
####
track <- import(here(refDir, "33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed"))
plotSumScores(track, peak, "H3K4me3")

track <- import(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed"))
plotSumScores(track, peak, "H3K27ac")

track <- import(here(refDir, "GSM2683440_J1_H3K14ac_mm10Lifted.black.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "GSM2683440_J1_H3K14ac_mm10Lifted.bed"))
plotSumScores(track, peak, "H3K14ac")

track <- import(here(refDir, "33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed"))
plotSumScores(track, peak, "CTCF")

track <- import(here(refDir, "33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw"), format = "BigWig")
peak.temp <- fread(here(refDir, "33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed")) %>%
  dplyr::mutate(V2 = V2 - 1000,
                V3 = V3 + 1000)
colnames(peak.temp) <- c("chr", "start", "end")
peak <- makeGRangesFromDataFrame(peak.temp)
plotSumScores(track, peak, "YY1")


### For those with only summit
track <- import(here(refDir, "GSM5571895_ESC_YY1_1.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "GSM5571895_ESC_YY1_summit.bed"))
plotSumScores(track, peak, "RAD21")

### FOR THOSE WITHOUT PEAKS
track <- import(here(refDir, "GSM2082708_ESC.H3K27me3.1_mm10Lifted.black.bw"), format = "BigWig")
a <- getSumScores(track, anchor.up)
b <- getSumScores(track, anchor.no)
c <- getSumScores(track, anchor.down)
a.tb <- tibble(loop = "UP",
               sumScore = a)
b.tb <- tibble(loop = "NO",
               sumScore = b)
c.tb <- tibble(loop = "DOWN",
               sumScore = c)
data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()
ggplot(data, aes(x = loop, y = sumScore)) + geom_boxplot(outlier.shape = NA) + theme_classic() + ggtitle(paste0("H3K27me3 sum no peak")) +
  coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.9)))
```
#### Peak density instead of intensity
```{r}
name <- "chromo_cons_annoHierarchy"

# UP loop
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe"))
anchor.up <- (extractAnchor(loop.up))
# NO loop
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe"))
anchor.no <- (extractAnchor(loop.no))
# DOWN loop
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- (extractAnchor(loop.down))


peak.H3K4me3 <- importPeak(here(refDir, "33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed"))
peak.H3K27ac <- importPeak(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed"))
peak.CTCF <- importPeak(here(refDir, "33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed"))
peak.temp <- fread(here(refDir, "33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed")) %>%
  dplyr::mutate(V2 = V2 - 1000,
                V3 = V3 + 1000)
colnames(peak.temp) <- c("chr", "start", "end")
peak.RAD21 <- makeGRangesFromDataFrame(peak.temp)


calculatePeakDensity <- function(peak, note){
  
  overlap_counts <- countOverlaps(anchor.up, peak)
  anchor_widths <- (width(anchor.up)-1)/1000
  density <- overlap_counts / anchor_widths
  data1 <- tibble(type = "UP",
                  densityPerKb = density)
  
  overlap_counts <- countOverlaps(anchor.no, peak)
  anchor_widths <- (width(anchor.no)-1)/1000
  density <- overlap_counts / anchor_widths
  mcols(anchor.no)$density <- density
  data2 <- tibble(type = "NO",
                  densityPerKb = density)
  
  overlap_counts <- countOverlaps(anchor.down, peak)
  anchor_widths <- (width(anchor.down)-1)/1000
  density <- overlap_counts / anchor_widths
  mcols(anchor.down)$density <- density
  data3 <- tibble(type = "DOWN",
                  densityPerKb = density)
  
  data <- bind_rows(data1, data2, data3)
  
  ggplot(data, aes(x = type, y = densityPerKb))  + geom_violin() + geom_boxplot(outlier.shape = NA, width = 0.1 ) + theme_bw() + ggtitle(note) +
    coord_cartesian(ylim = c(0, quantile(data$sumScore, 0.9)))
}

calculatePeakDensity(peak.H3K4me3, "H3K4me3")
calculatePeakDensity(peak.H3K27ac, "H3K27ac")
calculatePeakDensity(peak.CTCF, "CTCF")
calculatePeakDensity(peak.RAD21, "RAD21")

```

## [2.27] Overlap with SE?
#### Q1. How many SEs are covered with Micro-C loops?
```{r}
name <- "chromo_cons_annoHierarchy"
loop <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe"))
anchor <- extractAnchor(loop)

### Whyte
n <- length(unique(subjectHits(findOverlaps(anchor, peak.Whyte.SE))))
total <- length(peak.Whyte.SE)
counts <- c(n, total - n)
labels <- paste(c("covered", "NOT covered"), counts)
pie(counts, labels = labels,  main = paste0("Whyte SE coverage \n", total), col = c("grey", "white"))

fileName <- here(figDir, "pie_SE_Whyte")
width <- panelSize(4)*mmToInch
height <- panelSize(4)*mmToInch
# svglite(paste0(fileName, ".svg"), width = width, height =height)
# pie(counts, labels = labels,  main = paste0("Whyte SE coverage \n", total), col = c("grey", "white"),
#     cex = 1, cex.main = 1)
# dev.off()



### Dylan
n <- length(unique(subjectHits(findOverlaps(anchor, peak.Dylan.SE))))
total <- length(peak.Dylan.SE)
counts <- c(n, total - n)
labels <- paste(c("covered", "NOT covered"), counts)
pie(counts, labels = labels, main = paste0("Dylan SE coverage \n", total), col = c("grey", "white"))

fileName <- here(figDir, "pie_SE_Murphy")
width <- panelSize(4)*mmToInch
height <- panelSize(4)*mmToInch
# svglite(paste0(fileName, ".svg"), width = width, height =height)
# pie(counts, labels = labels, main = paste0("Murphy SE coverage \n", total), col = c("grey", "white"))
# 
# dev.off()

```
#### Q2. Fisher's exact test?
##### dTAG
```{r}
name <- "chromo_cons_annoHierarchy"
loop <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe"))

getOverlapLoopNum <- function(loop, peak){
  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))
  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))
  a <- queryHits(findOverlaps(anchor1, peak))
  b <- queryHits(findOverlaps(anchor2, peak))
  return(length(unique(c(a, b))))
}

getSEOverlapFisher <- function(allLoop, subsetLoop, peak){
  all.overlap <- getOverlapLoopNum(allLoop, peak)
  all.notOverlap <- nrow(allLoop) - all.overlap
  
  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)
  subset.notOverlap <- nrow(subsetLoop) - subset.overlap
  
  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,
                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)
  colnames(contingency_table) <- c("Overlapping", "Not_Overlapping")
  rownames(contingency_table) <- c("All loops", "Subset loops")
  
  # Perform Fisher's Exact Test
  fisher_test_result <- fisher.test(contingency_table)
  return(fisher_test_result)
}



loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe"))
loop.upno <- bind_rows(loop.up, loop.no)
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe"))

### Dylan
# Seeding
temp <- getSEOverlapFisher(loop, loop.upno, peak.Dylan.SE)
result.tb <- tibble(loopType = "UP/NO",
                    target = "Dylan SE",
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)

# temp <- getSEOverlapFisher(loop, loop.up, peak.Dylan.SE)
# result.tb <- tibble(loopType = "UP",
#                     target = "Dylan SE",
#                     pvalue = temp$p.value,
#                     oddsRatio = temp$estimate)
# Add row
# temp <- getSEOverlapFisher(loop, loop.no, peak.Dylan.SE)
# result.tb <- result.tb %>% 
#   add_row(loopType = "NO",
#           target = "Dylan SE",
#           pvalue = temp$p.value,
#           oddsRatio = temp$estimate)

temp <- getSEOverlapFisher(loop, loop.down, peak.Dylan.SE)
result.tb <- result.tb %>% 
  add_row(loopType = "DOWN",
          target = "Dylan SE",
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

### Whyte
# Seeding
# temp <- getSEOverlapFisher(loop, loop.up, peak.Whyte.SE)
# result.tb <- result.tb %>% 
#   add_row(loopType = "UP",
#                     target = "Whyte SE",
#                     pvalue = temp$p.value,
#                     oddsRatio = temp$estimate)

# Add row
temp <- getSEOverlapFisher(loop, loop.upno, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = "UP/NO",
          target = "Whyte SE",
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

temp <- getSEOverlapFisher(loop, loop.down, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = "DOWN",
          target = "Whyte SE",
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)


# Visualization
library(circlize)
data <- result.tb
heatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%
pivot_wider(names_from = loopType, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%
  pivot_wider(names_from = loopType, values_from = pvalue) %>%
  column_to_rownames(var = "target")

col_fun <- colorRamp2(c(0, 1, 2), 
                      c("#4852A0", "white", "#CB333A"))

p <- Heatmap(as.matrix(heatmap_data),
        name = "Odds Ratio",
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, "n.s.", sprintf("%.2e", pval))
          grid.text(label, x, y, gp = gpar(fontsize = fontSizeS, fontfamily = fontType))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        row_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),
  column_names_gp = gpar(fontsize = fontSizeS, fontfamily = fontType),
        heatmap_legend_param = list(
          at = c(0, 1, 2),
          labels = c("0", "1", "2"),
          title_gp = gpar(fontfamily = fontType, fontsize = fontSizeS),
          labels_gp = gpar(fontfamily = fontType, fontsize = fontSizeS)
        )
)

# fileName <- here(figDir, "heatmap_SE_enrichment")
# width <- panelSize(1.5)*mmToInch
# height <- panelSize(0.7)*mmToInch
# svglite(paste0(fileName, ".svg"), width = width, height =height)
# print(p)
# dev.off()
# png(paste0(fileName, ".png"), width = width, height =height, res = 600, unit = "in")
# print(p)
# dev.off()

#######################

data$loopType <- factor(data$loopType, levels = c("UP/NO", "DOWN"))
data$target <- factor(data$target, levels = c("Whyte SE", "Dylan SE"))

p <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
  scale_fill_gradientn(colors = c("#4852A0", "white", "#CB333A"),  # Define gradient colors
                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), 
                      #low = "white", high = "#CB333A",
                      #                  limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) +
  labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- here(figDir, "heatmap_SE_enrichment_dotplot")
width <- panelSize(1.8)*mmToInch
height <- panelSize(1.1)*mmToInch
# png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
# print(p)
# dev.off()
svglite(paste0(fileName, ".svg"),  height = height, width = width)
print(p)
dev.off()

```
##### A485
```{r}
name <- "chromo_cons_annoHierarchy"
loop <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe"))

getOverlapLoopNum <- function(loop, peak){
  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))
  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))
  a <- queryHits(findOverlaps(anchor1, peak))
  b <- queryHits(findOverlaps(anchor2, peak))
  return(length(unique(c(a, b))))
}

getSEOverlapFisher <- function(allLoop, subsetLoop, peak){
  all.overlap <- getOverlapLoopNum(allLoop, peak)
  all.notOverlap <- nrow(allLoop) - all.overlap
  
  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)
  subset.notOverlap <- nrow(subsetLoop) - subset.overlap
  
  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,
                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)
  colnames(contingency_table) <- c("Overlapping", "Not_Overlapping")
  rownames(contingency_table) <- c("All loops", "Subset loops")
  
  # Perform Fisher's Exact Test
  fisher_test_result <- fisher.test(contingency_table)
  return(fisher_test_result)
}



loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe"))
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe"))

### Dylan
# Seeding
temp <- getSEOverlapFisher(loop, loop.up, peak.Dylan.SE)
result.tb <- tibble(loopType = "UP",
                    target = "Dylan SE",
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)
# Add row
temp <- getSEOverlapFisher(loop, loop.no, peak.Dylan.SE)
result.tb <- result.tb %>% 
  add_row(loopType = "NO",
          target = "Dylan SE",
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

temp <- getSEOverlapFisher(loop, loop.down, peak.Dylan.SE)
result.tb <- result.tb %>% 
  add_row(loopType = "DOWN",
          target = "Dylan SE",
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

### Whyte
# Seeding
temp <- getSEOverlapFisher(loop, loop.up, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = "UP",
                    target = "Whyte SE",
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)
# Add row
temp <- getSEOverlapFisher(loop, loop.no, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = "NO",
          target = "Whyte SE",
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)

temp <- getSEOverlapFisher(loop, loop.down, peak.Whyte.SE)
result.tb <- result.tb %>% 
  add_row(loopType = "DOWN",
          target = "Whyte SE",
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)


# Visualization
library(circlize)
data <- result.tb
heatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%
pivot_wider(names_from = loopType, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%
  pivot_wider(names_from = loopType, values_from = pvalue) %>%
  column_to_rownames(var = "target")

col_fun <- colorRamp2(c(0, 1, 5), 
                      c("blue", "white", "red"))

Heatmap(as.matrix(heatmap_data),
        name = "Odds Ratio",
        col = col_fun,
        # Add annotation for p-values
        cell_fun = function(j, i, x, y, width, height, fill) {
          pval <- pvalue_data[i, j]
          label <- ifelse(pval > 0.05, "n.s.", sprintf("%.2e", pval))
          grid.text(label, x, y, gp = gpar(fontsize = 10))
        },
        # Customize the heatmap layout
        cluster_rows = TRUE,
        show_row_dend = FALSE,
        cluster_columns = FALSE,
        column_title = "Interest",
        row_title = "Target",
        heatmap_legend_param = list(at = c(0, 1, 2, 3, 4, 5), 
                                    labels = c("0", "1", "2", "3", "4", "5")))



```


## [2.28] Comparing differential loops in dTAG to A485
The question I want to ask here is whether perturbed loops in dTAG experiments are either perturbed or not perturbed in A485 experiment. If there is compensation going on between RAD21 and A485, UP loop in RAD21 should be more DOWN in A485 and vice versa
#### Exploratory part
```{r}
diffCutoff <- 0.2
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))
data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, "UP", 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, "NO", "DOWN")),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, "UP", 
                                            ifelse(diff_A485_DMSO > -diffCutoff, "NO", "DOWN")))

 temp <- data
  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)
  temp <- temp %>% dplyr::arrange(density)
  
  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() + 
    geom_hline(yintercept = diffCutoff, alpha = 1, color = "black") +
    geom_hline(yintercept = -diffCutoff, alpha = 1, color = "black") +
    geom_vline(xintercept = diffCutoff, alpha = 1, color = "black") +
    geom_vline(xintercept = -diffCutoff, alpha = 1, color = "black") +
    geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
    geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + 
    theme_classic()
  
  fileName <- paste0("scatterplot_", name, "_", diffCutoff, "_diff_", loopName, "_dTAG-", diffName)
  png(here(figDir, paste0(fileName, ".png")), res = 600, units = "in", width = 3.5, height = 3)
  print(p1)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()



```


#### Scatterplot & box plot
```{r}
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))
data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(diff_dTAG_DMSO > diffCutoff, "UP", 
                                            ifelse(diff_dTAG_DMSO > -diffCutoff, "NO", "DOWN")),
                  updown_A485_DMSO = ifelse(diff_A485_DMSO > diffCutoff, "UP", 
                                            ifelse(diff_A485_DMSO > -diffCutoff, "NO", "DOWN")))

makeAcrossSampleScatterplotdTAG <- function(data, AnnoList, diff, name, loopName, diffName){
  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,
                                 updown_dTAG_DMSO %in% diff)
  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)
  temp <- temp %>% dplyr::arrange(density)

  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() + 
    geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
    geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
    geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
    geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
    geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + 
    theme_classic() + ggtitle(paste0(name, "_", loopName, "_dTAG-", diffName)) + theme(plot.title = element_text(size = 5))
  
  fileName <- paste0("scatterplot_", name, "_", diffCutoff, "_diff_", loopName, "_dTAG-", diffName)
  png(here(figDir, paste0(fileName, ".png")), res = 600, units = "in", width = 3.5, height = 3)
  print(p1)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()
}

makeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c("UP", "NO", "DOWN"), name, "all", "all")
makeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c("UP"), name, "all", "UP")
makeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c("NO"), name, "all", "NO")
makeAcrossSampleScatterplotdTAG(data, unique(data$Anno2), c("DOWN"), name, "all", "DOWN")

makeAcrossSampleScatterplotdTAG(data, c("P-P", "P-E", "E-E"), c("UP", "NO", "DOWN"), name, "pe-pe", "all")
makeAcrossSampleScatterplotdTAG(data, c("P-P", "P-E", "E-E"), c("UP"), name, "pe-pe", "UP")
makeAcrossSampleScatterplotdTAG(data, c("P-P", "P-E", "E-E"), c("NO"), name, "pe-pe", "NO")
makeAcrossSampleScatterplotdTAG(data, c("P-P", "P-E", "E-E"), c("DOWN"), name, "pe-pe", "DOWN")

makeAcrossSampleScatterplotdTAG(data, c("S-S", "S-X"), c("UP", "NO", "DOWN"), name, "str", "all")
makeAcrossSampleScatterplotdTAG(data, c("S-S", "S-X"), c("UP"), name, "str", "UP")
makeAcrossSampleScatterplotdTAG(data, c("S-S", "S-X"), c("NO"), name, "str", "NO")
makeAcrossSampleScatterplotdTAG(data, c("S-S", "S-X"), c("DOWN"), name, "str", "DOWN")

makeAcrossSampleScatterplotA485 <- function(data, AnnoList, diff, name, loopName, diffName){
  temp <- data %>% dplyr::filter(Anno2 %in% AnnoList,
                                 updown_A485_DMSO %in% diff)
  temp$density <- get_density(temp$diff_dTAG_DMSO, temp$diff_A485_DMSO, n = 100)
  temp <- temp %>% dplyr::arrange(density)

  p1 <- ggplot(temp, aes(x = diff_dTAG_DMSO, y = diff_A485_DMSO, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() + 
    geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
    geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
    geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
    geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
    geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +coord_fixed(ratio = 1, ylim = c(-1, 1), xlim = c(-1, 1)) + 
    theme_classic() + ggtitle(paste0(name, "_", loopName, "_A485G-", diffName)) + theme(plot.title = element_text(size = 5))
  
  fileName <- paste0("scatterplot_", name, "_", diffCutoff, "_diff_", loopName, "_A485-", diffName)
  png(here(figDir, paste0(fileName, ".png")), res = 600, units = "in", width = 3.5, height = 3)
  print(p1)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")), 
          width = 3.5, height = 3)
  print(p1)
  dev.off()
}

makeAcrossSampleScatterplotA485(data, unique(data$Anno2), c("UP", "NO", "DOWN"), name, "all", "all")
makeAcrossSampleScatterplotA485(data, unique(data$Anno2), c("UP"), name, "all", "UP")
makeAcrossSampleScatterplotA485(data, unique(data$Anno2), c("NO"), name, "all", "NO")
makeAcrossSampleScatterplotA485(data, unique(data$Anno2), c("DOWN"), name, "all", "DOWN")

makeAcrossSampleScatterplotA485(data, c("P-P", "P-E", "E-E"), c("UP", "NO", "DOWN"), name, "pe-pe", "all")
makeAcrossSampleScatterplotA485(data, c("P-P", "P-E", "E-E"), c("UP"), name, "pe-pe", "UP")
makeAcrossSampleScatterplotA485(data, c("P-P", "P-E", "E-E"), c("NO"), name, "pe-pe", "NO")
makeAcrossSampleScatterplotA485(data, c("P-P", "P-E", "E-E"), c("DOWN"), name, "pe-pe", "DOWN")

makeAcrossSampleScatterplotA485(data, c("S-S", "S-X"), c("UP", "NO", "DOWN"), name, "str", "all")
makeAcrossSampleScatterplotA485(data, c("S-S", "S-X"), c("UP"), name, "str", "UP")
makeAcrossSampleScatterplotA485(data, c("S-S", "S-X"), c("NO"), name, "str", "NO")
makeAcrossSampleScatterplotA485(data, c("S-S", "S-X"), c("DOWN"), name, "str", "DOWN")

######## Barplot
temp <- data %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO)
ggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = "dashed") +
  geom_hline(yintercept = -0.2, linetype = "dashed") + coord_cartesian(ylim = c(-0.5, 0.5))

temp <- data %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E")) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) 
ggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = "dashed") +
  geom_hline(yintercept = -0.2, linetype = "dashed") + coord_cartesian(ylim = c(-0.5, 0.5))


temp <- data %>% dplyr::filter(Anno2 %in% c("S-S", "S-X")) %>% dplyr::select(updown_dTAG_DMSO, diff_A485_DMSO) 
ggplot(temp, aes(x = updown_dTAG_DMSO, y = diff_A485_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = "dashed") +
  geom_hline(yintercept = -0.2, linetype = "dashed") + coord_cartesian(ylim = c(-0.5, 0.5))

###
temp <- data %>% dplyr::select(updown_A485_DMSO, diff_dTAG_DMSO)
ggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = "dashed") +
  geom_hline(yintercept = -0.2, linetype = "dashed") + coord_cartesian(ylim = c(-0.5, 0.5))

temp <- data %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E")) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)
ggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = "dashed") +
  geom_hline(yintercept = -0.2, linetype = "dashed") + coord_cartesian(ylim = c(-0.5, 0.5))


temp <- data %>% dplyr::filter(Anno2 %in% c("S-S", "S-X")) %>% dplyr:::select(updown_A485_DMSO, diff_dTAG_DMSO)
ggplot(temp, aes(x = updown_A485_DMSO, y = diff_dTAG_DMSO)) + geom_boxplot(outlier.shape = NA) + theme_classic() +
  geom_hline(yintercept = 0) +
  geom_hline(yintercept = 0.2, linetype = "dashed") +
  geom_hline(yintercept = -0.2, linetype = "dashed") + coord_cartesian(ylim = c(-0.5, 0.5))

```

## [2.29] Compartment analysis
Q. What are the changes in compartment level upon A485 treatment?
#### Compartment change distribution
```{r}
### IMPORTING COMPARMTNET SCORES
compDir <- here("../..", "result", "compartment", "CscoreTools")

cscore.DMSO <- as_tibble(fread(here(compDir, "G1DMSO_Merged_10kb_cscore_final.bedgraph"), skip = 1)) %>%
  dplyr::mutate(V2 = V2 + 1)
colnames(cscore.DMSO) <- c("chr", "start", "end", "cscore_DMSO")

cscore.A485 <- as_tibble(fread(here(compDir, "G1A485_Merged_10kb_cscore_final.bedgraph"), skip = 1)) %>%
  dplyr::mutate(V2 = V2 + 1)
colnames(cscore.A485) <- c("chr", "start", "end", "cscore_A485")


cscore <- dplyr::full_join(cscore.DMSO, cscore.A485, by = c("chr", "start", "end"))

# FILTER ROWS WITH NA
cscore <- cscore %>% filter(!if_any(everything(), is.na))

# Annotating how the compartment changed
threshold <- 0.1
cscore <- cscore %>% rowwise() %>% dplyr::mutate(isAB_DMSO = ifelse(cscore_DMSO > 0, "A", "B"),
                                                 isAB_A485 = ifelse(cscore_A485 > 0, "A", "B"),
                                                 changeType = case_when(
                                                   abs(cscore_DMSO - cscore_A485) < threshold ~ "Unchanged",
                                                   isAB_DMSO == "A" & isAB_A485 == "B" ~ "AtoB",
                                                   isAB_DMSO == "B" & isAB_A485 == "A" ~ "BtoA",
                                                   isAB_DMSO == "A" & isAB_A485 == "A" & abs(cscore_DMSO) > abs(cscore_A485) ~ "A_weakening",
                                                   isAB_DMSO == "A" & isAB_A485 == "A" & abs(cscore_DMSO) <= abs(cscore_A485) ~ "A_strengthening",
                                                   isAB_DMSO == "B" & isAB_A485 == "B" & abs(cscore_DMSO) > abs(cscore_A485) ~ "B_weakening",
                                                   isAB_DMSO == "B" & isAB_A485 == "B" & abs(cscore_DMSO) <= abs(cscore_A485) ~ "B_strengthening"                                                 ))
cscore_summary <- tibble(comparison = rep("A485_vs_DMSO", 7),
                         changeType = c("AtoB", "BtoA", "A_weakening", "A_strengthening", "B_weakening", "B_strengthening", "Unchanged"),
                         value = c(sum(cscore$changeType == "AtoB"),
                                   sum(cscore$changeType == "BtoA"),
                                   sum(cscore$changeType == "A_weakening"),
                                   sum(cscore$changeType == "A_strengthening"),
                                   sum(cscore$changeType == "B_weakening"),
                                   sum(cscore$changeType == "B_strengthening"),
                                   sum(cscore$changeType == "Unchanged")))
cscore_summary$changeType <- factor(cscore_summary$changeType, levels = c("A_weakening", "AtoB", "B_strengthening",
                                                                          "B_weakening", "BtoA", "A_strengthening",
                                                                          "Unchanged"))
ggplot(cscore_summary, aes(x = comparison, y = value, fill = changeType)) + geom_bar(position = "stack", stat = "identity") +
  theme_bw() +
  scale_fill_manual(values = c("skyblue", "blue", "darkblue", "pink", "red2", "darkred" ,"grey"))
  
```
#### Combining with RNA-seq
```{r}
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3)) %>%
  dplyr::select(V1, TSS, V6)
colnames(gene.tb) <- c("chr", "TSS", "ensembl")

diff.RNA <- fread(here(refDir, "diff_G1.A485.selected2_G1.2i.A485_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)
diff.RNA <- diff.RNA %>% dplyr::left_join(gene.tb, by = c("ensembl_gene_id" = "ensembl")) %>%
  dplyr::filter(!is.na(TSS))

alpha <- 0.05
fcCutoff <- 0.5

diff.RNA <- diff.RNA %>% dplyr::mutate(diff = case_when(padj < alpha & shrinked_log2FC > fcCutoff ~ "UP",
                                                        padj < alpha & shrinked_log2FC < -fcCutoff ~ "DOWN",
                                                        TRUE ~ "NO"))


getCompChangeType <- function(chrom, TSS, cscore.tb){
  temp.tb <- cscore.tb %>% dplyr::filter(chr == chrom, start < TSS, end > TSS)
  out <- temp.tb$changeType
  if(length(out) < 1){
    return(NA)
  }else{
    return(out)
  }
}

cscore.gr <- makeGRangesFromDataFrame(cscore[1:3])
temp <-diff.RNA %>% dplyr::mutate(start = TSS, end = TSS +1) %>%
  dplyr::select(chr, start, end)
diff.RNA.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(diff.RNA.gr, cscore.gr)

#cscore.selected <- cscore %>% dplyr::slice(subjectHits(overlap))
## Problem of certain genes not getting overlap with cscore due to sparse calling?
batch1 <- bind_cols(diff.RNA[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


missed <- diff.RNA[-queryHits(overlap)]
temp <- missed %>% dplyr::mutate(TSS = TSS + 10000) %>% dplyr::mutate(start = TSS, end = TSS +1) %>%
  dplyr::select(chr, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch2 <- bind_cols(missed[queryHits(overlap)],
                    data.table(cscore)[subjectHits(overlap)])

missed2 <- missed[-queryHits(overlap)]
temp <- missed2 %>% dplyr::mutate(TSS = TSS - 10000) %>% dplyr::mutate(start = TSS, end = TSS +1) %>%
  dplyr::select(chr, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch3 <- bind_cols(missed2[queryHits(overlap)],
                    data.table(cscore)[subjectHits(overlap)])

#missed3 <- missed2[-queryHits(overlap)]


diff.RNA <- bind_rows(batch1, batch2, batch3)


# VISUALIZE
diff.RNA$changeType <- factor(diff.RNA$changeType, levels = c("A_weakening", "AtoB", "B_strengthening",
                                                                          "B_weakening", "BtoA", "A_strengthening",
                                                                          "Unchanged"))
ggplot(diff.RNA, aes(x = diff, fill = changeType)) +
  geom_bar(position = "fill") +
  labs(title = "Stacked Bar Plot of Change Type by Diff",
       x = "Diff",
       y = "Count") +
  theme_bw() +  scale_fill_manual(values = c("skyblue", "blue", "darkblue", "pink", "red2", "darkred" ,"grey"))



```
#### Combining with loop
```{r}
name <- "chromo_cons_annoHierarchy"

# UP loop
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_UP_diff0.2.bedpe"))
anchor.up <- (extractAnchor(loop.up))
anchor.up.tb <- as_tibble(anchor.up) %>%
  dplyr::mutate(center = (start + end)/2) %>%
  dplyr::mutate(start = center-1, end = center+1) %>%
  dplyr::select(seqnames, start, end)
anchor.up <- makeGRangesFromDataFrame(anchor.up.tb)
# NO loop
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_NO_diff0.2.bedpe"))
anchor.no <- (extractAnchor(loop.no))
anchor.no.tb <- as_tibble(anchor.no) %>%
  dplyr::mutate(center = (start + end)/2) %>%
  dplyr::mutate(start = center-1, end = center+1) %>%
  dplyr::select(seqnames, start, end)
anchor.no <- makeGRangesFromDataFrame(anchor.no.tb)
# DOWN loop
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_A485vsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- (extractAnchor(loop.down))
anchor.down.tb <- as_tibble(anchor.down) %>%
  dplyr::mutate(center = (start + end)/2) %>%
  dplyr::mutate(start = center-1, end = center+1) %>%
  dplyr::select(seqnames, start, end)
anchor.down <- makeGRangesFromDataFrame(anchor.down.tb)


########################################################################
### Overlap
cscore.gr <- makeGRangesFromDataFrame(cscore[1:3])
overlap <- findOverlaps(anchor.up, cscore.gr)

## Problem of certain genes not getting overlap with cscore due to sparse calling?
batch1 <- bind_cols(data.table(anchor.up.tb)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


missed <- data.table(anchor.up.tb)[-queryHits(overlap)]
temp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%
  dplyr::select(seqnames, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch2 <- bind_cols((missed)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


data.up <- bind_rows(batch1, batch2)

########################################################################
### Overlap
cscore.gr <- makeGRangesFromDataFrame(cscore[1:3])
overlap <- findOverlaps(anchor.no, cscore.gr)

## Problem of certain genes not getting overlap with cscore due to sparse calling?
batch1 <- bind_cols(data.table(anchor.no.tb)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


missed <- data.table(anchor.no.tb)[-queryHits(overlap)]
temp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%
  dplyr::select(seqnames, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch2 <- bind_cols((missed)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


data.no <- bind_rows(batch1, batch2)

########################################################################
### Overlap
cscore.gr <- makeGRangesFromDataFrame(cscore[1:3])
overlap <- findOverlaps(anchor.down, cscore.gr)

## Problem of certain genes not getting overlap with cscore due to sparse calling?
batch1 <- bind_cols(data.table(anchor.down.tb)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


missed <- data.table(anchor.down.tb)[-queryHits(overlap)]
temp <- missed %>% dplyr::mutate(start = start - 10000, end = end - 10000) %>%
  dplyr::select(seqnames, start, end)
missed.gr <- makeGRangesFromDataFrame(temp)
overlap <- findOverlaps(missed.gr, cscore.gr)
batch2 <- bind_cols((missed)[queryHits(overlap)],
          data.table(cscore)[subjectHits(overlap)])


data.down <- bind_rows(batch1, batch2)

n.up <- nrow(data.up)
n.no <- nrow(data.no)
n.down <- nrow(data.down)

data <- tibble(loopDiff = c(rep("UP", n.up), rep("NO", n.no), rep("DOWN", n.down)),
              changeType = c(data.up$changeType, data.no$changeType, data.down$changeType))

# VISUALIZE
data$changeType <- factor(data$changeType, levels = c("A_weakening", "AtoB", "B_strengthening",
                                                                          "B_weakening", "BtoA", "A_strengthening",
                                                                          "Unchanged"))
ggplot(data, aes(x = loopDiff, fill = changeType)) +
  geom_bar(position = "fill") +
  labs(title = "Stacked Bar Plot of Change Type by Diff",
       x = "Diff",
       y = "Count") +
  theme_bw() +  scale_fill_manual(values = c("skyblue", "blue", "darkblue", "pink", "red2", "darkred" ,"grey"))




```
## [2.30] ChromHMM
```{r}
resultDir <- here("../../result")

data <- fread(here(resultDir, "chromHMM", "A485_pe-pe_anchors", "overlap_enrich_100_state.txt"))
colnames(data) <- c("state", "genome", "pe-pe_A485_down", "pe-pe_A485_no", "pe-pe_A485_up")
data <- data %>% dplyr::select(-genome)

data_matrix <- data %>%
  column_to_rownames(var = "state") %>%
  as.matrix()

library(circlize)

col_fun <- colorRamp2(c(0, 1, 10), 
                      c("blue", "white", "red"))

Heatmap(
  data_matrix,
  name = "Value",
  show_row_names = TRUE,
  show_column_names = TRUE,
  cluster_columns = FALSE,
  cluster_rows = FALSE,
   col = col_fun
)

#######
data2 <- data %>% dplyr::select(c(1, 2, 4))
data2 <- data2 %>% dplyr::filter(`pe-pe_A485_down` > `pe-pe_A485_up`)
data_matrix <- data2 %>%
  column_to_rownames(var = "state") %>%
  as.matrix()

library(circlize)

col_fun <- colorRamp2(c(0, 1, 10), 
                      c("blue", "white", "red"))

Heatmap(
  data_matrix,
  name = "Value",
  show_row_names = TRUE,
  show_column_names = TRUE,
  cluster_columns = FALSE,
  cluster_rows = FALSE,
   col = col_fun
)


```

## [2.31] Making Visualization Easy
https://bioconductor.org/books/devel/OHCA/pages/visualization.html
```{r}
### Getting loop ID
temp <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe")) %>%
  dplyr::mutate(res = V3 - V2,
                id = paste(V1, res, V2, V5, sep = "_"))
regID <- temp$id

temp <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure.bedpe")) %>%
  dplyr::mutate(res = V3 - V2,
                id = paste(V1, res, V2, V5, sep = "_"))
strID <- temp$id

############## REG
## Filtering loops to plot
data <- fread(here(consensusDir, "chromo_cons_score.tsv"))
temp <- data %>% dplyr::filter(id %in% regID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))
temp <- temp %>% dplyr::select(seq(1, 6))
colnames(temp) <- c("V1", "V2", "V3", "V4", "V5", "V6")
loops <- importBedpe(temp)

# Visualization
hicDir <- "/Volumes/UKJIN_SSD/data_vault_2024summer_microC/hic"
windowSize <- 1*1e6

i = 1
# for(i in seq(1, 25)){
  ## Loading hic and plotting
  chr <- as_tibble(loops[i])$seqnames1
  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2
  start <- floor(center - 0.5*windowSize)
  end <- floor(center + 0.5*windowSize)
  
  cf.G1DMSO <- HicFile(path = here(hicDir, "G1.DMSO.Merged.hic"))
  cf.G1dTAG <- HicFile(path = here(hicDir, "G1.dTAG.Merged.hic"))
  #cf.G1dTAG <- HicFile(path = here(hicDir, "G1.A485.Merged.hic"))

  res <- 10*1000
  zmax <- 2.5
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, ":", start, "-", end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, ":", start, "-", end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0("visuzliation_regLoop_dTAG_", i, "_10kb_figureVer"))
  
  width <- panelSize(20)*mmToInch
  height <- panelSize(10)*mmToInch
  
  png(paste0(fileName, ".png"), res = 600, units = "in", width = width, height = height)
  print(cowplot::plot_grid(p1, p2, align = "h"))
  dev.off()
  svglite(paste0(fileName, ".svg"), width = width, height = height)
  print(cowplot::plot_grid(p1, p2, align = "h"))
  dev.off()
  
  res <- 25*1000
  zmax <- 3
  start <- floor(center - windowSize)
  end <- floor(center + windowSize)
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, ":", start, "-", end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, ":", start, "-", end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0("visuzliation_regLoop_dTAG_", i, "_25kb"))
  png(paste0(fileName, ".png"), res = 600, units = "in", width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = "h"))
  dev.off()
  # svglite(paste0(fileName, ".svg"), width = 10, height = 5)
  # print(cowplot::plot_grid(p1, p2, align = "h"))
  # dev.off()
# }

############## Str
## Filtering loops to plot
data <- fread(here(consensusDir, "chromo_cons_score.tsv"))
temp <- data %>% dplyr::filter(id %in% strID, dTAG > 0.5) %>% dplyr::arrange(desc(dTAG))
temp <- temp %>% dplyr::select(seq(1, 6))
colnames(temp) <- c("V1", "V2", "V3", "V4", "V5", "V6")
loops <- importBedpe(temp)

# Visualization
hicDir <- "/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic"
windowSize <- 2*1e6

for(i in seq(1, 25)){
  ## Loading hic and plotting
  chr <- as_tibble(loops[i])$seqnames1
  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2
  start <- floor(center - 0.5*windowSize)
  end <- floor(center + 0.5*windowSize)
  
  cf.G1DMSO <- HicFile(path = here(hicDir, "G1.DMSO.Merged.hic"))
  cf.G1dTAG <- HicFile(path = here(hicDir, "G1.dTAG.Merged.hic"))

  res <- 10*1000
  zmax <- 2.5
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, ":", start, "-", end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, ":", start, "-", end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0("visuzliation_strLoop_dTAG_", i, "_10kb"))
  png(paste0(fileName, ".png"), res = 600, units = "in", width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = "h"))
  dev.off()
  
  
  res <- 25*1000
  zmax <- 3
  start <- floor(center - windowSize)
  end <- floor(center + windowSize)
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, ":", start, "-", end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, ":", start, "-", end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0("visuzliation_strLoop_dTAG_", i, "_25kb"))
  png(paste0(fileName, ".png"), res = 600, units = "in", width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = "h"))
  dev.off()
}

############## dTAG called loops
## Filtering loops to plot
data1 <- fread(here(loopDir, "G1.dTAG.Merged_chromosight_25kb.tsv"))
data2 <- fread(here(loopDir, "G1.dTAG.Merged_chromosight_10kb.tsv"))
data3 <- fread(here(loopDir, "G1.dTAG.Merged_chromosight_5kb.tsv"))
data <- bind_rows(data1, data2, data3)

temp <- data %>% dplyr::arrange(desc(score))

temp <- temp %>% dplyr::select(seq(1, 6))
colnames(temp) <- c("V1", "V2", "V3", "V4", "V5", "V6")
loops <- importBedpe(temp)

# Visualization
hicDir <- "/Volumes/UKJIN_SSD/Genomics_03_Analysis_Working/data_vault_2024summer_microC/hic"
windowSize <- 2*1e6

for(i in seq(1, 25)){
  ## Loading hic and plotting
  chr <- as_tibble(loops[i])$seqnames1
  center <- (as_tibble(loops[i])$start1 + as_tibble(loops[i])$end2)/2
  start <- floor(center - 0.5*windowSize)
  end <- floor(center + 0.5*windowSize)
  
  cf.G1DMSO <- HicFile(path = here(hicDir, "G1.DMSO.Merged.hic"))
  cf.G1dTAG <- HicFile(path = here(hicDir, "G1.dTAG.Merged.hic"))

  res <- 10*1000
  zmax <- 2.5
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, ":", start, "-", end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, ":", start, "-", end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0("visuzliation_dTAGcalledLoop_dTAG_", i, "_10kb"))
  png(paste0(fileName, ".png"), res = 600, units = "in", width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = "h"))
  dev.off()
  
  
  res <- 25*1000
  zmax <- 3
  start <- floor(center - windowSize)
  end <- floor(center + windowSize)
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, ":", start, "-", end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, ":", start, "-", end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax), loop = loops)
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax), loop = loops)
  
  fileName <- here(figDir, paste0("visuzliation_dTAGcalledLoop_dTAG_", i, "_25kb"))
  png(paste0(fileName, ".png"), res = 600, units = "in", width = 10, height = 5)
  print(cowplot::plot_grid(p1, p2, align = "h"))
  dev.off()
}

chr = "chr13"
start = 96900000
end = 98100000
  res <- 10*1000
  zmax <- 2.5
  hic1 <- import(cf.G1DMSO, focus = paste0(chr, ":", start, "-", end), resolution = res)
  hic2 <- import(cf.G1dTAG, focus = paste0(chr, ":", start, "-", end), resolution = res)
  p1 <- plotMatrix(hic1, dpi = 1000, limits = c(0, zmax))
  p2 <- plotMatrix(hic2, dpi = 1000, limits = c(0, zmax))
    print(cowplot::plot_grid(p1, p2, align = "h"))

```

## [2.32] Heatmap of loops
Strategy: check overlap of the union loops to the loops called at each condition
#### Check sample specific called loops
```{r}
library(circlize)

name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))
temp <- data %>% dplyr::select(seq(1, 6))
colnames(temp) <- c("V1", "V2", "V3", "V4", "V5", "V6")
cons.loop <- importBedpe(temp)

# Checking DMSO
loop.25kb <- importBedpe(fread(here(loopDir, paste0("G1.DMSO.Merged_chromosight_", 25, "kb.bedpe"))))
loop.10kb <- importBedpe(fread(here(loopDir, paste0("G1.DMSO.Merged_chromosight_", 10, "kb.bedpe"))))
loop.5kb <- importBedpe(fread(here(loopDir, paste0("G1.DMSO.Merged_chromosight_", 5, "kb.bedpe"))))


overlap.25kb <- findOverlaps(cons.loop, loop.25kb)
overlap.10kb <- findOverlaps(cons.loop, loop.10kb)
overlap.5kb <- findOverlaps(cons.loop, loop.5kb)

index <- sort(unique(c(queryHits(overlap.25kb),
         queryHits(overlap.10kb),
         queryHits(overlap.5kb))))
data$calledByDMSO <- 0
data$calledByDMSO[index] <- 1

# Checking dTAG
loop.25kb <- importBedpe(fread(here(loopDir, paste0("G1.dTAG.Merged_chromosight_", 25, "kb.bedpe"))))
loop.10kb <- importBedpe(fread(here(loopDir, paste0("G1.dTAG.Merged_chromosight_", 10, "kb.bedpe"))))
loop.5kb <- importBedpe(fread(here(loopDir, paste0("G1.dTAG.Merged_chromosight_", 5, "kb.bedpe"))))


overlap.25kb <- findOverlaps(cons.loop, loop.25kb)
overlap.10kb <- findOverlaps(cons.loop, loop.10kb)
overlap.5kb <- findOverlaps(cons.loop, loop.5kb)

index <- sort(unique(c(queryHits(overlap.25kb),
         queryHits(overlap.10kb),
         queryHits(overlap.5kb))))
data$calledBydTAG <- 0
data$calledBydTAG[index] <- 1

# Checking A485
loop.25kb <- importBedpe(fread(here(loopDir, paste0("G1.A485.Merged_chromosight_", 25, "kb.bedpe"))))
loop.10kb <- importBedpe(fread(here(loopDir, paste0("G1.A485.Merged_chromosight_", 10, "kb.bedpe"))))
loop.5kb <- importBedpe(fread(here(loopDir, paste0("G1.A485.Merged_chromosight_", 5, "kb.bedpe"))))


overlap.25kb <- findOverlaps(cons.loop, loop.25kb)
overlap.10kb <- findOverlaps(cons.loop, loop.10kb)
overlap.5kb <- findOverlaps(cons.loop, loop.5kb)

index <- sort(unique(c(queryHits(overlap.25kb),
         queryHits(overlap.10kb),
         queryHits(overlap.5kb))))
data$calledByA485 <- 0
data$calledByA485[index] <- 1


# Heatmap (checking whether certain peak is called by specific sample)
dataToPlot <- data %>% dplyr::select(id, calledByDMSO, calledBydTAG, calledByA485)
dataToPlot <- dataToPlot %>% dplyr::mutate(flag = 4*calledByDMSO + 2*calledBydTAG + calledByA485) %>%
  dplyr::arrange(desc(flag))

row_groups <- dataToPlot$flag
data_matrix <- dataToPlot %>% column_to_rownames(var = "id") %>% dplyr::select(-flag) %>% as.matrix()
col_fun <- colorRamp2(c(0, 1), 
                      c("white", "green"))
h1 <- Heatmap(data_matrix, name = "calledBy",
        cluster_columns = FALSE,
        cluster_rows = FALSE,
        show_row_dend = FALSE,
        border = TRUE,
        show_row_names = FALSE,
        col = col_fun,
        row_split = row_groups)


# Prepare data for the second heatmap
dataToPlot2 <- data %>% dplyr::select(id, DMSO, dTAG, A485) %>%
  arrange(match(id, dataToPlot$id))

data_matrix2 <- dataToPlot2 %>% column_to_rownames(var = "id") %>% as.matrix()


col_fun2 <- colorRamp2(c(-0.5, 0, 1), c("blue", "white", "red"))

h2 <- Heatmap(data_matrix2, name = "score",
              cluster_columns = FALSE,
              cluster_rows = TRUE,
              show_row_dend = FALSE,
              border = TRUE,
              show_row_names = FALSE,
              col = col_fun2,
              row_split = row_groups)


fileName <- here(figDir, paste0("heatmap_checkingSampleCalledLoops"))
png(paste0(fileName, ".png"), res = 600, units = "in", width = 3, height = 10)
print(h1 + h2)
dev.off()

```
#### Checking updown
##### All loops
```{r}
# Heatmap
library(circlize)

# Heatmap 2
set.seed(123)

diffCutoff <- 0.2
dataToPlot <- data %>% dplyr::mutate(isdiff_dTAG_DMSO = 
                                       case_when(diff_dTAG_DMSO >= diffCutoff ~ 1,
                                                 abs(diff_dTAG_DMSO) < diffCutoff ~ 0,
                                                 diff_dTAG_DMSO <= -diffCutoff ~ -1,
                                                 TRUE ~ NA),
                                     isdiff_A485_DMSO = 
                                       case_when(diff_A485_DMSO >= diffCutoff ~ 1,
                                                 abs(diff_A485_DMSO) < diffCutoff ~ 0,
                                                 diff_A485_DMSO <= -diffCutoff ~ -1,
                                                 TRUE ~ NA)) %>%
  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)
data_matrix <- dataToPlot %>% column_to_rownames(var = "id")%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c("blue", "grey", "red"))
h1 <- Heatmap(data_matrix, name = "loop score",
        cluster_columns = FALSE,
        cluster_rows = FALSE,
        row_km = 9,
        show_row_dend = FALSE,
        border = FALSE,
        show_row_names = FALSE,
        col = col_fun)

fileName <- here(figDir, paste0("heatmap_checkingDeltaAcrossCondition"))
png(paste0(fileName, ".png"), res = 600, units = "in", width = 2, height = 10)
print(h1)
dev.off()

set.seed(123)

hm_drawn <- draw(h1)
row_clusters <- row_order(hm_drawn)

loop.cluster1 <- temp[row_clusters[[1]]]
loop.cluster2 <- temp[row_clusters[[2]]]
loop.cluster3 <- temp[row_clusters[[3]]]
loop.cluster4 <- temp[row_clusters[[4]]]
loop.cluster5 <- temp[row_clusters[[5]]]
loop.cluster6 <- temp[row_clusters[[6]]]
loop.cluster7 <- temp[row_clusters[[7]]]
loop.cluster8 <- temp[row_clusters[[8]]]
loop.cluster9 <- temp[row_clusters[[9]]]

```

##### Reg loops
```{r}
# Heatmap
library(circlize)

# Heatmap 2
set.seed(123)

diffCutoff <- 0.2
dataToPlot <- data %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E")) %>%
  dplyr::mutate(isdiff_dTAG_DMSO = 
                  case_when(diff_dTAG_DMSO >= diffCutoff ~ 1,
                            abs(diff_dTAG_DMSO) < diffCutoff ~ 0,
                            diff_dTAG_DMSO <= -diffCutoff ~ -1,
                            TRUE ~ NA),
                isdiff_A485_DMSO = 
                  case_when(diff_A485_DMSO >= diffCutoff ~ 1,
                            abs(diff_A485_DMSO) < diffCutoff ~ 0,
                            diff_A485_DMSO <= -diffCutoff ~ -1,
                            TRUE ~ NA)) %>%
  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)
data_matrix <- dataToPlot %>% column_to_rownames(var = "id")%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c("blue", "grey", "red"))
h1 <- Heatmap(data_matrix, name = "loop score",
              cluster_columns = FALSE,
              cluster_rows = FALSE,
        row_km = 8,
        show_row_dend = FALSE,
        border = FALSE,
        show_row_names = FALSE,
        col = col_fun)

fileName <- here(figDir, paste0("heatmap_checkingDeltaAcrossCondition_reg"))
png(paste0(fileName, ".png"), res = 600, units = "in", width = 2, height = 10)
print(h1)
dev.off()

set.seed(123)

hm_drawn <- draw(h1)
row_clusters <- row_order(hm_drawn)

loop.cluster1 <- temp[row_clusters[[1]]]
loop.cluster2 <- temp[row_clusters[[2]]]
loop.cluster3 <- temp[row_clusters[[3]]]
loop.cluster4 <- temp[row_clusters[[4]]]
loop.cluster5 <- temp[row_clusters[[5]]]
loop.cluster6 <- temp[row_clusters[[6]]]
loop.cluster7 <- temp[row_clusters[[7]]]
loop.cluster8 <- temp[row_clusters[[8]]]

```

```{r}
library(circlize)

set.seed(123)
dataToPlot <- data %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E")) %>%
  dplyr::select(id, diff_dTAG_DMSO, diff_A485_DMSO)
data_matrix <- dataToPlot %>% column_to_rownames(var = "id")%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c("blue", "white", "red"))
h1 <- Heatmap(data_matrix, name = "loop score",
              cluster_columns = FALSE,
              cluster_rows = FALSE,
        row_km = 4,
        show_row_dend = FALSE,
        border = TRUE,
        show_row_names = FALSE,
        col = col_fun)


fileName <- here(figDir, paste0("heatmap_diffScore_reg_k4"))
png(paste0(fileName, ".png"), res = 600, units = "in", width = 2, height = 6)
print(h1)
dev.off()

hm_drawn <- draw(h1)
row_clusters <- row_order(hm_drawn)

loop.cluster1 <- temp[row_clusters[[1]]]
loop.cluster2 <- temp[row_clusters[[2]]]
loop.cluster3 <- temp[row_clusters[[3]]]
loop.cluster4 <- temp[row_clusters[[4]]]
```
##### All loops _OE
```{r}
# Heatmap
library(circlize)

name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))
# Heatmap 2
set.seed(123)

# Import obs/exp scores and merge to the dataset
minValue <- -4
diffCutoff <- 0.5
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))


# Merge dataset
dataToPlot <- data %>% dplyr::left_join(obsexp, by = c("id")) %>%
  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO,
                isdiff_dTAG_DMSO = case_when(log_obsexp_diff_dTAG_DMSO >= diffCutoff ~ 1,
                                             abs(log_obsexp_diff_dTAG_DMSO) < diffCutoff ~ 0,
                                             log_obsexp_diff_dTAG_DMSO <= diffCutoff ~ -1,
                                             TRUE ~ NA ),
                isdiff_A485_DMSO = case_when(log_obsexp_diff_A485_DMSO >= diffCutoff ~ 1,
                                             abs(log_obsexp_diff_A485_DMSO) < diffCutoff ~ 0,
                                             log_obsexp_diff_A485_DMSO <= diffCutoff ~ -1,
                                             TRUE ~ NA))%>%
  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)



data_matrix <- dataToPlot %>% column_to_rownames(var = "id")%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c("blue", "grey", "red"))
h1 <- Heatmap(data_matrix, name = "loop score",
        cluster_columns = FALSE,
        cluster_rows = FALSE,
        row_km = 9,
        show_row_dend = FALSE,
        border = FALSE,
        show_row_names = FALSE,
        col = col_fun)

fileName <- here(figDir, paste0("heatmap_checkingDeltaAcrossCondition_OE"))
png(paste0(fileName, ".png"), res = 600, units = "in", width = 2, height = 10)
print(h1)
dev.off()
# 
# set.seed(123)
# 
# hm_drawn <- draw(h1)
# row_clusters <- row_order(hm_drawn)
# 
# loop.cluster1 <- temp[row_clusters[[1]]]
# loop.cluster2 <- temp[row_clusters[[2]]]
# loop.cluster3 <- temp[row_clusters[[3]]]
# loop.cluster4 <- temp[row_clusters[[4]]]
# loop.cluster5 <- temp[row_clusters[[5]]]
# loop.cluster6 <- temp[row_clusters[[6]]]
# loop.cluster7 <- temp[row_clusters[[7]]]
# loop.cluster8 <- temp[row_clusters[[8]]]
# loop.cluster9 <- temp[row_clusters[[9]]]

```
##### Reg loops _OE
```{r}
# Heatmap
library(circlize)

name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))
# Heatmap 2
set.seed(123)

# Import obs/exp scores and merge to the dataset
minValue <- -4
diffCutoff <- 0.5
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))


# Merge dataset
dataToPlot <- data %>% dplyr::left_join(obsexp, by = c("id")) %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E")) %>%
  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO,
                isdiff_dTAG_DMSO = case_when(log_obsexp_diff_dTAG_DMSO >= diffCutoff ~ 1,
                                             abs(log_obsexp_diff_dTAG_DMSO) < diffCutoff ~ 0,
                                             log_obsexp_diff_dTAG_DMSO <= diffCutoff ~ -1,
                                             TRUE ~ NA ),
                isdiff_A485_DMSO = case_when(log_obsexp_diff_A485_DMSO >= diffCutoff ~ 1,
                                             abs(log_obsexp_diff_A485_DMSO) < diffCutoff ~ 0,
                                             log_obsexp_diff_A485_DMSO <= diffCutoff ~ -1,
                                             TRUE ~ NA))%>%
  dplyr::select(id, isdiff_dTAG_DMSO, isdiff_A485_DMSO)



data_matrix <- dataToPlot %>% column_to_rownames(var = "id")%>% as.matrix()
col_fun <- colorRamp2(c(-1, 0, 1), c("blue", "grey", "red"))
h1 <- Heatmap(data_matrix, name = "loop score",
        cluster_columns = FALSE,
        cluster_rows = FALSE,
        row_km = 9,
        show_row_dend = FALSE,
        border = FALSE,
        show_row_names = FALSE,
        col = col_fun)

fileName <- here(figDir, paste0("heatmap_checkingDeltaAcrossCondition_reg_OE"))
png(paste0(fileName, ".png"), res = 600, units = "in", width = 2, height = 10)
print(h1)
dev.off()
# 
# set.seed(123)
# 
# hm_drawn <- draw(h1)
# row_clusters <- row_order(hm_drawn)
# 
# loop.cluster1 <- temp[row_clusters[[1]]]
# loop.cluster2 <- temp[row_clusters[[2]]]
# loop.cluster3 <- temp[row_clusters[[3]]]
# loop.cluster4 <- temp[row_clusters[[4]]]
# loop.cluster5 <- temp[row_clusters[[5]]]
# loop.cluster6 <- temp[row_clusters[[6]]]
# loop.cluster7 <- temp[row_clusters[[7]]]
# loop.cluster8 <- temp[row_clusters[[8]]]
# loop.cluster9 <- temp[row_clusters[[9]]]

```
### [2.32] Comparing with Bobbie's data
Where does differentiated related genes fall into?
```{r}
marginError <- function(myList) {
  sample.n = length(myList)
  sample.sd = sd(myList)
  sample.se = sample.sd/sqrt(sample.n)
  alpha = 0.05
  degrees.freedom = sample.n - 1
  t.score = qt(p = alpha/2, df = degrees.freedom, lower.tail = F)
  margin.error = t.score*sample.se
  return(margin.error)
}

PROseq.bobbie <- as_tibble(fread(here(refDir, "bobbie_gene_classification.csv")))

geneList.Epi.dTAG.up <- (fread(here(refDir, "diff_G1.dTAG_G1.Epi.dTAG_vs_G1.Epi.DMSO.tsv")) %>% dplyr::filter(padj < 0.05, log2FoldChange > 0))$ensembl_gene_id

geneList.Epi.dTAG.down <- (fread(here(refDir, "diff_G1.dTAG_G1.Epi.dTAG_vs_G1.Epi.DMSO.tsv")) %>% dplyr::filter(padj < 0.05, log2FoldChange < 0))$ensembl_gene_id

## Converting transcript ID to gene ID
idPair_tg <- getBM(attributes = c("ensembl_transcript_id", "ensembl_gene_id"),
                 filters = "ensembl_transcript_id",
                 values = PROseq.bobbie$enst,
                 mart = ensembl.v102)
PROseq.bobbie <- PROseq.bobbie %>% dplyr::left_join(idPair_tg, by = c("enst" = "ensembl_transcript_id"))

## Bar Plot
temp <- PROseq.bobbie %>% dplyr::filter(ensembl_gene_id %in% geneList.Epi.dTAG.down)

group <- c(rep("EpiLC_dTAGvsDMSO_DOWN", 4))
cluster <- rep(c("Early", "Middle", "Late", "Transient"), 1)
cluster <- factor(cluster, levels = c("Early", "Middle", "Late", "Transient"))
value <- c(sum(temp$Cluster == "Early"),
           sum(temp$Cluster == "Middle"),
           sum(temp$Cluster == "Late"),
           sum(temp$Cluster == "Transient"))
data <- data.frame(group, cluster, value)
ggplot(data, aes(fill=cluster, y=value, x=group)) + 
    geom_bar(position="fill", stat="identity") + theme_classic()

## Line plot
temp <- temp %>% dplyr::select(c(4, 5, 6, 7, 8, 9))
temp.tall = temp %>% pivot_longer(-c(1, 2), names_to = "timepoints", values_to = "value")

gg1 = ggplot(temp.tall,
       aes( x = factor(timepoints, level = c("MIT", "EG1", "LG1", "ASYN")),
            y = value,
            group = enst, col = enst)) +
  geom_line() +
  theme_classic() +
  ggtitle("Bobbie, PRO-seq", subtitle = "selected genes") +
  xlab ("timepoints") + ylab("value") +
  theme(plot.title = element_text(hjust = 0.5),
        plot.subtitle = element_text(hjust = 0.5),
        legend.position = "none",
        axis.text.x = element_text(angle = 90, vjust = 0.5, hjust = 1))

ggsave(filename = here(figDir, "bobbie_gene_EpiLC_dTAGvsDMSO_DOWN.png"), gg1, width = 4, height = 4, dpi = 300, units = "in", device = "png")


# DRAW RIBBON


temp.ribbon = tibble("timepoints" = c("MIT", "EG1", "LG1", "ASYN"),
                      "value" = c(mean(temp$MIT), mean(temp$EG1), mean(temp$LG1), mean(temp$ASYN)),
                      "lower" = c(mean(temp$MIT) - marginError(temp$MIT), 
                                  mean(temp$EG1) - marginError(temp$EG1), 
                                  mean(temp$LG1) - marginError(temp$LG1), 
                                  mean(temp$ASYN) - marginError(temp$ASYN)),
                      "upper" = c(mean(temp$MIT) + marginError(temp$MIT), 
                                  mean(temp$EG1) + marginError(temp$EG1), 
                                  mean(temp$LG1) + marginError(temp$LG1), 
                                  mean(temp$ASYN) + marginError(temp$ASYN)))
gg1 = ggplot(temp.ribbon, aes(x = factor(timepoints, level = c("MIT", "EG1", "LG1", "ASYN")), 
                        y = value, group = 1)) +
  geom_line(color = "black") +
  geom_ribbon(aes(ymin = lower, ymax = upper), fill = "grey70", alpha = 0.3) +
  theme_classic() +
  ggtitle("Bobbie, PRO-seq", subtitle = "selected genes") +
  xlab ("timepoints") + ylab("value") + ylim(0, 65) +
  theme(plot.title = element_text(hjust = 0.5),
        plot.subtitle = element_text(hjust = 0.5),
        legend.position = "none",
        axis.text.x = element_text(angle = 90, vjust = 0.5, hjust = 1))

ggsave(filename = here(figDir, "bobbie_gene_EpiLC_dTAGvsDMSO_DOWN_95CI.png"), gg1, width = 4, height = 4, dpi = 300, units = "in", device = "png")


```

###[2.33] Finding closest enhancer
Here, enhancer will be defined by H3K27ac peak
It makes more sence to include the enhancer peak on gene body
(strategy 1) exclude +-10kb region from TSS only
(strategy 2) only check the E-P loops called in Micro-C
##### binary group - excluding all gene body
```{r}
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS)

group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene


gene.tb <- gene.tb %>% dplyr::filter(ensembl %in% c(group1, group2))
genes.gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),
  ensembl = gene.tb$ensembl
)

genebody.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>% dplyr::select(V1, V2, V3)
colnames(genebody.tb) <- c("chr", "start", "end")
genebody.gr <- makeGRangesFromDataFrame(genebody.tb)


peak.H3K27ac <- importPeak(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed"))
peak.H3K27ac<- makeGRangesFromDataFrame(fread(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed")) %>% 
                                          dplyr::mutate(chr = V1, start = (V2 + V3)/2, end = (V2 + V3)/2) %>%
                                          dplyr::select(chr, start, end))

####### Filtering out peaks overlapping with the gene body
overlaps <- findOverlaps(genebody.gr, peak.H3K27ac)

# Indices of peaks that overlap the TSS
overlapping_peak_indices <- unique(subjectHits(overlaps))

# Exclude overlapping peaks
non_overlapping_peaks <- peak.H3K27ac[-overlapping_peak_indices]


####### Calculating distance to nearest peak
nearest_peak_indices <- nearest(genes.gr, non_overlapping_peaks)
nearest_peaks <- non_overlapping_peaks[nearest_peak_indices]
distances <- distance(genes.gr, nearest_peaks)


results <- data.frame(
  ensembl = mcols(genes.gr)$ensembl,
  gene_chr = as.character(seqnames(genes.gr)),
  gene_TSS = start(genes.gr),
  peak_chr = as.character(seqnames(nearest_peaks)),
  peak_start = start(nearest_peaks),
  peak_end = end(nearest_peaks),
  distance = distances
)

results <- results %>% dplyr::mutate(group = case_when(ensembl %in% group1 ~ "group1",
                                            ensembl %in% group2 ~ "group2",
                                            TRUE ~ NA))

ggplot(results, aes(x = group, y = distance, fill = group)) + geom_violin() + geom_boxplot(outlier.shape = NA, width = 0.1, fill = "white") + theme_bw() + ggtitle("distance to nearest H3K27ac peak excluding gene body") + scale_y_continuous(labels = label_kb_mb) + coord_cartesian(ylim = c(0, 250*1000))

  
```
##### binary group - excluding specific gene body
```{r}
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene


gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS) %>% dplyr::filter(ensembl %in% c(group1, group2))
genes.gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),
  ensembl = gene.tb$ensembl
)

genebody.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>% dplyr::filter(V6 %in% c(group1, group2))%>% dplyr::select(V1, V2, V3)
colnames(genebody.tb) <- c("chr", "start", "end")
genebody.gr <- makeGRangesFromDataFrame(genebody.tb)


# Step 1: Find overlaps between gene bodies and peaks
overlaps <- findOverlaps(genebody.gr, peak.H3K27ac)

# Create a list mapping each gene to the indices of peaks overlapping with its gene body
overlapping_peaks_per_gene <- split(subjectHits(overlaps), queryHits(overlaps))

# Initialize an empty list to store results
results_list <- vector("list", length(genes.gr))

# Step 2: For each gene, exclude overlapping peaks and find the nearest peak to its TSS
for (i in seq_along(genes.gr)) {
  gene <- genes.gr[i]
  
  # Get indices of peaks overlapping with this gene's body
  overlapping_peak_indices <- overlapping_peaks_per_gene[[as.character(i)]]
  
  # Exclude overlapping peaks for this gene
  if (!is.null(overlapping_peak_indices)) {
    peaks_to_consider <- peak.H3K27ac[-overlapping_peak_indices]
  } else {
    peaks_to_consider <- peak.H3K27ac
  }
  
  # Find the nearest peak to the TSS of this gene
  nearest_peak_index <- nearest(gene, peaks_to_consider)
  
  if (is.na(nearest_peak_index)) {
    # No peaks found; set NA values
    results_list[[i]] <- data.frame(
      ensembl = mcols(gene)$ensembl,
      gene_chr = as.character(seqnames(gene)),
      gene_TSS = start(gene),
      peak_chr = NA,
      peak_start = NA,
      peak_end = NA,
      distance = NA
    )
  } else {
    nearest_peak <- peaks_to_consider[nearest_peak_index]
    dist <- distance(gene, nearest_peak)
    
    results_list[[i]] <- data.frame(
      ensembl = mcols(gene)$ensembl,
      gene_chr = as.character(seqnames(gene)),
      gene_TSS = start(gene),
      peak_chr = as.character(seqnames(nearest_peak)),
      peak_start = start(nearest_peak),
      peak_end = end(nearest_peak),
      distance = dist
    )
  }
}

# Combine results into a single data frame
results <- do.call(rbind, results_list)

# Add group information
results <- results %>% dplyr::mutate(group = case_when(
  ensembl %in% group1 ~ "group1",
  ensembl %in% group2 ~ "group2",
  TRUE ~ NA_character_
))

# Plotting
ggplot(results, aes(x = group, y = distance, fill = group)) +
  geom_violin() +
  geom_boxplot(outlier.shape = NA, width = 0.1, fill = "white") +
  theme_bw() +
  ggtitle("Distance to Nearest H3K27ac Peak Excluding Gene Body Overlaps") +
  scale_y_continuous(labels = label_kb_mb) +
  coord_cartesian(ylim = c(0, 50 * 1000))
```

##### binary group - excluding all TSS +- 10kb
```{r}
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS)

group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene


gene.tb <- gene.tb %>% dplyr::filter(ensembl %in% c(group1, group2))
genes.gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),
  ensembl = gene.tb$ensembl
)

genebody.tb <- gene.tb %>% dplyr::mutate(start = TSS-10*1000, end = TSS + 10*1000) %>%
  dplyr::select(chr, start, end)

genebody.gr <- makeGRangesFromDataFrame(genebody.tb)


peak.H3K27ac <- importPeak(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed"))
# peak.H3K27ac<- makeGRangesFromDataFrame(fread(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed")) %>% 
#                                           dplyr::mutate(chr = V1, start = (V2 + V3)/2, end = (V2 + V3)/2) %>%
#                                           dplyr::select(chr, start, end))

####### Filtering out peaks overlapping with the gene body
overlaps <- findOverlaps(genebody.gr, peak.H3K27ac)

# Indices of peaks that overlap the TSS
overlapping_peak_indices <- unique(subjectHits(overlaps))

# Exclude overlapping peaks
non_overlapping_peaks <- peak.H3K27ac[-overlapping_peak_indices]


####### Calculating distance to nearest peak
nearest_peak_indices <- nearest(genes.gr, non_overlapping_peaks)
nearest_peaks <- non_overlapping_peaks[nearest_peak_indices]
distances <- distance(genes.gr, nearest_peaks)


results <- data.frame(
  ensembl = mcols(genes.gr)$ensembl,
  gene_chr = as.character(seqnames(genes.gr)),
  gene_TSS = start(genes.gr),
  peak_chr = as.character(seqnames(nearest_peaks)),
  peak_start = start(nearest_peaks),
  peak_end = end(nearest_peaks),
  distance = distances
)

results <- results %>% dplyr::mutate(group = case_when(ensembl %in% group1 ~ "group1",
                                            ensembl %in% group2 ~ "group2",
                                            TRUE ~ NA))

ggplot(results, aes(x = group, y = distance, fill = group)) + geom_violin() + geom_boxplot(outlier.shape = NA, width = 0.1, fill = "white") + theme_bw() + ggtitle("distance to nearest H3K27ac peak excluding gene body") + scale_y_continuous(labels = label_kb_mb) + coord_cartesian(ylim = c(0, 250*1000))

  
```

##### binary group - excluding specific TSS +- 10 kb
```{r}
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene


gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS) %>% dplyr::filter(ensembl %in% c(group1, group2))
genes.gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$TSS, end = gene.tb$TSS),
  ensembl = gene.tb$ensembl
)

genebody.tb <- gene.tb %>% dplyr::mutate(start = TSS-10*1000, end = TSS + 10*1000) %>%
  dplyr::select(chr, start, end)
genebody.gr <- makeGRangesFromDataFrame(genebody.tb)

peak.H3K27ac <- importPeak(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed"))


# Step 1: Find overlaps between gene bodies and peaks
overlaps <- findOverlaps(genebody.gr, peak.H3K27ac)

# Create a list mapping each gene to the indices of peaks overlapping with its gene body
overlapping_peaks_per_gene <- split(subjectHits(overlaps), queryHits(overlaps))

# Initialize an empty list to store results
results_list <- vector("list", length(genes.gr))

# Step 2: For each gene, exclude overlapping peaks and find the nearest peak to its TSS
for (i in seq_along(genes.gr)) {
  gene <- genes.gr[i]
  
  # Get indices of peaks overlapping with this gene's body
  overlapping_peak_indices <- overlapping_peaks_per_gene[[as.character(i)]]
  
  # Exclude overlapping peaks for this gene
  if (!is.null(overlapping_peak_indices)) {
    peaks_to_consider <- peak.H3K27ac[-overlapping_peak_indices]
  } else {
    peaks_to_consider <- peak.H3K27ac
  }
  
  # Find the nearest peak to the TSS of this gene
  nearest_peak_index <- nearest(gene, peaks_to_consider)
  
  if (is.na(nearest_peak_index)) {
    # No peaks found; set NA values
    results_list[[i]] <- data.frame(
      ensembl = mcols(gene)$ensembl,
      gene_chr = as.character(seqnames(gene)),
      gene_TSS = start(gene),
      peak_chr = NA,
      peak_start = NA,
      peak_end = NA,
      distance = NA
    )
  } else {
    nearest_peak <- peaks_to_consider[nearest_peak_index]
    dist <- distance(gene, nearest_peak)
    
    results_list[[i]] <- data.frame(
      ensembl = mcols(gene)$ensembl,
      gene_chr = as.character(seqnames(gene)),
      gene_TSS = start(gene),
      peak_chr = as.character(seqnames(nearest_peak)),
      peak_start = start(nearest_peak),
      peak_end = end(nearest_peak),
      distance = dist
    )
  }
}

# Combine results into a single data frame
results <- do.call(rbind, results_list)

# Add group information
results <- results %>% dplyr::mutate(group = case_when(
  ensembl %in% group1 ~ "group1",
  ensembl %in% group2 ~ "group2",
  TRUE ~ NA_character_
))

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group == group1) )$distance
  distance2 <- (data %>% dplyr::filter(group == group2) )$distance
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

getPvalWilcox(results, "group1", "group2")
# Plotting
ggplot(results, aes(x = group, y = distance, fill = group)) +
  geom_violin() +
  geom_boxplot(outlier.shape = NA, width = 0.1, fill = "white") +
  theme_bw() +
  ggtitle("Distance to Nearest H3K27ac Peak Excluding Gene Body Overlaps") +
  scale_y_continuous(labels = label_kb_mb) +
  coord_cartesian(ylim = c(0, 50 * 1000)) +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") 
```

##### Only limiting to E-P loops from Micro-C
```{r}

group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene



name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-pe_ensemblList.tsv")),
                                 diffCutoff = 0.2) %>%
  dplyr::filter(Anno2 == "P-E")

temp <- geneAnnoData %>% unnest(gene)

gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3), ensembl = V6, chr = V1) %>%
  dplyr::select(ensembl, chr, TSS)

temp <- dplyr::left_join(temp, gene.tb, by = c("gene" = "ensembl"))

temp <- temp %>% dplyr::mutate(center1 = (start1 + end1)/2,
                               center2 = (start2 + end2)/2,
                               distance1 = abs(TSS-center1),
                               distance2 = abs(TSS-center2)) %>%
  dplyr::mutate(distance = pmax(distance1, distance2))

temp <- temp %>% group_by(gene) %>% summarize(min_enh_distance = min(distance)) %>%
  dplyr::mutate(group = case_when(gene %in% group1 ~ "group1",
                                  gene %in% group2 ~ "group2",
                                  TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(temp, aes(x = group, y = min_enh_distance, fill = group)) + 
  geom_violin() +
  geom_boxplot(outlier.shape = NA, width = 0.1, fill = "white") +
  theme_bw() +
  ggtitle("Distance to Nearest Enhancer fro E-P") +
  scale_y_continuous(labels = label_kb_mb)  +
  coord_cartesian(ylim = c(0, 1000 * 1000))

```



### [2.24] (WORKING ON)Checking the percentage of non-important loops
Idea: having one non-perturbed reg loops could be enough.
```{r}
name <- "chromo_cons_annoHierarchy"
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                 diffCutoff = 0.2)


loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe")) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = "_"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe")) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = "_"))
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe")) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = "_"))

geneAnnoData <- geneAnnoData %>% dplyr::filter(id %in% c(loop.up$id, loop.no$id, loop.down$id)) %>%
  dplyr::mutate(loopType = case_when(id %in% c(loop.up$id, loop.no$id) ~ "insensitive",
                                     id %in% c(loop.down$id) ~ "sensitive",
                                     TRUE ~ NA))

data <- geneAnnoData %>% dplyr::select(gene, id, loopType) %>% unnest(gene) %>%
  group_by(gene) %>% summarize(
    insensitive = sum(loopType == "insensitive", na.rm = TRUE),
    sensitive = sum(loopType == "sensitive", na.rm = TRUE))



###

group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

geneGroup <- tibble(group = c(rep("group1", length(group1)), rep("group2", length(group2))),
                    gene = c(group1, group2))

data <- left_join(geneGroup, data, by = c("gene")) %>% dplyr::mutate(mutate(across(everything(), ~replace_na(., 0))))


###
data <- data %>% dplyr::mutate(presenceOfRetained = if_else(insensitive > 0, "YES", "NO"),
                       percOfRetained = if_else(insensitive + sensitive == 0, 0, 100*insensitive/(insensitive + sensitive)))


###
ggplot(data, aes(x = group, y = percOfRetained, fill = group)) + geom_violin() + 
  geom_boxplot(outlier.shape = NA, width = 0.1, fill = "white") + theme_bw()


### Stacked barplot
group <- c("group1", "group1", "group2", "group2")
presenceOfRetained <- rep(c("YES", "NO"), 2)
presenceOfRetained <- factor (presenceOfRetained, levels = c("YES", "NO"))
value <- c(nrow(data %>% dplyr::filter(group == "group1", presenceOfRetained == "YES")),
           nrow(data %>% dplyr::filter(group == "group1", presenceOfRetained == "NO")),
           nrow(data %>% dplyr::filter(group == "group2", presenceOfRetained == "YES")),
           nrow(data %>% dplyr::filter(group == "group2", presenceOfRetained == "NO")))
plotData <- data.frame(group, presenceOfRetained, value)

ggplot(plotData, aes(fill=presenceOfRetained, y=value, x=group)) + 
    geom_bar(position="fill", stat="identity") + theme_classic()


```

```{r}
name <- "chromo_cons_annoHierarchy"
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-pe_ensemblList.tsv")),
                                 diffCutoff = 0.2)


loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe")) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = "_"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe")) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = "_"))
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe")) %>%
  dplyr::mutate(size = V3 - V2,
                id = paste(V1, size, V2, V5, sep = "_"))

geneAnnoData <- geneAnnoData %>% dplyr::filter(id %in% c(loop.up$id, loop.no$id, loop.down$id)) %>%
  dplyr::mutate(loopType = case_when(id %in% c(loop.up$id, loop.no$id) ~ "insensitive",
                                     id %in% c(loop.down$id) ~ "sensitive",
                                     TRUE ~ NA))

data <- geneAnnoData %>% dplyr::select(gene, id, loopType) %>% unnest(gene) %>%
  group_by(gene) %>% summarize(
    insensitive = sum(loopType == "insensitive", na.rm = TRUE),
    sensitive = sum(loopType == "sensitive", na.rm = TRUE))



###

group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

geneGroup <- tibble(group = c(rep("group1", length(group1)), rep("group2", length(group2))),
                    gene = c(group1, group2))

data <- left_join(geneGroup, data, by = c("gene")) %>% dplyr::mutate(mutate(across(everything(), ~replace_na(., 0))))


###
data <- data %>% dplyr::mutate(presenceOfRetained = if_else(insensitive > 0, "YES", "NO"),
                       percOfRetained = if_else(insensitive + sensitive == 0, 0, 100*insensitive/(insensitive + sensitive)))


###
ggplot(data, aes(x = group, y = percOfRetained, fill = group)) + geom_violin() + 
  geom_boxplot(outlier.shape = NA, width = 0.05, fill = "white") + theme_bw()


### Stacked barplot
group <- c("group1", "group1", "group2", "group2")
presenceOfRetained <- rep(c("YES", "NO"), 2)
presenceOfRetained <- factor (presenceOfRetained, levels = c("YES", "NO"))
value <- c(nrow(data %>% dplyr::filter(group == "group1", presenceOfRetained == "YES")),
           nrow(data %>% dplyr::filter(group == "group1", presenceOfRetained == "NO")),
           nrow(data %>% dplyr::filter(group == "group2", presenceOfRetained == "YES")),
           nrow(data %>% dplyr::filter(group == "group2", presenceOfRetained == "NO")))
plotData <- data.frame(group, presenceOfRetained, value)

ggplot(plotData, aes(fill=presenceOfRetained, y=value, x=group)) + 
    geom_bar(position="fill", stat="identity") + theme_classic()


```

### [2.25] Obs/Exp loops


#### Merging obs/exp scores from different resolution & samples
##### G1
```{r}
loops <- fread(here(consensusDir, "chromo_cons_score.tsv"))

sample <- "G1.DMSO.Merged"
for(sample in c("G1.DMSO.Merged", "G1.dTAG.Merged", "G1.A485.Merged")){
  temp.25kb <- fread(here(consensusDir, paste0("loopScore_", sample, "_25kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, "O/E")
  colnames(temp.25kb) <- c("chrom1", "start1", "end1", "chrom2", "start2", "end2", "id", "obs", "obsexp")
  
  temp.10kb <- fread(here(consensusDir, paste0("loopScore_", sample, "_10kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, "O/E")
  colnames(temp.10kb) <- c("chrom1", "start1", "end1", "chrom2", "start2", "end2", "id", "obs", "obsexp")
  
  temp.5kb <-fread(here(consensusDir, paste0("loopScore_", sample, "_5kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, "O/E")
  colnames(temp.5kb) <- c("chrom1", "start1", "end1", "chrom2", "start2", "end2", "id", "obs", "obsexp")
  
  temp <- bind_rows(temp.25kb, temp.10kb, temp.5kb)
  fwrite(temp, here(consensusDir, paste0("loopScore_", sample, ".tsv")), sep = "\t")
}


temp.DMSO <- fread(here(consensusDir, "loopScore_G1.DMSO.Merged.tsv")) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.DMSO) <- c("id", "obs_DMSO", "obsexp_DMSO")
temp.dTAG <- fread(here(consensusDir, "loopScore_G1.dTAG.Merged.tsv")) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.dTAG) <- c("id", "obs_dTAG", "obsexp_dTAG")
temp.A485 <- fread(here(consensusDir, "loopScore_G1.A485.Merged.tsv")) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.A485) <- c("id", "obs_A485", "obsexp_A485")

loops_oe <- full_join(full_join(temp.DMSO, temp.dTAG, by = "id"),
          temp.A485, by = "id") %>%
  dplyr::mutate(oeFC_dTAG_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_dTAG/obsexp_DMSO),
                oeFC_A485_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_A485/obsexp_DMSO))

fwrite(loops_oe, here(consensusDir, paste0("loopScore_cons_obsexp.tsv")), sep = "\t")
```

##### Async
```{r}
loops <- fread(here(consensusDir, "chromo_cons_score.tsv"))

for(sample in c("Async.UT", "Async.AID")){
  temp.25kb <- fread(here(consensusDir, paste0("loopScore_", sample, "_25kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, "O/E")
  colnames(temp.25kb) <- c("chrom1", "start1", "end1", "chrom2", "start2", "end2", "id", "obs", "obsexp")
  
  temp.10kb <- fread(here(consensusDir, paste0("loopScore_", sample, "_10kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, "O/E")
  colnames(temp.10kb) <- c("chrom1", "start1", "end1", "chrom2", "start2", "end2", "id", "obs", "obsexp")
  
  temp.5kb <-fread(here(consensusDir, paste0("loopScore_", sample, "_5kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(chrom1, start1, end1, chrom2, start2, end2, id, observed, "O/E")
  colnames(temp.5kb) <- c("chrom1", "start1", "end1", "chrom2", "start2", "end2", "id", "obs", "obsexp")
  
  temp <- bind_rows(temp.25kb, temp.10kb, temp.5kb)
  fwrite(temp, here(consensusDir, paste0("loopScore_", sample, ".tsv")), sep = "\t")
}


temp.UT <- fread(here(consensusDir, "loopScore_Async.UT.tsv")) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.UT) <- c("id", "obs_UT", "obsexp_UT")
temp.AID <- fread(here(consensusDir, "loopScore_Async.AID.tsv")) %>%
  dplyr::select(id, obs, obsexp)
colnames(temp.AID) <- c("id", "obs_AID", "obsexp_AID")

loops_oe <- full_join(temp.UT, temp.AID, by = "id") %>%
  dplyr::mutate(oeFC_AID_UT = if_else(obsexp_UT == 0, NA, obsexp_AID/obsexp_UT))

fwrite(loops_oe, here(consensusDir, paste0("loopScore_cons_obsexp_Async.tsv")), sep = "\t")
```

#### Merging obs/exp per resolution
Only the loops that made to consensus loops are considered
##### G1
```{r}
loops <- fread(here(consensusDir, "chromo_cons_score.tsv"))

res <- 25

for (res in c(25, 10, 5)){
  
  temp.DMSO <- fread(here(consensusDir, paste0("loopScore_G1.DMSO.Merged_", res, "kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, "O/E")
  colnames(temp.DMSO) <- c("id", "obs_DMSO", "obsexp_DMSO")
  
  temp.dTAG <- fread(here(consensusDir, paste0("loopScore_G1.dTAG.Merged_", res, "kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, "O/E")
  colnames(temp.dTAG) <- c("id", "obs_dTAG", "obsexp_dTAG")
  
  temp.A485 <- fread(here(consensusDir, paste0("loopScore_G1.A485.Merged_", res, "kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, "O/E")
  colnames(temp.A485) <- c("id", "obs_A485", "obsexp_A485")
  
  temp <- full_join(full_join(temp.DMSO, temp.dTAG, by = c("id")), temp.A485, by = c("id")) %>% 
    dplyr::mutate(oeFC_dTAG_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_dTAG/obsexp_DMSO),
                  oeFC_A485_DMSO = if_else(obsexp_DMSO == 0, NA, obsexp_A485/obsexp_DMSO))
  
  fwrite(temp, here(consensusDir, paste0("loopScore_cons_obsexp_", res, "kb.tsv")), sep = "\t")
}


```

##### Async
```{r}
loops <- fread(here(consensusDir, "chromo_cons_score.tsv"))

res <- 25

for (res in c(25, 10, 5)){
  
  temp.UT <- fread(here(consensusDir, paste0("loopScore_Async.UT_", res, "kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, "O/E")
  colnames(temp.UT) <- c("id", "obs_UT", "obsexp_UT")
  
  temp.AID <- fread(here(consensusDir, paste0("loopScore_Async.AID_", res, "kb.tsv"))) %>%
    dplyr::mutate(binSize = end1 - start1,
                  id = paste(chrom1, binSize, start1, start2, sep = "_")) %>%
    dplyr::filter(id %in% loops$id) %>%
    dplyr::select(id, observed, "O/E")
  colnames(temp.AID) <- c("id", "obs_AID", "obsexp_AID")

  
  temp <- full_join(temp.UT, temp.AID, by = c("id")) %>% 
    dplyr::mutate(oeFC_AID_UT = if_else(obsexp_UT == 0, NA, obsexp_AID/obsexp_UT))
  
  fwrite(temp, here(consensusDir, paste0("loopScore_cons_obsexp_", res, "kb_async.tsv")), sep = "\t")
}


```

#### Comparing obs/exp from chrommosight loop scores
##### dTAG per res
```{r}
# Importing loops
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))

for(res in c(25, 10, 5)){
  minValue <- -4
  maxValue <- 5
  obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp_", res, "kb.tsv"))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))
  
  
  # dTAG
  obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_dTAG, n = 100)
  obsexp <- obsexp %>% dplyr::arrange(density)
  g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
    geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
    geom_abline(slope = 1, intercept = 0) +
    ggtitle(paste0(res, "kb, log2(obs/exp)")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 
  
  
  # Visualize UP DOWN loops
  temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
  temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
  temp <- temp %>% dplyr::arrange(density)
  g2 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
    geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
    geom_abline(slope = 1, intercept = 0) +
    ggtitle(paste0(res, "kb, log2(obs/exp), down")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue))
  
  
  temp <- obsexp %>% dplyr::filter(id %in% loop.no$id)
  temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
  temp <- temp %>% dplyr::arrange(density)
  g3 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
    geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
    geom_abline(slope = 1, intercept = 0) +
    ggtitle(paste0(res, "kb, log2(obs/exp), no")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue))
  
  temp <- obsexp %>% dplyr::filter(id %in% loop.up$id)
  temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
  temp <- temp %>% dplyr::arrange(density)
  g4 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
    geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
    geom_abline(slope = 1, intercept = 0) +
    ggtitle(paste0(res, "kb, log2(obs/exp), up")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue))
  
  
  fileName <- paste0("obsexp_dTAG_vs_DMSO_", res, "kb")
  height <- 4
  width <- 12
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(plot_grid(g1, g4, g3, g2, ncol = 4))
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(plot_grid(g1, g4, g3, g2, ncol = 4))
  dev.off()
}

```

##### dTAG all res
```{r}
# Importing loops
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))

minValue <- -4
maxValue <- 5

obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))



# dTAG
obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_dTAG, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp)")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), down")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


temp <- obsexp %>% dplyr::filter(id %in% loop.no$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g3 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), no")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

temp <- obsexp %>% dplyr::filter(id %in% loop.up$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g4 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), up")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


fileName <- paste0("obsexp_dTAG_vs_DMSO")
height <- 4
width <- 12
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()


# Structural
loop.str <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.str$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g5 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), structural loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Reg (PE-PE)
loop.reg <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.reg$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g6 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), regulatory loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

fileName <- paste0("obsexp_dTAG_vs_DMSO_str_vs_reg")
height <- 4
width <- 6
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
```
###### Plotting only subset
```{r}

specificLoop.25kb <- fread(here(loopDir, "G1.DMSO.Merged_chromosight_25kb.bedpe")) %>%
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
specificLoop.10kb <- fread(here(loopDir, "G1.DMSO.Merged_chromosight_10kb.bedpe")) %>%
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
specificLoop.5kb <- fread(here(loopDir, "G1.DMSO.Merged_chromosight_5kb.bedpe")) %>%
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))

specificLoops.DMSO <- c(specificLoop.25kb$id, specificLoop.10kb$id, specificLoop.5kb$id)


minValue <- -4
maxValue <- 5

obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))




# Structural
loop.str <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.str$id,
                                 id %in% specificLoops.DMSO)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g5 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), structural loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Reg (PE-PE)
loop.reg <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.reg$id,
                                 id %in% specificLoops.DMSO)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g6 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), regulatory loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

fileName <- paste0("obsexp_dTAG_vs_DMSO_str_vs_reg_DMSOspecificLoops")
height <- 4
width <- 6
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()

```
###### Plotting 1mb
```{r}
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))

# Import obs/exp scores and merge to the dataset
minValue <- -4
maxValue <- 5
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c("id")) %>% dplyr::mutate(distance = start2 - start1)


# Importing loops
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))

# distance filter
obsexp <- data %>% dplyr::filter(distance > 1e6)


# dTAG
obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_dTAG, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp)")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), down")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


temp <- obsexp %>% dplyr::filter(id %in% loop.no$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g3 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), no")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

temp <- obsexp %>% dplyr::filter(id %in% loop.up$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g4 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), up")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


fileName <- paste0("obsexp_dTAG_vs_DMSO_1mbover")
height <- 4
width <- 12
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()


# Structural
loop.str <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.str$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g5 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), structural loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Reg (PE-PE)
loop.reg <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.reg$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g6 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), regulatory loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

fileName <- paste0("obsexp_dTAG_vs_DMSO_1mbover_str_vs_reg")
height <- 4
width <- 6
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
```

###### Plotting Obs
```{r}
minValue <- -4
maxValue <- 10
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                  log_obs_DMSO = if_else(obs_DMSO == 0, minValue, log2(obs_DMSO)),
                  log_obs_dTAG = if_else(obs_dTAG == 0, minValue, log2(obs_dTAG)),
                  log_obs_A485 = if_else(obs_A485 == 0, minValue, log2(obs_A485)))

# Importing loops
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))



# dTAG
obsexp$density <- get_density(obsexp$log_obs_DMSO, obsexp$log_obs_dTAG, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obs_DMSO, y = log_obs_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs)")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), down")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


temp <- obsexp %>% dplyr::filter(id %in% loop.no$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g3 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), no")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

temp <- obsexp %>% dplyr::filter(id %in% loop.up$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g4 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), up")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


fileName <- paste0("obsexp_dTAG_vs_DMSO_obs")
height <- 4
width <- 12
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()


# Structural
loop.str <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.str$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g5 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), structural loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Reg (PE-PE)
loop.reg <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.reg$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_dTAG, n = 100)
temp <- temp %>% dplyr::arrange(density)
g6 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_dTAG, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), regulatory loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

fileName <- paste0("obsexp_dTAG_vs_DMSO_obs_str_vs_reg")
height <- 4
width <- 6
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
```

##### Async.AID all res
```{r}
# Importing loops
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))

minValue <- -8
maxValue <- 7

obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp_Async.tsv"))) %>%
  dplyr::mutate(log_obsexp_UT = if_else(obsexp_UT == 0, minValue, log2(obsexp_UT)),
                log_obsexp_AID = if_else(obsexp_AID == 0, minValue, log2(obsexp_AID)))



# dTAG
obsexp$density <- get_density(obsexp$log_obsexp_UT, obsexp$log_obsexp_AID, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obsexp_UT, y = log_obsexp_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp)")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obsexp_UT, temp$log_obsexp_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obsexp_UT, y = log_obsexp_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), down")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


temp <- obsexp %>% dplyr::filter(id %in% loop.no$id)
temp$density <- get_density(temp$log_obsexp_UT, temp$log_obsexp_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g3 <- ggplot(temp, aes(x = log_obsexp_UT, y = log_obsexp_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), no")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

temp <- obsexp %>% dplyr::filter(id %in% loop.up$id)
temp$density <- get_density(temp$log_obsexp_UT, temp$log_obsexp_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g4 <- ggplot(temp, aes(x = log_obsexp_UT, y = log_obsexp_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), up")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


fileName <- paste0("obsexp_AID_vs_UT")
height <- 4
width <- 12
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()


# Structural
loop.str <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.str$id)
temp$density <- get_density(temp$log_obsexp_UT, temp$log_obsexp_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g5 <- ggplot(temp, aes(x = log_obsexp_UT, y = log_obsexp_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), structural loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Reg (PE-PE)
loop.reg <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.reg$id)
temp$density <- get_density(temp$log_obsexp_UT, temp$log_obsexp_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g6 <- ggplot(temp, aes(x = log_obsexp_UT, y = log_obsexp_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), regulatory loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

fileName <- paste0("obsexp_AID_vs_UT_str_vs_reg")
height <- 4
width <- 6
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
```

###### Plotting Obs
```{r}

minValue <- -20
maxValue <- 10

obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp_Async.tsv"))) %>%
  dplyr::mutate(log_obsexp_UT = if_else(obsexp_UT == 0, minValue, log2(obsexp_UT)),
                log_obsexp_AID = if_else(obsexp_AID == 0, minValue, log2(obsexp_AID)),
                log_obs_UT = if_else(obs_UT == 0, minValue, log2(obs_UT)),
                log_obs_AID = if_else(obs_AID == 0, minValue, log2(obs_AID)))

# Importing loops
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))



# dTAG
obsexp$density <- get_density(obsexp$log_obs_UT, obsexp$log_obs_AID, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obs_UT, y = log_obs_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs)")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obs_UT, temp$log_obs_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obs_UT, y = log_obs_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), down")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


temp <- obsexp %>% dplyr::filter(id %in% loop.no$id)
temp$density <- get_density(temp$log_obs_UT, temp$log_obs_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g3 <- ggplot(temp, aes(x = log_obs_UT, y = log_obs_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), no")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

temp <- obsexp %>% dplyr::filter(id %in% loop.up$id)
temp$density <- get_density(temp$log_obs_UT, temp$log_obs_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g4 <- ggplot(temp, aes(x = log_obs_UT, y = log_obs_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), up")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


fileName <- paste0("obs_AID_vs_UT_obs")
height <- 4
width <- 12
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()


# Structural
loop.str <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.str$id)
temp$density <- get_density(temp$log_obs_UT, temp$log_obs_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g5 <- ggplot(temp, aes(x = log_obs_UT, y = log_obs_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), structural loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Reg (PE-PE)
loop.reg <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.reg$id)
temp$density <- get_density(temp$log_obs_UT, temp$log_obs_AID, n = 100)
temp <- temp %>% dplyr::arrange(density)
g6 <- ggplot(temp, aes(x = log_obs_UT, y = log_obs_AID, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), regulatory loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

fileName <- paste0("obs_AID_vs_UT_obs_str_vs_reg")
height <- 4
width <- 6
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
```

##### A485 per res
```{r}
# Importing loops
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_NO_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))

for(res in c(25, 10, 5)){
  minValue <- -4
  maxValue <- 5
  obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp_", res, "kb.tsv"))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))
  
  
  # A485
  obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_A485, n = 100)
  obsexp <- obsexp %>% dplyr::arrange(density)
  g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
    geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
    geom_abline(slope = 1, intercept = 0) +
    ggtitle(paste0(res, "kb, log2(obs/exp)")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 
  
  
  # Visualize UP DOWN loops
  temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
  temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_A485, n = 100)
  temp <- temp %>% dplyr::arrange(density)
  g2 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
    geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
    geom_abline(slope = 1, intercept = 0) +
    ggtitle(paste0(res, "kb, log2(obs/exp), down")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 
  
  
  temp <- obsexp %>% dplyr::filter(id %in% loop.no$id)
  temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_A485, n = 100)
  temp <- temp %>% dplyr::arrange(density)
  g3 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
    geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
    geom_abline(slope = 1, intercept = 0) +
    ggtitle(paste0(res, "kb, log2(obs/exp), no")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 
  
  temp <- obsexp %>% dplyr::filter(id %in% loop.up$id)
  temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_A485, n = 100)
  temp <- temp %>% dplyr::arrange(density)
  g4 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
    geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
    geom_abline(slope = 1, intercept = 0) +
    ggtitle(paste0(res, "kb, log2(obs/exp), up")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 
  
  
  fileName <- paste0("obsexp_A485_vs_DMSO_", res, "kb")
  height <- 4
  width <- 12
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(plot_grid(g1, g4, g3, g2, ncol = 4))
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(plot_grid(g1, g4, g3, g2, ncol = 4))
  dev.off()
}

```
##### A485 all res
```{r}
# Importing loops
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_NO_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))

minValue <- -4
maxValue <- 5

obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))


# A485
obsexp$density <- get_density(obsexp$log_obsexp_DMSO, obsexp$log_obsexp_A485, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp)")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), down")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


temp <- obsexp %>% dplyr::filter(id %in% loop.no$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g3 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), no")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

temp <- obsexp %>% dplyr::filter(id %in% loop.up$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g4 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), up")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


fileName <- paste0("obsexp_A485_vs_DMSO")
height <- 4
width <- 12
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()


# Structural
loop.str <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.str$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g5 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), structural loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Reg (PE-PE)
loop.reg <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.reg$id)
temp$density <- get_density(temp$log_obsexp_DMSO, temp$log_obsexp_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g6 <- ggplot(temp, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs/exp), regulatory loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

fileName <- paste0("obsexp_A485_vs_DMSO_str_vs_reg")
height <- 4
width <- 6
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
```
###### Plotting Obs
```{r}
minValue <- -4
maxValue <- 10
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                  log_obs_DMSO = if_else(obs_DMSO == 0, minValue, log2(obs_DMSO)),
                  log_obs_dTAG = if_else(obs_dTAG == 0, minValue, log2(obs_dTAG)),
                  log_obs_A485 = if_else(obs_A485 == 0, minValue, log2(obs_A485)))

# Importing loops
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_UP_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_DOWN_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_A485vsDMSO_NO_diff0.2.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))



# dTAG
obsexp$density <- get_density(obsexp$log_obs_DMSO, obsexp$log_obs_A485, n = 100)
obsexp <- obsexp %>% dplyr::arrange(density)
g1 <- ggplot(obsexp, aes(x = log_obs_DMSO, y = log_obs_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs)")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Visualize UP DOWN loops
temp <- obsexp %>% dplyr::filter(id %in% loop.down$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g2 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), down")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


temp <- obsexp %>% dplyr::filter(id %in% loop.no$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g3 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), no")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

temp <- obsexp %>% dplyr::filter(id %in% loop.up$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g4 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), up")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 


fileName <- paste0("obsexp_A485_vs_DMSO_obs")
height <- 4
width <- 12
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g1, g4, g3, g2, ncol = 4))
dev.off()


# Structural
loop.str <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.str$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g5 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), structural loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

# Reg (PE-PE)
loop.reg <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe")) %>% 
  dplyr::mutate(binSize = V3 - V2,
                id = paste(V1, binSize, V2, V5, sep = "_"))
temp <- obsexp %>% dplyr::filter(id %in% loop.reg$id)
temp$density <- get_density(temp$log_obs_DMSO, temp$log_obs_A485, n = 100)
temp <- temp %>% dplyr::arrange(density)
g6 <- ggplot(temp, aes(x = log_obs_DMSO, y = log_obs_A485, color = density)) + 
  geom_point() + theme_bw() + scale_color_viridis(guide = "none") +
  geom_abline(slope = 1, intercept = 0) +
  ggtitle(paste0("log2(obs), regulatory loops")) +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) 

fileName <- paste0("obsexp_A485_vs_DMSO_obs_str_vs_reg")
height <- 4
width <- 6
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(g5, g6, ncol = 2))
dev.off()
```

### [2.26] Repeating few analysis with obs/exp
#### Function
```{r}
create_dist_vs_avgScore_perTreatment_oe <- function(data, figDir, name, loopList, colorList, se = FALSE){
  avg_scores_long <- data %>%
    group_by(distance, Anno2) %>%
    summarise(avg_score = mean(score, na.rm = TRUE)) %>%
    ungroup() 
  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + 
    geom_smooth(show.legend = TRUE, se = se)  +
    #ylim(0, 0.5) +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = colorList) +
    scale_fill_manual(values = colorList) +
    labs(title = paste0(name),
         x = "Distance",
         y = "Average Score") +
    theme(plot.title = element_text(size = 8))
  
  fileName <- paste0("dist_vs_score_linePlot_", name)
  png(here(figDir, paste0(fileName, ".png")), 
      res = 600, units = "in", width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")), 
          width = 4, height = 3)
  print(p4)
  dev.off()
} 

create_dist_vs_avgDiffScore_perTreatment_oe <- function(data, figDir, name, loopList, colorList, se = FALSE){
  avg_scores_long <- data %>%
    group_by(distance, Anno2) %>%
    summarise(avg_score = mean(score, na.rm = TRUE)) %>%
    ungroup() 
  avg_scores_long$Anno2 <- factor(avg_scores_long$Anno2, level = loopList)
  p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno2, fill = Anno2)) + 
    geom_hline(yintercept = 0) +
    geom_smooth(show.legend = TRUE, se = se)  +
    theme_classic() +  scale_x_continuous(labels = label_kb_mb) +
    scale_color_manual(values = colorList) +
    scale_fill_manual(values = colorList) +
    labs(title = paste0(name),
         x = "Distance",
         y = "Average Diff Score") +
    theme(plot.title = element_text(size = 8)) 
  
  fileName <- paste0("dist_vs_score_difflinePlot_", name)
  png(here(figDir, paste0(fileName, ".png")), 
      res = 600, units = "in", width = 4, height = 3)
  print(p4)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")), 
          width = 4, height = 3)
  print(p4)
  dev.off()
} 

create_dist_barplot_oe <- function(data, figDir, name, note, loopList, diffCutoff, distanceFilter = 2*e6){
    data <- data %>% 
    dplyr::mutate(distance = start2 - start1,
                  updown_dTAG_DMSO = ifelse(log_obsexp_diff_dTAG_DMSO > diffCutoff, "UP", 
                                            ifelse(log_obsexp_diff_dTAG_DMSO > -diffCutoff, "NO", "DOWN")),
                  updown_A485_DMSO = ifelse(log_obsexp_diff_A485_DMSO > diffCutoff, "UP", 
                                            ifelse(log_obsexp_diff_A485_DMSO > -diffCutoff, "NO", "DOWN"))) %>%
    dplyr::filter(Anno2 %in% loopList,
                  distance < distanceFilter)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c("UP", "NO", "DOWN"))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c("UP", "NO", "DOWN"))
  
  
  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%
    dplyr::filter(Anno2 %in% loopList,
                  updown_dTAG_DMSO %in% c("UP", "NO", "DOWN"))
  p <- ggplot(temp, aes(x = updown_dTAG_DMSO, y = distance)) +
    geom_violin(aes(fill = updown_dTAG_DMSO)) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = updown_dTAG_DMSO), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + ggtitle(note) +
    scale_y_continuous(labels = label_kb_mb)
  fileName <- paste0("size_barplot_", name, "_dTAG_vs_DMSO_", note, "_", diffCutoff)
  height <- 3
  width <- 4
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
  
  
  temp <- data %>% dplyr::select(Anno2, distance, updown_dTAG_DMSO, updown_A485_DMSO) %>%
    dplyr::filter(Anno2 %in% loopList,
                  updown_A485_DMSO %in% c("UP", "NO",  "DOWN"))
  p <- ggplot(temp, aes(x = updown_A485_DMSO, y = distance)) +
    geom_violin(aes(fill = updown_A485_DMSO)) + 
    geom_boxplot(width = 0.1, outlier.shape = NA) +
    stat_summary(aes(group = updown_A485_DMSO), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
    theme_classic() + ggtitle(note) +
    scale_y_continuous(labels = label_kb_mb)
  fileName <- paste0("size_barplot_", name, "_A485_vs_DMSO_", note, "_", diffCutoff)
  height <- 3
  width <- 4
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

create_loop_scatterplot_oe <- function(data, figDir, name, Anno2List, diffCutoff){
  data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(log_obsexp_diff_dTAG_DMSO > diffCutoff, "UP", 
                                            ifelse(log_obsexp_diff_dTAG_DMSO > -diffCutoff, "NO", "DOWN")),
                  updown_A485_DMSO = ifelse(log_obsexp_diff_A485_DMSO > diffCutoff, "UP", 
                                            ifelse(log_obsexp_diff_A485_DMSO > -diffCutoff, "NO", "DOWN"))) %>%
    dplyr::filter(Anno2 %in% Anno2List)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c("UP", "NO", "DOWN"))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c("UP", "NO", "DOWN"))
  
  num.up <- (summary(data$updown_dTAG_DMSO))["UP"]
  num.no <- (summary(data$updown_dTAG_DMSO))["NO"]
  num.down <- (summary(data$updown_dTAG_DMSO))["DOWN"]
  num.all <- num.up + num.no + num.down
  perc.up <- round(num.up / num.all * 100, 2)
  perc.no <- round(num.no / num.all * 100, 2)
  perc.down <- round(num.down / num.all * 100, 2)
  
  ### Scatterplot
    minValue <- -4
  maxValue <- 5
  data$density <- get_density(data$log_obsexp_DMSO, data$log_obsexp_dTAG, n = 100)
  data <- data %>% dplyr::arrange(density)
  correlation <- cor(data$log_obsexp_DMSO, data$log_obsexp_dTAG)
  p1 <- ggplot(data, aes(x = log_obsexp_DMSO, y = log_obsexp_dTAG, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) +
    geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
    geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
    geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
    geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
    geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
    annotate("text", x = minValue, y = maxValue, label = paste0("UP: ", num.up, " (", perc.up, "%)"), 
             color = "black", hjust = 0, size = 3) +
    annotate("text", x = minValue, y = maxValue-1, label = paste0("NO: ", num.no, " (", perc.no, "%)"), 
             color = "black", hjust = 0, size = 3) +
    annotate("text", x = minValue, y = maxValue-2, label = paste0("DOWN: ", num.down, " (", perc.down, "%)"), 
             color = "black", hjust = 0, size = 3) +
    theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5)) +
    annotate("text", x = minValue, y = maxValue, label = paste("r =", round(correlation, 2)), size = 5, color = "black")

  
  
  num.up <- (summary(data$updown_A485_DMSO))["UP"]
  num.no <- (summary(data$updown_A485_DMSO))["NO"]
  num.down <- (summary(data$updown_A485_DMSO))["DOWN"]
  num.all <- num.up + num.no + num.down
  perc.up <- round(num.up / num.all * 100, 2)
  perc.no <- round(num.no / num.all * 100, 2)
  perc.down <- round(num.down / num.all * 100, 2)
  
  data$density <- get_density(data$log_obsexp_DMSO, data$log_obsexp_A485, n = 100)
  data <- data %>% dplyr::arrange(density)
  correlation <- cor(data$log_obsexp_DMSO, data$log_obsexp_A485)
  p2 <- ggplot(data, aes(x = log_obsexp_DMSO, y = log_obsexp_A485, color = density)) +
    geom_point(show.legend = FALSE) + 
    scale_color_viridis() +
    coord_fixed(xlim = c(minValue, maxValue), ylim = c(minValue, maxValue)) +
    geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
    geom_abline(slope = 1, intercept = -diffCutoff, col = "grey", linetype = "dotted") +
    geom_abline(slope = 1, intercept = diffCutoff, col = "grey", linetype = "dotted") +
    geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
    geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
    annotate("text", x = minValue, y = maxValue, label = paste0("UP: ", num.up, " (", perc.up, "%)"), 
             color = "black", hjust = 0, size = 3) +
    annotate("text", x = minValue, y = maxValue-1, label = paste0("NO: ", num.no, " (", perc.no, "%)"), 
             color = "black", hjust = 0, size = 3) +
    annotate("text", x = minValue, y = maxValue-2, label = paste0("DOWN: ", num.down, " (", perc.down, "%)"), 
             color = "black", hjust = 0, size = 3) +
    theme_classic() + ggtitle(name) + theme(plot.title = element_text(size = 5)) +
    annotate("text", x = minValue, y = maxValue, label = paste("r =", round(correlation, 2)), size = 5, color = "black")

  
  
  fileName <- paste0("scatterplot_", name, "_", diffCutoff)
  png(here(figDir, paste0(fileName, ".png")), res = 600, units = "in", width = 5*1.5, height = 2.5*1.5)
  print(cowplot::plot_grid(p1, p2, align = "h"))
  dev.off()
  
  svglite(here(figDir, paste0(fileName, ".svg")), 
          width = 5*1.5, height = 2.5*1.5)
  print(cowplot::plot_grid(p1, p2, align = "h"))
  dev.off()
}

make_diff_bedpe_oe <- function(data, name, Anno2List, outDir, diffCutoff){
  data <- data %>%
    dplyr::mutate(updown_dTAG_DMSO = ifelse(log_obsexp_diff_dTAG_DMSO > diffCutoff, "UP", 
                                            ifelse(log_obsexp_diff_dTAG_DMSO > -diffCutoff, "NO", "DOWN")),
                  updown_A485_DMSO = ifelse(log_obsexp_diff_A485_DMSO > diffCutoff, "UP", 
                                            ifelse(log_obsexp_diff_A485_DMSO > -diffCutoff, "NO", "DOWN"))) %>%
    dplyr::filter(Anno2 %in% Anno2List)
  data$updown_dTAG_DMSO <- factor(data$updown_dTAG_DMSO, levels = c("UP", "NO", "DOWN"))
  data$updown_A485_DMSO <- factor(data$updown_A485_DMSO, levels = c("UP", "NO", "DOWN"))
  
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == "UP") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, "_dTAGvsDMSO_UP_diff", diffCutoff, ".bedpe")), 
         sep = "\t", col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == "NO") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, "_dTAGvsDMSO_NO_diff", diffCutoff, ".bedpe")), 
         sep = "\t", col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_dTAG_DMSO == "DOWN") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, "_dTAGvsDMSO_DOWN_diff", diffCutoff, ".bedpe")), 
         sep = "\t", col.names = FALSE)
  
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == "UP") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, "_A485vsDMSO_UP_diff", diffCutoff, ".bedpe")), 
         sep = "\t", col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == "NO") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, "_A485vsDMSO_NO_diff", diffCutoff, ".bedpe")), 
         sep = "\t", col.names = FALSE)
  out.temp <- data %>% dplyr::filter(updown_A485_DMSO == "DOWN") %>% dplyr::select(c(1, 2, 3, 4, 5, 6))
  fwrite(out.temp, here(outDir, paste0(name, "_A485vsDMSO_DOWN_diff", diffCutoff, ".bedpe")), 
         sep = "\t", col.names = FALSE)
}
```

#### Distance vs score plot
##### dTAG
###### OE
```{r}
# Import annotation
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))

# Import obs/exp scores and merge to the dataset
minValue <- -4
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c("id"))

# Plot
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obsexp_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, "_DMSO_logOE"), unique(data$Anno2), colorListLoop)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obsexp_dTAG, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, "_dTAG_logOE"), unique(data$Anno2), colorListLoop)


# Creating figures per each condition, differential
temp <- data %>% dplyr::mutate(distance = start2 - start1,
                               log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO) %>% 
  dplyr::select(distance, log_obsexp_diff_dTAG_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgDiffScore_perTreatment_oe(temp, figDir, paste0(name, "_dTAG_logOE"), unique(data$Anno2), colorListLoop)
```

###### OE, grouped
```{r}
# Import annotation
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))

# Import obs/exp scores and merge to the dataset
minValue <- -4
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c("id"))

temp <- data %>% dplyr::mutate(distance = start2 - start1,
                               log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO) %>% 
  dplyr::select(distance, log_obsexp_diff_dTAG_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")



temp <- temp %>% dplyr::mutate(Anno3 = case_when(Anno2 %in% c("S-X", "S-S") ~ "Structural",
                                                 Anno2 %in% c("P-P", "P-E", "E-E") ~ "Pure_Regulatory",
                                                 Anno2 %in% c("P-S", "P-X", "E-S", "E-X") ~ "Relaxed_Regulatory")) %>%
  dplyr::filter(!is.na(Anno3))

loopList <- rev(c("Structural", "Relaxed_Regulatory", "Pure_Regulatory"))
colorList <- rev(c(palette_3[["grey2"]], strong_green, darken(strong_green, amount = 0.5)))
avg_scores_long <- temp %>%
  group_by(distance, Anno3) %>%
  summarise(avg_score = mean(score, na.rm = TRUE)) %>%
  ungroup() 
avg_scores_long$Anno3 <- factor(avg_scores_long$Anno3, level = loopList)

p4 <- ggplot(avg_scores_long, aes(x = distance, y = avg_score, color = Anno3)) + 
  geom_hline(yintercept = 0,
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square") +
  geom_smooth(show.legend = TRUE, se = TRUE,
              size = lineThick*mmToLineUnit,
              lineend = "square",
              aes(fill = Anno3))  +
  theme_classic() + 
  scale_x_continuous(labels = label_kb_mb) +
  scale_color_manual(values = colorList) +
  scale_fill_manual(values = colorList) +
  labs(x = "Loop size",
       y = "Δ log2(obs/exp)",
       color = "Loop types", fill = "Loop types") +
  theme(
    axis.title = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +
  guides(
    color = guide_legend(
      keywidth = 0.5,  # Adjust the width of the legend color squares
      keyheight = 0.5  # Adjust the height of the legend color squares
    )
  )





fileName <- paste0("dist_vs_score_difflinePlot_grouped", name)

width <- panelSize(2.5)*mmToInch
height <- panelSize(1.25)*mmToInch
png(here(figDir, paste0(fileName, ".png")), 
    res = 600, units = "in", width = width, height = height)
print(p4)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")), 
        width = width, height = height)
print(p4)
dev.off()



```

###### Observed
```{r}
# Import annotation
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))

# Import obs/exp scores and merge to the dataset
minValue <- -4
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
    dplyr::mutate(log_obs_DMSO = if_else(obs_DMSO == 0, minValue, log2(obs_DMSO)),
                  log_obs_dTAG = if_else(obs_dTAG == 0, minValue, log2(obs_dTAG)),
                  log_obs_A485 = if_else(obs_A485 == 0, minValue, log2(obs_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c("id"))

# Plot
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obs_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, "_DMSO_logObs"), unique(data$Anno2), colorListLoop)

temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obs_dTAG, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, "_dTAG_logObs"), unique(data$Anno2), colorListLoop)


# Creating figures per each condition, differential
temp <- data %>% dplyr::mutate(distance = start2 - start1,
                               log_obs_diff_dTAG_DMSO = log_obs_dTAG - log_obs_DMSO) %>% 
  dplyr::select(distance, log_obs_diff_dTAG_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgDiffScore_perTreatment_oe(temp, figDir, paste0(name, "_dTAG_logObs"), unique(data$Anno2), colorListLoop)
```

##### A485
```{r}
# Import annotation
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))

# Import obs/exp scores and merge to the dataset
minValue <- -4
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c("id"))

# Plot
temp <- data %>% dplyr::mutate(distance = start2 - start1) %>% dplyr::select(distance, log_obsexp_A485, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgScore_perTreatment_oe(temp, figDir, paste0(name, "_A485_logOE"), unique(data$Anno2), colorListLoop)


# Creating figures per each condition, differential
temp <- data %>% dplyr::mutate(distance = start2 - start1,
                               log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO) %>% 
  dplyr::select(distance, log_obsexp_diff_A485_DMSO, Anno2)
colnames(temp) <- c("distance", "score", "Anno2")
create_dist_vs_avgDiffScore_perTreatment_oe(temp, figDir, paste0(name, "_A485_logOE"), unique(data$Anno2), colorListLoop)
```

#### Get size distribution of differential loops
```{r}
# Import annotation
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))

# Import obs/exp scores and merge to the dataset
minValue = -4
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c("id")) %>%
  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

diffCutoff <- 0.5
create_loop_scatterplot_oe(data, figDir, paste0(name, "_logOE_", "all"), unique(data$Anno2), diffCutoff)
create_loop_scatterplot_oe(data, figDir, paste0(name, "_logOE_", "reg"), c("P-P", "P-E", "E-E"), diffCutoff)
create_loop_scatterplot_oe(data, figDir, paste0(name, "_logOE_", "str"), c("S-S", "S-X"), diffCutoff)



create_dist_barplot_oe(data, figDir, paste0(name, "_logOE"), "all",  unique(data$Anno2), diffCutoff)
create_dist_barplot_oe(data, figDir, paste0(name, "_logOE"), "reg",  c("P-P", "P-E", "E-E"), diffCutoff)
create_dist_barplot_oe(data, figDir, paste0(name, "_logOE"), "reg_1mb",  c("P-P", "P-E", "E-E"), diffCutoff, 1e6)
create_dist_barplot_oe(data, figDir, paste0(name, "_logOE"), "str",  c("S-S", "S-X"), diffCutoff)
create_dist_barplot_oe(data, figDir, paste0(name, "_logOE"), "str_1mb",  c("S-S", "S-X"), diffCutoff, 1e6)

```
#### Splitting loops into diff bedpe
```{r}
# Import annotation
name <- "chromo_cons_annoHierarchy"
data <- fread(here(consensusDir, paste0(name, ".tsv")))

# Import obs/exp scores and merge to the dataset
minValue = -4
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
    dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                  log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                  log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)))

# Merge dataset
data <- data %>% dplyr::left_join(obsexp, by = c("id")) %>%
  dplyr::mutate(log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)
diffCutoff <- 0.5
make_diff_bedpe_oe(data, paste0(name, "_logOE_", "all"), unique(data$Anno2), consensusDir, diffCutoff)
make_diff_bedpe_oe(data, paste0(name, "_logOE_", "pe-pe"), c("P-P", "P-E", "E-E"), consensusDir, diffCutoff)
make_diff_bedpe_oe(data, paste0(name, "_logOE_", "str"), c("S-S", "S-X"), consensusDir, diffCutoff)

```

### [2.27] Extracting TSS for deeptools
```{r}
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

flankSize <- 1
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6)
colnames(gene.tb) <- c("chr", "start", "end", "ensembl")

bed.1 <- gene.tb %>% dplyr::filter(ensembl %in% group1) %>% dplyr::select(c(1, 2, 3))
bed.2 <- gene.tb %>% dplyr::filter(ensembl %in% group2) %>% dplyr::select(c(1, 2, 3))

fwrite(bed.1, here(refDir, "TSS_binaryGroup1.bed"), sep = "\t", col.names = FALSE)
fwrite(bed.2, here(refDir, "TSS_binaryGroup2.bed"), sep = "\t", col.names = FALSE)



gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed"))

bed.1 <- gene.tb %>% dplyr::filter(V6 %in% group1)
bed.2 <- gene.tb %>% dplyr::filter(V6 %in% group2)

fwrite(bed.1, here(refDir, "TSS_binaryGroup1_gtf.bed"), sep = "\t", col.names = FALSE)
fwrite(bed.2, here(refDir, "TSS_binaryGroup2_gtf.bed"), sep = "\t", col.names = FALSE)

```

### [2.28] Checking gene expression levels of binaryGroup
```{r}
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

data <- fread(here(refDir, "readCount.filtered.TPM.all.tsv")) %>% dplyr::mutate(
  group = case_when(ensembl %in% group1 ~ "group1",
                    ensembl %in% group2 ~ "group2",
                    TRUE ~ NA)
) %>%
  dplyr::filter(!is.na(group)) %>%
  dplyr::select(c(34, 1, 3, 4, 5, 14, 15, 34))

data <- data %>% mutate(average = rowMeans(across(colnames(data)[3:7])))

temp <- data %>% dplyr::select(group, average)


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$average
  distance2 <- (data %>% dplyr::filter(group ==group2) )$average
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pval <- convPvalue(getPvalWilcox(temp, "group1", "group2"))

ggplot(temp, aes(x = group, y = average)) + geom_boxplot() + scale_y_log10() +
  ylab("avgTPM") + theme_classic() +
  annotate("text", x = 1, y = 10000, label = pval)




```

### [2.29] Checking overlap with Stripes
```{r}
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

flankSize <- 1
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6)
colnames(gene.tb) <- c("chr", "start", "end", "ensembl")

bed.1 <- gene.tb %>% dplyr::filter(ensembl %in% group1) %>% dplyr::select(c(1, 2, 3))
bed.2 <- gene.tb %>% dplyr::filter(ensembl %in% group2) %>% dplyr::select(c(1, 2, 3))


data <- fread(here("../..", "result", "stripenn", "result_filtered.tsv"))

ggplot(data, aes(x = width)) + geom_histogram() + theme_classic() +
 scale_x_continuous(labels = label_kb_mb)


## Checking overlap with gene TSS

tss <- fread(here(refDir, "mm10_GRCm38.p6_TSS2.5kb.bed"))

tss.group1 <- tss %>% dplyr::filter(V6 %in% group1) %>% dplyr::select(V1, V2, V3)
colnames(tss.group1) <- c("chr", "start", "end")
tss.group1.gr <- makeGRangesFromDataFrame(tss.group1)

tss.group2 <- tss %>% dplyr::filter(V6 %in% group2) %>% dplyr::select(V1, V2, V3)
colnames(tss.group2) <- c("chr", "start", "end")
tss.group2.gr <- makeGRangesFromDataFrame(tss.group2)

## Anchor of stripes
temp <- data %>% dplyr::select(chr, pos1, pos2)
colnames(temp) <- c("chr", "start", "end")

stripeAnchor.gr <- makeGRangesFromDataFrame(temp)

overlap.group1 <- findOverlaps(tss.group1.gr, stripeAnchor.gr)
overlap.group2 <- findOverlaps(tss.group2.gr, stripeAnchor.gr)

length(unique(queryHits(overlap.group1)))
length(unique(queryHits(overlap.group2)))


## body of stripes
temp <- data %>% dplyr::select(chr, pos3, pos4)
colnames(temp) <- c("chr", "start", "end")

stripeBody.gr <- makeGRangesFromDataFrame(temp)

overlap.group1 <- findOverlaps(tss.group1.gr, stripeBody.gr)
overlap.group2 <- findOverlaps(tss.group2.gr, stripeBody.gr)

length(unique(queryHits(overlap.group1)))
length(unique(queryHits(overlap.group2)))

## Checking RAD21/CTCF presence at anchor
overlap.body.ctcf <- findOverlaps(stripeBody.gr, peak.CTCF)
overlap.body.rad21 <- findOverlaps(stripeBody.gr, peak.RAD21)
overlap.anchor.ctcf <- findOverlaps(stripeAnchor.gr, peak.CTCF)
overlap.anchor.rad21 <- findOverlaps(stripeAnchor.gr, peak.RAD21)

length(unique(queryHits(overlap.body.ctcf)))
length(unique(queryHits(overlap.body.rad21)))

length(unique(queryHits(overlap.anchor.ctcf)))
length(unique(queryHits(overlap.anchor.rad21)))
  
## Checking overlap with loop anchor (PE-PE)
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe"))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- extractAnchor(loop.down)


overlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)
overlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)
overlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)
overlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)

length(unique(subjectHits(overlap.body.upno)))
length(unique(subjectHits(overlap.body.down)))
length(unique(subjectHits(overlap.anchor.upno)))
length(unique(subjectHits(overlap.anchor.down)))


## Checking overlap with loop anchor (ALL)
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe"))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- extractAnchor(loop.down)


overlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)
overlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)
overlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)
overlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)

length(unique(subjectHits(overlap.body.upno)))
length(unique(subjectHits(overlap.body.down)))
length(unique(subjectHits(overlap.anchor.upno)))
length(unique(subjectHits(overlap.anchor.down)))


## Checking overlap with loop anchor (Structure)
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure_dTAGvsDMSO_UP_diff0.2.bedpe"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure_dTAGvsDMSO_NO_diff0.2.bedpe"))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure_dTAGvsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- extractAnchor(loop.down)

overlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)
overlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)
overlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)
overlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)

length(unique(subjectHits(overlap.body.upno)))
length(unique(subjectHits(overlap.body.down)))
length(unique(subjectHits(overlap.anchor.upno)))
length(unique(subjectHits(overlap.anchor.down)))


length(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100
length(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100
length(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100
length(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100


## Checking overlap with loop anchor (RelaxedReg)
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_UP_diff0.2.bedpe"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_NO_diff0.2.bedpe"))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_regulatory_dTAGvsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- extractAnchor(loop.down)

overlap.body.upno <- findOverlaps(stripeBody.gr, anchor.upno)
overlap.body.down <- findOverlaps(stripeBody.gr, anchor.down)
overlap.anchor.upno <- findOverlaps(stripeAnchor.gr, anchor.upno)
overlap.anchor.down <- findOverlaps(stripeAnchor.gr, anchor.down)

length(unique(subjectHits(overlap.body.upno)))
length(unique(subjectHits(overlap.body.down)))
length(unique(subjectHits(overlap.anchor.upno)))
length(unique(subjectHits(overlap.anchor.down)))


length(unique(subjectHits(overlap.body.upno)))/length(anchor.upno)*100
length(unique(subjectHits(overlap.body.down)))/length(anchor.down)*100
length(unique(subjectHits(overlap.anchor.upno)))/length(anchor.upno)*100
length(unique(subjectHits(overlap.anchor.down)))/length(anchor.down)*100




```

### [2.30] Hubs from Dylan Paper
#### All loops
```{r}
results <- tibble(i = numeric(), upno = numeric(), down = numeric())

for(i in seq(1, 10)){
  data <- fread(here(refDir, "Dylan_hub_esc.csv"))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c("chr", "start", "end")
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_UP_diff0.2.bedpe"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_NO_diff0.2.bedpe"))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_all_dTAGvsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- extractAnchor(loop.down)

  
  overlap.upno <- findOverlaps(anchor.upno, hub.anchor)
  overlap.down <- findOverlaps(anchor.down, hub.anchor)
  
  n1 <- length(unique(queryHits(overlap.upno)))
  n2 <- length(unique(queryHits(overlap.down)))
  
  perc1 <- round(n1/length(overlap.upno)*100, 2)
  perc2 <- round(n2/length(overlap.down)*100, 2)
  
  results <- results %>% add_row(i = i, upno = perc1, down = perc2)
}



results_long <- results %>%
  pivot_longer(cols = c(upno, down), names_to = "Group", values_to = "Percentage")

results_long$Group <- factor(results_long$Group, levels = c("upno", "down"))
# Create the bar plot
ggplot(results_long, aes(x = factor(i), y = Percentage, fill = Group)) +
  geom_bar(stat = "identity", position = "dodge") +
  labs(
    title = "All loops",
    x = "Presence of hub anchor with >i connections",
    y = "Percentage"
  ) +
  theme_minimal() +
  scale_fill_manual(values = c("upno" = "blue", "down" = "red")) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1)) + ylim(0, 100)
```

##### Fishers
```{r}
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe"))
loop.upno <- (bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe"))

getOverlapLoopNum <- function(loop, peak){
  anchor1 <- GRanges(seqnames = loop$V1, ranges = IRanges(start = loop$V2, end = loop$V3))
  anchor2 <- GRanges(seqnames = loop$V4, ranges = IRanges(start = loop$V5, end = loop$V6))
  a <- queryHits(findOverlaps(anchor1, peak))
  b <- queryHits(findOverlaps(anchor2, peak))
  return(length(unique(c(a, b))))
}

getSEOverlapFisher <- function(allLoop, subsetLoop, peak){
  all.overlap <- getOverlapLoopNum(allLoop, peak)
  all.notOverlap <- nrow(allLoop) - all.overlap
  
  subset.overlap <- getOverlapLoopNum(subsetLoop, peak)
  subset.notOverlap <- nrow(subsetLoop) - subset.overlap
  
  contingency_table <- matrix(c(subset.overlap, subset.notOverlap,
                                all.overlap, all.notOverlap), nrow = 2, byrow = TRUE)
  colnames(contingency_table) <- c("Overlapping", "Not_Overlapping")
  rownames(contingency_table) <- c("All loops", "Subset loops")
  
  # Perform Fisher's Exact Test
  fisher_test_result <- fisher.test(contingency_table)
  return(fisher_test_result)
}

name <- "chromo_cons_annoHierarchy"
loop <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe.bedpe"))


i <- 2
data <- fread(here(refDir, "Dylan_hub_esc.csv"))

data.hub <- data %>% dplyr::filter(all_lcon > i)
temp <- data.hub %>% dplyr::select(c(1, 2, 3))
colnames(temp) <- c("chr", "start", "end")
hub.anchor <- makeGRangesFromDataFrame(temp)


temp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)
result.tb <- tibble(loopType = "UP/NO",
                    target = paste0("hub_", i),
                    pvalue = temp$p.value,
                    oddsRatio = temp$estimate)
temp <- getSEOverlapFisher(loop, loop.down, hub.anchor)
result.tb <- result.tb %>% 
  add_row(loopType = "DOWN",
          target =  paste0("hub_", i),
          pvalue = temp$p.value,
          oddsRatio = temp$estimate)


for(i in c(5)){
  data <- fread(here(refDir, "Dylan_hub_esc.csv"))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c("chr", "start", "end")
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  temp <- getSEOverlapFisher(loop, loop.upno, hub.anchor)
  result.tb <- result.tb %>% add_row(loopType = "UP/NO",
                      target = paste0("hub_", i),
                      pvalue = temp$p.value,
                      oddsRatio = temp$estimate)
  temp <- getSEOverlapFisher(loop, loop.down, hub.anchor)
  result.tb <- result.tb %>% 
    add_row(loopType = "DOWN",
            target =  paste0("hub_", i),
            pvalue = temp$p.value,
            oddsRatio = temp$estimate)
  
  
}

library(circlize)
data <- result.tb
heatmap_data <- data %>% dplyr::select(target, loopType, oddsRatio) %>%
pivot_wider(names_from = loopType, values_from = oddsRatio) %>%
  column_to_rownames(var = "target")

pvalue_data <- data %>% dplyr::select(target, loopType, pvalue) %>%
  pivot_wider(names_from = loopType, values_from = pvalue) %>%
  column_to_rownames(var = "target")

# col_fun <- colorRamp2(c(0, 1, 2), 
#                       c("blue", "white", "red"))

data$target <- factor(data$target, levels = c("hub_5", "hub_2"))
data$loopType <- factor(data$loopType, levels = c("UP/NO", "DOWN"))
p <- ggplot(data, aes(x = loopType, y = target, size = -log10(pvalue), fill = oddsRatio)) +
  geom_point(shape = 21,        # Ensures a point with an outline
             stroke = 1*ptToMM      # Line width for the border
  ) + theme_bw() + 
  scale_size_continuous(range = c(1, 3)) +  # Set min and max point sizes here
  scale_fill_gradientn(colors = c("#4852A0", "white", "#CB333A"),  # Define gradient colors
                      values = scales::rescale(c(0.5, 1, 1.5)), limits = c(0.5, 1.5), 
                      #low = "white", high = "#CB333A",
                      #                  limits = c(1, 3),
                      oob = scales::squish, # Define gradient colors
                      guide = guide_colorbar(
                        barwidth = 1.5/5.08,  # Adjust width of the color bar
                        barheight = 15/5.08   # Adjust height of the color bar
                      )
  ) + labs(x = NULL, y = NULL)  +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )


fileName <- here(figDir, "heatmap_hub_enrichment_dotplot_all")
width <- panelSize(1.65)*mmToInch
height <- panelSize(1.1)*mmToInch
# # png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
# # print(p)
# # dev.off()
svglite(paste0(fileName, ".svg"),  height = height, width = width)
print(p)
dev.off()
```



#### PE-PE loops
```{r}
results <- tibble(i = numeric(), upno = numeric(), down = numeric())

for(i in seq(1, 10)){
  data <- fread(here(refDir, "Dylan_hub_esc.csv"))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c("chr", "start", "end")
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe"))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- extractAnchor(loop.down)


  
  overlap.upno <- findOverlaps(anchor.upno, hub.anchor)
  overlap.down <- findOverlaps(anchor.down, hub.anchor)
  
  n1 <- length(unique(queryHits(overlap.upno)))
  n2 <- length(unique(queryHits(overlap.down)))
  
  perc1 <- round(n1/length(overlap.upno)*100, 2)
  perc2 <- round(n2/length(overlap.down)*100, 2)
  
  results <- results %>% add_row(i = i, upno = perc1, down = perc2)
}



results_long <- results %>%
  pivot_longer(cols = c(upno, down), names_to = "Group", values_to = "Percentage")
results_long$Group <- factor(results_long$Group, levels = c("upno", "down"))

# Create the bar plot
ggplot(results_long, aes(x = factor(i), y = Percentage, fill = Group)) +
  geom_bar(stat = "identity", position = "dodge") +
  labs(
    title = "PE-PE loops",
    x = "Presence of hub anchor with >i connections",
    y = "Percentage"
  ) +
  theme_minimal() +
  scale_fill_manual(values = c("upno" = "blue", "down" = "red")) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1)) + ylim(0, 100)
```


#### Str loops
```{r}
results <- tibble(i = numeric(), upno = numeric(), down = numeric())

for(i in seq(1, 10)){
  data <- fread(here(refDir, "Dylan_hub_esc.csv"))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c("chr", "start", "end")
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure_dTAGvsDMSO_UP_diff0.2.bedpe"))
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure_dTAGvsDMSO_NO_diff0.2.bedpe"))
anchor.upno <- extractAnchor(bind_rows(loop.up, loop.no))

loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_structure_dTAGvsDMSO_DOWN_diff0.2.bedpe"))
anchor.down <- extractAnchor(loop.down)

  
  overlap.upno <- findOverlaps(anchor.upno, hub.anchor)
  overlap.down <- findOverlaps(anchor.down, hub.anchor)
  
  n1 <- length(unique(queryHits(overlap.upno)))
  n2 <- length(unique(queryHits(overlap.down)))
  
  perc1 <- round(n1/length(overlap.upno)*100, 2)
  perc2 <- round(n2/length(overlap.down)*100, 2)
  
  results <- results %>% add_row(i = i, upno = perc1, down = perc2)
}



results_long <- results %>%
  pivot_longer(cols = c(upno, down), names_to = "Group", values_to = "Percentage")
results_long$Group <- factor(results_long$Group, levels = c("upno", "down"))

# Create the bar plot
ggplot(results_long, aes(x = factor(i), y = Percentage, fill = Group)) +
  geom_bar(stat = "identity", position = "dodge") +
  labs(
    title = "Structure loops",
    x = "Presence of hub anchor with >i connections",
    y = "Percentage"
  ) +
  theme_minimal() +
  scale_fill_manual(values = c("upno" = "blue", "down" = "red")) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1)) + ylim(0, 100)
```
#### TSS
```{r}
results <- tibble(i = numeric(), perc1 = numeric(), perc2 = numeric())

for(i in seq(1, 10)){
  data <- fread(here(refDir, "Dylan_hub_episc.csv"))
  
  data.hub <- data %>% dplyr::filter(all_lcon > i)
  temp <- data.hub %>% dplyr::select(c(1, 2, 3))
  colnames(temp) <- c("chr", "start", "end")
  hub.anchor <- makeGRangesFromDataFrame(temp)
  
  
  
  ## Checking overlap with gene TSS
  tss <- fread(here(refDir, "mm10_GRCm38.p6_TSS2.5kb.bed"))
  
  tss.group1 <- tss %>% dplyr::filter(V6 %in% group1) %>% dplyr::select(V1, V2, V3)
  colnames(tss.group1) <- c("chr", "start", "end")
  tss.group1.gr <- makeGRangesFromDataFrame(tss.group1)
  
  tss.group2 <- tss %>% dplyr::filter(V6 %in% group2) %>% dplyr::select(V1, V2, V3)
  colnames(tss.group2) <- c("chr", "start", "end")
  tss.group2.gr <- makeGRangesFromDataFrame(tss.group2)
  
  
  overlap.group1 <- findOverlaps(tss.group1.gr, hub.anchor)
  overlap.group2 <- findOverlaps(tss.group2.gr, hub.anchor)
  
  n1 <- length(unique(queryHits(overlap.group1)))
  n2 <- length(unique(queryHits(overlap.group2)))
  
  perc1 <- round(n1/nrow(tss.group1)*100, 2)
  perc2 <- round(n2/nrow(tss.group2)*100, 2)
  
  results <- results %>% add_row(i = i, perc1 = perc1, perc2 = perc2)
}



results_long <- results %>%
  pivot_longer(cols = c(perc1, perc2), names_to = "Group", values_to = "Percentage")

# Create the bar plot
ggplot(results_long, aes(x = factor(i), y = Percentage, fill = Group)) +
  geom_bar(stat = "identity", position = "dodge") +
  labs(
    title = "Percentage by 'i' for perc1 and perc2",
    x = "Presence of hub anchor with >i connections",
    y = "Percentage"
  ) +
  theme_minimal() +
  scale_fill_manual(values = c("perc1" = "blue", "perc2" = "red")) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1))
```

###[2.30] H3K27ac peak number per 10kb
```{r}
process_group <- function(group_name, gene_data, bins) {
  # Filter for the specific group
  TSS_group <- makeGRangesFromDataFrame(
    gene_data %>% filter(ensembl %in% get(group_name)), 
    keep.extra.columns = TRUE
  )
  
  # Process each TSS in the group
  all_results <- map_dfr(seq_len(length(TSS_group)), function(i) {
    # Find overlapping bins
    overlapping_bins <- findOverlaps(TSS_group[i], bins)
    bins_near_tss <- as_tibble(bins[subjectHits(overlapping_bins)])
    
    # Calculate distance bin
    TSScenter <- (as_tibble(TSS_group[i]) %>%
                    mutate(center = (start + end) / 2))$center
    centerBinStart <- floor(TSScenter / 10e3) * 10e3 + 1
    bins_near_tss <- bins_near_tss %>%
      mutate(distanceBin = abs((start - centerBinStart)) / 10e3)
    
    # Summarize results
    result <- bins_near_tss %>%
      group_by(distanceBin) %>%
      summarise(mean_peak_counts = mean(peak_counts, na.rm = TRUE), .groups = "drop") %>%
      mutate(gene = TSS_group[i]$ensembl)
    return(result)
  })
  
  # Calculate mean and SD for the group
  mean_data <- all_results %>%
    group_by(distanceBin) %>%
    summarise(mean_peak_counts = mean(mean_peak_counts, na.rm = TRUE))
  
  sd_data <- all_results %>%
    group_by(distanceBin) %>%
    summarise(sd_peak_counts = sd(mean_peak_counts, na.rm = TRUE))
  
  # Join and add group name
  summary_data <- left_join(mean_data, sd_data, by = "distanceBin") %>%
    mutate(group = group_name)
  
  return(summary_data)
}

##########################################################



## Import peak
refDir <- here("../..", "reference")
#peak.H3K27ac <- importPeak(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed"))
peak.H3K27ac <- importPeak(here(refDir, "33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed"))
#peak.H3K27ac <- importPeak(here(refDir, "33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed"))

## Import 10kb bin
temp <- fread(here(refDir, "mm10.bin.10kb.bed"))
colnames(temp) <- c("chr", "start", "end")
temp <- temp %>% dplyr::mutate(start = start+1)
bins.10kb <- makeGRangesFromDataFrame(temp)

## Count overlap
counts <- countOverlaps(bins.10kb, peak.H3K27ac)
mcols(bins.10kb)$peak_counts <- counts

## Getting TSS
flankSize <- 1e6
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6)
colnames(gene.tb) <- c("chr", "start", "end", "ensembl")

gene.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
gene.group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

#TSS1mb.group1.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group1), keep.extra.columns = TRUE)
#TSS1mb.group2.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group2), keep.extra.columns = TRUE)

##########################################################
# List of groups to process
groups <- c("gene.group1", "gene.group2")

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "gene.group1") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "gene.group2")

# Plot the results
p <- ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 0.5) +
  labs(
    x = "Distance bin (10kb)",
    y = "H3K4me3 peak count"
  ) +
  theme_classic() +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS),
    legend.position = c(0.8, 0.8)  # Moves legend inside the plot (x, y relative coordinates)
  ) +
  guides(
    fill = guide_legend(
      keywidth = 0.2,  # Adjust the width of the legend keys
      keyheight = 0.2  # Adjust the height of the legend keys
    ))+
  scale_color_manual(values = rev(c("#777777", "#F28E2C")))

##########################################################

fileName <- paste0("binPeakDensity_RAD21_binaryGroup")
width <- 32*mmToInch
height <- 35*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```


```{r}

####### DOing this for P-S groups
resultDir <- here("../../result")
temp2 <- readRDS(here(resultDir, "gene_loop_link.rds"))

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene

# List of groups to process
groups <- c("psOver0", "psOver1", "psOver2", "psOver3", "psOver4")

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "psOver0") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "psOver1") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "psOver2") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "psOver3")%>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "psOver4")

# Plot the results
p <- ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 0.5) +
  labs(
    x = "Distance bin (10kb)",
    y = "H3K4me3 peak count"
  ) +
  theme_classic() +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS),
    legend.position = c(0.8, 0.8)  # Moves legend inside the plot (x, y relative coordinates)
  ) +
  guides(
    fill = guide_legend(
      keywidth = 0.2,  # Adjust the width of the legend keys
      keyheight = 0.2  # Adjust the height of the legend keys
    ))+
  scale_color_manual(values = c("#777777", "#8B7E65", "#A28452", "#C2884D", "#F28E2C"))

fileName <- paste0("binPeakDensity_RAD21_psGroup11")
width <- 32*mmToInch
height <- 35*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

### PE
peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene

# List of groups to process
groups <- c("peOver0", "peOver1", "peOver2", "peOver3", "peOver4")

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "peOver0") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "peOver1") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "peOver2") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "peOver3")%>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "peOver4")

# Plot the results
ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 1) + xlim(0, 10)+
  labs(
    title = "Mean Peak Counts",
    x = "Distance Bin (10 kb)",
    y = "Mean Peak Counts"
  ) +
  theme_minimal() +
  theme(
    plot.title = element_text(hjust = 0.5, size = 14, face = "bold"),
    axis.text = element_text(size = 12),
    axis.title = element_text(size = 13)
  )

###############
ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene

# List of groups to process
groups <- c("ppOver0", "ppOver1", "ppOver2", "ppOver3", "ppOver4")

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "ppOver0") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "ppOver1") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "ppOver2") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "ppOver3")%>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "ppOver4")

# Plot the results
ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 1) +
  labs(
    title = "Mean Peak Counts",
    x = "Distance Bin (10 kb)",
    y = "Mean Peak Counts"
  ) +
  theme_minimal() +
  theme(
    plot.title = element_text(hjust = 0.5, size = 14, face = "bold"),
    axis.text = element_text(size = 12),
    axis.title = element_text(size = 13)
  )
```
### [2.31] Testing SEs?
```{r}
peak.Whyte.SE <- importPeak(here(refDir, "superEnhancer_Whyte_ESC_mm10.bed"))
peak.Dylan.SE <- importPeak(here(refDir, "superEnhancer_Dylan_ESC.bed"))



flankSize <- 0.5e6
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c("chr", "start", "end", "ensembl", "gene")

gene.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
gene.group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

TSS1mb.group1.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group1), keep.extra.columns = TRUE)
TSS1mb.group2.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group2), keep.extra.columns = TRUE)


length(unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Whyte.SE))))/length(gene.group1)*100
length(unique(queryHits(findOverlaps(TSS1mb.group2.gr, peak.Whyte.SE))))/length(gene.group2)*100

length(unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE))))/length(gene.group1)*100
length(unique(queryHits(findOverlaps(TSS1mb.group2.gr, peak.Dylan.SE))))/length(gene.group2)*100

#View(as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Whyte.SE)))]))
#View(as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE)))]))

gene.group1.SE <- (as_tibble(TSS1mb.group1.gr[unique(queryHits(findOverlaps(TSS1mb.group1.gr, peak.Dylan.SE)))]))$ensembl
gene.group1.noSE <- gene.group1[!(gene.group1 %in% gene.group1.SE)]

overlaps <- findOverlaps(TSS1mb.group2.gr, peak.Dylan.SE)
unique_hits <- unique(queryHits(overlaps))
gene.group2.SE <- as_tibble(TSS1mb.group2.gr[unique_hits])$ensembl
gene.group2.noSE <- as_tibble(TSS1mb.group2.gr[-unique_hits])$ensembl


##########################################################
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - 1e6,
                TSSend = TSS + 1e6) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c("chr", "start", "end", "ensembl", "gene")

##########################################################
# List of groups to process
groups <- c("gene.group1.SE", "gene.group1.noSE")

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "gene.group1.SE") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "gene.group1.noSE")

# Plot the results
ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 1) +
  labs(
    title = paste0("Mean Peak Counts, +-", flankSize, "bp, Whyte SE"),
    x = "Distance Bin (10 kb)",
    y = "Mean Peak Counts"
  ) +
  theme_minimal() +
  theme(
    plot.title = element_text(hjust = 0.5, size = 14, face = "bold"),
    axis.text = element_text(size = 12),
    axis.title = element_text(size = 13)
  )

##########################################################
# List of groups to process
groups <- c("gene.group1.SE", "gene.group1.noSE", "gene.group2.SE", "gene.group2.noSE")

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
    add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "gene.group1.SE") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "gene.group1.noSE") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "gene.group2.SE") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "gene.group2.noSE")

# Plot the results
ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 1) +
  labs(
    title = paste0("Mean Peak Counts, +-", flankSize, "bp, Whyte SE"),
    x = "Distance Bin (10 kb)",
    y = "Mean Peak Counts"
  ) +
  theme_minimal() +
  theme(
    plot.title = element_text(hjust = 0.5, size = 14, face = "bold"),
    axis.text = element_text(size = 12),
    axis.title = element_text(size = 13)
  )
##########################################################
# List of groups to process
groups <- c("gene.group2.SE", "gene.group2.noSE")

# Process each group and combine results
summary_data <- map_dfr(groups, ~ process_group(.x, gene.tb, bins.10kb))

# Add the additional rows for distanceBin = 0
summary_data <- summary_data %>%
  mutate(distanceBin = distanceBin + 1) %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "gene.group2.SE") %>%
  add_row(distanceBin = 0, mean_peak_counts = 0, sd_peak_counts = 0, group = "gene.group2.noSE")

# Plot the results
ggplot(summary_data, aes(x = distanceBin, y = mean_peak_counts, color = group)) + 
  geom_line(size = 1) +
  labs(
    title = paste0("Mean Peak Counts, +-", flankSize, "bp, Whyte SE"),
    x = "Distance Bin (10 kb)",
    y = "Mean Peak Counts"
  ) +
  theme_minimal() +
  theme(
    plot.title = element_text(hjust = 0.5, size = 14, face = "bold"),
    axis.text = element_text(size = 12),
    axis.title = element_text(size = 13)
  )

## Checking P-S in the subset of genes

resultDir <- here("../../result")
temp2 <- readRDS(here(resultDir, "gene_loop_link.rds"))

temp3 <- temp2 %>% dplyr::filter(gene %in% c(gene.group1)) %>%
  dplyr::mutate(group = case_when(gene %in% gene.group1.SE ~ "SE",
                                  TRUE ~ "noSE"))


ggplot(temp3, aes(x = group, y = num_ps)) + geom_violin(aes(fill = group)) + geom_boxplot(width = 0.1) + theme_classic()

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$num_pp
  distance2 <- (data %>% dplyr::filter(group ==group2) )$num_pp
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


getPvalWilcox(temp3, "noSE", "SE")
```

### [2.32] Checking directionality
```{r}
name <- "chromo_cons_annoHierarchy"
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff)%>% 
  dplyr::mutate(distance = start2 - start1)


geneAnnoData <- geneAnnoData %>% unnest(gene)


gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3)) %>%
  dplyr::select(V6, TSS)
colnames(gene.tb) <- c("ensembl", "TSS")


geneAnnoData  <- geneAnnoData %>% dplyr::left_join(gene.tb, by = c("gene" = "ensembl"))

data <- geneAnnoData %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 29, 31, 35)) %>%
  rowwise() %>%
  dplyr::mutate(distToAnchor1 = (start1 + end1)/2 - TSS,
                distToAnchor2 = (start2 + end2)/2 - TSS,
                distToAnchor = if_else(abs(distToAnchor1) > abs(distToAnchor2), distToAnchor1, distToAnchor2),
                direction = if_else(distToAnchor > 0, "right", "left"))

data.directionality <- data %>% group_by(gene) %>%
  summarise(count = n(),
            n_right = sum(direction == "right"),
            n_left = sum(direction == "left")) %>%
  dplyr::filter(count > 1) %>%
  dplyr::mutate(n = n_right + n_left,
                directionality = abs((n_right - n_left)/n))


#ggplot(data.directionality, aes(x = directionality)) + geom_histogram() + theme_classic()


gene.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
gene.group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

temp <- data.directionality %>% dplyr::filter(gene %in% c(gene.group1, gene.group2)) %>%
  dplyr::mutate(group = if_else(gene %in% gene.group1, "group1", "group2"))


ggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + 
  geom_hline(yintercept = 0) + theme_classic() + ggtitle("P-S") +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")


#########################PS

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$directionality
  distance2 <- (data %>% dplyr::filter(group ==group2) )$directionality
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}


resultDir <- here("../../result")
temp2 <- readRDS(here(resultDir, "gene_loop_link.rds"))
#####################

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene

temp <- data.directionality %>% dplyr::filter(gene %in% c(psOver0, psOver1, psOver2, psOver3, psOver4)) %>%
  dplyr::mutate(group = case_when(gene %in% psOver0 ~ "psOver0",
                                  gene %in% psOver1 ~ "psOver1",
                                  gene %in% psOver2 ~ "psOver2",
                                  gene %in% psOver3 ~ "psOver3",
                                  gene %in% psOver4 ~ "psOver4"))

p34 <- round(getPvalWilcox(temp, "psOver3", "psOver4"), 5)
p23 <- round(getPvalWilcox(temp, "psOver2", "psOver3"), 5)
p12 <- round(getPvalWilcox(temp, "psOver1", "psOver2"), 5)
p01 <- round(getPvalWilcox(temp, "psOver0", "psOver1"), 5)
p04 <- round(getPvalWilcox(temp, "psOver0", "psOver4"), 5)



ggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + 
  geom_hline(yintercept = 0) + theme_classic() + ggtitle("P-N") +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  annotate("text", x = 1, y = 0.5, label = paste0("p34: ", convPvalue(p34), "\n",
                                                "p23: ", convPvalue(p23), "\n",
                                                "p12: ", convPvalue(p12), "\n",
                                                "p01: ", convPvalue(p01), "\n",
                                                "p04: ", convPvalue(p04), "\n"),
           color = "black", hjust = 0, size = 3)


#################### pe

peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene

temp <- data.directionality %>% dplyr::filter(gene %in% c(peOver0, peOver1, peOver2, peOver3, peOver4)) %>%
  dplyr::mutate(group = case_when(gene %in% peOver0 ~ "peOver0",
                                  gene %in% peOver1 ~ "peOver1",
                                  gene %in% peOver2 ~ "peOver2",
                                  gene %in% peOver3 ~ "peOver3",
                                  gene %in% peOver4 ~ "peOver4"))

p34 <- round(getPvalWilcox(temp, "peOver3", "peOver4"), 5)
p23 <- round(getPvalWilcox(temp, "peOver2", "peOver3"), 5)
p12 <- round(getPvalWilcox(temp, "peOver1", "peOver2"), 5)
p01 <- round(getPvalWilcox(temp, "peOver0", "peOver1"), 5)
p04 <- round(getPvalWilcox(temp, "peOver0", "peOver4"), 5)



ggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + 
  geom_hline(yintercept = 0) + theme_classic() + ggtitle("P-N") +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  annotate("text", x = 1, y = 0.5, label = paste0("p34: ", convPvalue(p34), "\n",
                                                "p23: ", convPvalue(p23), "\n",
                                                "p12: ", convPvalue(p12), "\n",
                                                "p01: ", convPvalue(p01), "\n",
                                                "p04: ", convPvalue(p04), "\n"),
           color = "black", hjust = 0, size = 3)


#################### pp

ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene

temp <- data.directionality %>% dplyr::filter(gene %in% c(ppOver0, ppOver1, ppOver2, ppOver3, ppOver4)) %>%
  dplyr::mutate(group = case_when(gene %in% ppOver0 ~ "ppOver0",
                                  gene %in% ppOver1 ~ "ppOver1",
                                  gene %in% ppOver2 ~ "ppOver2",
                                  gene %in% ppOver3 ~ "ppOver3",
                                  gene %in% ppOver4 ~ "ppOver4"))

p34 <- round(getPvalWilcox(temp, "ppOver3", "ppOver4"), 5)
p23 <- round(getPvalWilcox(temp, "ppOver2", "ppOver3"), 5)
p12 <- round(getPvalWilcox(temp, "ppOver1", "ppOver2"), 5)
p01 <- round(getPvalWilcox(temp, "ppOver0", "ppOver1"), 5)
p04 <- round(getPvalWilcox(temp, "ppOver0", "ppOver4"), 5)



ggplot(temp, aes(x = group, y = directionality)) + geom_violin() + geom_boxplot(width = 0.1) + 
  geom_hline(yintercept = 0) + theme_classic() + ggtitle("P-N") +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  annotate("text", x = 1, y = 0.5, label = paste0("p34: ", convPvalue(p34), "\n",
                                                "p23: ", convPvalue(p23), "\n",
                                                "p12: ", convPvalue(p12), "\n",
                                                "p01: ", convPvalue(p01), "\n",
                                                "p04: ", convPvalue(p04), "\n"),
           color = "black", hjust = 0, size = 3)


```

### [2.33] Checking guidance
```{r}
name <- "chromo_cons_annoHierarchy"
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff)%>% 
  dplyr::mutate(distance = start2 - start1)

geneAnnoData <- geneAnnoData %>% unnest(gene)

gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3)) %>%
  dplyr::select(V6, TSS)
colnames(gene.tb) <- c("ensembl", "TSS")


geneAnnoData  <- geneAnnoData %>% dplyr::left_join(gene.tb, by = c("gene" = "ensembl"))

data <- geneAnnoData %>% dplyr::select(c(1, 2, 3, 4, 5, 6, 29, 31, 35)) %>%
  rowwise() %>%
  dplyr::mutate(distToAnchor1 = (start1 + end1)/2 - TSS,
                distToAnchor2 = (start2 + end2)/2 - TSS,
                distToAnchor = if_else(abs(distToAnchor1) > abs(distToAnchor2), distToAnchor1, distToAnchor2),
                direction = if_else(distToAnchor > 0, "right", "left"))


result <- data %>%
  group_by(gene, direction) %>%
  mutate(distToAnchor = abs(distToAnchor)) %>%
  mutate(max_dist_P_S = ifelse(any(Anno2 == "P-S"), 
                               max(distToAnchor[Anno2 == "P-S"], na.rm = TRUE), 
                               NA)) %>%
  mutate(is_smaller = ifelse(is.na(max_dist_P_S), NA, 
                             ifelse(distToAnchor == max_dist_P_S, NA, distToAnchor < max_dist_P_S))) %>%
  ungroup()



result2 <- result %>% dplyr::filter(!is.na(is_smaller))

result3 <- result2 %>% group_by(gene, direction) %>%
  summarize(count_true = sum(is_smaller, na.rm = TRUE),
            count_false = sum(is_smaller == FALSE, na.rm = TRUE)) %>%
  dplyr::mutate(count = count_true + count_false,
                perc = count_true/count*100) %>%
  dplyr::select(gene, direction, perc)

result3 <- result3 %>% group_by(gene) %>% summarize(perc = mean(perc))

####### DOing this for P-S groups
resultDir <- here("../../result")
temp2 <- readRDS(here(resultDir, "gene_loop_link.rds"))

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% psOver0 ~ "psOver0",
                                            gene %in% psOver1 ~ "psOver1",
                                            gene %in% psOver2 ~ "psOver2",
                                            gene %in% psOver3 ~ "psOver3",
                                            gene %in% psOver4 ~ "psOver4",
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")

####### DOing this for P-E groups
peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% peOver0 ~ "peOver0",
                                            gene %in% peOver1 ~ "peOver1",
                                            gene %in% peOver2 ~ "peOver2",
                                            gene %in% peOver3 ~ "peOver3",
                                            gene %in% peOver4 ~ "peOver4",
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")

####### DOing this for P-P groups

ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% ppOver0 ~ "ppOver0",
                                            gene %in% ppOver1 ~ "ppOver1",
                                            gene %in% ppOver2 ~ "ppOver2",
                                            gene %in% ppOver3 ~ "ppOver3",
                                            gene %in% ppOver4 ~ "ppOver4",
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")


```

```{r}

result <- data %>%
  group_by(gene, direction) %>%
  mutate(distToAnchor = abs(distToAnchor)) %>%
  mutate(max_dist_P_S = ifelse(any(Anno2 == "P-S"), 
                               max(distToAnchor[Anno2 == "P-S"], na.rm = TRUE), 
                               NA))
result <- result %>% dplyr::filter(Anno2 != "P-S") %>%
  mutate(is_smaller = ifelse(is.na(max_dist_P_S), NA, 
                             ifelse(distToAnchor == max_dist_P_S, NA, distToAnchor < max_dist_P_S))) %>%
  ungroup()



result2 <- result %>% dplyr::filter(!is.na(is_smaller))

result3 <- result2 %>% group_by(gene, direction) %>%
  summarize(count_true = sum(is_smaller, na.rm = TRUE),
            count_false = sum(is_smaller == FALSE, na.rm = TRUE)) %>%
  dplyr::mutate(count = count_true + count_false,
                perc = count_true/count*100) %>%
  dplyr::select(gene, direction, perc)

result3 <- result3 %>% group_by(gene) %>% summarize(perc = mean(perc))

####### DOing this for P-S groups
resultDir <- here("../../result")
temp2 <- readRDS(here(resultDir, "gene_loop_link.rds"))

psOver4 <- (temp2 %>% dplyr::filter(num_ps >= 4))$gene
psOver3 <- (temp2 %>% dplyr::filter(num_ps >= 3, num_ps < 4))$gene
psOver2 <- (temp2 %>% dplyr::filter(num_ps >= 2, num_ps < 3))$gene
psOver1 <- (temp2 %>% dplyr::filter(num_ps >= 1, num_ps < 2))$gene
psOver0 <- (temp2 %>% dplyr::filter(num_ps < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% psOver0 ~ "psOver0",
                                            gene %in% psOver1 ~ "psOver1",
                                            gene %in% psOver2 ~ "psOver2",
                                            gene %in% psOver3 ~ "psOver3",
                                            gene %in% psOver4 ~ "psOver4",
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")

####### DOing this for P-E groups
peOver4 <- (temp2 %>% dplyr::filter(num_pe >= 4))$gene
peOver3 <- (temp2 %>% dplyr::filter(num_pe >= 3, num_pe < 4))$gene
peOver2 <- (temp2 %>% dplyr::filter(num_pe >= 2, num_pe < 3))$gene
peOver1 <- (temp2 %>% dplyr::filter(num_pe >= 1, num_pe < 2))$gene
peOver0 <- (temp2 %>% dplyr::filter(num_pe < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% peOver0 ~ "peOver0",
                                            gene %in% peOver1 ~ "peOver1",
                                            gene %in% peOver2 ~ "peOver2",
                                            gene %in% peOver3 ~ "peOver3",
                                            gene %in% peOver4 ~ "peOver4",
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")

####### DOing this for P-P groups

ppOver4 <- (temp2 %>% dplyr::filter(num_pp >= 4))$gene
ppOver3 <- (temp2 %>% dplyr::filter(num_pp >= 3, num_pp < 4))$gene
ppOver2 <- (temp2 %>% dplyr::filter(num_pp >= 2, num_pp < 3))$gene
ppOver1 <- (temp2 %>% dplyr::filter(num_pp >= 1, num_pp < 2))$gene
ppOver0 <- (temp2 %>% dplyr::filter(num_pp < 1))$gene


result4 <- result3 %>% dplyr::mutate(group = case_when(gene %in% ppOver0 ~ "ppOver0",
                                            gene %in% ppOver1 ~ "ppOver1",
                                            gene %in% ppOver2 ~ "ppOver2",
                                            gene %in% ppOver3 ~ "ppOver3",
                                            gene %in% ppOver4 ~ "ppOver4",
                                            TRUE ~ NA)) %>%
  dplyr::filter(!is.na(group))


ggplot(result4, aes(x =  group, y = perc)) + geom_violin() + geom_boxplot(width = 0.05) + theme_classic() +
  stat_summary(aes(group = group), fun = mean, geom = "point", shape = 21, size = 2, fill = "red", color = "black")

```

### [2.34] Checking CTCF motif orientation
#### Calculating CTCF motif
```{r}
peak.CTCF <- importPeak(here(refDir, "33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed"))

library(BSgenome.Mmusculus.UCSC.mm10)

# Extract sequences
sequences <- getSeq(BSgenome.Mmusculus.UCSC.mm10, peak.CTCF)


# Get the CTCF motif (or provide your own PWM)
ctcf_motif <- query(MotifDb, c("CTCF", "Mmusculus"))[[1]]

# Scan for the motif
motif_hits <- lapply(sequences, function(seq) {
    matchPWM(ctcf_motif, seq, min.score = "80%") # Adjust min.score as needed
})

motif_hits_reverse <- lapply(sequences, function(seq) {
    matchPWM(ctcf_motif, reverseComplement(seq), min.score = "80%")
})

# Combine results
result <- mapply(function(fwd, rev) {
    list(forward = fwd, reverse = rev)
}, motif_hits, motif_hits_reverse, SIMPLIFY = FALSE)


result[[5]]


result_tibble <- tibble(
    peak_id = seq_along(result), # Create an identifier for each peak
    alignment = map_chr(result, function(res) {
        has_fwd <- length(res$forward) > 0
        has_rev <- length(res$reverse) > 0
        
        if (has_fwd && has_rev) "fwdrev"
        else if (has_fwd) "fwd"
        else if (has_rev) "rev"
        else "none"
    })
)

temp <- as_tibble(peak.CTCF) %>% bind_cols(result_tibble) %>%
  dplyr::select(seqnames, start, end, alignment)

fwrite(temp, here(refDir, "33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed"), col.names = FALSE, sep = "\t")
```
#### Comparing it to TSS
```{r}
ctcf.peak <- fread(here(refDir, "33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed"))
colnames(ctcf.peak) <- c("chr", "start", "end", "motif")
ctcf.peak.gr <- makeGRangesFromDataFrame(ctcf.peak, keep.extra.columns = TRUE)


flankSize <- 1
gene.TSS.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)
colnames(gene.TSS.tb) <- c("chr", "start", "end", "strand", "gene", "ensembl")

tss.gr <- makeGRangesFromDataFrame(gene.TSS.tb, keep.extra.columns = TRUE)

fwd_peaks <- ctcf.peak.gr[ctcf.peak.gr$motif %in% c("fwd", "fwdrev")]
rev_peaks <- ctcf.peak.gr[ctcf.peak.gr$motif %in% c("rev", "fwdrev")]

# Find convergent CTCF pairs for each TSS
convergent_pairs <- lapply(seq_along(tss.gr), function(i) {
    current_tss <- tss.gr[i]
    
    # Filter peaks on the same chromosome as the TSS
    fwd_peaks_chr <- fwd_peaks[as.character(seqnames(fwd_peaks)) == as.character(seqnames(current_tss))]
    rev_peaks_chr <- rev_peaks[as.character(seqnames(rev_peaks)) == as.character(seqnames(current_tss))]
    
    # Find the closest forward peak to the left of the TSS
    left_fwd <- fwd_peaks_chr[start(fwd_peaks_chr) < start(current_tss)]
    closest_fwd <- if (length(left_fwd) > 0) {
      left_fwd[which.max(start(left_fwd))]
    } else {
      NA
    }
    
    # Find the closest reverse peak to the right of the TSS
    right_rev <- rev_peaks_chr[start(rev_peaks_chr) > start(current_tss)]
    closest_rev <- if (length(right_rev) > 0) {
      right_rev[which.min(start(right_rev))]
    } else {
      NA
    }
    
    # Combine results if both closest peaks exist
    if (!is.na(closest_fwd) && !is.na(closest_rev)) {
        tibble(
          chrom1 = as.character(seqnames(closest_fwd)),
          start1 = start(closest_fwd),
          end1 = end(closest_fwd),
          chrom2 = as.character(seqnames(closest_rev)),
          start2 = start(closest_rev),
          end2 = end(closest_rev),
          ensembl = current_tss$ensembl,
        )
    } else {
        NULL
    }
})

# Combine results into a tibble
result_tibble <- bind_rows(convergent_pairs)

fwrite(result_tibble, here(refDir, "tss_convergent_ctcf_motif_pairs.bedpe"), sep = "\t", col.names = FALSE)
fwrite(gene.TSS.tb %>% dplyr::select(c(1, 2, 3, 5)), here(refDir, "tss_2bp.bed"), sep = "\t", col.names = FALSE)

temp <- fread(here(refDir, "tss_convergent_ctcf_motif_pairs.bedpe")) %>% dplyr::filter(V7 == "Klf4")

fwrite(as_tibble(temp), here(refDir, "tss_convergent_ctcf_motif_pairs_klf4.bedpe"), sep = "\t", col.names = FALSE)

# Checking size distribution of ctcf pair
temp <- fread(here(refDir, "tss_convergent_ctcf_motif_pairs.bedpe"))
temp <- temp %>% dplyr::mutate(size = (V6 + V5)/2 - (V3 + V2)/2,
                       id = paste(V1, V2, V3, V5, V6, sep = "_"))
temp <- temp %>% dplyr::select(id, size) %>% distinct()

ggplot(temp, aes(x = size)) + geom_histogram() + scale_x_continuous(labels = label_kb_mb, limits = c(0, 1e6)) + scale_y_log10() + theme_classic() + ggtitle("size distribution of smallest convergent ctcf pairs around gene")
```
#### Filtering loops that fall within CTCF boundaries
```{r}
flankSize <- 1
gene.TSS.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V4, V5, V6)
colnames(gene.TSS.tb) <- c("chr", "start", "end", "strand", "gene", "ensembl")
geneEnsemblPair <- gene.TSS.tb %>% dplyr::select(gene, ensembl)

boundary.pair <- fread(here(refDir, "tss_convergent_ctcf_motif_pairs.bedpe"))
colnames(boundary.pair) <- c("boundary_chrom1", "boundary_start1", "boundary_end1", "boundary_chrom2", "boundary_start2", "boundary_end2", "ensembl")
boundary.pair <- boundary.pair %>% dplyr::left_join(geneEnsemblPair, by = c("ensembl"))


# Importing loop gene annotation
name <- "chromo_cons_annoHierarchy"
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff,
                                      annoList = c("P-P", "P-E")) %>%
  dplyr::select(c(1, 2, 3, 4, 5, 6, 11, 12, 24, 29, 31)) %>% unnest(gene)


data <- geneAnnoData %>% dplyr::left_join(boundary.pair, by = c("gene" = "ensembl"))

data <- data %>% rowwise() %>% dplyr::mutate(isWithinLeftBd = (boundary_start1 <= min(end1, end2)),
                       isWithinRightBd = (boundary_end2 >= max(start1, start2)),
                       isWithinBd = isWithinLeftBd & isWithinRightBd)
data <- data %>% drop_na()


ggplot(data, aes(x = DMSO, y = dTAG)) + geom_point() + coord_fixed() +  
  geom_abline(slope = 1, intercept = 0, col = "grey50", linetype = "dashed") +
  geom_hline(yintercept = 0, alpha = 0.5, color = "grey") +
  geom_vline(xintercept = 0, alpha = 0.5, color = "grey") +
  theme_classic() + facet_wrap(~ isWithinBd)

ggplot(data, aes(x = isWithinBd, y = diff_dTAG_DMSO, fill = isWithinBd)) + geom_violin() + geom_boxplot(width = 0.1) + theme_classic() +
  geom_hline(yintercept = 0)


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(isWithinBd ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(isWithinBd ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

getPvalWilcox(data, TRUE, FALSE)


# Proportion of those gene between group1 and group2
data.isWithinBd <- data %>% dplyr::filter(isWithinBd)

gene.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
gene.group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

sum(gene.group1 %in% data.isWithinBd$gene)/length(gene.group1)*100

sum(gene.group2 %in% data.isWithinBd$gene)/length(gene.group2)*100

# Checking size of those loops
data <- data %>% dplyr::mutate(distance = start2 - start1)

ggplot(data, aes(x = isWithinBd, y = distance, fill = isWithinBd)) + geom_violin() + geom_boxplot(width = 0.1) + theme_classic()



```


### [2.35] Checking CTCF motif presence at gene TSS
```{r}
flankSize <- 2.5e3
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c("chr", "start", "end", "ensembl", "gene")

gene.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
gene.group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

TSS1mb.group1.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group1), keep.extra.columns = TRUE)
TSS1mb.group2.gr <- makeGRangesFromDataFrame(gene.tb %>% dplyr::filter(ensembl %in% gene.group2), keep.extra.columns = TRUE)


ctcf.peak <- fread(here(refDir, "33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed"))
colnames(ctcf.peak) <- c("chr", "start", "end", "motif")
ctcf.peak.gr <- makeGRangesFromDataFrame(ctcf.peak)


print("+-2.5kb TSS overla with CTCF peak")
length(unique(queryHits(findOverlaps(TSS1mb.group1.gr, ctcf.peak.gr))))/length(gene.group1)*100
length(unique(queryHits(findOverlaps(TSS1mb.group2.gr, ctcf.peak.gr))))/length(gene.group2)*100



ctcf.peak.gr <- makeGRangesFromDataFrame(ctcf.peak %>% dplyr::filter(motif != "none"))
print("+-2.5kb TSS overla with CTCF peak with motif")
length(unique(queryHits(findOverlaps(TSS1mb.group1.gr, ctcf.peak.gr))))/length(gene.group1)*100
length(unique(queryHits(findOverlaps(TSS1mb.group2.gr, ctcf.peak.gr))))/length(gene.group2)*100




```

### [2.36] Finding farthest P-S
```{r}
name <- "chromo_cons_annoHierarchy"
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff,
                                      annoList = c("P-P", "P-E", "P-S", "P-X")) %>%
  dplyr::select(c(1, 2, 3, 4, 5, 6, 7, 11, 12, 24, 29, 31)) %>% unnest(gene)


gene.TSS.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3)) %>%
  dplyr::select(V6, TSS)
colnames(gene.TSS.tb) <- c("ensembl", "TSS")


geneAnnoData <- geneAnnoData %>% dplyr::left_join(gene.TSS.tb, by = c("gene" = "ensembl"))

geneAnnoData <- geneAnnoData %>% 
  dplyr::mutate(distance1 = (start1 + end1)/2 - TSS,
                distance2 = (start2 + end2)/2 - TSS,
                distance = if_else(abs(distance1) > abs(distance2), distance1, distance2))

result <- geneAnnoData %>%
  filter(Anno2 == "P-S") %>%
  group_by(gene) %>%
  summarise(
    farRight = if (any(distance > 0)) max(distance[distance > 0]) else 0,  # Return 0 if no positive distance
    farLeft = if (any(distance < 0)) min(distance[distance < 0]) else 0  # Return 0 if no negative distance
  ) %>%
  ungroup()

geneAnnoData <- geneAnnoData %>% left_join(result, by = c("gene"))

geneAnnoData <- geneAnnoData %>% dplyr::filter(Anno2 %in% c("P-P", "P-E")) %>%
  dplyr::mutate(group = case_when(is.na(farRight) ~ "No",
                                  (distance > farLeft) & (distance < farRight) ~ "Within",
                                  TRUE ~ "Outside"),
                size = start2 - start1)

data <- geneAnnoData %>% dplyr::select(group, id, size) %>% distinct()
anchor.data <- geneAnnoData %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()

temp1 <- anchor.data %>% dplyr::filter(group == "No") %>% dplyr::select(-group)
fwrite(temp1, here(consensusDir, "insulated_domain_ps_no.bedpe"), sep = "\t", col.names = FALSE)
temp2 <- anchor.data %>% dplyr::filter(group == "Within") %>% dplyr::select(-group)
fwrite(temp2, here(consensusDir, "insulated_domain_ps_within.bedpe"), sep = "\t", col.names = FALSE)
temp3 <- anchor.data %>% dplyr::filter(group == "Outside") %>% dplyr::select(-group)
fwrite(temp3, here(consensusDir, "insulated_domain_ps_outside.bedpe"), sep = "\t", col.names = FALSE)


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$size
  distance2 <- (data %>% dplyr::filter(group ==group2) )$size
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

# convPvalue(getPvalWilcox(data, "noBoundary", "withinBoundary"))
# convPvalue(getPvalWilcox(data, "noBoundary", "outsideBoundary"))
# convPvalue(getPvalWilcox(data, "outsideBoundary", "withinBoundary"))


p <- ggplot(data, aes(x = group, y = size, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = "square", alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = "black",
                 linewidth = lineThick * mmToLineUnit, lineend = "square",
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  stat_summary(
      aes(group = group), fun = mean,
      geom = "point", shape = 21, size = 0.5,
      fill = "black", color = "black", position = position_dodge(.3)
    ) +
  scale_fill_manual(values = c("grey50", "#5EC962", "#5EC962")) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = "Loop size")

fileName <- paste0("insulationBoundary_size")
width <- panelSize(1.5)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
  
########################
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

data <- geneAnnoData %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()

# convPvalue(getPvalWilcox(data, "noBoundary", "withinBoundary"))
# convPvalue(getPvalWilcox(data, "noBoundary", "outsideBoundary"))
# convPvalue(getPvalWilcox(data, "outsideBoundary", "withinBoundary"))

p <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = "square", alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black", position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c("grey50", "#5EC962", "#5EC962")) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = "Δ loop score")  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square") + 
  geom_hline(yintercept = -0.2,
             alpha = 0.5, 
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square", linetype = "dashed") +
  coord_cartesian(ylim = c(-0.8, 0.5))
    
fileName <- paste0("insulationBoundary_delta")
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()  
  
  
 ###################### 
    
    minValue <- -4
  obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

geneAnnoData <- geneAnnoData %>% left_join(obsexp, by = c("id"))

data <- geneAnnoData %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

# convPvalue(getPvalWilcox(data, "noBoundary", "withinBoundary"))
# convPvalue(getPvalWilcox(data, "noBoundary", "outsideBoundary"))
# convPvalue(getPvalWilcox(data, "outsideBoundary", "withinBoundary"))
# 

p <- ggplot(data, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = "square", alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black", position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c("grey50", "#5EC962", "#5EC962")) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = "log2(fc of obs/exp)")  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square") + 
  coord_cartesian(ylim = c(-2, 2))
    
fileName <- paste0("insulationBoundary_obsexp")
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()  





#####################


gene.withinBoundary <- unique((geneAnnoData %>% dplyr::filter(group == "withinBoundary"))$gene)
gene.outsideBoundary <- unique((geneAnnoData %>% dplyr::filter(group == "outsideBoundary"))$gene)
gene.noBoundary <- unique((geneAnnoData %>% dplyr::filter(group == "noBoundary"))$gene)

gene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))

gene.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
gene.group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

print("perc of gene with loop within Boundary")
sum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100

print("perc of gene with loop outside Boundary")
sum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100

print("perc of gene with loop with no Boundary")
sum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100


diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%
  dplyr::mutate(group = case_when(
    ensembl_gene_id %in% gene.wBoundary ~ "withinBoundary",
    ensembl_gene_id %in% gene.noBoundary ~ "noBoundary",
    TRUE ~ NA
  )) %>%
  dplyr::filter(!is.na(group)) %>%
  dplyr::mutate(absLog2FC = abs(log2FoldChange))


ggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC
  distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
convPvalue(getPvalWilcox(diff.RNA, "withinBoundary", "noBoundary"))


# Create the CDF plot
p <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +
stat_ecdf(size = 0.4 ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = "Absolute log2(fold change)",
    y = "Cumulative Probability"
  ) + coord_cartesian(xlim = c(0, 0.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )

fileName <- paste0("log2FC_cdf_insulationBoundary")
width <- panelSize(2.5)*mmToInch
height <- panelSize(1.5)*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()



### Checking characterstics of anchors
temp1 <- anchor.data %>% dplyr::filter(group == "noBoundary") %>% dplyr::select(-group)
anchor.noBoundary <- extractAnchor(temp1)

temp2 <- anchor.data %>% dplyr::filter(group == "withinBoundary") %>% dplyr::select(-group)
anchor.withinBoundary <- extractAnchor(temp2)

temp3 <- anchor.data %>% dplyr::filter(group == "outsideBoundary") %>% dplyr::select(-group)
anchor.outsideBoundary <- extractAnchor(temp3)


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(loop ==group1) )$sumScore
  distance2 <- (data %>% dplyr::filter(loop ==group2) )$sumScore
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

getSumScores <- function(track, anchor) {
  # Find overlaps between all anchors and track regions at once
  overlaps <- findOverlaps(anchor, track)
  
  # Extract the scores and corresponding anchor indices
  anchor_indices <- queryHits(overlaps)
  track_scores <- score(track)[subjectHits(overlaps)]
  
  # Use tapply to calculate the median scores for each anchor
  median_scores <- tapply(track_scores, anchor_indices, mean, na.rm = TRUE)
  
  # Initialize a numeric vector to store the median scores for each anchor
  all_median_scores <- rep(NA, length(anchor))
  
  # Populate the median scores for the anchors that have overlaps
  all_median_scores[as.numeric(names(median_scores))] <- median_scores
  
  return(all_median_scores)
}

plotSumScoresBinary <- function(track, peak, name, anchor1, anchor2, anchor3){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  a <- getSumScores(peakTrack, anchor1)
  b <- getSumScores(peakTrack, anchor2)
  c <- getSumScores(peakTrack, anchor3)
  a.tb <- tibble(loop = "noBoundary",
                 sumScore = a)
  b.tb <- tibble(loop = "withBoundary",
                 sumScore = b)
  c.tb <- tibble(loop = "outsideBoundary",
                 sumScore = c)
  
  data <- bind_rows(a.tb, b.tb, c.tb) %>% drop_na()
  data$loop <- factor(data$loop, levels = c("noBoundary", "withBoundary", "outsideBoundary"))
  
  p12 <- getPvalWilcox(data, "noBoundary", "withBoundary")
  p13 <- getPvalWilcox(data, "noBoundary", "outsideBoundary")
  p23 <- getPvalWilcox(data, "withBoundary", "outsideBoundary")
  p <-  ggplot(data, aes(x = loop, y = sumScore)) + 
    labs(x = NULL, y = paste0(name, "\nlog(avg peak score per anchor)")) +
    geom_violin(aes(fill = loop), color = "black",
                linewidth = lineThick * mmToLineUnit, lineend = "square",
                show.legend = FALSE) +
    geom_boxplot(width = 0.1, color = "black",
                 linewidth = lineThick * mmToLineUnit, lineend = "square",
                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +
    stat_summary(
      aes(group = loop), fun = mean,
      geom = "point", shape = 21, size = 1,
      fill = "red", color = "black"
    ) + theme(
      axis.title = element_text(
        size = fontSizeS, family = fontType, color = "#000000"
      ),
      axis.text = element_text(
        size = fontSizeS, family = fontType, color = "#000000"
      ),
      axis.text.x = element_text(
        angle = 45, hjust = 1, vjust = 1
      ),
      axis.line = element_line(
        color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
      ),
      axis.ticks = element_line(
        color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
      ),
      panel.background = element_rect(fill = "transparent"),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    ) + 
    #coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.99))) + 
    annotate(
      "text", x = 1, y = quantile(data$sumScore, 0.5),
      label = paste0("p12: ", convPvalue(p12), "\n",
                     "p13: ", convPvalue(p13), "\n",
                     "p23: ", convPvalue(p23)),
      color = "black", hjust = 0, size = 3
    ) 
  #+ scale_y_continuous(trans = "log10")
  
  fileName <- paste0("ChIP_peak_avgPeakScore_boundaryAnchor_", name)
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

# Sum peak score
####
track <- import(here(refDir, "33255_H3K4me3_04-745_Bruce-4_trim_q20_dedup_black_depthNorm.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "33255_H3K4me3_04-745_Bruce-4_peaks.mergePeak.bed"))
plotSumScoresBinary(track, peak, "H3K4me3", anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)

track <- import(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "GSM2438476_EC-DG-3458-H3K27AC_ASYN_1.narrowPeak.bed"))
#plotSumScores(track, peak, "H3K27ac")
plotSumScoresBinary(track, peak, "H3K27ac", anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)

track <- import(here(refDir, "GSM2683440_J1_H3K14ac_mm10Lifted.black.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "GSM2683440_J1_H3K14ac_mm10Lifted.bed"))
#plotSumScores(track, peak, "H3K14ac")
plotSumScoresBinary(track, peak, "H3K14ac", anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)

track <- import(here(refDir, "33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed"))
#plotSumScores(track, peak, "CTCF")
plotSumScoresBinary(track, peak, "CTCF", anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)

track <- import(here(refDir, "33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed"))
#plotSumScores(track, peak, "RAD21")
plotSumScoresBinary(track, peak, "RAD21", anchor.noBoundary, anchor.withinBoundary, anchor.outsideBoundary)



######## LOLA
atac <- fread(here(refDir, "GSM3106257_ATAC_ESC_1.bed")) %>% dplyr::select(V1, V2, V3)
colnames(atac) <- c("chr", "start", "end")
atac.gr <- makeGRangesFromDataFrame(atac)

# LOADING LOOPS
loop.all <- fread(here(consensusDir, "chromo_cons_annoHierarchy.tsv")) %>% dplyr::filter(Anno2 %in% c("P-P", "P-E", "E-E"))
anchor.all <- (extractAnchor(loop.all))
overlaps <- findOverlaps(anchor.all, atac.gr)
anchor.all <- pintersect(anchor.all[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])

overlaps <- findOverlaps(anchor.noBoundary, atac.gr)
anchor.noBoundary <- pintersect(anchor.noBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
overlaps <- findOverlaps(anchor.withinBoundary, atac.gr)
anchor.withinBoundary <- pintersect(anchor.withinBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])
overlaps <- findOverlaps(anchor.outsideBoundary, atac.gr)
anchor.outsideBoundary <- pintersect(anchor.outsideBoundary[queryHits(overlaps)], atac.gr[subjectHits(overlaps)])



anchors <- list(anchor.noBoundary, anchor.withBoundary, anchor.outsideBoundary)
tbs <- list()
temps <- list()

alpha <- 0.05

# Process clusters c1 to c8
for (i in 1:3) {
  
  anchor <- anchors[[i]]
  # Run LOLA
  result <- runLOLA(anchor, anchor.all, lolaDB)
  tb <- as_tibble(result)
  
  # Filter and summarize
  tb <- tb %>%
    dplyr::mutate(target = toupper(antibody)) %>%
    filter(str_to_lower(cellType) == "embryonic stem cell") %>%
    dplyr::filter(qValue < alpha) %>%
    dplyr::group_by(target) %>%
    slice_min(meanRnk, with_ties = FALSE)
  
  # Store tb
  tbs[[i]] <- tb
  
  # Select and rename oddsRatio
  temp <- tb %>% dplyr::select(target, oddsRatio)
  colnames(temp) <- c("target", paste0("OR_c", i))
  
  # Store temp
  temps[[i]] <- temp
}

# Merge all temp tables into one
temp <- Reduce(function(x, y) full_join(x, y, by = "target"), temps) %>%
  mutate_all(~replace_na(., 1))
colnames(temp) <- c("target", "noBoundary", "withinBoundary", "outsideBoundary")
data <- temp %>% column_to_rownames("target") %>% as.matrix()

library(circlize)
col_fun <- colorRamp2(c(1, max(data)), c("white", "red"))


#fviz_nbclust(data, kmeans, method = "wss")

p <- Heatmap(
  data,
  name = "Odds Ratio",                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)
```

### [3.37] Checking RAD21 level at tss
```{r}
tss.5kb.group1 <- fread(here(refDir, "TSS_binaryGroup1.bed")) %>%
  dplyr::mutate(start = (V2 + V3)/2 - 2500,
                end = (V2 + V3)/2 + 2500,
                chr = V1) %>%
  dplyr::select(chr, start, end)
tss.5kb.group1 <- makeGRangesFromDataFrame(tss.5kb.group1)

tss.5kb.group2 <- fread(here(refDir, "TSS_binaryGroup2.bed")) %>%
  dplyr::mutate(start = (V2 + V3)/2 - 2500,
                end = (V2 + V3)/2 + 2500,
                chr = V1) %>%
  dplyr::select(chr, start, end)
tss.5kb.group2 <- makeGRangesFromDataFrame(tss.5kb.group2)


plotSumScoresBinary <- function(track, peak, name, anchor1, anchor2){
  peakTrack <- track[unique(queryHits(findOverlaps(track, peak)))]
  a <- getSumScores(peakTrack, anchor1)
  b <- getSumScores(peakTrack, anchor2)
  a.tb <- tibble(loop = "group1",
                 sumScore = a)
  b.tb <- tibble(loop = "group2",
                 sumScore = b)
  
  data <- bind_rows(a.tb, b.tb) %>% drop_na()
  data$loop <- factor(data$loop, levels = c("group1", "group2"))
  
  p12 <- getPvalWilcox(data, "group1", "group2")
  p <-  ggplot(data, aes(x = loop, y = sumScore)) + 
    labs(x = NULL, y = paste0(name, "\nlog(avg peak score per anchor)")) +
    geom_violin(aes(fill = loop), color = "black",
                linewidth = lineThick * mmToLineUnit, lineend = "square",
                show.legend = FALSE) +
    geom_boxplot(width = 0.1, color = "black",
                 linewidth = lineThick * mmToLineUnit, lineend = "square",
                 outlier.size = 1, outlier.stroke = NA) + theme_classic() +
    stat_summary(
      aes(group = loop), fun = mean,
      geom = "point", shape = 21, size = 1,
      fill = "red", color = "black"
    ) + theme(
      axis.title = element_text(
        size = fontSizeS, family = fontType, color = "#000000"
      ),
      axis.text = element_text(
        size = fontSizeS, family = fontType, color = "#000000"
      ),
      axis.text.x = element_text(
        angle = 45, hjust = 1, vjust = 1
      ),
      axis.line = element_line(
        color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
      ),
      axis.ticks = element_line(
        color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
      ),
      panel.background = element_rect(fill = "transparent"),
      legend.text = element_text(family = fontType, size = fontSizeS),
      legend.title = element_text(family = fontType, size = fontSizeS)
    ) + 
    #coord_cartesian(ylim = c(quantile(data$sumScore, 0.0), quantile(data$sumScore, 0.99))) + 
    annotate(
      "text", x = 1, y = quantile(data$sumScore, 0.5),
      label = paste0("p12: ", convPvalue(p12)),
      color = "black", hjust = 0, size = 3
    ) 
  #+ scale_y_continuous(trans = "log10")
  
  fileName <- paste0("ChIP_peak_avgPeakScore_binaryGroup_", name)
  width <- panelSize(2)*mmToInch
  height <- panelSize(2)*mmToInch
  png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
  print(p)
  dev.off()
  svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
  print(p)
  dev.off()
}

# Sum peak score
####
track <- import(here(refDir, "33248_CTCF_07-729_Bruce-4_trim_q20_dedup_black_depthNorm.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "33248_CTCF_07-729_Bruce-4_peaks.mergePeak.bed"))
plotSumScoresBinary(track, peak, "CTCF", tss.5kb.group1, tss.5kb.group2)

track <- import(here(refDir, "33250_RAD21_ab992_Bruce-4_trim_q20_dedup_black_depthNorm.bw"), format = "BigWig")
peak <- importPeak(here(refDir, "33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed"))
plotSumScoresBinary(track, peak, "RAD21", tss.5kb.group1, tss.5kb.group2)



```

### [3.38] Stripe percentage
```{r}
# Create the data
data <- data.frame(
  Group = c("Group1", "Group2"),
  Value = c(31.03, 10.64)
)

# Create the bar plot
p <- ggplot(data, aes(x = Group, y = Value, fill = Group)) + 
  geom_bar(stat = "identity", color = "black", width = 0.7, alpha = 0.6, show.legend = FALSE,
           linewidth = lineThick * mmToLineUnit, lineend = "square") + # Use identity for raw values
  labs(y = "% of TSS on stripe") + 
  theme_classic() +
  theme(
    axis.title = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )

fileName <- paste0("perc_on_stripe_binaryGroup")
width <- panelSize(1.25)*mmToInch
height <- panelSize(1.2)*mmToInch
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

###[3.39] Splitting bedpe
```{r}
temp <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>% dplyr::select(c(1, 2))
geneList <- (temp %>% dplyr::filter(external_gene_name %in% c("Klf4", "Tbx3", "Jun", "Fosl2", "Myc", "Phlda1")))$ensembl_gene_id

# LOAD ANNOTATED LOOP
name <- "chromo_cons_annoHierarchy"
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>%
  dplyr::mutate(distance = start2 - start1)

filteredLoop <- geneAnnoData %>% unnest(gene) %>% dplyr::filter(gene %in% geneList)
fwrite(filteredLoop, here(consensusDir, paste0("P-N_selectedGene.bedpe")), 
         sep = "\t", col.names = FALSE)
  
temploop <- filteredLoop %>% dplyr::filter(Anno2 %in% c("P-P", "P-E"))
fwrite(temploop, here(consensusDir, paste0("P-PE_selectedGene.bedpe")), 
         sep = "\t", col.names = FALSE)
  
temploop <- filteredLoop %>% dplyr::filter(Anno2 %in% c("P-S"))
fwrite(temploop, here(consensusDir, paste0("P-S_selectedGene.bedpe")), 
         sep = "\t", col.names = FALSE)
```

### [3.40] Finding largest encompassing S-S
```{r}
name <- "chromo_cons_annoHierarchy"

# IMPORT S-S loops
allLoops <- fread(here(consensusDir, "chromo_cons_annoHierarchy.tsv"))
strLoops <- allLoops %>% dplyr::filter(Anno2 %in% c("S-S"))
temp <- strLoops %>% dplyr::select(c(1, 2, 6))
colnames(temp) <- c("chrom", "start", "end")
strLoopsGr <- makeGRangesFromDataFrame(temp)

# IMPORT TSS
flankSize <- 10
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c("chrom", "start", "end", "ensembl", "gene")
geneGr <- makeGRangesFromDataFrame(gene.tb, keep.extra.columns = TRUE)


# Find overlaps between loops and TSS
overlaps <- findOverlaps(geneGr, strLoopsGr)

# Annotate overlaps
tss_with_loops <- geneGr[queryHits(overlaps)]
loops_with_tss <- strLoopsGr[subjectHits(overlaps)]

# Combine into a data frame for processing
loop_data <- data.frame(gene = tss_with_loops$ensembl,
                        loop_chr = seqnames(loops_with_tss),
                        loop_start = start(loops_with_tss),
                        loop_end = end(loops_with_tss),
                        loop_width = width(loops_with_tss))

# Identify the largest loop for each gene
largest_loops <- loop_data[order(loop_data$gene, -loop_data$loop_width), ]
largest_loops <- largest_loops[!duplicated(largest_loops$gene), ]
largest_loops <- largest_loops %>% dplyr::mutate(loopID = paste(loop_chr, loop_start, loop_end, sep = "_"))
largest_loops <- largest_loops[order(largest_loops$loop_chr, largest_loops$loop_start),]
rownames(largest_loops) <- NULL

# Checking smaller loops
allLoopsGr <- makeGRangesFromDataFrame(allLoops, 
                                       seqnames.field = "chrom1", 
                                       start.field = "start1", 
                                       end.field = "end2")
largestLoopsGr <- makeGRangesFromDataFrame(largest_loops, 
                                           seqnames.field = "loop_chr", 
                                           start.field = "loop_start", 
                                           end.field = "loop_end")
largestLoopsGr <- sort(unique(largestLoopsGr))
complete_overlaps <- subsetByOverlaps(allLoopsGr, largestLoopsGr, type = "within")
overlaps <- findOverlaps(complete_overlaps, largestLoopsGr)


completeOverlapDf <- as.data.frame(complete_overlaps) %>% dplyr::mutate(loopIDAll = paste(seqnames, start, end, sep = "_"))
largestLoopsDf <- as.data.frame(largestLoopsGr) %>% dplyr::mutate(loopID = paste(seqnames, start, end, sep = "_"))

loopIDpairs <- data.frame(loopID = completeOverlapDf$loopIDAll[queryHits(overlaps)],
                          loopID2 = largestLoopsDf$loopID[subjectHits(overlaps)])

allLoopsAnnotated <- allLoops %>% dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = "_")) %>% dplyr::left_join(loopIDpairs, by = c("loopID"))

temp <- allLoopsAnnotated %>% dplyr::filter(Anno2 %in% c("P-E", "P-P", "E-E")) %>% dplyr::mutate(hasSS = !is.na(loopID2))
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(hasSS ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(hasSS ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
pv <- convPvalue(getPvalWilcox(temp, TRUE, FALSE))
ggplot(temp, aes(x = hasSS, y = diff_dTAG_DMSO)) + geom_violin(aes(fill = hasSS), show.legend = FALSE) + 
  geom_boxplot(width = 0.1, outlier.shape = NA) +
  stat_summary(aes(group = hasSS), fun = mean, 
               geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  theme_classic() +
  annotate("text", x = 1, y = 0, label = pv, size = 5, color = "black") +
  ggtitle("PE-PE") + geom_hline(yintercept = 0)


# Counting loop types
allLoopsAnnotatedFiltered <- allLoopsAnnotated %>% dplyr::filter(!is.na(loopID2)) %>%
  dplyr::filter(!(loopID == loopID2))
temp <- allLoopsAnnotatedFiltered %>% dplyr::select(loopID2, Anno2)
result <- temp %>%
  group_by(loopID2, Anno2) %>%
  summarise(count = n(), .groups = 'drop') %>%
  group_by(loopID2) %>%
  mutate(frequency = count / sum(count)) %>%
  arrange(loopID2, Anno2)

result <- largest_loops %>% dplyr::left_join(result, by = c("loopID" = "loopID2"))

gene.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
gene.group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep("group1", length(gene.group1)),
            rep("group2", length(gene.group2)))
)

data <- data %>% dplyr::left_join(result, by = c("gene"))
data <- data %>% filter(complete.cases(.))

all_anno2 <- unique(data$Anno2)

# Calculate average frequency of Anno2 for each gene in each group
result <- data %>%
  # Ensure all possible Anno2 values are present for each gene and group
  complete(gene, Anno2 = all_anno2, fill = list(frequency = 0)) %>% 
  dplyr::mutate(group = case_when(
    gene %in% gene.group1 ~ "group1",
    gene %in% gene.group2 ~ "group2",
    TRUE ~ NA
  )) %>%
  dplyr::select(group, Anno2, frequency)
  

ggplot(result, aes(x = Anno2, fill = group, y = frequency)) + geom_boxplot()

```


```{r}
# View results
ggplot(largest_loops, aes(x = loop_width)) + geom_histogram()


### Checking how many genes from each group has encompassing S-S
gene.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
gene.group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep("group1", length(gene.group1)),
            rep("group2", length(gene.group2)))
)

data <- data %>% dplyr::left_join(largest_loops, by = c("gene"))
data <- data %>% dplyr::mutate(
  hasSS = ifelse(is.na(loop_width), "NO", "YES")
)

data_summary <- data %>%
  group_by(group) %>%
  summarize(
    total = n(),
    hasSS_yes = sum(hasSS == "YES"),
    percentage_yes = (hasSS_yes / total) * 100
  )

ggplot(data_summary, aes(x = group, y = percentage_yes, fill = group)) +
  geom_bar(stat = "identity", color = "black") +
  labs(
    title = "Percentage of Each Group with hasSS = YES",
    x = "Group",
    y = "Percentage (%)"
  ) + ylim(0, 100) +
  theme_minimal()


temp <- data %>% dplyr::filter(hasSS == "YES")
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$loop_width
  distance2 <- (data %>% dplyr::filter(group ==group2) )$loop_width
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
pv <- convPvalue(getPvalWilcox(temp, "group1", "group2"))

ggplot(temp, aes(x = group, y = loop_width)) + geom_violin() + geom_boxplot(width = 0.5) +
  annotate("text", x = 1, y = 0, label = pv, size = 5, color = "black")

### Comparing RNA perturbation

diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(c(1, 4, 5)) %>%
  dplyr::mutate(hasSS = ifelse(ensembl_gene_id %in% largest_loops$gene, "hasSS", "noSS"))


ggplot(diff.RNA, aes(x = abs(log2FoldChange), color = hasSS)) +
  stat_ecdf(size = 0.4) +
  labs(
    x = "Absolute log2(fold change)",
    y = "Cumulative Probability"
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )


### Checking ChIP peak density
largest_loopsGr <- makeGRangesFromDataFrame(largest_loops, 
                                            seqnames.field = "loop_chr", 
                                            start.field = "loop_start", 
                                            end.field = "loop_end", 
                                            keep.extra.columns = TRUE)

# Find overlaps between ChIP-seq peaks and the largest loops
chip_overlaps <- findOverlaps(largest_loopsGr, peak.CTCF)

# Count the number of ChIP-seq peaks per loop
loop_peak_counts <- table(queryHits(chip_overlaps))

# Create a data frame with the counts and loop details
largest_loops$density <- 0  # Initialize density column
largest_loops$count <- 0    # Initialize peak count column

# Add peak counts to the corresponding loops
largest_loops[as.numeric(names(loop_peak_counts)), "count"] <- as.integer(loop_peak_counts)

# Calculate the density (peaks per kilobase)
largest_loops$density <- largest_loops$count / ((largest_loops$loop_width-1) / 1000)


data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep("group1", length(gene.group1)),
            rep("group2", length(gene.group2)))
)

data <- data %>% dplyr::left_join(largest_loops, by = c("gene"))
data <- data %>% dplyr::mutate(
  hasSS = ifelse(is.na(loop_width), "NO", "YES")
) %>% dplyr::filter(hasSS == "YES")

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$density
  distance2 <- (data %>% dplyr::filter(group ==group2) )$density
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv <- convPvalue(getPvalWilcox(data, "group1", "group2"))

ggplot(data, aes(x = group, y = density)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
  geom_boxplot(width = 0.1, outlier.shape = NA) +
  stat_summary(aes(group = group), fun = mean, 
               geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  theme_classic() +
  annotate("text", x = 1, y = 0, label = pv, size = 5, color = "black") +
  ggtitle("CTCF")


```

### [3.41] Finding largest convergent encompassing S-S
#### Filtering convergent S-S loops
```{r}
name <- "chromo_cons_annoHierarchy"

# IMPORT S-S LOOPS
allLoops <- fread(here(consensusDir, "chromo_cons_annoHierarchy.tsv"))
strLoops <- allLoops %>% dplyr::filter(Anno2 %in% c("S-S"))
temp <- strLoops %>% dplyr::select(c(1, 2, 3, 5, 6))  # Assuming columns include anchor positions
colnames(temp) <- c("chrom", "start1", "end1", "start2", "end2")
strLoopsGr1 <- makeGRangesFromDataFrame(
  temp %>% dplyr::select(chrom, start = start1, end = end1)
)
strLoopsGr2 <- makeGRangesFromDataFrame(
  temp %>% dplyr::select(chrom, start = start2, end = end2)
)

# IMPORT CTCF MOTIF ANNOTATION
ctcfMotifs <- fread(here(refDir, "33248_CTCF_07-729_Bruce-4_peaks.mergePeak.motifAnnotated.bed"))
colnames(ctcfMotifs) <- c("chrom", "start", "end", "motif")
ctcfGr <- makeGRangesFromDataFrame(ctcfMotifs, keep.extra.columns = TRUE)

# Annotate each loop anchor with CTCF motifs
anchor1_with_ctcf <- findOverlaps(strLoopsGr1, ctcfGr)
anchor2_with_ctcf <- findOverlaps(strLoopsGr2, ctcfGr)

# Get motif information for anchor1 overlaps
anchor1_ctcf_motif <- rep(NA, length(strLoopsGr1))  # Initialize motif vector
anchor1_ctcf_motif[queryHits(anchor1_with_ctcf)] <- ctcfGr[subjectHits(anchor1_with_ctcf)]$motif

# Get motif information for anchor2 overlaps
anchor2_ctcf_motif <- rep(NA, length(strLoopsGr2))  # Initialize motif vector
anchor2_ctcf_motif[queryHits(anchor2_with_ctcf)] <- ctcfGr[subjectHits(anchor2_with_ctcf)]$motif

# Add motif information to strLoops
strLoops <- strLoops %>%
  mutate(
    anchor1_motif = anchor1_ctcf_motif,
    anchor2_motif = anchor2_ctcf_motif
  )

# Filter for convergent CTCF interactions (forward in anchor1, reverse in anchor2)
convergent_loops <- strLoops %>%
  filter(anchor1_motif == "fwd" & anchor2_motif == "rev") %>% dplyr::filter(Anno2 %in% c("S-S"))
```

#### Processing
```{r}
# Extract loop boundary from left to right
temp <- convergent_loops %>% dplyr::select(c(1, 2, 6))
colnames(temp) <- c("chrom", "start", "end")
strLoopsGr <- makeGRangesFromDataFrame(temp)

# IMPORT TSS
flankSize <- 10
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V1, TSSstart, TSSend, V6, V5)
colnames(gene.tb) <- c("chrom", "start", "end", "ensembl", "gene")
geneGr <- makeGRangesFromDataFrame(gene.tb, keep.extra.columns = TRUE)


# Find overlaps between loops and TSS
overlaps <- findOverlaps(geneGr, strLoopsGr)

# Annotate overlaps
tss_with_loops <- geneGr[queryHits(overlaps)]
loops_with_tss <- strLoopsGr[subjectHits(overlaps)]

# Combine into a data frame for processing
loop_data <- data.frame(gene = tss_with_loops$ensembl,
                        loop_chr = seqnames(loops_with_tss),
                        loop_start = start(loops_with_tss),
                        loop_end = end(loops_with_tss),
                        loop_width = width(loops_with_tss))

# Identify the largest loop for each gene
largest_loops <- loop_data[order(loop_data$gene, -loop_data$loop_width), ]
largest_loops <- largest_loops[!duplicated(largest_loops$gene), ]
largest_loops <- largest_loops %>% dplyr::mutate(loopID = paste(loop_chr, loop_start, loop_end, sep = "_"))
largest_loops <- largest_loops[order(largest_loops$loop_chr, largest_loops$loop_start),]
rownames(largest_loops) <- NULL

# Checking smaller loops
allLoopsGr <- makeGRangesFromDataFrame(allLoops, 
                                       seqnames.field = "chrom1", 
                                       start.field = "start1", 
                                       end.field = "end2")
largestLoopsGr <- makeGRangesFromDataFrame(largest_loops, 
                                           seqnames.field = "loop_chr", 
                                           start.field = "loop_start", 
                                           end.field = "loop_end")
largestLoopsGr <- sort(unique(largestLoopsGr))
complete_overlaps <- subsetByOverlaps(allLoopsGr, largestLoopsGr, type = "within")
overlaps <- findOverlaps(complete_overlaps, largestLoopsGr)


completeOverlapDf <- as.data.frame(complete_overlaps) %>% dplyr::mutate(loopIDAll = paste(seqnames, start, end, sep = "_"))
largestLoopsDf <- as.data.frame(largestLoopsGr) %>% dplyr::mutate(loopID = paste(seqnames, start, end, sep = "_"))

loopIDpairs <- data.frame(loopID = completeOverlapDf$loopIDAll[queryHits(overlaps)],
                          loopID2 = largestLoopsDf$loopID[subjectHits(overlaps)])

# allLoopsAnnotated <- allLoops %>% dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = "_")) %>% dplyr::left_join(loopIDpairs, by = c("loopID"))


##################################
diffCutoff <- 0.2
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = diffCutoff,
                                      annoList = c("P-P", "P-E", "P-S", "P-X")) %>% unnest(gene) %>%
  dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = "_"))
temp <- geneAnnoData %>% dplyr::left_join(loopIDpairs, by = c("loopID"))
temp2 <- temp %>% dplyr::select(gene, loopID2) %>%
  group_by(gene) %>%              # Group data by the 'gene' column
  summarize(geneHasSS = !all(is.na(loopID2)))  # Check if all loopID2 values for each gene are NA
temp <- temp %>% left_join(temp2, by = c("gene"))
data.all <- temp %>% dplyr::mutate(group = ifelse(!geneHasSS, "No",
                                              ifelse(is.na(loopID2), "Outside", "Within")),
                               size = start2 - start1)

##################################
outfile <- data.all %>% dplyr::select(loopID2, gene) %>% dplyr::filter(!is.na(loopID2)) %>%
  separate(loopID2, into = c("chrom", "start", "end"), sep = "_", convert = TRUE)
# fwrite(outfile, here(consensusDir, "convergent_ss_domain.bed"), sep = "\t", col.names = FALSE)
```

#### Plotting
```{r}
data <- data.all %>% dplyr::filter(Anno2 %in% c("P-E"))

temp <- data %>% dplyr::select(chrom1, start1, end1, chrom2, start2, end2, group) %>% distinct()

temp1 <- temp %>% dplyr::filter(group == "No") %>% dplyr::select(-group)
fwrite(temp1, here(consensusDir, "insulated_domain_ss_no.bedpe"), sep = "\t", col.names = FALSE)
temp2 <- temp %>% dplyr::filter(group == "Within") %>% dplyr::select(-group)
fwrite(temp2, here(consensusDir, "insulated_domain_ss_within.bedpe"), sep = "\t", col.names = FALSE)
temp3 <- temp %>% dplyr::filter(group == "Outside") %>% dplyr::select(-group)
fwrite(temp3, here(consensusDir, "insulated_domain_ss_outside.bedpe"), sep = "\t", col.names = FALSE)

temp <- data %>% dplyr::select(id, group, size) %>% distinct()


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$size
  distance2 <- (data %>% dplyr::filter(group ==group2) )$size
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

convPvalue(getPvalWilcox(temp, "No", "Within"))
convPvalue(getPvalWilcox(temp, "No", "Outside"))
convPvalue(getPvalWilcox(temp, "Outside", "Within"))


p <- ggplot(temp, aes(x = group, y = size, fill = group)) + 
  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = "square", alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = "black",
                 linewidth = lineMedium * mmToLineUnit, lineend = "square",
                 outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + scale_y_continuous(labels = label_kb_mb) +
  scale_fill_manual(values = c("#777777", "#F28E2C", "#F28E2C")) +
  stat_summary(
      aes(group = group), fun = mean,
      geom = "point", shape = 21, size = 0.5,
      fill = "black", color = "black", position = position_dodge(.3)
  ) +
  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = "Loop size")

fileName <- paste0("insulationBoundary_size_convSS_PE")
width <-33*mmToInch
height <- 35*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(group ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

temp <- data %>% dplyr::select(group, id, diff_dTAG_DMSO) %>% distinct()

convPvalue(getPvalWilcox(temp, "No", "Within"))
convPvalue(getPvalWilcox(temp, "No", "Outside"))
convPvalue(getPvalWilcox(temp, "Outside", "Within"))

p <- ggplot(data, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineMedium * mmToLineUnit, lineend = "square", alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = "black",
               linewidth = lineMedium * mmToLineUnit, lineend = "square",
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() +   
    scale_fill_manual(values = c("#777777", "#F28E2C", "#F28E2C")) +
  stat_summary(
    aes(group = group), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black", position = position_dodge(.3)
  ) +
  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = "Δ loop score") +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square") + 
  geom_hline(yintercept = -0.2,
             alpha = 0.5, 
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square", linetype = "dashed") +
  coord_cartesian(ylim = c(-0.8, 0.5))
    
fileName <- paste0("insulationBoundary_delta_convSS_pe")
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()  


###################### 

minValue <- -4
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

data2 <- data %>% left_join(obsexp, by = c("id"))

temp <- data2 %>% dplyr::select(group, id, log_obsexp_diff_dTAG_DMSO) %>% distinct()


getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$log_obsexp_diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(group ==group2) )$log_obsexp_diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

convPvalue(getPvalWilcox(temp, "No", "Within"))
convPvalue(getPvalWilcox(temp, "No", "Outside"))
convPvalue(getPvalWilcox(temp, "Outside", "Within"))


p <- ggplot(temp, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineMedium* mmToLineUnit, lineend = "square", alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = "black",
               linewidth = lineMedium * mmToLineUnit, lineend = "square",
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  scale_fill_manual(values = c("#777777", "#F28E2C", "#F28E2C")) +
  
  stat_summary(
    aes(group = group), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black", position = position_dodge(.3)
  ) +
  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = "log2(fc of obs/exp)") +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square") + 
  coord_cartesian(ylim = c(-2, 2))
    width <-30*mmToInch
height <- 35*mmToInch
fileName <- paste0("insulationBoundary_obsexp_convSS_pe")
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()  





#####################

data <- data.all
gene.withinBoundary <- unique((data %>% dplyr::filter(group == "Within"))$gene)
gene.outsideBoundary <- unique((data %>% dplyr::filter(group == "Outside"))$gene)
gene.noBoundary <- unique((data %>% dplyr::filter(group == "No"))$gene)

gene.wBoundary <- unique(c(gene.withinBoundary, gene.outsideBoundary))

gene.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
gene.group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

print("perc of gene with loop within Boundary")
sum(gene.group1 %in% gene.withinBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.withinBoundary)/length(gene.group2)*100

print("perc of gene with loop outside Boundary")
sum(gene.group1 %in% gene.outsideBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.outsideBoundary)/length(gene.group2)*100

print("perc of gene with loop with no Boundary")
sum(gene.group1 %in% gene.noBoundary)/length(gene.group1)*100
sum(gene.group2 %in% gene.noBoundary)/length(gene.group2)*100


diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name) %>%
  dplyr::mutate(group = case_when(
    ensembl_gene_id %in% gene.wBoundary ~ "withinBoundary",
    ensembl_gene_id %in% gene.noBoundary ~ "noBoundary",
    TRUE ~ NA
  )) %>%
  dplyr::filter(!is.na(group)) %>%
  dplyr::mutate(absLog2FC = abs(log2FoldChange))
ks_result <- ks.test(
  diff.RNA %>% dplyr::filter(group == "withinBoundary") %>% pull(absLog2FC),
  diff.RNA %>% dplyr::filter(group == "noBoundary") %>% pull(absLog2FC)
)

ggplot(diff.RNA, aes(x = group, y = log2FoldChange)) + geom_violin() + geom_boxplot(width = 0.1)

# getPvalWilcox <- function(data, group1, group2){
#   distance1 <- (data %>% dplyr::filter(group ==group1) )$absLog2FC
#   distance2 <- (data %>% dplyr::filter(group ==group2) )$absLog2FC
#   wil <- wilcox.test(distance1, distance2)
#   return(wil$p.value)
# }
# convPvalue(getPvalWilcox(diff.RNA, "withBoundary", "noBoundary"))
# 

# Create the CDF plot
p <- ggplot(diff.RNA, aes(x = absLog2FC, color = group)) +
  scale_color_manual(values = (c("#777777", "#F28E2C"))) +

stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = "square"  ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = "Abs. log2(fold change)",
    y = "Cumulative Probability"
  ) + coord_cartesian(xlim = c(0, 1)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.position = "none",
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )

fileName <- paste0("log2FC_cdf_insulationBoundary_convSS_pe")
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```


```{r}
temp <- allLoopsAnnotated %>% dplyr::filter(Anno2 %in% c("P-E")) %>% dplyr::mutate(hasSS = !is.na(loopID2))
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(hasSS ==group1) )$diff_dTAG_DMSO
  distance2 <- (data %>% dplyr::filter(hasSS ==group2) )$diff_dTAG_DMSO
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
pv <- convPvalue(getPvalWilcox(temp, TRUE, FALSE))
ggplot(temp, aes(x = hasSS, y = diff_dTAG_DMSO)) + geom_violin(aes(fill = hasSS), show.legend = FALSE) + 
  geom_boxplot(width = 0.1, outlier.shape = NA) +
  stat_summary(aes(group = hasSS), fun = mean, 
               geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  theme_classic() +
  annotate("text", x = 1, y = 0, label = pv, size = 5, color = "black") +
  ggtitle("PE") + geom_hline(yintercept = 0)




# Counting loop types
allLoopsAnnotatedFiltered <- allLoopsAnnotated %>% dplyr::filter(!is.na(loopID2)) %>%
  dplyr::filter(!(loopID == loopID2))
temp <- allLoopsAnnotatedFiltered %>% dplyr::select(loopID2, Anno2)
result <- temp %>%
  group_by(loopID2, Anno2) %>%
  summarise(count = n(), .groups = 'drop') %>%
  group_by(loopID2) %>%
  mutate(frequency = count / sum(count)) %>%
  arrange(loopID2, Anno2)

result <- largest_loops %>% dplyr::left_join(result, by = c("loopID" = "loopID2"))

gene.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
gene.group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep("group1", length(gene.group1)),
            rep("group2", length(gene.group2)))
)

data <- data %>% dplyr::left_join(result, by = c("gene"))
data <- data %>% filter(complete.cases(.))

all_anno2 <- unique(data$Anno2)

# Calculate average frequency of Anno2 for each gene in each group
result <- data %>%
  # Ensure all possible Anno2 values are present for each gene and group
  complete(gene, Anno2 = all_anno2, fill = list(frequency = 0)) %>% 
  dplyr::mutate(group = case_when(
    gene %in% gene.group1 ~ "group1",
    gene %in% gene.group2 ~ "group2",
    TRUE ~ NA
  )) %>%
  dplyr::select(group, Anno2, frequency)
  

ggplot(result, aes(x = Anno2, fill = group, y = frequency)) + geom_boxplot()



# View results
ggplot(largest_loops, aes(x = loop_width)) + geom_histogram()


### Checking how many genes from each group has encompassing S-S
gene.group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
gene.group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep("group1", length(gene.group1)),
            rep("group2", length(gene.group2)))
)

data <- data %>% dplyr::left_join(largest_loops, by = c("gene"))
data <- data %>% dplyr::mutate(
  hasSS = ifelse(is.na(loop_width), "NO", "YES")
)

data_summary <- data %>%
  group_by(group) %>%
  summarize(
    total = n(),
    hasSS_yes = sum(hasSS == "YES"),
    percentage_yes = (hasSS_yes / total) * 100
  )

ggplot(data_summary, aes(x = group, y = percentage_yes, fill = group)) +
  geom_bar(stat = "identity", color = "black") +
  labs(
    title = "Percentage of Each Group with hasSS = YES",
    x = "Group",
    y = "Percentage (%)"
  ) + ylim(0, 100) +
  theme_minimal()

temp <- data %>% dplyr::filter(hasSS == "YES")
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$loop_width
  distance2 <- (data %>% dplyr::filter(group ==group2) )$loop_width
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}
pv <- convPvalue(getPvalWilcox(temp, "group1", "group2"))

ggplot(temp, aes(x = group, y = loop_width)) + geom_violin() + geom_boxplot(width = 0.5) +
  annotate("text", x = 1, y = 0, label = pv, size = 5, color = "black")


### Comparing RNA perturbation

diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(c(1, 4, 5)) %>%
  dplyr::mutate(hasSS = ifelse(ensembl_gene_id %in% largest_loops$gene, "hasSS", "noSS"))


ggplot(diff.RNA, aes(x = abs(log2FoldChange), color = hasSS)) +
  stat_ecdf(size = 0.4) +
  labs(
    x = "Absolute log2(fold change)",
    y = "Cumulative Probability"
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    )



### Checking ChIP peak density
largest_loopsGr <- makeGRangesFromDataFrame(largest_loops, 
                                            seqnames.field = "loop_chr", 
                                            start.field = "loop_start", 
                                            end.field = "loop_end", 
                                            keep.extra.columns = TRUE)

# Find overlaps between ChIP-seq peaks and the largest loops
chip_overlaps <- findOverlaps(largest_loopsGr, peak.H3K4me3)

# Count the number of ChIP-seq peaks per loop
loop_peak_counts <- table(queryHits(chip_overlaps))

# Create a data frame with the counts and loop details
largest_loops$density <- 0  # Initialize density column
largest_loops$count <- 0    # Initialize peak count column

# Add peak counts to the corresponding loops
largest_loops[as.numeric(names(loop_peak_counts)), "count"] <- as.integer(loop_peak_counts)

# Calculate the density (peaks per kilobase)
largest_loops$density <- largest_loops$count / ((largest_loops$loop_width-1) / 1000)


data <- tibble(
  gene = c(gene.group1, gene.group2),
  group = c(rep("group1", length(gene.group1)),
            rep("group2", length(gene.group2)))
)

data <- data %>% dplyr::left_join(largest_loops, by = c("gene"))
data <- data %>% dplyr::mutate(
  hasSS = ifelse(is.na(loop_width), "NO", "YES")
) %>% dplyr::filter(hasSS == "YES")

getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(group ==group1) )$density
  distance2 <- (data %>% dplyr::filter(group ==group2) )$density
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

pv <- convPvalue(getPvalWilcox(data, "group1", "group2"))

ggplot(data, aes(x = group, y = density)) + geom_violin(aes(fill = group), show.legend = FALSE) + 
  geom_boxplot(width = 0.1, outlier.shape = NA) +
  stat_summary(aes(group = group), fun = mean, 
               geom = "point", shape = 21, size = 2, fill = "red", color = "black") +
  theme_classic() +
  annotate("text", x = 1, y = 0, label = pv, size = 5, color = "black") +
  ggtitle("H3K4me3")


```

### [3.42] Comparing to Reg loops to A485
```{r}
name <- "chromo_cons_annoHierarchy"
# UP loop
loop.up <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_UP_diff0.2.bedpe")) %>%
  dplyr::mutate(loopID = paste(V1, V2, V6, sep = "_"))
# NO loop
loop.no <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_NO_diff0.2.bedpe")) %>%
  dplyr::mutate(loopID = paste(V1, V2, V6, sep = "_"))
# UP NO
loop.upno <- bind_rows(loop.up, loop.no)
# DOWN loop
loop.down <- fread(here(consensusDir, "chromo_cons_annoHierarchy_pe-pe_dTAGvsDMSO_DOWN_diff0.2.bedpe")) %>%
  dplyr::mutate(loopID = paste(V1, V2, V6, sep = "_"))


allLoops <- fread(here(consensusDir, "chromo_cons_annoHierarchy.tsv")) %>%
  dplyr::mutate(loopID = paste(chrom1, start1, end2, sep = "_")) %>%
  dplyr::mutate(group = case_when(
    loopID %in% loop.upno$loopID ~ "UP&NO",
    loopID %in% loop.down$loopID ~ "DOWN",
    TRUE ~ NA
  )) %>%
  dplyr::filter(!is.na(group))

minValue <- -4
obsexp <- fread(here(consensusDir, paste0("loopScore_cons_obsexp.tsv"))) %>%
  dplyr::mutate(log_obsexp_DMSO = if_else(obsexp_DMSO == 0, minValue, log2(obsexp_DMSO)),
                log_obsexp_dTAG = if_else(obsexp_dTAG == 0, minValue, log2(obsexp_dTAG)),
                log_obsexp_A485 = if_else(obsexp_A485 == 0, minValue, log2(obsexp_A485)),
                log_obsexp_diff_dTAG_DMSO = log_obsexp_dTAG - log_obsexp_DMSO,
                log_obsexp_diff_A485_DMSO = log_obsexp_A485 - log_obsexp_DMSO)

allLoops <- allLoops %>% left_join(obsexp, by = c("id"))
allLoops$group <- factor(allLoops$group, levels = c("UP&NO", "DOWN"))


### Plotting
p1 <- ggplot(allLoops, aes(x = group, y = diff_A485_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = "square", alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black", position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c("grey50", "grey50")) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = "Δ loop score")  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square") + 
  geom_hline(yintercept = -0.2,
             alpha = 0.5, 
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square", linetype = "dashed") +
  coord_cartesian(ylim = c(-0.5, 0.5))
    

####
p2 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_A485_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = "square", alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black", position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c("grey50", "grey50")) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = "log2(fc of obs/exp)")  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square") + 
  coord_cartesian(ylim = c(-2, 2))
  


#############

### Plotting
p3 <- ggplot(allLoops, aes(x = group, y = diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = "square", alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black", position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c("grey50", "grey50")) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = "Δ loop score")  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square") + 
  geom_hline(yintercept = -0.2,
             alpha = 0.5, 
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square", linetype = "dashed") +
  coord_cartesian(ylim = c(-0.5, 0.5))
    

####
p4 <- ggplot(allLoops, aes(x = group, y = log_obsexp_diff_dTAG_DMSO, fill = group)) + 
  geom_violin(linewidth = lineThick * mmToLineUnit, lineend = "square", alpha = .4, , show.legend = FALSE) + 
  geom_boxplot(width = 0.3, color = "black",
               linewidth = lineThick * mmToLineUnit, lineend = "square",
               outlier.shape = NA,  alpha = 0.6, show.legend = FALSE) + 
  theme_classic() + 
  stat_summary(
    aes(group = group), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black", position = position_dodge(.3)
  ) +
  scale_fill_manual(values = c("grey50", "grey50")) +

  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_text(
      size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),    
    axis.text.x = element_text(
      size = fontSizeM,
      angle = 45,      # Rotate x-axis labels 45 degrees
      hjust = 1,       # Adjust horizontal justification
      vjust = 1        # Adjust vertical justification
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +labs(y = "log2(fc of obs/exp)")  +    
  geom_hline(yintercept = 0,
             alpha = 1,
             color = "black",
             size = lineThick*mmToLineUnit,
             lineend = "square") + 
  coord_cartesian(ylim = c(-2, 2))
  
width <- panelSize(2)*mmToInch
height <- panelSize(1.5)*mmToInch
fileName <- paste0("regLoopScorefromdTAG_dTAG")
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(p1, p2))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(p1, p2))
dev.off()  

width <- panelSize(2)*mmToInch
height <- panelSize(1.5)*mmToInch
fileName <- paste0("regLoopScorefromdTAG_A485")
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(p3, p4))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(p3, p4))
dev.off()  

width <- panelSize(2)*mmToInch
height <- panelSize(1.5)*mmToInch
fileName <- paste0("regLoopScorefromdTAG_loopScore")
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(p1, p3))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(p1, p3))
dev.off()  

width <- panelSize(2)*mmToInch
height <- panelSize(1.5)*mmToInch
fileName <- paste0("regLoopScorefromdTAG_log2fc")
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(plot_grid(p2, p4))
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(plot_grid(p2, p4))
dev.off()  

```

### [3.43] Checking RAD21 peak density at group1 and group2 promoter
```{r}

peak.RAD21 <- importPeak(here(refDir, "33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed"))

##########################################################
flankSize <- 5000
gene.tb <- fread(here(refDir, "mm10_GRCm38.p6_gene_sorted.bed")) %>%
  dplyr::mutate(TSS = ifelse(V4 == "+", V2, V3),
                TSSstart = TSS - flankSize,
                TSSend = TSS + flankSize) %>%
  dplyr::select(V6, V5, V1, TSSstart, TSSend)
colnames(gene.tb) <- c("ensembl_gene_id", "external_gene_name", "chr", "start", "end")


# Convert gene.tb to a GRanges object
gene_gr <- GRanges(
  seqnames = gene.tb$chr,
  ranges = IRanges(start = gene.tb$start, end = gene.tb$end),
  gene_id = gene.tb$ensembl_gene_id
)

# Count overlaps between peaks and genes
overlap_counts <- countOverlaps(gene_gr, peak.RAD21)

# Add overlap counts to the original gene.tb data
gene.tb$peak_count <- overlap_counts

###############################################################################

peakNum0 <- (gene.tb %>% dplyr::filter(peak_count == 0))$ensembl_gene_id
peakNum1 <- (gene.tb %>% dplyr::filter(peak_count == 1))$ensembl_gene_id
peakNum2 <- (gene.tb %>% dplyr::filter(peak_count == 2))$ensembl_gene_id
peakNum3 <- (gene.tb %>% dplyr::filter(peak_count == 3))$ensembl_gene_id
peakNumOver4 <- (gene.tb %>% dplyr::filter(peak_count >= 4))$ensembl_gene_id


###############################################################################
name <- "chromo_cons_annoHierarchy"

alpha <- 0.05
fcCutoff <- 0.5
diff.RNA.G1.dTAG <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha, abs(shrinked_log2FC) > fcCutoff)
diff.RNA.G1.dTAG.noFCcutoff <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::filter(padj < alpha)
geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = 0.2,
                                      annoList = c("P-P", "P-E", "P-S", "P-X"))%>% 
  dplyr::mutate(distance = start2 - start1,
                peakID = paste(chrom1, start1, start2, sep = "_"))


## Dividing genes into groups
temp <- geneAnnoData %>% dplyr::select(diff_dTAG_DMSO, distance, gene) %>% 
  unnest(gene) %>% group_by(gene) %>%
  summarize(mean_diff_score = mean(diff_dTAG_DMSO),
            mean_distance = mean(distance),
            .groups = 'drop')

diff.RNA <- fread(here(refDir, "diff_G1.dTAG_G1.2i.dTAG_vs_G1.2i.DMSO.tsv")) %>%
  dplyr::select(ensembl_gene_id, log2FoldChange, shrinked_log2FC, padj, external_gene_name)

maxLog2FC = 2

temp <- left_join(temp, diff.RNA, by = c("gene" = "ensembl_gene_id")) %>% 
  dplyr::mutate(flag = ifelse(gene %in% diff.RNA.G1.dTAG$ensembl_gene_id, "2DOWN", "0NO"),
                maxFlag = (abs(shrinked_log2FC) > maxLog2FC),
                log2fcMax = pmax(pmin(shrinked_log2FC, maxLog2FC), -maxLog2FC)) %>% 
  dplyr::arrange(flag) %>%
  drop_na(shrinked_log2FC)

temp <- temp %>% dplyr::mutate(
  pnOver = ifelse(gene %in% peakNum0, "peakNum0",
                  ifelse(gene %in% peakNum1, "peakNum1",
                         ifelse(gene %in% peakNum2, "peakNum2",
                                ifelse(gene %in% peakNum3, "peakNum3",
                                       ifelse(gene %in% peakNumOver4, "peakNumOver4", NA)))))) %>%
  drop_na(pnOver)

###############################################################################
# Checking percentage of genes with RAD21 peaks
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene

aaa <- temp %>% dplyr::mutate(group = case_when(
  gene %in% group1 ~ "group1",
  gene %in% group2 ~ "group2",
  TRUE ~ NA
)) %>%
  dplyr::select(group, pnOver, gene) %>%
  dplyr::filter(group %in% c("group1", "group2")) %>%
  dplyr::mutate(hasPeak = ifelse(pnOver == "peakNum0", FALSE, TRUE))

bbb <- aaa %>% dplyr::filter(group == "group1") 

sum(bbb$hasPeak)
bbb <- aaa %>% dplyr::filter(group == "group2") 
sum(bbb$hasPeak)

aaa_summary <- aaa %>%
  group_by(group, pnOver) %>%
  summarize(count = n(), .groups = "drop")

# Create the stacked barplot
aaa_summary <- aaa %>%
  group_by(group, pnOver) %>%
  summarize(count = n(), .groups = "drop") %>%
  group_by(group) %>%
  mutate(ratio = count / sum(count))

# Define the gradient colors
gradient_colors <- c("#D4D4D4", "#DCB0AF", "#E48D8A", "#EC6965", "#F44641")
# gradient_colors <- c("#D4D4D4", "#A2BBCA", "#71A2C0", "#3F89B7", "#0E71AD")

# Create the stacked barplot with gradient colors
p <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = pnOver)) +
  geom_bar(stat = "identity", position = "stack",
           linewidth = lineMedium * mmToLineUnit, lineend = "square") +
  theme_classic() + labs(x = NULL , y = "Ratio") +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +
  scale_fill_manual(values = gradient_colors, 
                    guide = guide_legend(
      override.aes = list(size = 0.5), # Adjust legend key symbol size
      keywidth = 2 / 2.54, # Convert 2mm to cm
      keyheight = 2 / 2.54 # Convert 2mm to cm
    )) 

width <- panelSize(1.7)*mmToInch
height <- panelSize(1.3)*mmToInch
fileName <- paste0("rad21perc_promoter")
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()  

```

##### loop score
```{r}
getPvalWilcox <- function(data, group1, group2){
  distance1 <- (data %>% dplyr::filter(pnOver ==group1) )$mean_diff_score
  distance2 <- (data %>% dplyr::filter(pnOver ==group2) )$mean_diff_score
  wil <- wilcox.test(distance1, distance2)
  return(wil$p.value)
}

ps01 <- round(getPvalWilcox(temp, "peakNum0", "peakNum1"), 5)
ps12 <- round(getPvalWilcox(temp, "peakNum1", "peakNum2"), 5)
ps23 <- round(getPvalWilcox(temp, "peakNum2", "peakNum3"), 5)
ps34 <- round(getPvalWilcox(temp, "peakNum3", "peakNumOver4"), 5)
ps24 <- round(getPvalWilcox(temp, "peakNum2", "peakNumOver4"), 5)
ps14 <- round(getPvalWilcox(temp, "peakNum1", "peakNumOver4"), 5)
ps04 <- round(getPvalWilcox(temp, "peakNum0", "peakNumOver4"), 5)


p <- ggplot(temp, aes(x = pnOver, y = mean_diff_score)) + 
  geom_violin(aes(fill = pnOver), 
              color = "black",
              linewidth = lineMedium * mmToLineUnit, lineend = "square",
              show.legend = FALSE) +
  geom_boxplot(width = 0.3, color = "black",
               linewidth = lineMedium * mmToLineUnit, lineend = "square",
               outlier.shape = NA
  ) + theme_classic() + labs(x = NULL , y = "Average Δ loop score") +
  stat_summary(
    aes(group = pnOver), fun = mean,
    geom = "point", shape = 21, size = 0.5,
    fill = "black", color = "black"
  ) +
  geom_hline(yintercept = 0, linewidth = lineThick * mmToLineUnit) +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.text.x = element_text(
      angle = 45, hjust = 1, vjust = 1
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  )+
  annotate("text", x = 1, y = 0, label = paste0("ps01: ", convPvalue(ps01), "\n",
                                                "ps12: ", convPvalue(ps12), "\n",
                                                "ps23: ", convPvalue(ps23), "\n",
                                                "ps34: ", convPvalue(ps34), "\n",
                                                "ps24: ", convPvalue(ps24), "\n", 
                                                "ps14: ", convPvalue(ps14), "\n",
                                                "ps04: ", convPvalue(ps04), "\n"), 
           color = "black", hjust = 0, size = 2) +
    scale_fill_manual(values = c("#777777", "#8B7E65", "#A28452", "#C2884D", "#F28E2C")) +
  coord_cartesian(ylim = c(-0.5, 0.1))



fileName <- paste0("diffScore_barplot_RAD21peakWithin10kb_dTAG_vs_DMSO")
width <- 33*mmToInch
height <-38*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()
```

##### log2FC
```{r}
temp <- temp %>% dplyr::mutate(absLog2FC = abs(log2FoldChange))
p <- ggplot(temp, aes(x = absLog2FC, color = pnOver)) +
scale_color_manual(values = (c("#777777", "#8B7E65", "#A28452", "#C2884D", "#F28E2C"))) +
  stat_ecdf(size = 0.4, linewidth = lineMedium * mmToLineUnit, lineend = "square" ) + # Use stat_ecdf to plot the empirical CDF
  labs(
    x = "Abs. log2(fold change)",
    y = "Cumulative Probability"
  ) + coord_cartesian(xlim = c(0, 1.5)) +
  theme_classic() + # Clean theme
  theme(
      axis.title = element_text(
        size = fontSizeM,
      family = fontType,
      color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS,
      family = fontType,
      color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000",
      size = lineThick*mmToLineUnit,
      lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.position = "none",
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
    ) + scale_y_continuous(labels = scales::number_format(accuracy = 0.1))
fileName <- paste0("log2FC_cdf_psGroup_dTAG_vs_DMSO")
width <- 33*mmToInch
height <-33*mmToInch
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

```

### [3.44] Checking RAD21 peak density at group1 and group2 promoter
```{r}

peak.RAD21 <- importPeak(here(refDir, "33250_RAD21_ab992_Bruce-4_peaks.mergePeak.bed"))
group1 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup1.tsv"))$gene
group2 <- fread(here(refDir, "geneList_dTAG_vs_DMSO_RNA_loop_binaryGroup2.tsv"))$gene


##########################################################
name <- "chromo_cons_annoHierarchy"

geneAnnoData <- loadLoopAnnoData(here(consensusDir, paste0(name, "_p-n_ensemblList.tsv")),
                                      diffCutoff = 0.2,
                                      annoList = c("P-E"))

temp1 <- geneAnnoData %>% dplyr::filter(A1 == "E") %>% dplyr::select(chrom1, start1, end1, gene)
colnames(temp1) <- c("chr", "start", "end", "gene")
temp2 <- geneAnnoData %>% dplyr::filter(A2 == "E") %>% dplyr::select(chrom2, start2, end2, gene)
colnames(temp2) <- c("chr", "start", "end", "gene")

enhAnchors <- bind_rows(temp1, temp2) %>% unnest(gene) %>%
  dplyr::mutate(
    group = case_when(
      gene %in% group1 ~ "Grp1",
      gene %in% group2 ~ "Grp2",
      TRUE ~ NA
    )
  ) %>% dplyr::filter(!is.na(group))

enh <- makeGRangesFromDataFrame(enhAnchors %>% dplyr::select(c(1, 2, 3)))

# Count overlaps between peaks and genes
overlap_counts <- countOverlaps(enh, peak.RAD21)

# Add overlap counts to the original gene.tb data
enhAnchors$peak_count <- overlap_counts

enhAnchors <- enhAnchors %>% dplyr::mutate(
  peakGroup = case_when(
    peak_count == 0 ~ "peakNum0",
    peak_count == 1 ~ "peakNum1",
    peak_count == 2 ~ "peakNum2",
    peak_count == 3 ~ "peakNum3",
    peak_count >= 4 ~ "peakNumOver4"
  )
)

aaa <- enhAnchors %>% 
  dplyr::select(group, peakGroup, gene) %>%
  dplyr::mutate(hasPeak = ifelse(peakGroup == "peakNum0", FALSE, TRUE))

bbb <- aaa %>% dplyr::filter(group == "Grp1") 
sum(bbb$hasPeak)/nrow(bbb)
bbb <- aaa %>% dplyr::filter(group == "Grp2") 
sum(bbb$hasPeak)/nrow(bbb)


aaa_summary <- aaa %>%
  group_by(group, peakGroup) %>%
  summarize(count = n(), .groups = "drop")

# Create the stacked barplot
aaa_summary <- aaa %>%
  group_by(group, peakGroup) %>%
  summarize(count = n(), .groups = "drop") %>%
  group_by(group) %>%
  mutate(ratio = count / sum(count))

# Define the gradient colors
# gradient_colors <- c("#D4D4D4", "#DCB0AF", "#E48D8A", "#EC6965", "#F44641")
gradient_colors <- c("#D4D4D4", "#A2BBCA", "#71A2C0", "#3F89B7", "#0E71AD")

# Create the stacked barplot with gradient colors
p <- ggplot(aaa_summary, aes(x = group, y = ratio, fill = peakGroup)) +
  geom_bar(stat = "identity", position = "stack",
           linewidth = lineMedium * mmToLineUnit, lineend = "square") +
  theme_classic() + labs(x = NULL , y = "Ratio") +
  theme(
    axis.title = element_text(
      size = fontSizeM, family = fontType, color = "#000000"
    ),
    axis.text = element_text(
      size = fontSizeS, family = fontType, color = "#000000"
    ),
    axis.line = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    axis.ticks = element_line(
      color = "#000000", size = lineThick * mmToLineUnit, lineend = "square"
    ),
    panel.background = element_rect(fill = "transparent"),
    legend.text = element_text(family = fontType, size = fontSizeS),
    legend.title = element_text(family = fontType, size = fontSizeS)
  ) +
  scale_fill_manual(values = gradient_colors, 
                    guide = guide_legend(
      override.aes = list(size = 0.5), # Adjust legend key symbol size
      keywidth = 2 / 2.54, # Convert 2mm to cm
      keyheight = 2 / 2.54 # Convert 2mm to cm
    )) 

width <- panelSize(1.7)*mmToInch
height <- panelSize(1.3)*mmToInch
fileName <- paste0("rad21perc_enh")
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()  

```

# NOT CONCLUSIVE BELOW HERE
################################################################################

```{r}

data <- fread(here(resultDir, "chromHMM", "A485_pe-pe_anchors", "overlap_enrich_100_state.txt"))
colnames(data) <- c("state", "genome", "pe-pe_A485_down", "pe-pe_A485_no", "pe-pe_A485_up")
data <- data %>% dplyr::select(-genome) %>% as.matrix()

  column_to_rownames(var = "state") %>%
  as.matrix()

library(circlize)

col_fun <- colorRamp2(c(0, 1, 10), 
                      c("blue", "white", "red"))

library(circlize)
col_fun <- colorRamp2(c(min(data), max(data)), c("white", "red"))


#fviz_nbclust(data, kmeans, method = "wss")

p <- Heatmap(
  data,
  name = "Odds Ratio",                   # Name of the heatmap legend
  cluster_columns = FALSE,            # Remove column dendrogram
  row_km = 10,                         # Define the number of k-means clusters for rows (adjust as needed)
  show_row_dend = FALSE,
  col = col_fun,
  border = TRUE
)

fileName <- paste0("anchorLOLA_dTAG_vs_DMSO_diff0.2_allLoops_extreme_regAnchorBackground_atac")
height <- 7
width <- 3.5
png(here(figDir, paste0(fileName, ".png")), res = 600, unit = "in", height = height, width = width)
print(p)
dev.off()
svglite(here(figDir, paste0(fileName, ".svg")),  height = height, width = width)
print(p)
dev.off()

```



#################################################################################
#################################################################################
#################################################################################
#################################################################################
#################################################################################

